com.lithic.api.models.AccountHolderSimulateEnrollmentDocumentReviewParams.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.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.errors.LithicInvalidDataException
import com.lithic.api.models.*
import java.util.Objects
class AccountHolderSimulateEnrollmentDocumentReviewParams
constructor(
private val documentUploadToken: String,
private val status: Status,
private val acceptedEntityStatusReasons: List?,
private val statusReason: DocumentUploadStatusReasons?,
private val additionalHeaders: Headers,
private val additionalQueryParams: QueryParams,
private val additionalBodyProperties: Map,
) {
fun documentUploadToken(): String = documentUploadToken
fun status(): Status = status
fun acceptedEntityStatusReasons(): List? = acceptedEntityStatusReasons
fun statusReason(): DocumentUploadStatusReasons? = statusReason
internal fun getBody(): AccountHolderSimulateEnrollmentDocumentReviewBody {
return AccountHolderSimulateEnrollmentDocumentReviewBody(
documentUploadToken,
status,
acceptedEntityStatusReasons,
statusReason,
additionalBodyProperties,
)
}
internal fun getHeaders(): Headers = additionalHeaders
internal fun getQueryParams(): QueryParams = additionalQueryParams
@JsonDeserialize(builder = AccountHolderSimulateEnrollmentDocumentReviewBody.Builder::class)
@NoAutoDetect
class AccountHolderSimulateEnrollmentDocumentReviewBody
internal constructor(
private val documentUploadToken: String?,
private val status: Status?,
private val acceptedEntityStatusReasons: List?,
private val statusReason: DocumentUploadStatusReasons?,
private val additionalProperties: Map,
) {
/** The account holder document upload which to perform the simulation upon. */
@JsonProperty("document_upload_token")
fun documentUploadToken(): String? = documentUploadToken
/** An account holder document's upload status for use within the simulation. */
@JsonProperty("status") fun status(): Status? = status
/** A list of status reasons associated with a KYB account holder in PENDING_REVIEW */
@JsonProperty("accepted_entity_status_reasons")
fun acceptedEntityStatusReasons(): List? = acceptedEntityStatusReasons
/**
* Status reason that will be associated with the simulated account holder status. Only
* required for a `REJECTED` status or `PARTIAL_APPROVAL` status.
*/
@JsonProperty("status_reason")
fun statusReason(): DocumentUploadStatusReasons? = statusReason
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var documentUploadToken: String? = null
private var status: Status? = null
private var acceptedEntityStatusReasons: List? = null
private var statusReason: DocumentUploadStatusReasons? = null
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(
accountHolderSimulateEnrollmentDocumentReviewBody:
AccountHolderSimulateEnrollmentDocumentReviewBody
) = apply {
this.documentUploadToken =
accountHolderSimulateEnrollmentDocumentReviewBody.documentUploadToken
this.status = accountHolderSimulateEnrollmentDocumentReviewBody.status
this.acceptedEntityStatusReasons =
accountHolderSimulateEnrollmentDocumentReviewBody.acceptedEntityStatusReasons
this.statusReason = accountHolderSimulateEnrollmentDocumentReviewBody.statusReason
additionalProperties(
accountHolderSimulateEnrollmentDocumentReviewBody.additionalProperties
)
}
/** The account holder document upload which to perform the simulation upon. */
@JsonProperty("document_upload_token")
fun documentUploadToken(documentUploadToken: String) = apply {
this.documentUploadToken = documentUploadToken
}
/** An account holder document's upload status for use within the simulation. */
@JsonProperty("status") fun status(status: Status) = apply { this.status = status }
/** A list of status reasons associated with a KYB account holder in PENDING_REVIEW */
@JsonProperty("accepted_entity_status_reasons")
fun acceptedEntityStatusReasons(acceptedEntityStatusReasons: List) = apply {
this.acceptedEntityStatusReasons = acceptedEntityStatusReasons
}
/**
* Status reason that will be associated with the simulated account holder status. Only
* required for a `REJECTED` status or `PARTIAL_APPROVAL` status.
*/
@JsonProperty("status_reason")
fun statusReason(statusReason: DocumentUploadStatusReasons) = apply {
this.statusReason = statusReason
}
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(): AccountHolderSimulateEnrollmentDocumentReviewBody =
AccountHolderSimulateEnrollmentDocumentReviewBody(
checkNotNull(documentUploadToken) {
"`documentUploadToken` is required but was not set"
},
checkNotNull(status) { "`status` is required but was not set" },
acceptedEntityStatusReasons?.toImmutable(),
statusReason,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is AccountHolderSimulateEnrollmentDocumentReviewBody && this.documentUploadToken == other.documentUploadToken && this.status == other.status && this.acceptedEntityStatusReasons == other.acceptedEntityStatusReasons && this.statusReason == other.statusReason && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(documentUploadToken, status, acceptedEntityStatusReasons, statusReason, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"AccountHolderSimulateEnrollmentDocumentReviewBody{documentUploadToken=$documentUploadToken, status=$status, acceptedEntityStatusReasons=$acceptedEntityStatusReasons, statusReason=$statusReason, 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 AccountHolderSimulateEnrollmentDocumentReviewParams && this.documentUploadToken == other.documentUploadToken && this.status == other.status && this.acceptedEntityStatusReasons == other.acceptedEntityStatusReasons && this.statusReason == other.statusReason && this.additionalHeaders == other.additionalHeaders && this.additionalQueryParams == other.additionalQueryParams && this.additionalBodyProperties == other.additionalBodyProperties /* spotless:on */
}
override fun hashCode(): Int {
return /* spotless:off */ Objects.hash(documentUploadToken, status, acceptedEntityStatusReasons, statusReason, additionalHeaders, additionalQueryParams, additionalBodyProperties) /* spotless:on */
}
override fun toString() =
"AccountHolderSimulateEnrollmentDocumentReviewParams{documentUploadToken=$documentUploadToken, status=$status, acceptedEntityStatusReasons=$acceptedEntityStatusReasons, statusReason=$statusReason, additionalHeaders=$additionalHeaders, additionalQueryParams=$additionalQueryParams, additionalBodyProperties=$additionalBodyProperties}"
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
@NoAutoDetect
class Builder {
private var documentUploadToken: String? = null
private var status: Status? = null
private var acceptedEntityStatusReasons: MutableList = mutableListOf()
private var statusReason: DocumentUploadStatusReasons? = null
private var additionalHeaders: Headers.Builder = Headers.builder()
private var additionalQueryParams: QueryParams.Builder = QueryParams.builder()
private var additionalBodyProperties: MutableMap = mutableMapOf()
internal fun from(
accountHolderSimulateEnrollmentDocumentReviewParams:
AccountHolderSimulateEnrollmentDocumentReviewParams
) = apply {
this.documentUploadToken =
accountHolderSimulateEnrollmentDocumentReviewParams.documentUploadToken
this.status = accountHolderSimulateEnrollmentDocumentReviewParams.status
this.acceptedEntityStatusReasons(
accountHolderSimulateEnrollmentDocumentReviewParams.acceptedEntityStatusReasons
?: listOf()
)
this.statusReason = accountHolderSimulateEnrollmentDocumentReviewParams.statusReason
additionalHeaders(accountHolderSimulateEnrollmentDocumentReviewParams.additionalHeaders)
additionalQueryParams(
accountHolderSimulateEnrollmentDocumentReviewParams.additionalQueryParams
)
additionalBodyProperties(
accountHolderSimulateEnrollmentDocumentReviewParams.additionalBodyProperties
)
}
/** The account holder document upload which to perform the simulation upon. */
fun documentUploadToken(documentUploadToken: String) = apply {
this.documentUploadToken = documentUploadToken
}
/** An account holder document's upload status for use within the simulation. */
fun status(status: Status) = apply { this.status = status }
/** A list of status reasons associated with a KYB account holder in PENDING_REVIEW */
fun acceptedEntityStatusReasons(acceptedEntityStatusReasons: List) = apply {
this.acceptedEntityStatusReasons.clear()
this.acceptedEntityStatusReasons.addAll(acceptedEntityStatusReasons)
}
/** A list of status reasons associated with a KYB account holder in PENDING_REVIEW */
fun addAcceptedEntityStatusReason(acceptedEntityStatusReason: String) = apply {
this.acceptedEntityStatusReasons.add(acceptedEntityStatusReason)
}
/**
* Status reason that will be associated with the simulated account holder status. Only
* required for a `REJECTED` status or `PARTIAL_APPROVAL` status.
*/
fun statusReason(statusReason: DocumentUploadStatusReasons) = apply {
this.statusReason = statusReason
}
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(): AccountHolderSimulateEnrollmentDocumentReviewParams =
AccountHolderSimulateEnrollmentDocumentReviewParams(
checkNotNull(documentUploadToken) {
"`documentUploadToken` is required but was not set"
},
checkNotNull(status) { "`status` is required but was not set" },
if (acceptedEntityStatusReasons.size == 0) null
else acceptedEntityStatusReasons.toImmutable(),
statusReason,
additionalHeaders.build(),
additionalQueryParams.build(),
additionalBodyProperties.toImmutable(),
)
}
class Status
@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 Status && this.value == other.value /* spotless:on */
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
val UPLOADED = Status(JsonField.of("UPLOADED"))
val ACCEPTED = Status(JsonField.of("ACCEPTED"))
val REJECTED = Status(JsonField.of("REJECTED"))
val PARTIAL_APPROVAL = Status(JsonField.of("PARTIAL_APPROVAL"))
fun of(value: String) = Status(JsonField.of(value))
}
enum class Known {
UPLOADED,
ACCEPTED,
REJECTED,
PARTIAL_APPROVAL,
}
enum class Value {
UPLOADED,
ACCEPTED,
REJECTED,
PARTIAL_APPROVAL,
_UNKNOWN,
}
fun value(): Value =
when (this) {
UPLOADED -> Value.UPLOADED
ACCEPTED -> Value.ACCEPTED
REJECTED -> Value.REJECTED
PARTIAL_APPROVAL -> Value.PARTIAL_APPROVAL
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
UPLOADED -> Known.UPLOADED
ACCEPTED -> Known.ACCEPTED
REJECTED -> Known.REJECTED
PARTIAL_APPROVAL -> Known.PARTIAL_APPROVAL
else -> throw LithicInvalidDataException("Unknown Status: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
class DocumentUploadStatusReasons
@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 DocumentUploadStatusReasons && this.value == other.value /* spotless:on */
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
val DOCUMENT_MISSING_REQUIRED_DATA =
DocumentUploadStatusReasons(JsonField.of("DOCUMENT_MISSING_REQUIRED_DATA"))
val DOCUMENT_UPLOAD_TOO_BLURRY =
DocumentUploadStatusReasons(JsonField.of("DOCUMENT_UPLOAD_TOO_BLURRY"))
val FILE_SIZE_TOO_LARGE =
DocumentUploadStatusReasons(JsonField.of("FILE_SIZE_TOO_LARGE"))
val INVALID_DOCUMENT_TYPE =
DocumentUploadStatusReasons(JsonField.of("INVALID_DOCUMENT_TYPE"))
val INVALID_DOCUMENT_UPLOAD =
DocumentUploadStatusReasons(JsonField.of("INVALID_DOCUMENT_UPLOAD"))
val INVALID_ENTITY = DocumentUploadStatusReasons(JsonField.of("INVALID_ENTITY"))
val DOCUMENT_EXPIRED = DocumentUploadStatusReasons(JsonField.of("DOCUMENT_EXPIRED"))
val DOCUMENT_ISSUED_GREATER_THAN_30_DAYS =
DocumentUploadStatusReasons(JsonField.of("DOCUMENT_ISSUED_GREATER_THAN_30_DAYS"))
val DOCUMENT_TYPE_NOT_SUPPORTED =
DocumentUploadStatusReasons(JsonField.of("DOCUMENT_TYPE_NOT_SUPPORTED"))
val UNKNOWN_FAILURE_REASON =
DocumentUploadStatusReasons(JsonField.of("UNKNOWN_FAILURE_REASON"))
val UNKNOWN_ERROR = DocumentUploadStatusReasons(JsonField.of("UNKNOWN_ERROR"))
fun of(value: String) = DocumentUploadStatusReasons(JsonField.of(value))
}
enum class Known {
DOCUMENT_MISSING_REQUIRED_DATA,
DOCUMENT_UPLOAD_TOO_BLURRY,
FILE_SIZE_TOO_LARGE,
INVALID_DOCUMENT_TYPE,
INVALID_DOCUMENT_UPLOAD,
INVALID_ENTITY,
DOCUMENT_EXPIRED,
DOCUMENT_ISSUED_GREATER_THAN_30_DAYS,
DOCUMENT_TYPE_NOT_SUPPORTED,
UNKNOWN_FAILURE_REASON,
UNKNOWN_ERROR,
}
enum class Value {
DOCUMENT_MISSING_REQUIRED_DATA,
DOCUMENT_UPLOAD_TOO_BLURRY,
FILE_SIZE_TOO_LARGE,
INVALID_DOCUMENT_TYPE,
INVALID_DOCUMENT_UPLOAD,
INVALID_ENTITY,
DOCUMENT_EXPIRED,
DOCUMENT_ISSUED_GREATER_THAN_30_DAYS,
DOCUMENT_TYPE_NOT_SUPPORTED,
UNKNOWN_FAILURE_REASON,
UNKNOWN_ERROR,
_UNKNOWN,
}
fun value(): Value =
when (this) {
DOCUMENT_MISSING_REQUIRED_DATA -> Value.DOCUMENT_MISSING_REQUIRED_DATA
DOCUMENT_UPLOAD_TOO_BLURRY -> Value.DOCUMENT_UPLOAD_TOO_BLURRY
FILE_SIZE_TOO_LARGE -> Value.FILE_SIZE_TOO_LARGE
INVALID_DOCUMENT_TYPE -> Value.INVALID_DOCUMENT_TYPE
INVALID_DOCUMENT_UPLOAD -> Value.INVALID_DOCUMENT_UPLOAD
INVALID_ENTITY -> Value.INVALID_ENTITY
DOCUMENT_EXPIRED -> Value.DOCUMENT_EXPIRED
DOCUMENT_ISSUED_GREATER_THAN_30_DAYS -> Value.DOCUMENT_ISSUED_GREATER_THAN_30_DAYS
DOCUMENT_TYPE_NOT_SUPPORTED -> Value.DOCUMENT_TYPE_NOT_SUPPORTED
UNKNOWN_FAILURE_REASON -> Value.UNKNOWN_FAILURE_REASON
UNKNOWN_ERROR -> Value.UNKNOWN_ERROR
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
DOCUMENT_MISSING_REQUIRED_DATA -> Known.DOCUMENT_MISSING_REQUIRED_DATA
DOCUMENT_UPLOAD_TOO_BLURRY -> Known.DOCUMENT_UPLOAD_TOO_BLURRY
FILE_SIZE_TOO_LARGE -> Known.FILE_SIZE_TOO_LARGE
INVALID_DOCUMENT_TYPE -> Known.INVALID_DOCUMENT_TYPE
INVALID_DOCUMENT_UPLOAD -> Known.INVALID_DOCUMENT_UPLOAD
INVALID_ENTITY -> Known.INVALID_ENTITY
DOCUMENT_EXPIRED -> Known.DOCUMENT_EXPIRED
DOCUMENT_ISSUED_GREATER_THAN_30_DAYS -> Known.DOCUMENT_ISSUED_GREATER_THAN_30_DAYS
DOCUMENT_TYPE_NOT_SUPPORTED -> Known.DOCUMENT_TYPE_NOT_SUPPORTED
UNKNOWN_FAILURE_REASON -> Known.UNKNOWN_FAILURE_REASON
UNKNOWN_ERROR -> Known.UNKNOWN_ERROR
else ->
throw LithicInvalidDataException("Unknown DocumentUploadStatusReasons: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy