View Javadoc
1   /*
2    * MoneyWise: Finance Application
3    * Copyright 2012-2026. Tony Washer
4    *
5    * Licensed under the Apache License, Version 2.0 (the "License"); you may not
6    * use this file except in compliance with the License.  You may obtain a copy
7    * of the License at
8    *
9    *   http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13   * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
14   * License for the specific language governing permissions and limitations under
15   * the License.
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   * TableEncrypted extension for DepositRate.
36   *
37   * @author Tony Washer
38   */
39  public class MoneyWiseTableDepositRate
40          extends PrometheusTableEncrypted<MoneyWiseDepositRate> {
41      /**
42       * The name of the Rates table.
43       */
44      protected static final String TABLE_NAME = MoneyWiseDepositRate.LIST_NAME;
45  
46      /**
47       * Constructor.
48       *
49       * @param pDatabase the database control
50       */
51      protected MoneyWiseTableDepositRate(final PrometheusDataStore pDatabase) {
52          super(pDatabase, TABLE_NAME);
53          final PrometheusTableDefinition myTableDef = getTableDef();
54  
55          /* Declare the columns */
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          /* Declare Sort Columns */
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          /* Access the table definition */
75          final PrometheusTableDefinition myTableDef = getTableDef();
76  
77          /* Build data values */
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          /* Return the values */
85          return myValues;
86      }
87  
88      @Override
89      protected void setFieldValue(final MoneyWiseDepositRate pItem,
90                                   final MetisDataFieldId iField) throws OceanusException {
91          /* Switch on field id */
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 }