com.increase.api.models.OAuthTokenCreateParams.kt Maven / Gradle / Ivy
// File generated from our OpenAPI spec by Stainless.
package com.increase.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.increase.api.core.Enum
import com.increase.api.core.ExcludeMissing
import com.increase.api.core.JsonField
import com.increase.api.core.JsonValue
import com.increase.api.core.NoAutoDetect
import com.increase.api.core.http.Headers
import com.increase.api.core.http.QueryParams
import com.increase.api.core.toImmutable
import com.increase.api.errors.IncreaseInvalidDataException
import com.increase.api.models.*
import java.util.Objects
class OAuthTokenCreateParams
constructor(
private val grantType: GrantType,
private val clientId: String?,
private val clientSecret: String?,
private val code: String?,
private val productionToken: String?,
private val additionalHeaders: Headers,
private val additionalQueryParams: QueryParams,
private val additionalBodyProperties: Map,
) {
fun grantType(): GrantType = grantType
fun clientId(): String? = clientId
fun clientSecret(): String? = clientSecret
fun code(): String? = code
fun productionToken(): String? = productionToken
internal fun getBody(): OAuthTokenCreateBody {
return OAuthTokenCreateBody(
grantType,
clientId,
clientSecret,
code,
productionToken,
additionalBodyProperties,
)
}
internal fun getHeaders(): Headers = additionalHeaders
internal fun getQueryParams(): QueryParams = additionalQueryParams
@JsonDeserialize(builder = OAuthTokenCreateBody.Builder::class)
@NoAutoDetect
class OAuthTokenCreateBody
internal constructor(
private val grantType: GrantType?,
private val clientId: String?,
private val clientSecret: String?,
private val code: String?,
private val productionToken: String?,
private val additionalProperties: Map,
) {
/**
* The credential you request in exchange for the code. In Production, this is always
* `authorization_code`. In Sandbox, you can pass either enum value.
*/
@JsonProperty("grant_type") fun grantType(): GrantType? = grantType
/** The public identifier for your application. */
@JsonProperty("client_id") fun clientId(): String? = clientId
/**
* The secret that confirms you own the application. This is redundent given that the
* request is made with your API key but it's a required component of OAuth 2.0.
*/
@JsonProperty("client_secret") fun clientSecret(): String? = clientSecret
/** The authorization code generated by the user and given to you as a query parameter. */
@JsonProperty("code") fun code(): String? = code
/**
* The production token you want to exchange for a sandbox token. This is only available in
* Sandbox. Set `grant_type` to `production_token` to use this parameter.
*/
@JsonProperty("production_token") fun productionToken(): String? = productionToken
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var grantType: GrantType? = null
private var clientId: String? = null
private var clientSecret: String? = null
private var code: String? = null
private var productionToken: String? = null
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(oauthTokenCreateBody: OAuthTokenCreateBody) = apply {
this.grantType = oauthTokenCreateBody.grantType
this.clientId = oauthTokenCreateBody.clientId
this.clientSecret = oauthTokenCreateBody.clientSecret
this.code = oauthTokenCreateBody.code
this.productionToken = oauthTokenCreateBody.productionToken
additionalProperties(oauthTokenCreateBody.additionalProperties)
}
/**
* The credential you request in exchange for the code. In Production, this is always
* `authorization_code`. In Sandbox, you can pass either enum value.
*/
@JsonProperty("grant_type")
fun grantType(grantType: GrantType) = apply { this.grantType = grantType }
/** The public identifier for your application. */
@JsonProperty("client_id")
fun clientId(clientId: String) = apply { this.clientId = clientId }
/**
* The secret that confirms you own the application. This is redundent given that the
* request is made with your API key but it's a required component of OAuth 2.0.
*/
@JsonProperty("client_secret")
fun clientSecret(clientSecret: String) = apply { this.clientSecret = clientSecret }
/**
* The authorization code generated by the user and given to you as a query parameter.
*/
@JsonProperty("code") fun code(code: String) = apply { this.code = code }
/**
* The production token you want to exchange for a sandbox token. This is only available
* in Sandbox. Set `grant_type` to `production_token` to use this parameter.
*/
@JsonProperty("production_token")
fun productionToken(productionToken: String) = apply {
this.productionToken = productionToken
}
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(): OAuthTokenCreateBody =
OAuthTokenCreateBody(
checkNotNull(grantType) { "`grantType` is required but was not set" },
clientId,
clientSecret,
code,
productionToken,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is OAuthTokenCreateBody && this.grantType == other.grantType && this.clientId == other.clientId && this.clientSecret == other.clientSecret && this.code == other.code && this.productionToken == other.productionToken && this.additionalProperties == other.additionalProperties /* spotless:on */
}
private var hashCode: Int = 0
override fun hashCode(): Int {
if (hashCode == 0) {
hashCode = /* spotless:off */ Objects.hash(grantType, clientId, clientSecret, code, productionToken, additionalProperties) /* spotless:on */
}
return hashCode
}
override fun toString() =
"OAuthTokenCreateBody{grantType=$grantType, clientId=$clientId, clientSecret=$clientSecret, code=$code, productionToken=$productionToken, 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 OAuthTokenCreateParams && this.grantType == other.grantType && this.clientId == other.clientId && this.clientSecret == other.clientSecret && this.code == other.code && this.productionToken == other.productionToken && this.additionalHeaders == other.additionalHeaders && this.additionalQueryParams == other.additionalQueryParams && this.additionalBodyProperties == other.additionalBodyProperties /* spotless:on */
}
override fun hashCode(): Int {
return /* spotless:off */ Objects.hash(grantType, clientId, clientSecret, code, productionToken, additionalHeaders, additionalQueryParams, additionalBodyProperties) /* spotless:on */
}
override fun toString() =
"OAuthTokenCreateParams{grantType=$grantType, clientId=$clientId, clientSecret=$clientSecret, code=$code, productionToken=$productionToken, additionalHeaders=$additionalHeaders, additionalQueryParams=$additionalQueryParams, additionalBodyProperties=$additionalBodyProperties}"
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
@NoAutoDetect
class Builder {
private var grantType: GrantType? = null
private var clientId: String? = null
private var clientSecret: String? = null
private var code: String? = null
private var productionToken: String? = null
private var additionalHeaders: Headers.Builder = Headers.builder()
private var additionalQueryParams: QueryParams.Builder = QueryParams.builder()
private var additionalBodyProperties: MutableMap = mutableMapOf()
internal fun from(oauthTokenCreateParams: OAuthTokenCreateParams) = apply {
this.grantType = oauthTokenCreateParams.grantType
this.clientId = oauthTokenCreateParams.clientId
this.clientSecret = oauthTokenCreateParams.clientSecret
this.code = oauthTokenCreateParams.code
this.productionToken = oauthTokenCreateParams.productionToken
additionalHeaders(oauthTokenCreateParams.additionalHeaders)
additionalQueryParams(oauthTokenCreateParams.additionalQueryParams)
additionalBodyProperties(oauthTokenCreateParams.additionalBodyProperties)
}
/**
* The credential you request in exchange for the code. In Production, this is always
* `authorization_code`. In Sandbox, you can pass either enum value.
*/
fun grantType(grantType: GrantType) = apply { this.grantType = grantType }
/** The public identifier for your application. */
fun clientId(clientId: String) = apply { this.clientId = clientId }
/**
* The secret that confirms you own the application. This is redundent given that the
* request is made with your API key but it's a required component of OAuth 2.0.
*/
fun clientSecret(clientSecret: String) = apply { this.clientSecret = clientSecret }
/** The authorization code generated by the user and given to you as a query parameter. */
fun code(code: String) = apply { this.code = code }
/**
* The production token you want to exchange for a sandbox token. This is only available in
* Sandbox. Set `grant_type` to `production_token` to use this parameter.
*/
fun productionToken(productionToken: String) = apply {
this.productionToken = productionToken
}
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(): OAuthTokenCreateParams =
OAuthTokenCreateParams(
checkNotNull(grantType) { "`grantType` is required but was not set" },
clientId,
clientSecret,
code,
productionToken,
additionalHeaders.build(),
additionalQueryParams.build(),
additionalBodyProperties.toImmutable(),
)
}
class GrantType
@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 GrantType && this.value == other.value /* spotless:on */
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
val AUTHORIZATION_CODE = GrantType(JsonField.of("authorization_code"))
val PRODUCTION_TOKEN = GrantType(JsonField.of("production_token"))
fun of(value: String) = GrantType(JsonField.of(value))
}
enum class Known {
AUTHORIZATION_CODE,
PRODUCTION_TOKEN,
}
enum class Value {
AUTHORIZATION_CODE,
PRODUCTION_TOKEN,
_UNKNOWN,
}
fun value(): Value =
when (this) {
AUTHORIZATION_CODE -> Value.AUTHORIZATION_CODE
PRODUCTION_TOKEN -> Value.PRODUCTION_TOKEN
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
AUTHORIZATION_CODE -> Known.AUTHORIZATION_CODE
PRODUCTION_TOKEN -> Known.PRODUCTION_TOKEN
else -> throw IncreaseInvalidDataException("Unknown GrantType: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy