Fixed updating account data after retrieving transactions

This commit is contained in:
dankito 2024-10-04 09:13:39 +02:00
parent cd8f8a32e6
commit 390d529be0
5 changed files with 10 additions and 30 deletions

View File

@ -31,9 +31,9 @@ interface BankingRepository {
suspend fun updateBank(bank: BankAccessEntity, loginName: String, password: String, bankName: String?) suspend fun updateBank(bank: BankAccessEntity, loginName: String, password: String, bankName: String?)
suspend fun updateAccount(bank: BankAccountEntity, userSetDisplayName: String?, hideAccount: Boolean, includeInAutomaticAccountsUpdate: Boolean) suspend fun updateAccount(account: BankAccountEntity, userSetDisplayName: String?, hideAccount: Boolean, includeInAutomaticAccountsUpdate: Boolean)
suspend fun updateAccount(account: BankAccountEntity, balance: Amount?, lastAccountUpdateTime: Instant, retrievedTransactionsFrom: LocalDate?) suspend fun updateAccount(account: BankAccountEntity, balance: Amount, lastAccountUpdateTime: Instant, retrievedTransactionsFrom: LocalDate?)
suspend fun deleteBank(bank: BankAccessEntity) suspend fun deleteBank(bank: BankAccessEntity)

View File

@ -55,11 +55,11 @@ class InMemoryBankingRepository(
// no-op // no-op
} }
override suspend fun updateAccount(bank: BankAccountEntity, userSetDisplayName: String?, hideAccount: Boolean, includeInAutomaticAccountsUpdate: Boolean) { override suspend fun updateAccount(account: BankAccountEntity, userSetDisplayName: String?, hideAccount: Boolean, includeInAutomaticAccountsUpdate: Boolean) {
// no-op // no-op
} }
override suspend fun updateAccount(account: BankAccountEntity, balance: Amount?, lastAccountUpdateTime: Instant, retrievedTransactionsFrom: LocalDate?) { override suspend fun updateAccount(account: BankAccountEntity, balance: Amount, lastAccountUpdateTime: Instant, retrievedTransactionsFrom: LocalDate?) {
// no-op // no-op
} }

View File

@ -157,18 +157,8 @@ open class SqliteBankingRepository : BankingRepository {
} }
} }
override suspend fun updateAccount(account: BankAccountEntity, balance: Amount?, lastAccountUpdateTime: Instant, retrievedTransactionsFrom: LocalDate?) { override suspend fun updateAccount(account: BankAccountEntity, balance: Amount, lastAccountUpdateTime: Instant, retrievedTransactionsFrom: LocalDate?) {
bankQueries.transaction { bankQueries.updateBankAccount(mapAmount(balance), mapInstant(lastAccountUpdateTime), mapDate(retrievedTransactionsFrom), account.id)
if (balance != null && account.balance != balance) {
bankQueries.updateBankAccountBalance(mapAmount(balance), account.id)
}
bankQueries.updateBankAccountLastAccountUpdateTime(mapInstant(lastAccountUpdateTime), account.id)
if (retrievedTransactionsFrom != null && (account.retrievedTransactionsFrom == null || account.retrievedTransactionsFrom!! > retrievedTransactionsFrom)) {
bankQueries.updateBankAccountRetrievedTransactionsFrom(mapDate(retrievedTransactionsFrom), account.id)
}
}
} }
override suspend fun deleteBank(bank: BankAccessEntity) { override suspend fun deleteBank(bank: BankAccessEntity) {

View File

@ -187,20 +187,10 @@ SELECT BankAccount.*
FROM BankAccount; FROM BankAccount;
updateBankAccountBalance: updateBankAccount:
UPDATE BankAccount UPDATE BankAccount
SET balance = ? SET balance = :balance, lastAccountUpdateTime = :lastAccountUpdateTime, retrievedTransactionsFrom = :retrievedTransactionsFrom
WHERE id = ?; WHERE id = :accountId;
updateBankAccountLastAccountUpdateTime:
UPDATE BankAccount
SET lastAccountUpdateTime = ?
WHERE id = ?;
updateBankAccountRetrievedTransactionsFrom:
UPDATE BankAccount
SET retrievedTransactionsFrom = ?
WHERE id = ?;
updateBankAccountUserSetDisplayName: updateBankAccountUserSetDisplayName:

View File

@ -276,7 +276,7 @@ class BankingService(
val transactionsViewModel = updateTransactionsInUi(newTransactionsEntities) val transactionsViewModel = updateTransactionsInUi(newTransactionsEntities)
uiState.dispatchNewTransactionsRetrieved(AccountTransactionsRetrievedEvent(bank, account, transactionsViewModel, response.holdings)) uiState.dispatchNewTransactionsRetrieved(AccountTransactionsRetrievedEvent(bank, account, transactionsViewModel, response.holdings))
bankingRepository.updateAccount(account, response.balance, response.transactionsRetrievalTime, response.retrievedTransactionsFrom) bankingRepository.updateAccount(account, response.balance ?: account.balance, response.transactionsRetrievalTime, response.retrievedTransactionsFrom ?: account.retrievedTransactionsFrom)
} }
notifyBanksListUpdated() // notify about updated values like account balance notifyBanksListUpdated() // notify about updated values like account balance