]> git.ktnx.net Git - mobile-ledger.git/blobdiff - app/src/main/java/net/ktnx/mobileledger/db/DB.java
describe description_history to Room
[mobile-ledger.git] / app / src / main / java / net / ktnx / mobileledger / db / DB.java
index 2dbc7c24fbf8e6ce92de59de116677d403528514..630c5b272a64002061908d5db2cac881021b6f72 100644 (file)
 
 package net.ktnx.mobileledger.db;
 
+import androidx.annotation.NonNull;
 import androidx.room.Database;
 import androidx.room.Room;
 import androidx.room.RoomDatabase;
+import androidx.room.migration.Migration;
+import androidx.sqlite.db.SupportSQLiteDatabase;
 
 import net.ktnx.mobileledger.App;
+import net.ktnx.mobileledger.dao.AccountDAO;
 import net.ktnx.mobileledger.dao.CurrencyDAO;
-import net.ktnx.mobileledger.dao.PatternAccountDAO;
-import net.ktnx.mobileledger.dao.PatternHeaderDAO;
+import net.ktnx.mobileledger.dao.TemplateAccountDAO;
+import net.ktnx.mobileledger.dao.TemplateHeaderDAO;
 import net.ktnx.mobileledger.utils.MobileLedgerDatabase;
 
