com.lithic.api.models.TransactionSimulateCreditAuthorizationParams.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.JsonProperty
import com.fasterxml.jackson.databind.annotation.JsonDeserialize
import com.lithic.api.core.ExcludeMissing
import com.lithic.api.core.JsonValue
import com.lithic.api.core.NoAutoDetect
import com.lithic.api.core.http.Headers
import com.lithic.api.core.http.QueryParams
import com.lithic.api.core.toImmutable
import com.lithic.api.models.*
import java.util.Objects
class TransactionSimulateCreditAuthorizationParams
constructor(
private val amount: Long,
private val descriptor: String,
private val pan: String,
private val mcc: String?,
private val merchantAcceptorId: String?,
private val additionalHeaders: Headers,
private val additionalQueryParams: QueryParams,
private val additionalBodyProperties: Map,
) {
fun amount(): Long = amount
fun descriptor(): String = descriptor
fun pan(): String = pan
fun mcc(): String? = mcc
fun merchantAcceptorId(): String? = merchantAcceptorId
internal fun getBody(): TransactionSimulateCreditAuthorizationBody {
return TransactionSimulateCreditAuthorizationBody(
amount,
descriptor,
pan,
mcc,
merchantAcceptorId,
additionalBodyProperties,
)
}
internal fun getHeaders(): Headers = additionalHeaders
internal fun getQueryParams(): QueryParams = additionalQueryParams
@JsonDeserialize(builder = TransactionSimulateCreditAuthorizationBody.Builder::class)
@NoAutoDetect
class TransactionSimulateCreditAuthorizationBody
internal constructor(
private val amount: Long?,
private val descriptor: String?,
private val pan: String?,
private val mcc: String?,
private val merchantAcceptorId: String?,
private val additionalProperties: Map,
) {
/**
* Amount (in cents). Any value entered will be converted into a negative amount in the
* simulated transaction. For example, entering 100 in this field will appear as a -100
* amount in the transaction.
*/
@JsonProperty("amount") fun amount(): Long? = amount
/** Merchant descriptor. */
@JsonProperty("descriptor") fun descriptor(): String? = descriptor
/** Sixteen digit card number. */
@JsonProperty("pan") fun pan(): String? = pan
/**
* Merchant category code for the transaction to be simulated. A four-digit number listed in
* ISO 18245. Supported merchant category codes can be found
* [here](https://docs.lithic.com/docs/transactions#merchant-category-codes-mccs).
*/
@JsonProperty("mcc") fun mcc(): String? = mcc
/** Unique identifier to identify the payment card acceptor. */
@JsonProperty("merchant_acceptor_id") fun merchantAcceptorId(): String? = merchantAcceptorId
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var amount: Long? = null
private var descriptor: String? = null
private var pan: String? = null
private var mcc: String? = null
private var merchantAcceptorId: String? = null
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(
transactionSimulateCreditAuthorizationBody:
TransactionSimulateCreditAuthorizationBody
) = apply {
this.amount = transactionSimulateCreditAuthorizationBody.amount
this.descriptor = transactionSimulateCreditAuthorizationBody.descriptor
this.pan = transactionSimulateCreditAuthorizationBody.pan
this.mcc = transactionSimulateCreditAuthorizationBody.mcc
this.merchantAcceptorId =
transactionSimulateCreditAuthorizationBody.merchantAcceptorId
additionalProperties(
transactionSimulateCreditAuthorizationBody.additionalProperties
)
}
/**
* Amount (in cents). Any value entered will be converted into a negative amount in the
* simulated transaction. For example, entering 100 in this field will appear as a -100
* amount in the transaction.
*/
@JsonProperty("amount") fun amount(amount: Long) = apply { this.amount = amount }
/** Merchant descriptor. */
@JsonProperty("descriptor")
fun descriptor(descriptor: String) = apply { this.descriptor = descriptor }
/** Sixteen digit card number. */
@JsonProperty("pan") fun pan(pan: String) = apply { this.pan = pan }
/**
* Merchant category code for the transaction to be simulated. A four-digit number
* listed in ISO 18245. Supported merchant category codes can be found
* [here](https://docs.lithic.com/docs/transactions#merchant-category-codes-mccs).
*/
@JsonProperty("mcc") fun mcc(mcc: String) = apply { this.mcc = mcc }
/** Unique identifier to identify the payment card acceptor. */
@JsonProperty("merchant_acceptor_id")
fun merchantAcceptorId(merchantAcceptorId: String) = apply {
this.merchantAcceptorId = merchantAcceptorId
}
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(): TransactionSimulateCreditAuthorizationBody =
TransactionSimulateCreditAuthorizationBody(
checkNotNull(amount) { "`amount` is required but was not set" },
checkNotNull(descriptor) { "`descriptor` is required but was not set" },
checkNotNull(pan) { "`pan` is required but was not set" },
mcc,
merchantAcceptorId,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is TransactionSimulateCreditAuthorizationBody && this.amount == other.amount && this.descriptor == other.descriptor && this.pan == other.pan && this.mcc == other.mcc && this.merchantAcceptorId == other.merchantAcceptorId && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(amount, descriptor, pan, mcc, merchantAcceptorId, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"TransactionSimulateCreditAuthorizationBody{amount=$amount, descriptor=$descriptor, pan=$pan, mcc=$mcc, merchantAcceptorId=$merchantAcceptorId, additionalProperties=$additionalProperties}"
}
fun _additionalHeaders(): Headers = additionalHeaders
fun _additionalQueryParams(): QueryParams = additionalQueryParams
fun _additionalBodyProperties(): Map = additionalBodyProperties
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is TransactionSimulateCreditAuthorizationParams && this.amount == other.amount && this.descriptor == other.descriptor && this.pan == other.pan && this.mcc == other.mcc && this.merchantAcceptorId == other.merchantAcceptorId && this.additionalHeaders == other.additionalHeaders && this.additionalQueryParams == other.additionalQueryParams && this.additionalBodyProperties == other.additionalBodyProperties /* spotless:on */
}
override fun hashCode(): Int {
return /* spotless:off */ Objects.hash(amount, descriptor, pan, mcc, merchantAcceptorId, additionalHeaders, additionalQueryParams, additionalBodyProperties) /* spotless:on */
}
override fun toString() =
"TransactionSimulateCreditAuthorizationParams{amount=$amount, descriptor=$descriptor, pan=$pan, mcc=$mcc, merchantAcceptorId=$merchantAcceptorId, additionalHeaders=$additionalHeaders, additionalQueryParams=$additionalQueryParams, additionalBodyProperties=$additionalBodyProperties}"
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
@NoAutoDetect
class Builder {
private var amount: Long? = null
private var descriptor: String? = null
private var pan: String? = null
private var mcc: String? = null
private var merchantAcceptorId: String? = null
private var additionalHeaders: Headers.Builder = Headers.builder()
private var additionalQueryParams: QueryParams.Builder = QueryParams.builder()
private var additionalBodyProperties: MutableMap = mutableMapOf()
internal fun from(
transactionSimulateCreditAuthorizationParams:
TransactionSimulateCreditAuthorizationParams
) = apply {
this.amount = transactionSimulateCreditAuthorizationParams.amount
this.descriptor = transactionSimulateCreditAuthorizationParams.descriptor
this.pan = transactionSimulateCreditAuthorizationParams.pan
this.mcc = transactionSimulateCreditAuthorizationParams.mcc
this.merchantAcceptorId =
transactionSimulateCreditAuthorizationParams.merchantAcceptorId
additionalHeaders(transactionSimulateCreditAuthorizationParams.additionalHeaders)
additionalQueryParams(
transactionSimulateCreditAuthorizationParams.additionalQueryParams
)
additionalBodyProperties(
transactionSimulateCreditAuthorizationParams.additionalBodyProperties
)
}
/**
* Amount (in cents). Any value entered will be converted into a negative amount in the
* simulated transaction. For example, entering 100 in this field will appear as a -100
* amount in the transaction.
*/
fun amount(amount: Long) = apply { this.amount = amount }
/** Merchant descriptor. */
fun descriptor(descriptor: String) = apply { this.descriptor = descriptor }
/** Sixteen digit card number. */
fun pan(pan: String) = apply { this.pan = pan }
/**
* Merchant category code for the transaction to be simulated. A four-digit number listed in
* ISO 18245. Supported merchant category codes can be found
* [here](https://docs.lithic.com/docs/transactions#merchant-category-codes-mccs).
*/
fun mcc(mcc: String) = apply { this.mcc = mcc }
/** Unique identifier to identify the payment card acceptor. */
fun merchantAcceptorId(merchantAcceptorId: String) = apply {
this.merchantAcceptorId = merchantAcceptorId
}
fun additionalHeaders(additionalHeaders: Headers) = apply {
this.additionalHeaders.clear()
putAllAdditionalHeaders(additionalHeaders)
}
fun additionalHeaders(additionalHeaders: Map>) = apply {
this.additionalHeaders.clear()
putAllAdditionalHeaders(additionalHeaders)
}
fun putAdditionalHeader(name: String, value: String) = apply {
additionalHeaders.put(name, value)
}
fun putAdditionalHeaders(name: String, values: Iterable) = apply {
additionalHeaders.put(name, values)
}
fun putAllAdditionalHeaders(additionalHeaders: Headers) = apply {
this.additionalHeaders.putAll(additionalHeaders)
}
fun putAllAdditionalHeaders(additionalHeaders: Map>) = apply {
this.additionalHeaders.putAll(additionalHeaders)
}
fun replaceAdditionalHeaders(name: String, value: String) = apply {
additionalHeaders.replace(name, value)
}
fun replaceAdditionalHeaders(name: String, values: Iterable) = apply {
additionalHeaders.replace(name, values)
}
fun replaceAllAdditionalHeaders(additionalHeaders: Headers) = apply {
this.additionalHeaders.replaceAll(additionalHeaders)
}
fun replaceAllAdditionalHeaders(additionalHeaders: Map>) = apply {
this.additionalHeaders.replaceAll(additionalHeaders)
}
fun removeAdditionalHeaders(name: String) = apply { additionalHeaders.remove(name) }
fun removeAllAdditionalHeaders(names: Set) = apply {
additionalHeaders.removeAll(names)
}
fun additionalQueryParams(additionalQueryParams: QueryParams) = apply {
this.additionalQueryParams.clear()
putAllAdditionalQueryParams(additionalQueryParams)
}
fun additionalQueryParams(additionalQueryParams: Map>) = apply {
this.additionalQueryParams.clear()
putAllAdditionalQueryParams(additionalQueryParams)
}
fun putAdditionalQueryParam(key: String, value: String) = apply {
additionalQueryParams.put(key, value)
}
fun putAdditionalQueryParams(key: String, values: Iterable) = apply {
additionalQueryParams.put(key, values)
}
fun putAllAdditionalQueryParams(additionalQueryParams: QueryParams) = apply {
this.additionalQueryParams.putAll(additionalQueryParams)
}
fun putAllAdditionalQueryParams(additionalQueryParams: Map>) =
apply {
this.additionalQueryParams.putAll(additionalQueryParams)
}
fun replaceAdditionalQueryParams(key: String, value: String) = apply {
additionalQueryParams.replace(key, value)
}
fun replaceAdditionalQueryParams(key: String, values: Iterable) = apply {
additionalQueryParams.replace(key, values)
}
fun replaceAllAdditionalQueryParams(additionalQueryParams: QueryParams) = apply {
this.additionalQueryParams.replaceAll(additionalQueryParams)
}
fun replaceAllAdditionalQueryParams(additionalQueryParams: Map>) =
apply {
this.additionalQueryParams.replaceAll(additionalQueryParams)
}
fun removeAdditionalQueryParams(key: String) = apply { additionalQueryParams.remove(key) }
fun removeAllAdditionalQueryParams(keys: Set) = apply {
additionalQueryParams.removeAll(keys)
}
fun additionalBodyProperties(additionalBodyProperties: Map) = apply {
this.additionalBodyProperties.clear()
putAllAdditionalBodyProperties(additionalBodyProperties)
}
fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply {
additionalBodyProperties.put(key, value)
}
fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) =
apply {
this.additionalBodyProperties.putAll(additionalBodyProperties)
}
fun removeAdditionalBodyProperty(key: String) = apply {
additionalBodyProperties.remove(key)
}
fun removeAllAdditionalBodyProperties(keys: Set) = apply {
keys.forEach(::removeAdditionalBodyProperty)
}
fun build(): TransactionSimulateCreditAuthorizationParams =
TransactionSimulateCreditAuthorizationParams(
checkNotNull(amount) { "`amount` is required but was not set" },
checkNotNull(descriptor) { "`descriptor` is required but was not set" },
checkNotNull(pan) { "`pan` is required but was not set" },
mcc,
merchantAcceptorId,
additionalHeaders.build(),
additionalQueryParams.build(),
additionalBodyProperties.toImmutable(),
)
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy