com.lithic.api.models.FinancialAccountCreateParams.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.
// 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.JsonValue
import com.lithic.api.core.NoAutoDetect
import com.lithic.api.core.toUnmodifiable
import com.lithic.api.errors.LithicInvalidDataException
import com.lithic.api.models.*
import java.util.Objects
class FinancialAccountCreateParams
constructor(
private val nickname: String,
private val type: Type,
private val accountToken: String?,
private val isForBenefitOf: Boolean?,
private val additionalQueryParams: Map>,
private val additionalHeaders: Map>,
private val additionalBodyProperties: Map,
) {
fun nickname(): String = nickname
fun type(): Type = type
fun accountToken(): String? = accountToken
fun isForBenefitOf(): Boolean? = isForBenefitOf
internal fun getBody(): FinancialAccountCreateBody {
return FinancialAccountCreateBody(
nickname,
type,
accountToken,
isForBenefitOf,
additionalBodyProperties,
)
}
internal fun getQueryParams(): Map> = additionalQueryParams
internal fun getHeaders(): Map> = additionalHeaders
@JsonDeserialize(builder = FinancialAccountCreateBody.Builder::class)
@NoAutoDetect
class FinancialAccountCreateBody
internal constructor(
private val nickname: String?,
private val type: Type?,
private val accountToken: String?,
private val isForBenefitOf: Boolean?,
private val additionalProperties: Map,
) {
private var hashCode: Int = 0
@JsonProperty("nickname") fun nickname(): String? = nickname
@JsonProperty("type") fun type(): Type? = type
@JsonProperty("account_token") fun accountToken(): String? = accountToken
@JsonProperty("is_for_benefit_of") fun isForBenefitOf(): Boolean? = isForBenefitOf
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun toBuilder() = Builder().from(this)
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return other is FinancialAccountCreateBody &&
this.nickname == other.nickname &&
this.type == other.type &&
this.accountToken == other.accountToken &&
this.isForBenefitOf == other.isForBenefitOf &&
this.additionalProperties == other.additionalProperties
}
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode =
Objects.hash(
nickname,
type,
accountToken,
isForBenefitOf,
additionalProperties,
)
}
return hashCode
}
override fun toString() =
"FinancialAccountCreateBody{nickname=$nickname, type=$type, accountToken=$accountToken, isForBenefitOf=$isForBenefitOf, additionalProperties=$additionalProperties}"
companion object {
fun builder() = Builder()
}
class Builder {
private var nickname: String? = null
private var type: Type? = null
private var accountToken: String? = null
private var isForBenefitOf: Boolean? = null
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(financialAccountCreateBody: FinancialAccountCreateBody) = apply {
this.nickname = financialAccountCreateBody.nickname
this.type = financialAccountCreateBody.type
this.accountToken = financialAccountCreateBody.accountToken
this.isForBenefitOf = financialAccountCreateBody.isForBenefitOf
additionalProperties(financialAccountCreateBody.additionalProperties)
}
@JsonProperty("nickname")
fun nickname(nickname: String) = apply { this.nickname = nickname }
@JsonProperty("type") fun type(type: Type) = apply { this.type = type }
@JsonProperty("account_token")
fun accountToken(accountToken: String) = apply { this.accountToken = accountToken }
@JsonProperty("is_for_benefit_of")
fun isForBenefitOf(isForBenefitOf: Boolean) = apply {
this.isForBenefitOf = isForBenefitOf
}
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(): FinancialAccountCreateBody =
FinancialAccountCreateBody(
checkNotNull(nickname) { "`nickname` is required but was not set" },
checkNotNull(type) { "`type` is required but was not set" },
accountToken,
isForBenefitOf,
additionalProperties.toUnmodifiable(),
)
}
}
fun _additionalQueryParams(): Map> = additionalQueryParams
fun _additionalHeaders(): Map> = additionalHeaders
fun _additionalBodyProperties(): Map = additionalBodyProperties
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return other is FinancialAccountCreateParams &&
this.nickname == other.nickname &&
this.type == other.type &&
this.accountToken == other.accountToken &&
this.isForBenefitOf == other.isForBenefitOf &&
this.additionalQueryParams == other.additionalQueryParams &&
this.additionalHeaders == other.additionalHeaders &&
this.additionalBodyProperties == other.additionalBodyProperties
}
override fun hashCode(): Int {
return Objects.hash(
nickname,
type,
accountToken,
isForBenefitOf,
additionalQueryParams,
additionalHeaders,
additionalBodyProperties,
)
}
override fun toString() =
"FinancialAccountCreateParams{nickname=$nickname, type=$type, accountToken=$accountToken, isForBenefitOf=$isForBenefitOf, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}"
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
@NoAutoDetect
class Builder {
private var nickname: String? = null
private var type: Type? = null
private var accountToken: String? = null
private var isForBenefitOf: Boolean? = null
private var additionalQueryParams: MutableMap> = mutableMapOf()
private var additionalHeaders: MutableMap> = mutableMapOf()
private var additionalBodyProperties: MutableMap = mutableMapOf()
internal fun from(financialAccountCreateParams: FinancialAccountCreateParams) = apply {
this.nickname = financialAccountCreateParams.nickname
this.type = financialAccountCreateParams.type
this.accountToken = financialAccountCreateParams.accountToken
this.isForBenefitOf = financialAccountCreateParams.isForBenefitOf
additionalQueryParams(financialAccountCreateParams.additionalQueryParams)
additionalHeaders(financialAccountCreateParams.additionalHeaders)
additionalBodyProperties(financialAccountCreateParams.additionalBodyProperties)
}
fun nickname(nickname: String) = apply { this.nickname = nickname }
fun type(type: Type) = apply { this.type = type }
fun accountToken(accountToken: String) = apply { this.accountToken = accountToken }
fun isForBenefitOf(isForBenefitOf: Boolean) = apply { this.isForBenefitOf = isForBenefitOf }
fun additionalQueryParams(additionalQueryParams: Map>) = apply {
this.additionalQueryParams.clear()
putAllQueryParams(additionalQueryParams)
}
fun putQueryParam(name: String, value: String) = apply {
this.additionalQueryParams.getOrPut(name) { mutableListOf() }.add(value)
}
fun putQueryParams(name: String, values: Iterable) = apply {
this.additionalQueryParams.getOrPut(name) { mutableListOf() }.addAll(values)
}
fun putAllQueryParams(additionalQueryParams: Map>) = apply {
additionalQueryParams.forEach(this::putQueryParams)
}
fun removeQueryParam(name: String) = apply {
this.additionalQueryParams.put(name, mutableListOf())
}
fun additionalHeaders(additionalHeaders: Map>) = apply {
this.additionalHeaders.clear()
putAllHeaders(additionalHeaders)
}
fun putHeader(name: String, value: String) = apply {
this.additionalHeaders.getOrPut(name) { mutableListOf() }.add(value)
}
fun putHeaders(name: String, values: Iterable) = apply {
this.additionalHeaders.getOrPut(name) { mutableListOf() }.addAll(values)
}
fun putAllHeaders(additionalHeaders: Map>) = apply {
additionalHeaders.forEach(this::putHeaders)
}
fun removeHeader(name: String) = apply { this.additionalHeaders.put(name, mutableListOf()) }
fun additionalBodyProperties(additionalBodyProperties: Map) = apply {
this.additionalBodyProperties.clear()
this.additionalBodyProperties.putAll(additionalBodyProperties)
}
fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply {
this.additionalBodyProperties.put(key, value)
}
fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) =
apply {
this.additionalBodyProperties.putAll(additionalBodyProperties)
}
fun build(): FinancialAccountCreateParams =
FinancialAccountCreateParams(
checkNotNull(nickname) { "`nickname` is required but was not set" },
checkNotNull(type) { "`type` is required but was not set" },
accountToken,
isForBenefitOf,
additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(),
additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(),
additionalBodyProperties.toUnmodifiable(),
)
}
class Type
@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 other is Type && this.value == other.value
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
val OPERATING = Type(JsonField.of("OPERATING"))
fun of(value: String) = Type(JsonField.of(value))
}
enum class Known {
OPERATING,
}
enum class Value {
OPERATING,
_UNKNOWN,
}
fun value(): Value =
when (this) {
OPERATING -> Value.OPERATING
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
OPERATING -> Known.OPERATING
else -> throw LithicInvalidDataException("Unknown Type: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
}