-@Database(version = 51, entities = {PatternHeader.class, PatternAccount.class, Currency.class})
+@Database(version = 58,
+          entities = {TemplateHeader.class, TemplateAccount.class, Currency.class, Account.class,
+                      Profile.class, Option.class, AccountValue.class, DescriptionHistory.class,
+                      Transaction.class
+          })
 abstract public class DB extends RoomDatabase {
     private static DB instance;
     public static DB get() {
@@ -39,10 +47,135 @@ abstract public class DB extends RoomDatabase {
 
             return instance =
                     Room.databaseBuilder(App.instance, DB.class, MobileLedgerDatabase.DB_NAME)
+                        .addMigrations(new Migration[]{new Migration(51, 52) {
+                            @Override
+                            public void migrate(@NonNull SupportSQLiteDatabase db) {
+                                db.beginTransaction();
+                                try {
+                                    db.execSQL("create index fk_pattern_accounts_pattern on " +
+                                               "pattern_accounts(pattern_id);");
+                                    db.execSQL("create index fk_pattern_accounts_currency on " +
+                                               "pattern_accounts(currency);");
+                                    db.setTransactionSuccessful();
+                                }
+                                finally {
+                                    db.endTransaction();
+                                }
+                            }
+                        }, new Migration(52, 53) {
+                            @Override
+                            public void migrate(@NonNull SupportSQLiteDatabase db) {
+                                db.execSQL(
+                                        "alter table pattern_accounts add negate_amount boolean;");
+                            }
+                        }, new Migration(53, 54) {
+                            @Override
+                            public void migrate(@NonNull SupportSQLiteDatabase db) {
+                                db.execSQL("CREATE TABLE templates (id INTEGER PRIMARY KEY " +
+                                           "AUTOINCREMENT NOT NULL, name TEXT NOT NULL, " +
+                                           "regular_expression TEXT NOT NULL, test_text TEXT, " +
+                                           "transaction_description TEXT, " +
+                                           "transaction_description_match_group INTEGER, " +
+                                           "transaction_comment TEXT, " +
+                                           "transaction_comment_match_group INTEGER, date_year " +
+                                           "INTEGER, date_year_match_group INTEGER, date_month " +
+                                           "INTEGER, date_month_match_group INTEGER, date_day " +
+                                           "INTEGER, date_day_match_group INTEGER)");
+                                db.execSQL(
+                                        "CREATE TABLE template_accounts (id INTEGER PRIMARY KEY " +
+                                        "AUTOINCREMENT NOT NULL, template_id INTEGER NOT NULL, " +
+                                        "acc TEXT, position INTEGER NOT NULL, acc_match_group " +
+                                        "INTEGER, currency INTEGER, currency_match_group INTEGER," +
+                                        " amount REAL, amount_match_group INTEGER, comment TEXT, " +
+                                        "comment_match_group INTEGER, negate_amount INTEGER, " +
+                                        "FOREIGN KEY(template_id) REFERENCES templates(id) ON " +
+                                        "UPDATE NO ACTION ON DELETE NO ACTION , FOREIGN KEY" +
+                                        "(currency) REFERENCES currencies(id) ON UPDATE NO ACTION" +
+                                        " ON DELETE NO ACTION )");
+                                db.execSQL("insert into templates(id, name, regular_expression, " +
+                                           "test_text, transaction_description, " +
+                                           "transaction_description_match_group, " +
+                                           "transaction_comment, transaction_comment_match_group," +
+                                           " date_year, date_year_match_group, date_month, " +
+                                           "date_month_match_group, date_day, " +
+                                           "date_day_match_group)" +
+                                           " select id, name, regular_expression, test_text, " +
+                                           "transaction_description, " +
+                                           "transaction_description_match_group, " +
+                                           "transaction_comment, transaction_comment_match_group," +
+                                           " date_year, date_year_match_group, date_month, " +
+                                           "date_month_match_group, date_day, " +
+                                           "date_day_match_group from patterns");
+                                db.execSQL("insert into template_accounts(id, template_id, acc, " +
+                                           "position, acc_match_group, currency, " +
+                                           "currency_match_group, amount, amount_match_group, " +
+                                           "amount, amount_match_group, comment, " +
+                                           "comment_match_group, negate_amount) select id, " +
+                                           "pattern_id, acc, position, acc_match_group, " +
+                                           "currency, " +
+                                           "currency_match_group, amount, amount_match_group, " +
+                                           "amount, amount_match_group, comment, " +
+                                           "comment_match_group, negate_amount from " +
+                                           "pattern_accounts");
+                                db.execSQL("create index fk_template_accounts_template on " +
+                                           "template_accounts(template_id)");
+                                db.execSQL("create index fk_template_accounts_currency on " +
+                                           "template_accounts(currency)");
+                                db.execSQL("drop table pattern_accounts");
+                                db.execSQL("drop table patterns");
+                            }
+                        }, new Migration(54, 55) {
+                            @Override
+                            public void migrate(@NonNull SupportSQLiteDatabase db) {
+                                db.execSQL(
+                                        "CREATE TABLE template_accounts_new (id INTEGER PRIMARY " +
+                                        "KEY " +
+                                        "AUTOINCREMENT NOT NULL, template_id INTEGER NOT NULL, " +
+                                        "acc TEXT, position INTEGER NOT NULL, acc_match_group " +
+                                        "INTEGER, currency INTEGER, currency_match_group INTEGER," +
+                                        " amount REAL, amount_match_group INTEGER, comment TEXT, " +
+                                        "comment_match_group INTEGER, negate_amount INTEGER, " +
+                                        "FOREIGN KEY(template_id) REFERENCES templates(id) ON " +
+                                        "UPDATE RESTRICT ON DELETE CASCADE , FOREIGN KEY" +
+                                        "(currency) REFERENCES currencies(id) ON UPDATE RESTRICT" +
+                                        " ON DELETE RESTRICT)");
+                                db.execSQL(
+                                        "insert into template_accounts_new(id, template_id, acc, " +
+                                        "position, acc_match_group, currency, " +
+                                        "currency_match_group, amount, amount_match_group, " +
+                                        "amount, amount_match_group, comment, " +
+                                        "comment_match_group, negate_amount) select id, " +
+                                        "template_id, acc, position, acc_match_group, " +
+                                        "currency, " +
+                                        "currency_match_group, amount, amount_match_group, " +
+                                        "amount, amount_match_group, comment, " +
+                                        "comment_match_group, negate_amount from " +
+                                        "template_accounts");
+                                db.execSQL("drop table template_accounts");
+                                db.execSQL("alter table template_accounts_new rename to " +
+                                           "template_accounts");
+                                db.execSQL("create index fk_template_accounts_template on " +
+                                           "template_accounts(template_id)");
+                                db.execSQL("create index fk_template_accounts_currency on " +
+                                           "template_accounts(currency)");
+                            }
+                        }
+                        })
+                        .addCallback(new Callback() {
+                            @Override
+                            public void onOpen(@NonNull SupportSQLiteDatabase db) {
+                                super.onOpen(db);
+                                db.execSQL("PRAGMA foreign_keys = ON");
+                            }
+                        })
                         .build();
         }
     }
-    public abstract PatternHeaderDAO getPatternDAO();
-    public abstract PatternAccountDAO getPatternAccountDAO();
+    public abstract TemplateHeaderDAO getTemplateDAO();
+
+    public abstract TemplateAccountDAO getTemplateAccountDAO();
+
     public abstract CurrencyDAO getCurrencyDAO();
+
+    public abstract AccountDAO getAccountDAO();
 }