com.lithic.api.models.AccountHolderUpdateParams.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.
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
import java.util.Optional
class AccountHolderUpdateParams
constructor(
private val accountHolderToken: String,
private val businessAccountToken: String?,
private val email: String?,
private val phoneNumber: String?,
private val additionalHeaders: Headers,
private val additionalQueryParams: QueryParams,
private val additionalBodyProperties: Map,
) {
fun accountHolderToken(): String = accountHolderToken
fun businessAccountToken(): Optional = Optional.ofNullable(businessAccountToken)
fun email(): Optional = Optional.ofNullable(email)
fun phoneNumber(): Optional = Optional.ofNullable(phoneNumber)
@JvmSynthetic
internal fun getBody(): AccountHolderUpdateBody {
return AccountHolderUpdateBody(
businessAccountToken,
email,
phoneNumber,
additionalBodyProperties,
)
}
@JvmSynthetic internal fun getHeaders(): Headers = additionalHeaders
@JvmSynthetic internal fun getQueryParams(): QueryParams = additionalQueryParams
fun getPathParam(index: Int): String {
return when (index) {
0 -> accountHolderToken
else -> ""
}
}
@JsonDeserialize(builder = AccountHolderUpdateBody.Builder::class)
@NoAutoDetect
class AccountHolderUpdateBody
internal constructor(
private val businessAccountToken: String?,
private val email: String?,
private val phoneNumber: String?,
private val additionalProperties: Map,
) {
/**
* Only applicable for customers using the KYC-Exempt workflow to enroll authorized users of
* businesses. Pass the account_token of the enrolled business associated with the
* AUTHORIZED_USER in this field.
*/
@JsonProperty("business_account_token")
fun businessAccountToken(): String? = businessAccountToken
/**
* Account holder's email address. The primary purpose of this field is for cardholder
* identification and verification during the digital wallet tokenization process.
*/
@JsonProperty("email") fun email(): String? = email
/**
* Account holder's phone number, entered in E.164 format. The primary purpose of this field
* is for cardholder identification and verification during the digital wallet tokenization
* process.
*/
@JsonProperty("phone_number") fun phoneNumber(): String? = phoneNumber
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun toBuilder() = Builder().from(this)
companion object {
@JvmStatic fun builder() = Builder()
}
class Builder {
private var businessAccountToken: String? = null
private var email: String? = null
private var phoneNumber: String? = null
private var additionalProperties: MutableMap = mutableMapOf()
@JvmSynthetic
internal fun from(accountHolderUpdateBody: AccountHolderUpdateBody) = apply {
this.businessAccountToken = accountHolderUpdateBody.businessAccountToken
this.email = accountHolderUpdateBody.email
this.phoneNumber = accountHolderUpdateBody.phoneNumber
additionalProperties(accountHolderUpdateBody.additionalProperties)
}
/**
* Only applicable for customers using the KYC-Exempt workflow to enroll authorized
* users of businesses. Pass the account_token of the enrolled business associated with
* the AUTHORIZED_USER in this field.
*/
@JsonProperty("business_account_token")
fun businessAccountToken(businessAccountToken: String) = apply {
this.businessAccountToken = businessAccountToken
}
/**
* Account holder's email address. The primary purpose of this field is for cardholder
* identification and verification during the digital wallet tokenization process.
*/
@JsonProperty("email") fun email(email: String) = apply { this.email = email }
/**
* Account holder's phone number, entered in E.164 format. The primary purpose of this
* field is for cardholder identification and verification during the digital wallet
* tokenization process.
*/
@JsonProperty("phone_number")
fun phoneNumber(phoneNumber: String) = apply { this.phoneNumber = phoneNumber }
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(): AccountHolderUpdateBody =
AccountHolderUpdateBody(
businessAccountToken,
email,
phoneNumber,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is AccountHolderUpdateBody && this.businessAccountToken == other.businessAccountToken && this.email == other.email && this.phoneNumber == other.phoneNumber && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(businessAccountToken, email, phoneNumber, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"AccountHolderUpdateBody{businessAccountToken=$businessAccountToken, email=$email, phoneNumber=$phoneNumber, 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 AccountHolderUpdateParams && this.accountHolderToken == other.accountHolderToken && this.businessAccountToken == other.businessAccountToken && this.email == other.email && this.phoneNumber == other.phoneNumber && this.additionalHeaders == other.additionalHeaders && this.additionalQueryParams == other.additionalQueryParams && this.additionalBodyProperties == other.additionalBodyProperties /* spotless:on */
}
override fun hashCode(): Int {
return /* spotless:off */ Objects.hash(accountHolderToken, businessAccountToken, email, phoneNumber, additionalHeaders, additionalQueryParams, additionalBodyProperties) /* spotless:on */
}
override fun toString() =
"AccountHolderUpdateParams{accountHolderToken=$accountHolderToken, businessAccountToken=$businessAccountToken, email=$email, phoneNumber=$phoneNumber, additionalHeaders=$additionalHeaders, additionalQueryParams=$additionalQueryParams, additionalBodyProperties=$additionalBodyProperties}"
fun toBuilder() = Builder().from(this)
companion object {
@JvmStatic fun builder() = Builder()
}
@NoAutoDetect
class Builder {
private var accountHolderToken: String? = null
private var businessAccountToken: String? = null
private var email: String? = null
private var phoneNumber: String? = null
private var additionalHeaders: Headers.Builder = Headers.builder()
private var additionalQueryParams: QueryParams.Builder = QueryParams.builder()
private var additionalBodyProperties: MutableMap = mutableMapOf()
@JvmSynthetic
internal fun from(accountHolderUpdateParams: AccountHolderUpdateParams) = apply {
this.accountHolderToken = accountHolderUpdateParams.accountHolderToken
this.businessAccountToken = accountHolderUpdateParams.businessAccountToken
this.email = accountHolderUpdateParams.email
this.phoneNumber = accountHolderUpdateParams.phoneNumber
additionalHeaders(accountHolderUpdateParams.additionalHeaders)
additionalQueryParams(accountHolderUpdateParams.additionalQueryParams)
additionalBodyProperties(accountHolderUpdateParams.additionalBodyProperties)
}
fun accountHolderToken(accountHolderToken: String) = apply {
this.accountHolderToken = accountHolderToken
}
/**
* Only applicable for customers using the KYC-Exempt workflow to enroll authorized users of
* businesses. Pass the account_token of the enrolled business associated with the
* AUTHORIZED_USER in this field.
*/
fun businessAccountToken(businessAccountToken: String) = apply {
this.businessAccountToken = businessAccountToken
}
/**
* Account holder's email address. The primary purpose of this field is for cardholder
* identification and verification during the digital wallet tokenization process.
*/
fun email(email: String) = apply { this.email = email }
/**
* Account holder's phone number, entered in E.164 format. The primary purpose of this field
* is for cardholder identification and verification during the digital wallet tokenization
* process.
*/
fun phoneNumber(phoneNumber: String) = apply { this.phoneNumber = phoneNumber }
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(): AccountHolderUpdateParams =
AccountHolderUpdateParams(
checkNotNull(accountHolderToken) {
"`accountHolderToken` is required but was not set"
},
businessAccountToken,
email,
phoneNumber,
additionalHeaders.build(),
additionalQueryParams.build(),
additionalBodyProperties.toImmutable(),
)
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy