]> git.ktnx.net Git - mobile-ledger.git/blobdiff - app/src/main/java/net/ktnx/mobileledger/async/UpdateAccountsTask.java
somewhat complete profile implementation
[mobile-ledger.git] / app / src / main / java / net / ktnx / mobileledger / async / UpdateAccountsTask.java
index c63dd32cfeb7f1f207acc74ed157871735802d08..1ade3d536a7168b6e5be99c0c8e04bb1a75d38dc 100644 (file)
@@ -31,21 +31,22 @@ import java.util.ArrayList;
 public class UpdateAccountsTask extends AsyncTask<Boolean, Void, ArrayList<LedgerAccount>> {
     protected ArrayList<LedgerAccount> doInBackground(Boolean[] onlyStarred) {
         Data.backgroundTaskCount.incrementAndGet();
+        String profileUUID = Data.profile.get().getUuid();
         try {
             ArrayList<LedgerAccount> newList = new ArrayList<>();
 
-            String sql = "SELECT name, hidden FROM accounts";
-            if (onlyStarred[0]) sql += " WHERE hidden = 0";
+            String sql = "SELECT name, hidden FROM accounts WHERE profile = ?";
+            if (onlyStarred[0]) sql += " AND hidden = 0";
             sql += " ORDER BY name";
 
             SQLiteDatabase db = MLDB.getReadableDatabase();
-            try (Cursor cursor = db.rawQuery(sql, null)) {
+            try (Cursor cursor = db.rawQuery(sql, new String[]{profileUUID})) {
                 while (cursor.moveToNext()) {
                     LedgerAccount acc = new LedgerAccount(cursor.getString(0));
                     acc.setHidden(cursor.getInt(1) == 1);
                     try (Cursor c2 = db.rawQuery(
-                            "SELECT value, currency FROM account_values " + "WHERE account = ?",
-                            new String[]{acc.getName()}))
+                            "SELECT value, currency FROM account_values WHERE profile = ? " +
+                            "AND account = ?", new String[]{profileUUID, acc.getName()}))
                     {
                         while (c2.moveToNext()) {
                             acc.addAmount(c2.getFloat(0), c2.getString(1));