Renamed id to technicalId and extracted createDefaultId() so that technicalId easier overridable in sub classes
This commit is contained in:
parent
0e194faee7
commit
37d471781f
|
@ -52,7 +52,7 @@ open class LuceneBankingPersistence(
|
||||||
|
|
||||||
transactions.forEach { transaction ->
|
transactions.forEach { transaction ->
|
||||||
writer.updateDocumentForNonNullFields(
|
writer.updateDocumentForNonNullFields(
|
||||||
IdFieldName, transaction.id,
|
IdFieldName, transaction.technicalId,
|
||||||
*createFieldsForAccountTransaction(bankAccount, transaction).toTypedArray()
|
*createFieldsForAccountTransaction(bankAccount, transaction).toTypedArray()
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,7 @@ open class LuceneBankingPersistence(
|
||||||
|
|
||||||
protected open fun createFieldsForAccountTransaction(bankAccount: BankAccount, transaction: AccountTransaction): List<IndexableField?> {
|
protected open fun createFieldsForAccountTransaction(bankAccount: BankAccount, transaction: AccountTransaction): List<IndexableField?> {
|
||||||
return listOf(
|
return listOf(
|
||||||
fields.keywordField(BankAccountIdFieldName, bankAccount.id),
|
fields.keywordField(BankAccountIdFieldName, bankAccount.technicalId),
|
||||||
fields.nullableFullTextSearchField(OtherPartyNameFieldName, transaction.otherPartyName, true),
|
fields.nullableFullTextSearchField(OtherPartyNameFieldName, transaction.otherPartyName, true),
|
||||||
fields.fullTextSearchField(UsageFieldName, transaction.usage, true),
|
fields.fullTextSearchField(UsageFieldName, transaction.usage, true),
|
||||||
fields.nullableFullTextSearchField(BookingTextFieldName, transaction.bookingText, true),
|
fields.nullableFullTextSearchField(BookingTextFieldName, transaction.bookingText, true),
|
||||||
|
@ -92,7 +92,7 @@ open class LuceneBankingPersistence(
|
||||||
protected open fun deleteAccountTransactions(bankAccounts: List<BankAccount>) {
|
protected open fun deleteAccountTransactions(bankAccounts: List<BankAccount>) {
|
||||||
val writer = getWriter()
|
val writer = getWriter()
|
||||||
|
|
||||||
val bankAccountIds = bankAccounts.map { it.id }
|
val bankAccountIds = bankAccounts.map { it.technicalId }
|
||||||
writer.deleteDocumentsAndFlushChangesToDisk(BankAccountIdFieldName, *bankAccountIds.toTypedArray())
|
writer.deleteDocumentsAndFlushChangesToDisk(BankAccountIdFieldName, *bankAccountIds.toTypedArray())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@ import net.dankito.utils.multiplatform.DateFormatStyle
|
||||||
import net.dankito.utils.multiplatform.DateFormatter
|
import net.dankito.utils.multiplatform.DateFormatter
|
||||||
|
|
||||||
|
|
||||||
//@JsonIdentityInfo(property = "id", generator = ObjectIdGenerators.PropertyGenerator::class) // to avoid stack overflow due to circular references
|
//@JsonIdentityInfo(property = "technicalId", generator = ObjectIdGenerators.PropertyGenerator::class) // to avoid stack overflow due to circular references
|
||||||
open class AccountTransaction(
|
open class AccountTransaction(
|
||||||
open val bankAccount: BankAccount,
|
open val bankAccount: BankAccount,
|
||||||
open val amount: BigDecimal,
|
open val amount: BigDecimal,
|
||||||
|
@ -72,11 +72,15 @@ open class AccountTransaction(
|
||||||
0, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, "", "", null, null, "", null)
|
0, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, "", "", null, null, "", null)
|
||||||
|
|
||||||
|
|
||||||
|
open val technicalId: String = createDefaultId()
|
||||||
|
|
||||||
|
protected fun createDefaultId() =
|
||||||
|
"${bankAccount.technicalId} ${IdDateFormat.format(bookingDate)} ${IdDateFormat.format(valueDate)} $amount $currency $unparsedUsage $otherPartyName $otherPartyBankCode $otherPartyAccountId"
|
||||||
|
|
||||||
open var id: String = "${bankAccount.id} ${IdDateFormat.format(bookingDate)} ${IdDateFormat.format(valueDate)} $amount $currency $unparsedUsage $otherPartyName $otherPartyBankCode $otherPartyAccountId"
|
|
||||||
|
|
||||||
open val showOtherPartyName: Boolean
|
open val showOtherPartyName: Boolean
|
||||||
get() = otherPartyName.isNullOrBlank() == false /* && type != "ENTGELTABSCHLUSS" && type != "AUSZAHLUNG" */ // TODO
|
get() = otherPartyName.isNullOrBlank() == false /* && type != "ENTGELTABSCHLUSS" && type != "AUSZAHLUNG" */ // TODO
|
||||||
|
|
||||||
open val usage: String
|
open val usage: String
|
||||||
get() = sepaUsage ?: unparsedUsage
|
get() = sepaUsage ?: unparsedUsage
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,14 @@
|
||||||
package net.dankito.banking.ui.model
|
package net.dankito.banking.ui.model
|
||||||
|
|
||||||
|
//import com.fasterxml.jackson.annotation.JsonIdentityInfo
|
||||||
|
//import com.fasterxml.jackson.annotation.ObjectIdGenerators
|
||||||
import net.dankito.utils.multiplatform.BigDecimal
|
import net.dankito.utils.multiplatform.BigDecimal
|
||||||
import net.dankito.utils.multiplatform.Date
|
import net.dankito.utils.multiplatform.Date
|
||||||
import net.dankito.utils.multiplatform.UUID
|
import net.dankito.utils.multiplatform.UUID
|
||||||
import kotlin.jvm.JvmOverloads
|
import kotlin.jvm.JvmOverloads
|
||||||
|
|
||||||
|
|
||||||
|
//@JsonIdentityInfo(property = "technicalId", generator = ObjectIdGenerators.PropertyGenerator::class) // to avoid stack overflow due to circular references
|
||||||
open class BankAccount @JvmOverloads constructor(
|
open class BankAccount @JvmOverloads constructor(
|
||||||
open val customer: Customer,
|
open val customer: Customer,
|
||||||
open val identifier: String,
|
open val identifier: String,
|
||||||
|
@ -37,7 +40,7 @@ open class BankAccount @JvmOverloads constructor(
|
||||||
: this(customer, identifier, "", null, null, "", balance, "EUR", type, productName)
|
: this(customer, identifier, "", null, null, "", balance, "EUR", type, productName)
|
||||||
|
|
||||||
|
|
||||||
open var id: String = UUID.random()
|
open var technicalId: String = UUID.random()
|
||||||
|
|
||||||
|
|
||||||
open val displayName: String
|
open val displayName: String
|
||||||
|
|
|
@ -10,7 +10,7 @@ import net.dankito.banking.ui.model.tan.TanProcedure
|
||||||
import net.dankito.utils.multiplatform.UUID
|
import net.dankito.utils.multiplatform.UUID
|
||||||
|
|
||||||
|
|
||||||
//@JsonIdentityInfo(property = "id", generator = ObjectIdGenerators.PropertyGenerator::class) // to avoid stack overflow due to circular references
|
//@JsonIdentityInfo(property = "technicalId", generator = ObjectIdGenerators.PropertyGenerator::class) // to avoid stack overflow due to circular references
|
||||||
open class Customer(
|
open class Customer(
|
||||||
open val bankCode: String,
|
open val bankCode: String,
|
||||||
open val customerId: String,
|
open val customerId: String,
|
||||||
|
@ -33,7 +33,7 @@ open class Customer(
|
||||||
: this(bankCode, customerId, password, finTsServerAddress, "", "", "")
|
: this(bankCode, customerId, password, finTsServerAddress, "", "", "")
|
||||||
|
|
||||||
|
|
||||||
open var id: String = UUID.random()
|
open var technicalId: String = UUID.random()
|
||||||
|
|
||||||
|
|
||||||
open var supportedTanProcedures: List<TanProcedure> = listOf()
|
open var supportedTanProcedures: List<TanProcedure> = listOf()
|
||||||
|
|
Loading…
Reference in New Issue