X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fmodel%2FMobileLedgerProfile.java;h=eef71a32b1a11490a513fdcf0156bb44b078edbe;hb=8098a8b37a4331b9faf6cf50a51a0d7aa9677421;hp=6f70bda5498d283aa5d62b5ba346d34ec1806b2a;hpb=9d9baff5b649eda7609fe77fe6d6aadf986bb300;p=mobile-ledger.git diff --git a/app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java b/app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java index 6f70bda5..eef71a32 100644 --- a/app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java +++ b/app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java @@ -22,15 +22,21 @@ import android.content.Intent; import android.content.res.Resources; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; +import android.os.AsyncTask; import android.os.Bundle; import android.text.TextUtils; import android.util.SparseArray; import androidx.annotation.Nullable; +import androidx.room.Transaction; import net.ktnx.mobileledger.App; import net.ktnx.mobileledger.R; import net.ktnx.mobileledger.async.DbOpQueue; +import net.ktnx.mobileledger.dao.AccountDAO; +import net.ktnx.mobileledger.dao.OptionDAO; +import net.ktnx.mobileledger.dao.TransactionDAO; +import net.ktnx.mobileledger.db.DB; import net.ktnx.mobileledger.json.API; import net.ktnx.mobileledger.ui.profiles.ProfileDetailActivity; import net.ktnx.mobileledger.ui.profiles.ProfileDetailFragment; @@ -558,7 +564,8 @@ public final class MobileLedgerProfile { } private int getNextAccountsGeneration(SQLiteDatabase db) { try (Cursor c = db.rawQuery("SELECT generation FROM accounts WHERE profile_id=? LIMIT 1", - new String[]{String.valueOf(id)})) { + new String[]{String.valueOf(id)})) + { if (c.moveToFirst()) return c.getInt(0) + 1; } @@ -566,36 +573,39 @@ public final class MobileLedgerProfile { } private void deleteNotPresentAccounts(SQLiteDatabase db, int generation) { Logger.debug("db/benchmark", "Deleting obsolete accounts"); - db.execSQL("DELETE FROM account_values WHERE profile=? AND generation <> ?", + db.execSQL("DELETE FROM account_values WHERE (select a.profile_id from accounts a where a" + + ".id=account_values.account_id)=? AND generation <> ?", new Object[]{id, generation}); - db.execSQL("DELETE FROM accounts WHERE profile=? AND generation <> ?", + db.execSQL("DELETE FROM accounts WHERE profile_id=? AND generation <> ?", new Object[]{id, generation}); Logger.debug("db/benchmark", "Done deleting obsolete accounts"); } private void deleteNotPresentTransactions(SQLiteDatabase db, int generation) { Logger.debug("db/benchmark", "Deleting obsolete transactions"); - db.execSQL("DELETE FROM transaction_accounts WHERE profile=? AND generation <> ?", + db.execSQL( + "DELETE FROM transaction_accounts WHERE (select t.profile_id from transactions t " + + "where t.id=transaction_accounts.transaction_id)=? AND generation" + " <> ?", new Object[]{id, generation}); - db.execSQL("DELETE FROM transactions WHERE profile=? AND generation <> ?", + db.execSQL("DELETE FROM transactions WHERE profile_id=? AND generation <> ?", new Object[]{id, generation}); Logger.debug("db/benchmark", "Done deleting obsolete transactions"); } + @Transaction + public void wipeAllDataSync() { + OptionDAO optDao = DB.get() + .getOptionDAO(); + optDao.deleteSync(optDao.allForProfileSync(id)); + + AccountDAO accDao = DB.get() + .getAccountDAO(); + accDao.deleteSync(accDao.allForProfileSync(id)); + + TransactionDAO trnDao = DB.get() + .getTransactionDAO(); + trnDao.deleteSync(trnDao.allForProfileSync(id)); + } public void wipeAllData() { - SQLiteDatabase db = App.getDatabase(); - db.beginTransaction(); - try { - String[] pUuid = new String[]{String.valueOf(id)}; - db.execSQL("delete from options where profile=?", pUuid); - db.execSQL("delete from accounts where profile=?", pUuid); - db.execSQL("delete from account_values where profile=?", pUuid); - db.execSQL("delete from transactions where profile=?", pUuid); - db.execSQL("delete from transaction_accounts where profile=?", pUuid); - db.setTransactionSuccessful(); - debug("wipe", String.format(Locale.ENGLISH, "Profile %s wiped out", pUuid[0])); - } - finally { - db.endTransaction(); - } + AsyncTask.execute(this::wipeAllDataSync); } public List getCurrencies() { SQLiteDatabase db = App.getDatabase();