com.tryfinch.api.models.ConnectSessionReauthenticateParams.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of finch-kotlin-core Show documentation
Show all versions of finch-kotlin-core Show documentation
The Finch HRIS API provides a unified way to connect to a multitide of HRIS
systems. The API requires an access token issued by Finch.
By default, Organization and Payroll requests use Finch's
[Data Syncs](/developer-resources/Data-Syncs). If a request is made before the
initial sync has completed, Finch will request data live from the provider. The
latency on live requests may range from seconds to minutes depending on the
provider and batch size. For automated integrations, Deductions requests (both
read and write) are always made live to the provider. Latencies may range from
seconds to minutes depending on the provider and batch size.
Employer products are specified by the product parameter, a space-separated list
of products that your application requests from an employer authenticating
through Finch Connect. Valid product names are—
- `company`: Read basic company data
- `directory`: Read company directory and organization structure
- `individual`: Read individual data, excluding income and employment data
- `employment`: Read individual employment and income data
- `payment`: Read payroll and contractor related payments by the company
- `pay_statement`: Read detailed pay statements for each individual
- `benefits`: Create and manage deductions and contributions and enrollment for
an employer
[![Open in Postman](https://run.pstmn.io/button.svg)](https://god.gw.postman.com/run-collection/21027137-08db0929-883d-4094-a9ce-dbf5a9bee4a4?action=collection%2Ffork&collection-url=entityId%3D21027137-08db0929-883d-4094-a9ce-dbf5a9bee4a4%26entityType%3Dcollection%26workspaceId%3D1edf19bc-e0a8-41e9-ac55-481a4b50790b)
The newest version!
// File generated from our OpenAPI spec by Stainless.
package com.tryfinch.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.tryfinch.api.core.Enum
import com.tryfinch.api.core.ExcludeMissing
import com.tryfinch.api.core.JsonField
import com.tryfinch.api.core.JsonValue
import com.tryfinch.api.core.NoAutoDetect
import com.tryfinch.api.core.http.Headers
import com.tryfinch.api.core.http.QueryParams
import com.tryfinch.api.core.toImmutable
import com.tryfinch.api.errors.FinchInvalidDataException
import com.tryfinch.api.models.*
import java.util.Objects
class ConnectSessionReauthenticateParams
constructor(
private val connectionId: String,
private val minutesToExpire: Long?,
private val products: List?,
private val redirectUri: String?,
private val additionalHeaders: Headers,
private val additionalQueryParams: QueryParams,
private val additionalBodyProperties: Map,
) {
fun connectionId(): String = connectionId
fun minutesToExpire(): Long? = minutesToExpire
fun products(): List? = products
fun redirectUri(): String? = redirectUri
internal fun getBody(): ConnectSessionReauthenticateBody {
return ConnectSessionReauthenticateBody(
connectionId,
minutesToExpire,
products,
redirectUri,
additionalBodyProperties,
)
}
internal fun getHeaders(): Headers = additionalHeaders
internal fun getQueryParams(): QueryParams = additionalQueryParams
@JsonDeserialize(builder = ConnectSessionReauthenticateBody.Builder::class)
@NoAutoDetect
class ConnectSessionReauthenticateBody
internal constructor(
private val connectionId: String?,
private val minutesToExpire: Long?,
private val products: List?,
private val redirectUri: String?,
private val additionalProperties: Map,
) {
/** The ID of the existing connection to reauthenticate */
@JsonProperty("connection_id") fun connectionId(): String? = connectionId
/**
* The number of minutes until the session expires (defaults to 20,160, which is 14 days)
*/
@JsonProperty("minutes_to_expire") fun minutesToExpire(): Long? = minutesToExpire
/** The products to request access to (optional for reauthentication) */
@JsonProperty("products") fun products(): List? = products
/** The URI to redirect to after the Connect flow is completed */
@JsonProperty("redirect_uri") fun redirectUri(): String? = redirectUri
@JsonAnyGetter
@ExcludeMissing
fun _additionalProperties(): Map = additionalProperties
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
class Builder {
private var connectionId: String? = null
private var minutesToExpire: Long? = null
private var products: List? = null
private var redirectUri: String? = null
private var additionalProperties: MutableMap = mutableMapOf()
internal fun from(connectSessionReauthenticateBody: ConnectSessionReauthenticateBody) =
apply {
this.connectionId = connectSessionReauthenticateBody.connectionId
this.minutesToExpire = connectSessionReauthenticateBody.minutesToExpire
this.products = connectSessionReauthenticateBody.products
this.redirectUri = connectSessionReauthenticateBody.redirectUri
additionalProperties(connectSessionReauthenticateBody.additionalProperties)
}
/** The ID of the existing connection to reauthenticate */
@JsonProperty("connection_id")
fun connectionId(connectionId: String) = apply { this.connectionId = connectionId }
/**
* The number of minutes until the session expires (defaults to 20,160, which is 14
* days)
*/
@JsonProperty("minutes_to_expire")
fun minutesToExpire(minutesToExpire: Long) = apply {
this.minutesToExpire = minutesToExpire
}
/** The products to request access to (optional for reauthentication) */
@JsonProperty("products")
fun products(products: List) = apply { this.products = products }
/** The URI to redirect to after the Connect flow is completed */
@JsonProperty("redirect_uri")
fun redirectUri(redirectUri: String) = apply { this.redirectUri = redirectUri }
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(): ConnectSessionReauthenticateBody =
ConnectSessionReauthenticateBody(
checkNotNull(connectionId) { "`connectionId` is required but was not set" },
minutesToExpire,
products?.toImmutable(),
redirectUri,
additionalProperties.toImmutable(),
)
}
override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}
return /* spotless:off */ other is ConnectSessionReauthenticateBody && connectionId == other.connectionId && minutesToExpire == other.minutesToExpire && products == other.products && redirectUri == other.redirectUri && additionalProperties == other.additionalProperties /* spotless:on */
}
/* spotless:off */
private val hashCode: Int by lazy { Objects.hash(connectionId, minutesToExpire, products, redirectUri, additionalProperties) }
/* spotless:on */
override fun hashCode(): Int = hashCode
override fun toString() =
"ConnectSessionReauthenticateBody{connectionId=$connectionId, minutesToExpire=$minutesToExpire, products=$products, redirectUri=$redirectUri, 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 ConnectSessionReauthenticateParams && connectionId == other.connectionId && minutesToExpire == other.minutesToExpire && products == other.products && redirectUri == other.redirectUri && additionalHeaders == other.additionalHeaders && additionalQueryParams == other.additionalQueryParams && additionalBodyProperties == other.additionalBodyProperties /* spotless:on */
}
override fun hashCode(): Int = /* spotless:off */ Objects.hash(connectionId, minutesToExpire, products, redirectUri, additionalHeaders, additionalQueryParams, additionalBodyProperties) /* spotless:on */
override fun toString() =
"ConnectSessionReauthenticateParams{connectionId=$connectionId, minutesToExpire=$minutesToExpire, products=$products, redirectUri=$redirectUri, additionalHeaders=$additionalHeaders, additionalQueryParams=$additionalQueryParams, additionalBodyProperties=$additionalBodyProperties}"
fun toBuilder() = Builder().from(this)
companion object {
fun builder() = Builder()
}
@NoAutoDetect
class Builder {
private var connectionId: String? = null
private var minutesToExpire: Long? = null
private var products: MutableList = mutableListOf()
private var redirectUri: String? = null
private var additionalHeaders: Headers.Builder = Headers.builder()
private var additionalQueryParams: QueryParams.Builder = QueryParams.builder()
private var additionalBodyProperties: MutableMap = mutableMapOf()
internal fun from(connectSessionReauthenticateParams: ConnectSessionReauthenticateParams) =
apply {
this.connectionId = connectSessionReauthenticateParams.connectionId
this.minutesToExpire = connectSessionReauthenticateParams.minutesToExpire
this.products(connectSessionReauthenticateParams.products ?: listOf())
this.redirectUri = connectSessionReauthenticateParams.redirectUri
additionalHeaders(connectSessionReauthenticateParams.additionalHeaders)
additionalQueryParams(connectSessionReauthenticateParams.additionalQueryParams)
additionalBodyProperties(
connectSessionReauthenticateParams.additionalBodyProperties
)
}
/** The ID of the existing connection to reauthenticate */
fun connectionId(connectionId: String) = apply { this.connectionId = connectionId }
/**
* The number of minutes until the session expires (defaults to 20,160, which is 14 days)
*/
fun minutesToExpire(minutesToExpire: Long) = apply {
this.minutesToExpire = minutesToExpire
}
/** The products to request access to (optional for reauthentication) */
fun products(products: List) = apply {
this.products.clear()
this.products.addAll(products)
}
/** The products to request access to (optional for reauthentication) */
fun addProduct(product: ConnectProducts) = apply { this.products.add(product) }
/** The URI to redirect to after the Connect flow is completed */
fun redirectUri(redirectUri: String) = apply { this.redirectUri = redirectUri }
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(): ConnectSessionReauthenticateParams =
ConnectSessionReauthenticateParams(
checkNotNull(connectionId) { "`connectionId` is required but was not set" },
minutesToExpire,
if (products.size == 0) null else products.toImmutable(),
redirectUri,
additionalHeaders.build(),
additionalQueryParams.build(),
additionalBodyProperties.toImmutable(),
)
}
class ConnectProducts
@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 ConnectProducts && value == other.value /* spotless:on */
}
override fun hashCode() = value.hashCode()
override fun toString() = value.toString()
companion object {
val COMPANY = ConnectProducts(JsonField.of("company"))
val DIRECTORY = ConnectProducts(JsonField.of("directory"))
val INDIVIDUAL = ConnectProducts(JsonField.of("individual"))
val EMPLOYMENT = ConnectProducts(JsonField.of("employment"))
val PAYMENT = ConnectProducts(JsonField.of("payment"))
val PAY_STATEMENT = ConnectProducts(JsonField.of("pay_statement"))
val BENEFITS = ConnectProducts(JsonField.of("benefits"))
val SSN = ConnectProducts(JsonField.of("ssn"))
fun of(value: String) = ConnectProducts(JsonField.of(value))
}
enum class Known {
COMPANY,
DIRECTORY,
INDIVIDUAL,
EMPLOYMENT,
PAYMENT,
PAY_STATEMENT,
BENEFITS,
SSN,
}
enum class Value {
COMPANY,
DIRECTORY,
INDIVIDUAL,
EMPLOYMENT,
PAYMENT,
PAY_STATEMENT,
BENEFITS,
SSN,
_UNKNOWN,
}
fun value(): Value =
when (this) {
COMPANY -> Value.COMPANY
DIRECTORY -> Value.DIRECTORY
INDIVIDUAL -> Value.INDIVIDUAL
EMPLOYMENT -> Value.EMPLOYMENT
PAYMENT -> Value.PAYMENT
PAY_STATEMENT -> Value.PAY_STATEMENT
BENEFITS -> Value.BENEFITS
SSN -> Value.SSN
else -> Value._UNKNOWN
}
fun known(): Known =
when (this) {
COMPANY -> Known.COMPANY
DIRECTORY -> Known.DIRECTORY
INDIVIDUAL -> Known.INDIVIDUAL
EMPLOYMENT -> Known.EMPLOYMENT
PAYMENT -> Known.PAYMENT
PAY_STATEMENT -> Known.PAY_STATEMENT
BENEFITS -> Known.BENEFITS
SSN -> Known.SSN
else -> throw FinchInvalidDataException("Unknown ConnectProducts: $value")
}
fun asString(): String = _value().asStringOrThrow()
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy