com.lithic.api.models.PaymentCreateParams.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lithic-java-core Show documentation
Show all versions of lithic-java-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
import java.util.Optional
class PaymentCreateParams
constructor(
private val amount: Long,
private val externalBankAccountToken: String,
private val financialAccountToken: String,
private val method: Method,
private val methodAttributes: PaymentMethodRequestAttributes,
private val type: Type,
private val token: String?,
private val memo: String?,
private val userDefinedId: String?,
private val additionalQueryParams: Map>,
private val additionalHeaders: Map>,
private val additionalBodyProperties: Map,
) {
fun amount(): Long = amount
fun externalBankAccountToken(): String = externalBankAccountToken
fun financialAccountToken(): String = financialAccountToken
fun method(): Method = method
fun methodAttributes(): PaymentMethodRequestAttributes = methodAttributes
fun type(): Type = type
fun token(): Optional = Optional.ofNullable(token)
fun memo(): Optional = Optional.ofNullable(memo)
fun userDefinedId(): Optional = Optional.ofNullable(userDefinedId)
@JvmSynthetic
internal fun getBody(): PaymentCreateBody {
return PaymentCreateBody(
amount,
externalBankAccountToken,
financialAccountToken,
method,
methodAttributes,
type,
token,
memo,
userDefinedId,
additionalBodyProperties,
)
}
@JvmSynthetic internal fun getQueryParams(): Map> = additionalQueryParams
@JvmSynthetic internal fun getHeaders(): Map> = additionalHeaders
@JsonDeserialize(builder = PaymentCreateBody.Builder::class)
@NoAutoDetect
class PaymentCreateBody
internal constructor(
private val amount: Long?,
private val externalBankAccountToken: String?,
private val financialAccountToken: String?,
private val method: Method?,
private val methodAttributes: PaymentMethodRequestAttributes?,
private val type: Type?,
private val token: String?,
private val memo: String?,
private val userDefinedId: String?,
private val additionalProperties: Map,
) {
@JsonProperty("amount") fun amount(): Long? = amount
@JsonProperty("external_bank_account_token")
fun externalBankAccountToken(): String? = externalBankAccountToken
@JsonProperty("financial_account_token")
fun financialAccountToken(): String? = financialAccountToken
@JsonProperty("method") fun method(): Method? = method
@JsonProperty("method_attributes")
fun methodAttributes(): PaymentMethodRequestAttributes? = methodAttributes
@JsonProperty("type") fun type(): Type? = type
/**
* Customer-provided token that will serve as an idempotency token. This token will become
* the transaction token.
*/
@JsonProperty("token") fun token(): String? = token
@JsonProperty("memo") fun memo(): String? = memo
@JsonProperty("user_defined_id") fun userDefinedId(): String? = userDefinedId
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun toBuilder() = Builder().from(this)
companion object {
@JvmStatic fun builder() = Builder()
}
class Builder {
private var amount: Long? = null
private var externalBankAccountToken: String? = null
private var financialAccountToken: String? = null
private var method: Method? = null
private var methodAttributes: PaymentMethodRequestAttributes? = null
private var type: Type? = null
private var token: String? = null
private var memo: String? = null
private var userDefinedId: String? = null
private var additionalProperties: MutableMap = mutableMapOf()
@JvmSynthetic
internal fun from(paymentCreateBody: PaymentCreateBody) = apply {
this.amount = paymentCreateBody.amount
this.externalBankAccountToken = paymentCreateBody.externalBankAccountToken
this.financialAccountToken = paymentCreateBody.financialAccountToken
this.method = paymentCreateBody.method
this.methodAttributes = paymentCreateBody.methodAttributes
this.type = paymentCreateBody.type
this.token = paymentCreateBody.token
this.memo = paymentCreateBody.memo
this.userDefinedId = paymentCreateBody.userDefinedId
additionalProperties(paymentCreateBody.additionalProperties)
}
@JsonProperty("amount") fun amount(amount: Long) = apply { this.amount = amount }
@JsonProperty("external_bank_account_token")
fun externalBankAccountToken(externalBankAccountToken: String) = apply {
this.externalBankAccountToken = externalBankAccountToken
}
@JsonProperty("financial_account_token")
fun financialAccountToken(financialAccountToken: String) = apply {
this.financialAccountToken = financialAccountToken
}
@JsonProperty("method") fun method(method: Method) = apply { this.method = method }
@JsonProperty("method_attributes")
fun methodAttributes(methodAttributes: PaymentMethodRequestAttributes) = apply {
this.methodAttributes = methodAttributes
}
@JsonProperty("type") fun type(type: Type) = apply { this.type = type }
/**
* Customer-provided token that will serve as an idempotency token. This token will
* become the transaction token.
*/
@JsonProperty("token") fun token(token: String) = apply { this.token = token }
@JsonProperty("memo") fun memo(memo: String) = apply { this.memo = memo }
@JsonProperty("user_defined_id")
fun userDefinedId(userDefinedId: String) = apply { this.userDefinedId = userDefinedId }
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(): PaymentCreateBody =
PaymentCreateBody(
checkNotNull(amount) { "`amount` is required but was not set" },
checkNotNull(externalBankAccountToken) {
"`externalBankAccountToken` is required but was not set"
},
checkNotNull(financialAccountToken) {
"`financialAccountToken` is required but was not set"
},
checkNotNull(method) { "`method` is required but was not set" },
checkNotNull(methodAttributes) {
"`methodAttributes` is required but was not set"
},
checkNotNull(type) { "`type` is required but was not set" },
token,
memo,
userDefinedId,
additionalProperties.toUnmodifiable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return other is PaymentCreateBody &&
this.amount == other.amount &&
this.externalBankAccountToken == other.externalBankAccountToken &&
this.financialAccountToken == other.financialAccountToken &&
this.method == other.method &&
this.methodAttributes == other.methodAttributes &&
this.type == other.type &&
this.token == other.token &&
this.memo == other.memo &&
this.userDefinedId == other.userDefinedId &&
this.additionalProperties == other.additionalProperties
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode =
Objects.hash(
amount,
externalBankAccountToken,
financialAccountToken,
method,
methodAttributes,
type,
token,
memo,
userDefinedId,
additionalProperties,
)
}
return hashCode
}
override fun toString() =
"PaymentCreateBody{amount=$amount, externalBankAccountToken=$externalBankAccountToken, financialAccountToken=$financialAccountToken, method=$method, methodAttributes=$methodAttributes, type=$type, token=$token, memo=$memo, userDefinedId=$userDefinedId, additionalProperties=$additionalProperties}"
}
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 PaymentCreateParams &&
this.amount == other.amount &&
this.externalBankAccountToken == other.externalBankAccountToken &&
this.financialAccountToken == other.financialAccountToken &&
this.method == other.method &&
this.methodAttributes == other.methodAttributes &&
this.type == other.type &&
this.token == other.token &&
this.memo == other.memo &&
this.userDefinedId == other.userDefinedId &&
this.additionalQueryParams == other.additionalQueryParams &&
this.additionalHeaders == other.additionalHeaders &&
this.additionalBodyProperties == other.additionalBodyProperties
}
override fun hashCode(): Int {
return Objects.hash(
amount,
externalBankAccountToken,
financialAccountToken,
method,
methodAttributes,
type,
token,
memo,
userDefinedId,
additionalQueryParams,
additionalHeaders,
additionalBodyProperties,
)
}
override fun toString() =
"PaymentCreateParams{amount=$amount, externalBankAccountToken=$externalBankAccountToken, financialAccountToken=$financialAccountToken, method=$method, methodAttributes=$methodAttributes, type=$type, token=$token, memo=$memo, userDefinedId=$userDefinedId, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}"
fun toBuilder() = Builder().from(this)
companion object {
@JvmStatic fun builder() = Builder()
}
@NoAutoDetect
class Builder {
private var amount: Long? = null
private var externalBankAccountToken: String? = null
private var financialAccountToken: String? = null
private var method: Method? = null
private var methodAttributes: PaymentMethodRequestAttributes? = null
private var type: Type? = null
private var token: String? = null
private var memo: String? = null
private var userDefinedId: String? = null
private var additionalQueryParams: MutableMap> = mutableMapOf()
private var additionalHeaders: MutableMap> = mutableMapOf()
private var additionalBodyProperties: MutableMap = mutableMapOf()
@JvmSynthetic
internal fun from(paymentCreateParams: PaymentCreateParams) = apply {
this.amount = paymentCreateParams.amount
this.externalBankAccountToken = paymentCreateParams.externalBankAccountToken
this.financialAccountToken = paymentCreateParams.financialAccountToken
this.method = paymentCreateParams.method
this.methodAttributes = paymentCreateParams.methodAttributes
this.type = paymentCreateParams.type
this.token = paymentCreateParams.token
this.memo = paymentCreateParams.memo
this.userDefinedId = paymentCreateParams.userDefinedId
additionalQueryParams(paymentCreateParams.additionalQueryParams)
additionalHeaders(paymentCreateParams.additionalHeaders)
additionalBodyProperties(paymentCreateParams.additionalBodyProperties)
}
fun amount(amount: Long) = apply { this.amount = amount }
fun externalBankAccountToken(externalBankAccountToken: String) = apply {
this.externalBankAccountToken = externalBankAccountToken
}
fun financialAccountToken(financialAccountToken: String) = apply {
this.financialAccountToken = financialAccountToken
}
fun method(method: Method) = apply { this.method = method }
fun methodAttributes(methodAttributes: PaymentMethodRequestAttributes) = apply {
this.methodAttributes = methodAttributes
}
fun type(type: Type) = apply { this.type = type }
/**
* Customer-provided token that will serve as an idempotency token. This token will become
* the transaction token.
*/
fun token(token: String) = apply { this.token = token }
fun memo(memo: String) = apply { this.memo = memo }
fun userDefinedId(userDefinedId: String) = apply { this.userDefinedId = userDefinedId }
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(): PaymentCreateParams =
PaymentCreateParams(
checkNotNull(amount) { "`amount` is required but was not set" },
checkNotNull(externalBankAccountToken) {
"`externalBankAccountToken` is required but was not set"
},
checkNotNull(financialAccountToken) {
"`financialAccountToken` is required but was not set"
},
checkNotNull(method) { "`method` is required but was not set" },
checkNotNull(methodAttributes) { "`methodAttributes` is required but was not set" },
checkNotNull(type) { "`type` is required but was not set" },
token,
memo,
userDefinedId,
additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(),
additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(),
additionalBodyProperties.toUnmodifiable(),
)
}
class Method
@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 Method && this.value == other.value
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
@JvmField val ACH_NEXT_DAY = Method(JsonField.of("ACH_NEXT_DAY"))
@JvmField val ACH_SAME_DAY = Method(JsonField.of("ACH_SAME_DAY"))
@JvmStatic fun of(value: String) = Method(JsonField.of(value))
}
enum class Known {
ACH_NEXT_DAY,
ACH_SAME_DAY,
}
enum class Value {
ACH_NEXT_DAY,
ACH_SAME_DAY,
_UNKNOWN,
}
fun value(): Value =
when (this) {
ACH_NEXT_DAY -> Value.ACH_NEXT_DAY
ACH_SAME_DAY -> Value.ACH_SAME_DAY
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
ACH_NEXT_DAY -> Known.ACH_NEXT_DAY
ACH_SAME_DAY -> Known.ACH_SAME_DAY
else -> throw LithicInvalidDataException("Unknown Method: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
@JsonDeserialize(builder = PaymentMethodRequestAttributes.Builder::class)
@NoAutoDetect
class PaymentMethodRequestAttributes
private constructor(
private val secCode: SecCode?,
private val additionalProperties: Map,
) {
@JsonProperty("sec_code") fun secCode(): SecCode? = secCode
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun toBuilder() = Builder().from(this)
companion object {
@JvmStatic fun builder() = Builder()
}
class Builder {
private var secCode: SecCode? = null
private var additionalProperties: MutableMap = mutableMapOf()
@JvmSynthetic
internal fun from(paymentMethodRequestAttributes: PaymentMethodRequestAttributes) =
apply {
this.secCode = paymentMethodRequestAttributes.secCode
additionalProperties(paymentMethodRequestAttributes.additionalProperties)
}
@JsonProperty("sec_code")
fun secCode(secCode: SecCode) = apply { this.secCode = secCode }
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(): PaymentMethodRequestAttributes =
PaymentMethodRequestAttributes(
checkNotNull(secCode) { "`secCode` is required but was not set" },
additionalProperties.toUnmodifiable()
)
}
class SecCode
@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 SecCode && this.value == other.value
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
@JvmField val CCD = SecCode(JsonField.of("CCD"))
@JvmField val PPD = SecCode(JsonField.of("PPD"))
@JvmField val WEB = SecCode(JsonField.of("WEB"))
@JvmStatic fun of(value: String) = SecCode(JsonField.of(value))
}
enum class Known {
CCD,
PPD,
WEB,
}
enum class Value {
CCD,
PPD,
WEB,
_UNKNOWN,
}
fun value(): Value =
when (this) {
CCD -> Value.CCD
PPD -> Value.PPD
WEB -> Value.WEB
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
CCD -> Known.CCD
PPD -> Known.PPD
WEB -> Known.WEB
else -> throw LithicInvalidDataException("Unknown SecCode: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return other is PaymentMethodRequestAttributes &&
this.secCode == other.secCode &&
this.additionalProperties == other.additionalProperties
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = Objects.hash(secCode, additionalProperties)
}
return hashCode
}
override fun toString() =
"PaymentMethodRequestAttributes{secCode=$secCode, additionalProperties=$additionalProperties}"
}
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 {
@JvmField val COLLECTION = Type(JsonField.of("COLLECTION"))
@JvmField val PAYMENT = Type(JsonField.of("PAYMENT"))
@JvmStatic fun of(value: String) = Type(JsonField.of(value))
}
enum class Known {
COLLECTION,
PAYMENT,
}
enum class Value {
COLLECTION,
PAYMENT,
_UNKNOWN,
}
fun value(): Value =
when (this) {
COLLECTION -> Value.COLLECTION
PAYMENT -> Value.PAYMENT
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
COLLECTION -> Known.COLLECTION
PAYMENT -> Known.PAYMENT
else -> throw LithicInvalidDataException("Unknown Type: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
}