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 = 53, entities = {TemplateHeader.class, TemplateAccount.class, Currency.class})
+@Database(version = 57, entities = {TemplateHeader.class, TemplateAccount.class, Currency.class,
+ net.ktnx.mobileledger.db.Account.class
+})
abstract public class DB extends RoomDatabase {
private static DB instance;
public static DB get() {
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 TemplateHeaderDAO getTemplateDAO();
- public abstract PatternAccountDAO getPatternAccountDAO();
+ public abstract TemplateAccountDAO getTemplateAccountDAO();
public abstract CurrencyDAO getCurrencyDAO();
+
+ public abstract AccountDAO getAccountDAO();
}