com.lithic.api.models.LoanTape.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lithic-kotlin-core Show documentation
Show all versions of lithic-kotlin-core Show documentation
The Lithic Developer API is designed to provide a predictable programmatic
interface for accessing your Lithic account through an API and transaction
webhooks. Note that your API key is a secret and should be treated as such.
Don't share it with anyone, including us. We will never ask you for it.
The newest version!
// File generated from our OpenAPI spec by Stainless.
package com.lithic.api.models
import com.fasterxml.jackson.annotation.JsonAnyGetter
import com.fasterxml.jackson.annotation.JsonAnySetter
import com.fasterxml.jackson.annotation.JsonCreator
import com.fasterxml.jackson.annotation.JsonProperty
import com.fasterxml.jackson.databind.annotation.JsonDeserialize
import com.lithic.api.core.Enum
import com.lithic.api.core.ExcludeMissing
import com.lithic.api.core.JsonField
import com.lithic.api.core.JsonMissing
import com.lithic.api.core.JsonValue
import com.lithic.api.core.NoAutoDetect
import com.lithic.api.core.toImmutable
import com.lithic.api.errors.LithicInvalidDataException
import java.time.LocalDate
import java.time.OffsetDateTime
import java.util.Objects
@JsonDeserialize(builder = LoanTape.Builder::class)
@NoAutoDetect
class LoanTape
private constructor(
private val token: JsonField,
private val financialAccountToken: JsonField,
private val date: JsonField,
private val created: JsonField,
private val updated: JsonField,
private val version: JsonField,
private val ytdTotals: JsonField,
private val periodTotals: JsonField,
private val dayTotals: JsonField,
private val balances: JsonField,
private val startingBalance: JsonField,
private val endingBalance: JsonField,
private val creditLimit: JsonField,
private val availableCredit: JsonField,
private val excessCredits: JsonField,
private val accountStanding: JsonField,
private val creditProductToken: JsonField,
private val tier: JsonField,
private val paymentAllocation: JsonField,
private val minimumPaymentBalance: JsonField,
private val previousStatementBalance: JsonField,
private val interestDetails: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
/** Globally unique identifier for a loan tape */
fun token(): String = token.getRequired("token")
/** Globally unique identifier for a financial account */
fun financialAccountToken(): String =
financialAccountToken.getRequired("financial_account_token")
/** Date of transactions that this loan tape covers */
fun date(): LocalDate = date.getRequired("date")
/** Timestamp of when the loan tape was created */
fun created(): OffsetDateTime = created.getRequired("created")
/** Timestamp of when the loan tape was updated */
fun updated(): OffsetDateTime = updated.getRequired("updated")
/** Version number of the loan tape. This starts at 1 */
fun version(): Long = version.getRequired("version")
fun ytdTotals(): StatementTotals = ytdTotals.getRequired("ytd_totals")
fun periodTotals(): StatementTotals = periodTotals.getRequired("period_totals")
fun dayTotals(): StatementTotals = dayTotals.getRequired("day_totals")
fun balances(): Balances = balances.getRequired("balances")
/** Balance at the start of the day */
fun startingBalance(): Long = startingBalance.getRequired("starting_balance")
/** Balance at the end of the day */
fun endingBalance(): Long = endingBalance.getRequired("ending_balance")
/**
* For prepay accounts, this is the minimum prepay balance that must be maintained. For charge
* card accounts, this is the maximum credit balance extended by a lender
*/
fun creditLimit(): Long = creditLimit.getRequired("credit_limit")
/** Amount of credit available to spend in cents */
fun availableCredit(): Long = availableCredit.getRequired("available_credit")
/**
* Excess credits in the form of provisional credits, payments, or purchase refunds. If
* positive, the account is in net credit state with no outstanding balances. An overpayment
* could land an account in this state
*/
fun excessCredits(): Long = excessCredits.getRequired("excess_credits")
fun accountStanding(): AccountStanding = accountStanding.getRequired("account_standing")
/** Globally unique identifier for a credit product */
fun creditProductToken(): String = creditProductToken.getRequired("credit_product_token")
/** Interest tier to which this account belongs to */
fun tier(): String? = tier.getNullable("tier")
fun paymentAllocation(): CategoryBalances = paymentAllocation.getRequired("payment_allocation")
fun minimumPaymentBalance(): BalanceDetails =
minimumPaymentBalance.getRequired("minimum_payment_balance")
fun previousStatementBalance(): BalanceDetails =
previousStatementBalance.getRequired("previous_statement_balance")
fun interestDetails(): InterestDetails? = interestDetails.getNullable("interest_details")
/** Globally unique identifier for a loan tape */
@JsonProperty("token") @ExcludeMissing fun _token() = token
/** Globally unique identifier for a financial account */
@JsonProperty("financial_account_token")
@ExcludeMissing
fun _financialAccountToken() = financialAccountToken
/** Date of transactions that this loan tape covers */
@JsonProperty("date") @ExcludeMissing fun _date() = date
/** Timestamp of when the loan tape was created */
@JsonProperty("created") @ExcludeMissing fun _created() = created
/** Timestamp of when the loan tape was updated */
@JsonProperty("updated") @ExcludeMissing fun _updated() = updated
/** Version number of the loan tape. This starts at 1 */
@JsonProperty("version") @ExcludeMissing fun _version() = version
@JsonProperty("ytd_totals") @ExcludeMissing fun _ytdTotals() = ytdTotals
@JsonProperty("period_totals") @ExcludeMissing fun _periodTotals() = periodTotals
@JsonProperty("day_totals") @ExcludeMissing fun _dayTotals() = dayTotals
@JsonProperty("balances") @ExcludeMissing fun _balances() = balances
/** Balance at the start of the day */
@JsonProperty("starting_balance") @ExcludeMissing fun _startingBalance() = startingBalance
/** Balance at the end of the day */
@JsonProperty("ending_balance") @ExcludeMissing fun _endingBalance() = endingBalance
/**
* For prepay accounts, this is the minimum prepay balance that must be maintained. For charge
* card accounts, this is the maximum credit balance extended by a lender
*/
@JsonProperty("credit_limit") @ExcludeMissing fun _creditLimit() = creditLimit
/** Amount of credit available to spend in cents */
@JsonProperty("available_credit") @ExcludeMissing fun _availableCredit() = availableCredit
/**
* Excess credits in the form of provisional credits, payments, or purchase refunds. If
* positive, the account is in net credit state with no outstanding balances. An overpayment
* could land an account in this state
*/
@JsonProperty("excess_credits") @ExcludeMissing fun _excessCredits() = excessCredits
@JsonProperty("account_standing") @ExcludeMissing fun _accountStanding() = accountStanding
/** Globally unique identifier for a credit product */
@JsonProperty("credit_product_token")
@ExcludeMissing
fun _creditProductToken() = creditProductToken
/** Interest tier to which this account belongs to */
@JsonProperty("tier") @ExcludeMissing fun _tier() = tier
@JsonProperty("payment_allocation") @ExcludeMissing fun _paymentAllocation() = paymentAllocation
@JsonProperty("minimum_payment_balance")
@ExcludeMissing
fun _minimumPaymentBalance() = minimumPaymentBalance
@JsonProperty("previous_statement_balance")
@ExcludeMissing
fun _previousStatementBalance() = previousStatementBalance
@JsonProperty("interest_details") @ExcludeMissing fun _interestDetails() = interestDetails
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): LoanTape = apply {
if (!validated) {
token()
financialAccountToken()
date()
created()
updated()
version()
ytdTotals().validate()
periodTotals().validate()
dayTotals().validate()
balances().validate()
startingBalance()
endingBalance()
creditLimit()
availableCredit()
excessCredits()
accountStanding().validate()
creditProductToken()
tier()
paymentAllocation().validate()
minimumPaymentBalance().validate()
previousStatementBalance().validate()
interestDetails()?.validate()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var token: JsonField = JsonMissing.of()
private var financialAccountToken: JsonField = JsonMissing.of()
private var date: JsonField = JsonMissing.of()
private var created: JsonField = JsonMissing.of()
private var updated: JsonField = JsonMissing.of()
private var version: JsonField = JsonMissing.of()
private var ytdTotals: JsonField = JsonMissing.of()
private var periodTotals: JsonField = JsonMissing.of()
private var dayTotals: JsonField = JsonMissing.of()
private var balances: JsonField = JsonMissing.of()
private var startingBalance: JsonField = JsonMissing.of()
private var endingBalance: JsonField = JsonMissing.of()
private var creditLimit: JsonField = JsonMissing.of()
private var availableCredit: JsonField = JsonMissing.of()
private var excessCredits: JsonField = JsonMissing.of()
private var accountStanding: JsonField = JsonMissing.of()
private var creditProductToken: JsonField = JsonMissing.of()
private var tier: JsonField = JsonMissing.of()
private var paymentAllocation: JsonField = JsonMissing.of()
private var minimumPaymentBalance: JsonField = JsonMissing.of()
private var previousStatementBalance: JsonField = JsonMissing.of()
private var interestDetails: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(loanTape: LoanTape) = apply {
this.token = loanTape.token
this.financialAccountToken = loanTape.financialAccountToken
this.date = loanTape.date
this.created = loanTape.created
this.updated = loanTape.updated
this.version = loanTape.version
this.ytdTotals = loanTape.ytdTotals
this.periodTotals = loanTape.periodTotals
this.dayTotals = loanTape.dayTotals
this.balances = loanTape.balances
this.startingBalance = loanTape.startingBalance
this.endingBalance = loanTape.endingBalance
this.creditLimit = loanTape.creditLimit
this.availableCredit = loanTape.availableCredit
this.excessCredits = loanTape.excessCredits
this.accountStanding = loanTape.accountStanding
this.creditProductToken = loanTape.creditProductToken
this.tier = loanTape.tier
this.paymentAllocation = loanTape.paymentAllocation
this.minimumPaymentBalance = loanTape.minimumPaymentBalance
this.previousStatementBalance = loanTape.previousStatementBalance
this.interestDetails = loanTape.interestDetails
additionalProperties(loanTape.additionalProperties)
}
/** Globally unique identifier for a loan tape */
fun token(token: String) = token(JsonField.of(token))
/** Globally unique identifier for a loan tape */
@JsonProperty("token")
@ExcludeMissing
fun token(token: JsonField) = apply { this.token = token }
/** Globally unique identifier for a financial account */
fun financialAccountToken(financialAccountToken: String) =
financialAccountToken(JsonField.of(financialAccountToken))
/** Globally unique identifier for a financial account */
@JsonProperty("financial_account_token")
@ExcludeMissing
fun financialAccountToken(financialAccountToken: JsonField) = apply {
this.financialAccountToken = financialAccountToken
}
/** Date of transactions that this loan tape covers */
fun date(date: LocalDate) = date(JsonField.of(date))
/** Date of transactions that this loan tape covers */
@JsonProperty("date")
@ExcludeMissing
fun date(date: JsonField) = apply { this.date = date }
/** Timestamp of when the loan tape was created */
fun created(created: OffsetDateTime) = created(JsonField.of(created))
/** Timestamp of when the loan tape was created */
@JsonProperty("created")
@ExcludeMissing
fun created(created: JsonField) = apply { this.created = created }
/** Timestamp of when the loan tape was updated */
fun updated(updated: OffsetDateTime) = updated(JsonField.of(updated))
/** Timestamp of when the loan tape was updated */
@JsonProperty("updated")
@ExcludeMissing
fun updated(updated: JsonField) = apply { this.updated = updated }
/** Version number of the loan tape. This starts at 1 */
fun version(version: Long) = version(JsonField.of(version))
/** Version number of the loan tape. This starts at 1 */
@JsonProperty("version")
@ExcludeMissing
fun version(version: JsonField) = apply { this.version = version }
fun ytdTotals(ytdTotals: StatementTotals) = ytdTotals(JsonField.of(ytdTotals))
@JsonProperty("ytd_totals")
@ExcludeMissing
fun ytdTotals(ytdTotals: JsonField) = apply { this.ytdTotals = ytdTotals }
fun periodTotals(periodTotals: StatementTotals) = periodTotals(JsonField.of(periodTotals))
@JsonProperty("period_totals")
@ExcludeMissing
fun periodTotals(periodTotals: JsonField) = apply {
this.periodTotals = periodTotals
}
fun dayTotals(dayTotals: StatementTotals) = dayTotals(JsonField.of(dayTotals))
@JsonProperty("day_totals")
@ExcludeMissing
fun dayTotals(dayTotals: JsonField) = apply { this.dayTotals = dayTotals }
fun balances(balances: Balances) = balances(JsonField.of(balances))
@JsonProperty("balances")
@ExcludeMissing
fun balances(balances: JsonField) = apply { this.balances = balances }
/** Balance at the start of the day */
fun startingBalance(startingBalance: Long) = startingBalance(JsonField.of(startingBalance))
/** Balance at the start of the day */
@JsonProperty("starting_balance")
@ExcludeMissing
fun startingBalance(startingBalance: JsonField) = apply {
this.startingBalance = startingBalance
}
/** Balance at the end of the day */
fun endingBalance(endingBalance: Long) = endingBalance(JsonField.of(endingBalance))
/** Balance at the end of the day */
@JsonProperty("ending_balance")
@ExcludeMissing
fun endingBalance(endingBalance: JsonField) = apply {
this.endingBalance = endingBalance
}
/**
* For prepay accounts, this is the minimum prepay balance that must be maintained. For
* charge card accounts, this is the maximum credit balance extended by a lender
*/
fun creditLimit(creditLimit: Long) = creditLimit(JsonField.of(creditLimit))
/**
* For prepay accounts, this is the minimum prepay balance that must be maintained. For
* charge card accounts, this is the maximum credit balance extended by a lender
*/
@JsonProperty("credit_limit")
@ExcludeMissing
fun creditLimit(creditLimit: JsonField) = apply { this.creditLimit = creditLimit }
/** Amount of credit available to spend in cents */
fun availableCredit(availableCredit: Long) = availableCredit(JsonField.of(availableCredit))
/** Amount of credit available to spend in cents */
@JsonProperty("available_credit")
@ExcludeMissing
fun availableCredit(availableCredit: JsonField) = apply {
this.availableCredit = availableCredit
}
/**
* Excess credits in the form of provisional credits, payments, or purchase refunds. If
* positive, the account is in net credit state with no outstanding balances. An overpayment
* could land an account in this state
*/
fun excessCredits(excessCredits: Long) = excessCredits(JsonField.of(excessCredits))
/**
* Excess credits in the form of provisional credits, payments, or purchase refunds. If
* positive, the account is in net credit state with no outstanding balances. An overpayment
* could land an account in this state
*/
@JsonProperty("excess_credits")
@ExcludeMissing
fun excessCredits(excessCredits: JsonField) = apply {
this.excessCredits = excessCredits
}
fun accountStanding(accountStanding: AccountStanding) =
accountStanding(JsonField.of(accountStanding))
@JsonProperty("account_standing")
@ExcludeMissing
fun accountStanding(accountStanding: JsonField) = apply {
this.accountStanding = accountStanding
}
/** Globally unique identifier for a credit product */
fun creditProductToken(creditProductToken: String) =
creditProductToken(JsonField.of(creditProductToken))
/** Globally unique identifier for a credit product */
@JsonProperty("credit_product_token")
@ExcludeMissing
fun creditProductToken(creditProductToken: JsonField) = apply {
this.creditProductToken = creditProductToken
}
/** Interest tier to which this account belongs to */
fun tier(tier: String) = tier(JsonField.of(tier))
/** Interest tier to which this account belongs to */
@JsonProperty("tier")
@ExcludeMissing
fun tier(tier: JsonField) = apply { this.tier = tier }
fun paymentAllocation(paymentAllocation: CategoryBalances) =
paymentAllocation(JsonField.of(paymentAllocation))
@JsonProperty("payment_allocation")
@ExcludeMissing
fun paymentAllocation(paymentAllocation: JsonField) = apply {
this.paymentAllocation = paymentAllocation
}
fun minimumPaymentBalance(minimumPaymentBalance: BalanceDetails) =
minimumPaymentBalance(JsonField.of(minimumPaymentBalance))
@JsonProperty("minimum_payment_balance")
@ExcludeMissing
fun minimumPaymentBalance(minimumPaymentBalance: JsonField) = apply {
this.minimumPaymentBalance = minimumPaymentBalance
}
fun previousStatementBalance(previousStatementBalance: BalanceDetails) =
previousStatementBalance(JsonField.of(previousStatementBalance))
@JsonProperty("previous_statement_balance")
@ExcludeMissing
fun previousStatementBalance(previousStatementBalance: JsonField) = apply {
this.previousStatementBalance = previousStatementBalance
}
fun interestDetails(interestDetails: InterestDetails) =
interestDetails(JsonField.of(interestDetails))
@JsonProperty("interest_details")
@ExcludeMissing
fun interestDetails(interestDetails: JsonField) = apply {
this.interestDetails = interestDetails
}
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): LoanTape =
LoanTape(
token,
financialAccountToken,
date,
created,
updated,
version,
ytdTotals,
periodTotals,
dayTotals,
balances,
startingBalance,
endingBalance,
creditLimit,
availableCredit,
excessCredits,
accountStanding,
creditProductToken,
tier,
paymentAllocation,
minimumPaymentBalance,
previousStatementBalance,
interestDetails,
additionalProperties.toImmutable(),
)
}
@JsonDeserialize(builder = AccountStanding.Builder::class)
@NoAutoDetect
class AccountStanding
private constructor(
private val periodState: JsonField,
private val periodNumber: JsonField,
private val consecutiveMinimumPaymentsMade: JsonField,
private val consecutiveMinimumPaymentsMissed: JsonField,
private val consecutiveFullPaymentsMade: JsonField,
private val daysPastDue: JsonField,
private val hasGrace: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
fun periodState(): PeriodState = periodState.getRequired("period_state")
/** Current overall period number */
fun periodNumber(): Long = periodNumber.getRequired("period_number")
/** Number of consecutive minimum payments made */
fun consecutiveMinimumPaymentsMade(): Long =
consecutiveMinimumPaymentsMade.getRequired("consecutive_minimum_payments_made")
/** Number of consecutive minimum payments missed */
fun consecutiveMinimumPaymentsMissed(): Long =
consecutiveMinimumPaymentsMissed.getRequired("consecutive_minimum_payments_missed")
/** Number of consecutive full payments made */
fun consecutiveFullPaymentsMade(): Long =
consecutiveFullPaymentsMade.getRequired("consecutive_full_payments_made")
/** Number of days past due */
fun daysPastDue(): Long = daysPastDue.getRequired("days_past_due")
/** Whether the account currently has grace or not */
fun hasGrace(): Boolean = hasGrace.getRequired("has_grace")
@JsonProperty("period_state") @ExcludeMissing fun _periodState() = periodState
/** Current overall period number */
@JsonProperty("period_number") @ExcludeMissing fun _periodNumber() = periodNumber
/** Number of consecutive minimum payments made */
@JsonProperty("consecutive_minimum_payments_made")
@ExcludeMissing
fun _consecutiveMinimumPaymentsMade() = consecutiveMinimumPaymentsMade
/** Number of consecutive minimum payments missed */
@JsonProperty("consecutive_minimum_payments_missed")
@ExcludeMissing
fun _consecutiveMinimumPaymentsMissed() = consecutiveMinimumPaymentsMissed
/** Number of consecutive full payments made */
@JsonProperty("consecutive_full_payments_made")
@ExcludeMissing
fun _consecutiveFullPaymentsMade() = consecutiveFullPaymentsMade
/** Number of days past due */
@JsonProperty("days_past_due") @ExcludeMissing fun _daysPastDue() = daysPastDue
/** Whether the account currently has grace or not */
@JsonProperty("has_grace") @ExcludeMissing fun _hasGrace() = hasGrace
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): AccountStanding = apply {
if (!validated) {
periodState()
periodNumber()
consecutiveMinimumPaymentsMade()
consecutiveMinimumPaymentsMissed()
consecutiveFullPaymentsMade()
daysPastDue()
hasGrace()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var periodState: JsonField = JsonMissing.of()
private var periodNumber: JsonField = JsonMissing.of()
private var consecutiveMinimumPaymentsMade: JsonField = JsonMissing.of()
private var consecutiveMinimumPaymentsMissed: JsonField = JsonMissing.of()
private var consecutiveFullPaymentsMade: JsonField = JsonMissing.of()
private var daysPastDue: JsonField = JsonMissing.of()
private var hasGrace: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(accountStanding: AccountStanding) = apply {
this.periodState = accountStanding.periodState
this.periodNumber = accountStanding.periodNumber
this.consecutiveMinimumPaymentsMade = accountStanding.consecutiveMinimumPaymentsMade
this.consecutiveMinimumPaymentsMissed =
accountStanding.consecutiveMinimumPaymentsMissed
this.consecutiveFullPaymentsMade = accountStanding.consecutiveFullPaymentsMade
this.daysPastDue = accountStanding.daysPastDue
this.hasGrace = accountStanding.hasGrace
additionalProperties(accountStanding.additionalProperties)
}
fun periodState(periodState: PeriodState) = periodState(JsonField.of(periodState))
@JsonProperty("period_state")
@ExcludeMissing
fun periodState(periodState: JsonField) = apply {
this.periodState = periodState
}
/** Current overall period number */
fun periodNumber(periodNumber: Long) = periodNumber(JsonField.of(periodNumber))
/** Current overall period number */
@JsonProperty("period_number")
@ExcludeMissing
fun periodNumber(periodNumber: JsonField) = apply {
this.periodNumber = periodNumber
}
/** Number of consecutive minimum payments made */
fun consecutiveMinimumPaymentsMade(consecutiveMinimumPaymentsMade: Long) =
consecutiveMinimumPaymentsMade(JsonField.of(consecutiveMinimumPaymentsMade))
/** Number of consecutive minimum payments made */
@JsonProperty("consecutive_minimum_payments_made")
@ExcludeMissing
fun consecutiveMinimumPaymentsMade(consecutiveMinimumPaymentsMade: JsonField) =
apply {
this.consecutiveMinimumPaymentsMade = consecutiveMinimumPaymentsMade
}
/** Number of consecutive minimum payments missed */
fun consecutiveMinimumPaymentsMissed(consecutiveMinimumPaymentsMissed: Long) =
consecutiveMinimumPaymentsMissed(JsonField.of(consecutiveMinimumPaymentsMissed))
/** Number of consecutive minimum payments missed */
@JsonProperty("consecutive_minimum_payments_missed")
@ExcludeMissing
fun consecutiveMinimumPaymentsMissed(
consecutiveMinimumPaymentsMissed: JsonField
) = apply { this.consecutiveMinimumPaymentsMissed = consecutiveMinimumPaymentsMissed }
/** Number of consecutive full payments made */
fun consecutiveFullPaymentsMade(consecutiveFullPaymentsMade: Long) =
consecutiveFullPaymentsMade(JsonField.of(consecutiveFullPaymentsMade))
/** Number of consecutive full payments made */
@JsonProperty("consecutive_full_payments_made")
@ExcludeMissing
fun consecutiveFullPaymentsMade(consecutiveFullPaymentsMade: JsonField) = apply {
this.consecutiveFullPaymentsMade = consecutiveFullPaymentsMade
}
/** Number of days past due */
fun daysPastDue(daysPastDue: Long) = daysPastDue(JsonField.of(daysPastDue))
/** Number of days past due */
@JsonProperty("days_past_due")
@ExcludeMissing
fun daysPastDue(daysPastDue: JsonField) = apply { this.daysPastDue = daysPastDue }
/** Whether the account currently has grace or not */
fun hasGrace(hasGrace: Boolean) = hasGrace(JsonField.of(hasGrace))
/** Whether the account currently has grace or not */
@JsonProperty("has_grace")
@ExcludeMissing
fun hasGrace(hasGrace: JsonField) = apply { this.hasGrace = hasGrace }
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): AccountStanding =
AccountStanding(
periodState,
periodNumber,
consecutiveMinimumPaymentsMade,
consecutiveMinimumPaymentsMissed,
consecutiveFullPaymentsMade,
daysPastDue,
hasGrace,
additionalProperties.toImmutable(),
)
}
class PeriodState
@JsonCreator
private constructor(
private val value: JsonField,
) : Enum {
@com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is PeriodState && this.value == other.value /* spotless:on */
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
val STANDARD = PeriodState(JsonField.of("STANDARD"))
val PROMO = PeriodState(JsonField.of("PROMO"))
val PENALTY = PeriodState(JsonField.of("PENALTY"))
fun of(value: String) = PeriodState(JsonField.of(value))
}
enum class Known {
STANDARD,
PROMO,
PENALTY,
}
enum class Value {
STANDARD,
PROMO,
PENALTY,
_UNKNOWN,
}
fun value(): Value =
when (this) {
STANDARD -> Value.STANDARD
PROMO -> Value.PROMO
PENALTY -> Value.PENALTY
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
STANDARD -> Known.STANDARD
PROMO -> Known.PROMO
PENALTY -> Known.PENALTY
else -> throw LithicInvalidDataException("Unknown PeriodState: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is AccountStanding && this.periodState == other.periodState && this.periodNumber == other.periodNumber && this.consecutiveMinimumPaymentsMade == other.consecutiveMinimumPaymentsMade && this.consecutiveMinimumPaymentsMissed == other.consecutiveMinimumPaymentsMissed && this.consecutiveFullPaymentsMade == other.consecutiveFullPaymentsMade && this.daysPastDue == other.daysPastDue && this.hasGrace == other.hasGrace && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(periodState, periodNumber, consecutiveMinimumPaymentsMade, consecutiveMinimumPaymentsMissed, consecutiveFullPaymentsMade, daysPastDue, hasGrace, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"AccountStanding{periodState=$periodState, periodNumber=$periodNumber, consecutiveMinimumPaymentsMade=$consecutiveMinimumPaymentsMade, consecutiveMinimumPaymentsMissed=$consecutiveMinimumPaymentsMissed, consecutiveFullPaymentsMade=$consecutiveFullPaymentsMade, daysPastDue=$daysPastDue, hasGrace=$hasGrace, additionalProperties=$additionalProperties}"
}
@JsonDeserialize(builder = Balances.Builder::class)
@NoAutoDetect
class Balances
private constructor(
private val pastDue: JsonField,
private val due: JsonField,
private val pastStatementsDue: JsonField,
private val nextStatementDue: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
/** Amount not paid off on previous due dates */
fun pastDue(): CategoryBalances = pastDue.getRequired("past_due")
/**
* Amount due for the prior billing cycle. Any amounts not fully paid off on this due date
* will be considered past due the next day
*/
fun due(): CategoryBalances = due.getRequired("due")
/** Amount due for the past billing cycles. */
fun pastStatementsDue(): CategoryBalances =
pastStatementsDue.getRequired("past_statements_due")
/**
* Amount due for the current billing cycle. Any amounts not paid off by early payments or
* credits will be considered due at the end of the current billing period
*/
fun nextStatementDue(): CategoryBalances =
nextStatementDue.getRequired("next_statement_due")
/** Amount not paid off on previous due dates */
@JsonProperty("past_due") @ExcludeMissing fun _pastDue() = pastDue
/**
* Amount due for the prior billing cycle. Any amounts not fully paid off on this due date
* will be considered past due the next day
*/
@JsonProperty("due") @ExcludeMissing fun _due() = due
/** Amount due for the past billing cycles. */
@JsonProperty("past_statements_due")
@ExcludeMissing
fun _pastStatementsDue() = pastStatementsDue
/**
* Amount due for the current billing cycle. Any amounts not paid off by early payments or
* credits will be considered due at the end of the current billing period
*/
@JsonProperty("next_statement_due")
@ExcludeMissing
fun _nextStatementDue() = nextStatementDue
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): Balances = apply {
if (!validated) {
pastDue().validate()
due().validate()
pastStatementsDue().validate()
nextStatementDue().validate()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var pastDue: JsonField = JsonMissing.of()
private var due: JsonField = JsonMissing.of()
private var pastStatementsDue: JsonField = JsonMissing.of()
private var nextStatementDue: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(balances: Balances) = apply {
this.pastDue = balances.pastDue
this.due = balances.due
this.pastStatementsDue = balances.pastStatementsDue
this.nextStatementDue = balances.nextStatementDue
additionalProperties(balances.additionalProperties)
}
/** Amount not paid off on previous due dates */
fun pastDue(pastDue: CategoryBalances) = pastDue(JsonField.of(pastDue))
/** Amount not paid off on previous due dates */
@JsonProperty("past_due")
@ExcludeMissing
fun pastDue(pastDue: JsonField) = apply { this.pastDue = pastDue }
/**
* Amount due for the prior billing cycle. Any amounts not fully paid off on this due
* date will be considered past due the next day
*/
fun due(due: CategoryBalances) = due(JsonField.of(due))
/**
* Amount due for the prior billing cycle. Any amounts not fully paid off on this due
* date will be considered past due the next day
*/
@JsonProperty("due")
@ExcludeMissing
fun due(due: JsonField) = apply { this.due = due }
/** Amount due for the past billing cycles. */
fun pastStatementsDue(pastStatementsDue: CategoryBalances) =
pastStatementsDue(JsonField.of(pastStatementsDue))
/** Amount due for the past billing cycles. */
@JsonProperty("past_statements_due")
@ExcludeMissing
fun pastStatementsDue(pastStatementsDue: JsonField) = apply {
this.pastStatementsDue = pastStatementsDue
}
/**
* Amount due for the current billing cycle. Any amounts not paid off by early payments
* or credits will be considered due at the end of the current billing period
*/
fun nextStatementDue(nextStatementDue: CategoryBalances) =
nextStatementDue(JsonField.of(nextStatementDue))
/**
* Amount due for the current billing cycle. Any amounts not paid off by early payments
* or credits will be considered due at the end of the current billing period
*/
@JsonProperty("next_statement_due")
@ExcludeMissing
fun nextStatementDue(nextStatementDue: JsonField) = apply {
this.nextStatementDue = nextStatementDue
}
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): Balances =
Balances(
pastDue,
due,
pastStatementsDue,
nextStatementDue,
additionalProperties.toImmutable(),
)
}
/**
* Amount due for the prior billing cycle. Any amounts not fully paid off on this due date
* will be considered past due the next day
*/
@JsonDeserialize(builder = CategoryBalances.Builder::class)
@NoAutoDetect
class CategoryBalances
private constructor(
private val interest: JsonField,
private val principal: JsonField,
private val fees: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
fun interest(): Long = interest.getRequired("interest")
fun principal(): Long = principal.getRequired("principal")
fun fees(): Long = fees.getRequired("fees")
@JsonProperty("interest") @ExcludeMissing fun _interest() = interest
@JsonProperty("principal") @ExcludeMissing fun _principal() = principal
@JsonProperty("fees") @ExcludeMissing fun _fees() = fees
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): CategoryBalances = apply {
if (!validated) {
interest()
principal()
fees()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var interest: JsonField = JsonMissing.of()
private var principal: JsonField = JsonMissing.of()
private var fees: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(categoryBalances: CategoryBalances) = apply {
this.interest = categoryBalances.interest
this.principal = categoryBalances.principal
this.fees = categoryBalances.fees
additionalProperties(categoryBalances.additionalProperties)
}
fun interest(interest: Long) = interest(JsonField.of(interest))
@JsonProperty("interest")
@ExcludeMissing
fun interest(interest: JsonField) = apply { this.interest = interest }
fun principal(principal: Long) = principal(JsonField.of(principal))
@JsonProperty("principal")
@ExcludeMissing
fun principal(principal: JsonField) = apply { this.principal = principal }
fun fees(fees: Long) = fees(JsonField.of(fees))
@JsonProperty("fees")
@ExcludeMissing
fun fees(fees: JsonField) = apply { this.fees = fees }
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) =
apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): CategoryBalances =
CategoryBalances(
interest,
principal,
fees,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is CategoryBalances && this.interest == other.interest && this.principal == other.principal && this.fees == other.fees && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(interest, principal, fees, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"CategoryBalances{interest=$interest, principal=$principal, fees=$fees, additionalProperties=$additionalProperties}"
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is Balances && this.pastDue == other.pastDue && this.due == other.due && this.pastStatementsDue == other.pastStatementsDue && this.nextStatementDue == other.nextStatementDue && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(pastDue, due, pastStatementsDue, nextStatementDue, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"Balances{pastDue=$pastDue, due=$due, pastStatementsDue=$pastStatementsDue, nextStatementDue=$nextStatementDue, additionalProperties=$additionalProperties}"
}
@JsonDeserialize(builder = StatementTotals.Builder::class)
@NoAutoDetect
class StatementTotals
private constructor(
private val payments: JsonField,
private val purchases: JsonField,
private val fees: JsonField,
private val credits: JsonField,
private val interest: JsonField,
private val cashAdvances: JsonField,
private val balanceTransfers: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
/** Any funds transfers which affective the balance in cents */
fun payments(): Long = payments.getRequired("payments")
/** Net card transaction volume less any cash advances in cents */
fun purchases(): Long = purchases.getRequired("purchases")
/** Volume of debit management operation transactions less any interest in cents */
fun fees(): Long = fees.getRequired("fees")
/**
* Volume of credit management operation transactions less any balance transfers in cents
*/
fun credits(): Long = credits.getRequired("credits")
/** Interest accrued in cents */
fun interest(): Long = interest.getRequired("interest")
/** ATM and cashback transactions in cents */
fun cashAdvances(): Long = cashAdvances.getRequired("cash_advances")
/** Opening balance transferred from previous account in cents */
fun balanceTransfers(): Long = balanceTransfers.getRequired("balance_transfers")
/** Any funds transfers which affective the balance in cents */
@JsonProperty("payments") @ExcludeMissing fun _payments() = payments
/** Net card transaction volume less any cash advances in cents */
@JsonProperty("purchases") @ExcludeMissing fun _purchases() = purchases
/** Volume of debit management operation transactions less any interest in cents */
@JsonProperty("fees") @ExcludeMissing fun _fees() = fees
/**
* Volume of credit management operation transactions less any balance transfers in cents
*/
@JsonProperty("credits") @ExcludeMissing fun _credits() = credits
/** Interest accrued in cents */
@JsonProperty("interest") @ExcludeMissing fun _interest() = interest
/** ATM and cashback transactions in cents */
@JsonProperty("cash_advances") @ExcludeMissing fun _cashAdvances() = cashAdvances
/** Opening balance transferred from previous account in cents */
@JsonProperty("balance_transfers")
@ExcludeMissing
fun _balanceTransfers() = balanceTransfers
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): StatementTotals = apply {
if (!validated) {
payments()
purchases()
fees()
credits()
interest()
cashAdvances()
balanceTransfers()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var payments: JsonField = JsonMissing.of()
private var purchases: JsonField = JsonMissing.of()
private var fees: JsonField = JsonMissing.of()
private var credits: JsonField = JsonMissing.of()
private var interest: JsonField = JsonMissing.of()
private var cashAdvances: JsonField = JsonMissing.of()
private var balanceTransfers: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(statementTotals: StatementTotals) = apply {
this.payments = statementTotals.payments
this.purchases = statementTotals.purchases
this.fees = statementTotals.fees
this.credits = statementTotals.credits
this.interest = statementTotals.interest
this.cashAdvances = statementTotals.cashAdvances
this.balanceTransfers = statementTotals.balanceTransfers
additionalProperties(statementTotals.additionalProperties)
}
/** Any funds transfers which affective the balance in cents */
fun payments(payments: Long) = payments(JsonField.of(payments))
/** Any funds transfers which affective the balance in cents */
@JsonProperty("payments")
@ExcludeMissing
fun payments(payments: JsonField) = apply { this.payments = payments }
/** Net card transaction volume less any cash advances in cents */
fun purchases(purchases: Long) = purchases(JsonField.of(purchases))
/** Net card transaction volume less any cash advances in cents */
@JsonProperty("purchases")
@ExcludeMissing
fun purchases(purchases: JsonField) = apply { this.purchases = purchases }
/** Volume of debit management operation transactions less any interest in cents */
fun fees(fees: Long) = fees(JsonField.of(fees))
/** Volume of debit management operation transactions less any interest in cents */
@JsonProperty("fees")
@ExcludeMissing
fun fees(fees: JsonField) = apply { this.fees = fees }
/**
* Volume of credit management operation transactions less any balance transfers in
* cents
*/
fun credits(credits: Long) = credits(JsonField.of(credits))
/**
* Volume of credit management operation transactions less any balance transfers in
* cents
*/
@JsonProperty("credits")
@ExcludeMissing
fun credits(credits: JsonField) = apply { this.credits = credits }
/** Interest accrued in cents */
fun interest(interest: Long) = interest(JsonField.of(interest))
/** Interest accrued in cents */
@JsonProperty("interest")
@ExcludeMissing
fun interest(interest: JsonField) = apply { this.interest = interest }
/** ATM and cashback transactions in cents */
fun cashAdvances(cashAdvances: Long) = cashAdvances(JsonField.of(cashAdvances))
/** ATM and cashback transactions in cents */
@JsonProperty("cash_advances")
@ExcludeMissing
fun cashAdvances(cashAdvances: JsonField) = apply {
this.cashAdvances = cashAdvances
}
/** Opening balance transferred from previous account in cents */
fun balanceTransfers(balanceTransfers: Long) =
balanceTransfers(JsonField.of(balanceTransfers))
/** Opening balance transferred from previous account in cents */
@JsonProperty("balance_transfers")
@ExcludeMissing
fun balanceTransfers(balanceTransfers: JsonField) = apply {
this.balanceTransfers = balanceTransfers
}
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): StatementTotals =
StatementTotals(
payments,
purchases,
fees,
credits,
interest,
cashAdvances,
balanceTransfers,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is StatementTotals && this.payments == other.payments && this.purchases == other.purchases && this.fees == other.fees && this.credits == other.credits && this.interest == other.interest && this.cashAdvances == other.cashAdvances && this.balanceTransfers == other.balanceTransfers && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(payments, purchases, fees, credits, interest, cashAdvances, balanceTransfers, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"StatementTotals{payments=$payments, purchases=$purchases, fees=$fees, credits=$credits, interest=$interest, cashAdvances=$cashAdvances, balanceTransfers=$balanceTransfers, additionalProperties=$additionalProperties}"
}
@JsonDeserialize(builder = InterestDetails.Builder::class)
@NoAutoDetect
class InterestDetails
private constructor(
private val primeRate: JsonField,
private val interestCalculationMethod: JsonField,
private val effectiveApr: JsonField,
private val interestForPeriod: JsonField,
private val dailyBalanceAmounts: JsonField,
private val minimumInterestCharged: JsonField,
private val actualInterestCharged: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
fun primeRate(): String? = primeRate.getNullable("prime_rate")
fun interestCalculationMethod(): InterestCalculationMethod =
interestCalculationMethod.getRequired("interest_calculation_method")
fun effectiveApr(): CategoryDetails = effectiveApr.getRequired("effective_apr")
fun interestForPeriod(): CategoryDetails =
interestForPeriod.getRequired("interest_for_period")
fun dailyBalanceAmounts(): CategoryDetails =
dailyBalanceAmounts.getRequired("daily_balance_amounts")
fun minimumInterestCharged(): Long? =
minimumInterestCharged.getNullable("minimum_interest_charged")
fun actualInterestCharged(): Long? =
actualInterestCharged.getNullable("actual_interest_charged")
@JsonProperty("prime_rate") @ExcludeMissing fun _primeRate() = primeRate
@JsonProperty("interest_calculation_method")
@ExcludeMissing
fun _interestCalculationMethod() = interestCalculationMethod
@JsonProperty("effective_apr") @ExcludeMissing fun _effectiveApr() = effectiveApr
@JsonProperty("interest_for_period")
@ExcludeMissing
fun _interestForPeriod() = interestForPeriod
@JsonProperty("daily_balance_amounts")
@ExcludeMissing
fun _dailyBalanceAmounts() = dailyBalanceAmounts
@JsonProperty("minimum_interest_charged")
@ExcludeMissing
fun _minimumInterestCharged() = minimumInterestCharged
@JsonProperty("actual_interest_charged")
@ExcludeMissing
fun _actualInterestCharged() = actualInterestCharged
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): InterestDetails = apply {
if (!validated) {
primeRate()
interestCalculationMethod()
effectiveApr().validate()
interestForPeriod().validate()
dailyBalanceAmounts().validate()
minimumInterestCharged()
actualInterestCharged()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var primeRate: JsonField = JsonMissing.of()
private var interestCalculationMethod: JsonField =
JsonMissing.of()
private var effectiveApr: JsonField = JsonMissing.of()
private var interestForPeriod: JsonField = JsonMissing.of()
private var dailyBalanceAmounts: JsonField = JsonMissing.of()
private var minimumInterestCharged: JsonField = JsonMissing.of()
private var actualInterestCharged: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(interestDetails: InterestDetails) = apply {
this.primeRate = interestDetails.primeRate
this.interestCalculationMethod = interestDetails.interestCalculationMethod
this.effectiveApr = interestDetails.effectiveApr
this.interestForPeriod = interestDetails.interestForPeriod
this.dailyBalanceAmounts = interestDetails.dailyBalanceAmounts
this.minimumInterestCharged = interestDetails.minimumInterestCharged
this.actualInterestCharged = interestDetails.actualInterestCharged
additionalProperties(interestDetails.additionalProperties)
}
fun primeRate(primeRate: String) = primeRate(JsonField.of(primeRate))
@JsonProperty("prime_rate")
@ExcludeMissing
fun primeRate(primeRate: JsonField) = apply { this.primeRate = primeRate }
fun interestCalculationMethod(interestCalculationMethod: InterestCalculationMethod) =
interestCalculationMethod(JsonField.of(interestCalculationMethod))
@JsonProperty("interest_calculation_method")
@ExcludeMissing
fun interestCalculationMethod(
interestCalculationMethod: JsonField
) = apply { this.interestCalculationMethod = interestCalculationMethod }
fun effectiveApr(effectiveApr: CategoryDetails) =
effectiveApr(JsonField.of(effectiveApr))
@JsonProperty("effective_apr")
@ExcludeMissing
fun effectiveApr(effectiveApr: JsonField) = apply {
this.effectiveApr = effectiveApr
}
fun interestForPeriod(interestForPeriod: CategoryDetails) =
interestForPeriod(JsonField.of(interestForPeriod))
@JsonProperty("interest_for_period")
@ExcludeMissing
fun interestForPeriod(interestForPeriod: JsonField) = apply {
this.interestForPeriod = interestForPeriod
}
fun dailyBalanceAmounts(dailyBalanceAmounts: CategoryDetails) =
dailyBalanceAmounts(JsonField.of(dailyBalanceAmounts))
@JsonProperty("daily_balance_amounts")
@ExcludeMissing
fun dailyBalanceAmounts(dailyBalanceAmounts: JsonField) = apply {
this.dailyBalanceAmounts = dailyBalanceAmounts
}
fun minimumInterestCharged(minimumInterestCharged: Long) =
minimumInterestCharged(JsonField.of(minimumInterestCharged))
@JsonProperty("minimum_interest_charged")
@ExcludeMissing
fun minimumInterestCharged(minimumInterestCharged: JsonField) = apply {
this.minimumInterestCharged = minimumInterestCharged
}
fun actualInterestCharged(actualInterestCharged: Long) =
actualInterestCharged(JsonField.of(actualInterestCharged))
@JsonProperty("actual_interest_charged")
@ExcludeMissing
fun actualInterestCharged(actualInterestCharged: JsonField) = apply {
this.actualInterestCharged = actualInterestCharged
}
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): InterestDetails =
InterestDetails(
primeRate,
interestCalculationMethod,
effectiveApr,
interestForPeriod,
dailyBalanceAmounts,
minimumInterestCharged,
actualInterestCharged,
additionalProperties.toImmutable(),
)
}
@JsonDeserialize(builder = CategoryDetails.Builder::class)
@NoAutoDetect
class CategoryDetails
private constructor(
private val purchases: JsonField,
private val cashAdvances: JsonField,
private val balanceTransfers: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
fun purchases(): String = purchases.getRequired("purchases")
fun cashAdvances(): String = cashAdvances.getRequired("cash_advances")
fun balanceTransfers(): String = balanceTransfers.getRequired("balance_transfers")
@JsonProperty("purchases") @ExcludeMissing fun _purchases() = purchases
@JsonProperty("cash_advances") @ExcludeMissing fun _cashAdvances() = cashAdvances
@JsonProperty("balance_transfers")
@ExcludeMissing
fun _balanceTransfers() = balanceTransfers
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): CategoryDetails = apply {
if (!validated) {
purchases()
cashAdvances()
balanceTransfers()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var purchases: JsonField = JsonMissing.of()
private var cashAdvances: JsonField = JsonMissing.of()
private var balanceTransfers: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(categoryDetails: CategoryDetails) = apply {
this.purchases = categoryDetails.purchases
this.cashAdvances = categoryDetails.cashAdvances
this.balanceTransfers = categoryDetails.balanceTransfers
additionalProperties(categoryDetails.additionalProperties)
}
fun purchases(purchases: String) = purchases(JsonField.of(purchases))
@JsonProperty("purchases")
@ExcludeMissing
fun purchases(purchases: JsonField) = apply { this.purchases = purchases }
fun cashAdvances(cashAdvances: String) = cashAdvances(JsonField.of(cashAdvances))
@JsonProperty("cash_advances")
@ExcludeMissing
fun cashAdvances(cashAdvances: JsonField) = apply {
this.cashAdvances = cashAdvances
}
fun balanceTransfers(balanceTransfers: String) =
balanceTransfers(JsonField.of(balanceTransfers))
@JsonProperty("balance_transfers")
@ExcludeMissing
fun balanceTransfers(balanceTransfers: JsonField) = apply {
this.balanceTransfers = balanceTransfers
}
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) =
apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): CategoryDetails =
CategoryDetails(
purchases,
cashAdvances,
balanceTransfers,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is CategoryDetails && this.purchases == other.purchases && this.cashAdvances == other.cashAdvances && this.balanceTransfers == other.balanceTransfers && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(purchases, cashAdvances, balanceTransfers, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"CategoryDetails{purchases=$purchases, cashAdvances=$cashAdvances, balanceTransfers=$balanceTransfers, additionalProperties=$additionalProperties}"
}
class InterestCalculationMethod
@JsonCreator
private constructor(
private val value: JsonField,
) : Enum {
@com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is InterestCalculationMethod && this.value == other.value /* spotless:on */
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
val DAILY = InterestCalculationMethod(JsonField.of("DAILY"))
val AVERAGE_DAILY = InterestCalculationMethod(JsonField.of("AVERAGE_DAILY"))
fun of(value: String) = InterestCalculationMethod(JsonField.of(value))
}
enum class Known {
DAILY,
AVERAGE_DAILY,
}
enum class Value {
DAILY,
AVERAGE_DAILY,
_UNKNOWN,
}
fun value(): Value =
when (this) {
DAILY -> Value.DAILY
AVERAGE_DAILY -> Value.AVERAGE_DAILY
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
DAILY -> Known.DAILY
AVERAGE_DAILY -> Known.AVERAGE_DAILY
else ->
throw LithicInvalidDataException(
"Unknown InterestCalculationMethod: $value"
)
}
fun asString(): String = _value().asStringOrThrow()
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is InterestDetails && this.primeRate == other.primeRate && this.interestCalculationMethod == other.interestCalculationMethod && this.effectiveApr == other.effectiveApr && this.interestForPeriod == other.interestForPeriod && this.dailyBalanceAmounts == other.dailyBalanceAmounts && this.minimumInterestCharged == other.minimumInterestCharged && this.actualInterestCharged == other.actualInterestCharged && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(primeRate, interestCalculationMethod, effectiveApr, interestForPeriod, dailyBalanceAmounts, minimumInterestCharged, actualInterestCharged, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"InterestDetails{primeRate=$primeRate, interestCalculationMethod=$interestCalculationMethod, effectiveApr=$effectiveApr, interestForPeriod=$interestForPeriod, dailyBalanceAmounts=$dailyBalanceAmounts, minimumInterestCharged=$minimumInterestCharged, actualInterestCharged=$actualInterestCharged, additionalProperties=$additionalProperties}"
}
@JsonDeserialize(builder = BalanceDetails.Builder::class)
@NoAutoDetect
class BalanceDetails
private constructor(
private val amount: JsonField,
private val remaining: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
fun amount(): Long = amount.getRequired("amount")
fun remaining(): Long = remaining.getRequired("remaining")
@JsonProperty("amount") @ExcludeMissing fun _amount() = amount
@JsonProperty("remaining") @ExcludeMissing fun _remaining() = remaining
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): BalanceDetails = apply {
if (!validated) {
amount()
remaining()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var amount: JsonField = JsonMissing.of()
private var remaining: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(balanceDetails: BalanceDetails) = apply {
this.amount = balanceDetails.amount
this.remaining = balanceDetails.remaining
additionalProperties(balanceDetails.additionalProperties)
}
fun amount(amount: Long) = amount(JsonField.of(amount))
@JsonProperty("amount")
@ExcludeMissing
fun amount(amount: JsonField) = apply { this.amount = amount }
fun remaining(remaining: Long) = remaining(JsonField.of(remaining))
@JsonProperty("remaining")
@ExcludeMissing
fun remaining(remaining: JsonField) = apply { this.remaining = remaining }
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): BalanceDetails =
BalanceDetails(
amount,
remaining,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is BalanceDetails && this.amount == other.amount && this.remaining == other.remaining && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(amount, remaining, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"BalanceDetails{amount=$amount, remaining=$remaining, additionalProperties=$additionalProperties}"
}
@JsonDeserialize(builder = CategoryBalances.Builder::class)
@NoAutoDetect
class CategoryBalances
private constructor(
private val interest: JsonField,
private val principal: JsonField,
private val fees: JsonField,
private val additionalProperties: Map,
) {
private var validated: Boolean = false
fun interest(): Long = interest.getRequired("interest")
fun principal(): Long = principal.getRequired("principal")
fun fees(): Long = fees.getRequired("fees")
@JsonProperty("interest") @ExcludeMissing fun _interest() = interest
@JsonProperty("principal") @ExcludeMissing fun _principal() = principal
@JsonProperty("fees") @ExcludeMissing fun _fees() = fees
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun validate(): CategoryBalances = apply {
if (!validated) {
interest()
principal()
fees()
validated = true
}
}
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var interest: JsonField = JsonMissing.of()
private var principal: JsonField = JsonMissing.of()
private var fees: JsonField = JsonMissing.of()
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(categoryBalances: CategoryBalances) = apply {
this.interest = categoryBalances.interest
this.principal = categoryBalances.principal
this.fees = categoryBalances.fees
additionalProperties(categoryBalances.additionalProperties)
}
fun interest(interest: Long) = interest(JsonField.of(interest))
@JsonProperty("interest")
@ExcludeMissing
fun interest(interest: JsonField) = apply { this.interest = interest }
fun principal(principal: Long) = principal(JsonField.of(principal))
@JsonProperty("principal")
@ExcludeMissing
fun principal(principal: JsonField) = apply { this.principal = principal }
fun fees(fees: Long) = fees(JsonField.of(fees))
@JsonProperty("fees")
@ExcludeMissing
fun fees(fees: JsonField) = apply { this.fees = fees }
fun additionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.clear()
this.additionalProperties.putAll(additionalProperties)
}
@JsonAnySetter
fun putAdditionalProperty(key: String, value: JsonValue) = apply {
this.additionalProperties.put(key, value)
}
fun putAllAdditionalProperties(additionalProperties: Map) = apply {
this.additionalProperties.putAll(additionalProperties)
}
fun build(): CategoryBalances =
CategoryBalances(
interest,
principal,
fees,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is CategoryBalances && this.interest == other.interest && this.principal == other.principal && this.fees == other.fees && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(interest, principal, fees, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"CategoryBalances{interest=$interest, principal=$principal, fees=$fees, additionalProperties=$additionalProperties}"
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is LoanTape && this.token == other.token && this.financialAccountToken == other.financialAccountToken && this.date == other.date && this.created == other.created && this.updated == other.updated && this.version == other.version && this.ytdTotals == other.ytdTotals && this.periodTotals == other.periodTotals && this.dayTotals == other.dayTotals && this.balances == other.balances && this.startingBalance == other.startingBalance && this.endingBalance == other.endingBalance && this.creditLimit == other.creditLimit && this.availableCredit == other.availableCredit && this.excessCredits == other.excessCredits && this.accountStanding == other.accountStanding && this.creditProductToken == other.creditProductToken && this.tier == other.tier && this.paymentAllocation == other.paymentAllocation && this.minimumPaymentBalance == other.minimumPaymentBalance && this.previousStatementBalance == other.previousStatementBalance && this.interestDetails == other.interestDetails && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(token, financialAccountToken, date, created, updated, version, ytdTotals, periodTotals, dayTotals, balances, startingBalance, endingBalance, creditLimit, availableCredit, excessCredits, accountStanding, creditProductToken, tier, paymentAllocation, minimumPaymentBalance, previousStatementBalance, interestDetails, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"LoanTape{token=$token, financialAccountToken=$financialAccountToken, date=$date, created=$created, updated=$updated, version=$version, ytdTotals=$ytdTotals, periodTotals=$periodTotals, dayTotals=$dayTotals, balances=$balances, startingBalance=$startingBalance, endingBalance=$endingBalance, creditLimit=$creditLimit, availableCredit=$availableCredit, excessCredits=$excessCredits, accountStanding=$accountStanding, creditProductToken=$creditProductToken, tier=$tier, paymentAllocation=$paymentAllocation, minimumPaymentBalance=$minimumPaymentBalance, previousStatementBalance=$previousStatementBalance, interestDetails=$interestDetails, additionalProperties=$additionalProperties}"
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy