1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package io.github.tonywasher.joceanus.moneywise.database;
18
19 import io.github.tonywasher.joceanus.oceanus.base.OceanusException;
20 import io.github.tonywasher.joceanus.oceanus.decimal.OceanusDecimal;
21 import io.github.tonywasher.joceanus.metis.data.MetisDataItem.MetisDataFieldId;
22 import io.github.tonywasher.joceanus.moneywise.data.basic.MoneyWiseBasicDataType;
23 import io.github.tonywasher.joceanus.moneywise.data.basic.MoneyWiseBasicResource;
24 import io.github.tonywasher.joceanus.moneywise.data.basic.MoneyWiseDataSet;
25 import io.github.tonywasher.joceanus.moneywise.data.basic.MoneyWiseDepositRate;
26 import io.github.tonywasher.joceanus.prometheus.data.PrometheusDataSet;
27 import io.github.tonywasher.joceanus.prometheus.data.PrometheusDataValues;
28 import io.github.tonywasher.joceanus.prometheus.database.PrometheusColumnDefinition;
29 import io.github.tonywasher.joceanus.prometheus.database.PrometheusDataStore;
30 import io.github.tonywasher.joceanus.prometheus.database.PrometheusTableDefinition;
31 import io.github.tonywasher.joceanus.prometheus.database.PrometheusTableDefinition.PrometheusSortOrder;
32 import io.github.tonywasher.joceanus.prometheus.database.PrometheusTableEncrypted;
33
34
35
36
37
38
39 public class MoneyWiseTableDepositRate
40 extends PrometheusTableEncrypted<MoneyWiseDepositRate> {
41
42
43
44 protected static final String TABLE_NAME = MoneyWiseDepositRate.LIST_NAME;
45
46
47
48
49
50
51 protected MoneyWiseTableDepositRate(final PrometheusDataStore pDatabase) {
52 super(pDatabase, TABLE_NAME);
53 final PrometheusTableDefinition myTableDef = getTableDef();
54
55
56 final PrometheusColumnDefinition myActCol = myTableDef.addReferenceColumn(MoneyWiseBasicDataType.DEPOSIT, MoneyWiseTableDeposit.TABLE_NAME);
57 myTableDef.addEncryptedColumn(MoneyWiseBasicResource.MONEYWISEDATA_FIELD_RATE, OceanusDecimal.BYTE_LEN);
58 myTableDef.addNullEncryptedColumn(MoneyWiseBasicResource.DEPOSITRATE_BONUS, OceanusDecimal.BYTE_LEN);
59 final PrometheusColumnDefinition myDateCol = myTableDef.addNullDateColumn(MoneyWiseBasicResource.DEPOSITRATE_ENDDATE);
60
61
62 myDateCol.setSortOrder(PrometheusSortOrder.DESCENDING);
63 myActCol.setSortOrder(PrometheusSortOrder.ASCENDING);
64 }
65
66 @Override
67 protected void declareData(final PrometheusDataSet pData) {
68 final MoneyWiseDataSet myData = (MoneyWiseDataSet) pData;
69 setList(myData.getDepositRates());
70 }
71
72 @Override
73 protected PrometheusDataValues loadValues() throws OceanusException {
74
75 final PrometheusTableDefinition myTableDef = getTableDef();
76
77
78 final PrometheusDataValues myValues = getRowValues(MoneyWiseDepositRate.OBJECT_NAME);
79 myValues.addValue(MoneyWiseBasicDataType.DEPOSIT, myTableDef.getIntegerValue(MoneyWiseBasicDataType.DEPOSIT));
80 myValues.addValue(MoneyWiseBasicResource.MONEYWISEDATA_FIELD_RATE, myTableDef.getBinaryValue(MoneyWiseBasicResource.MONEYWISEDATA_FIELD_RATE));
81 myValues.addValue(MoneyWiseBasicResource.DEPOSITRATE_BONUS, myTableDef.getBinaryValue(MoneyWiseBasicResource.DEPOSITRATE_BONUS));
82 myValues.addValue(MoneyWiseBasicResource.DEPOSITRATE_ENDDATE, myTableDef.getDateValue(MoneyWiseBasicResource.DEPOSITRATE_ENDDATE));
83
84
85 return myValues;
86 }
87
88 @Override
89 protected void setFieldValue(final MoneyWiseDepositRate pItem,
90 final MetisDataFieldId iField) throws OceanusException {
91
92 final PrometheusTableDefinition myTableDef = getTableDef();
93 if (MoneyWiseBasicDataType.DEPOSIT.equals(iField)) {
94 myTableDef.setIntegerValue(iField, pItem.getDepositId());
95 } else if (MoneyWiseBasicResource.MONEYWISEDATA_FIELD_RATE.equals(iField)) {
96 myTableDef.setBinaryValue(iField, pItem.getRateBytes());
97 } else if (MoneyWiseBasicResource.DEPOSITRATE_BONUS.equals(iField)) {
98 myTableDef.setBinaryValue(iField, pItem.getBonusBytes());
99 } else if (MoneyWiseBasicResource.DEPOSITRATE_ENDDATE.equals(iField)) {
100 myTableDef.setDateValue(iField, pItem.getEndDate());
101 } else {
102 super.setFieldValue(pItem, iField);
103 }
104 }
105 }