com.lithic.api.services.blocking.FinancialAccountServiceImpl.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.
// File generated from our OpenAPI spec by Stainless.
package com.lithic.api.services.blocking
import com.lithic.api.core.ClientOptions
import com.lithic.api.core.RequestOptions
import com.lithic.api.core.http.HttpMethod
import com.lithic.api.core.http.HttpRequest
import com.lithic.api.core.http.HttpResponse.Handler
import com.lithic.api.errors.LithicError
import com.lithic.api.models.FinancialAccount
import com.lithic.api.models.FinancialAccountCreateParams
import com.lithic.api.models.FinancialAccountListPage
import com.lithic.api.models.FinancialAccountListParams
import com.lithic.api.models.FinancialAccountRetrieveParams
import com.lithic.api.models.FinancialAccountUpdateParams
import com.lithic.api.services.blocking.financialAccounts.BalanceService
import com.lithic.api.services.blocking.financialAccounts.BalanceServiceImpl
import com.lithic.api.services.blocking.financialAccounts.CreditConfigurationService
import com.lithic.api.services.blocking.financialAccounts.CreditConfigurationServiceImpl
import com.lithic.api.services.blocking.financialAccounts.FinancialTransactionService
import com.lithic.api.services.blocking.financialAccounts.FinancialTransactionServiceImpl
import com.lithic.api.services.blocking.financialAccounts.LoanTapeService
import com.lithic.api.services.blocking.financialAccounts.LoanTapeServiceImpl
import com.lithic.api.services.blocking.financialAccounts.StatementService
import com.lithic.api.services.blocking.financialAccounts.StatementServiceImpl
import com.lithic.api.services.errorHandler
import com.lithic.api.services.json
import com.lithic.api.services.jsonHandler
import com.lithic.api.services.withErrorHandler
class FinancialAccountServiceImpl
constructor(
private val clientOptions: ClientOptions,
) : FinancialAccountService {
private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper)
private val balances: BalanceService by lazy { BalanceServiceImpl(clientOptions) }
private val financialTransactions: FinancialTransactionService by lazy {
FinancialTransactionServiceImpl(clientOptions)
}
private val creditConfiguration: CreditConfigurationService by lazy {
CreditConfigurationServiceImpl(clientOptions)
}
private val statements: StatementService by lazy { StatementServiceImpl(clientOptions) }
private val loanTapes: LoanTapeService by lazy { LoanTapeServiceImpl(clientOptions) }
override fun balances(): BalanceService = balances
override fun financialTransactions(): FinancialTransactionService = financialTransactions
override fun creditConfiguration(): CreditConfigurationService = creditConfiguration
override fun statements(): StatementService = statements
override fun loanTapes(): LoanTapeService = loanTapes
private val createHandler: Handler =
jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler)
/** Create a new financial account */
override fun create(
params: FinancialAccountCreateParams,
requestOptions: RequestOptions
): FinancialAccount {
val request =
HttpRequest.builder()
.method(HttpMethod.POST)
.addPathSegments("v1", "financial_accounts")
.putAllQueryParams(clientOptions.queryParams)
.putAllQueryParams(params.getQueryParams())
.putAllHeaders(clientOptions.headers)
.putAllHeaders(params.getHeaders())
.body(json(clientOptions.jsonMapper, params.getBody()))
.build()
return clientOptions.httpClient.execute(request, requestOptions).let { response ->
response
.use { createHandler.handle(it) }
.apply {
if (requestOptions.responseValidation ?: clientOptions.responseValidation) {
validate()
}
}
}
}
private val retrieveHandler: Handler =
jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler)
/** Get a financial account */
override fun retrieve(
params: FinancialAccountRetrieveParams,
requestOptions: RequestOptions
): FinancialAccount {
val request =
HttpRequest.builder()
.method(HttpMethod.GET)
.addPathSegments("v1", "financial_accounts", params.getPathParam(0))
.putAllQueryParams(clientOptions.queryParams)
.putAllQueryParams(params.getQueryParams())
.putAllHeaders(clientOptions.headers)
.putAllHeaders(params.getHeaders())
.build()
return clientOptions.httpClient.execute(request, requestOptions).let { response ->
response
.use { retrieveHandler.handle(it) }
.apply {
if (requestOptions.responseValidation ?: clientOptions.responseValidation) {
validate()
}
}
}
}
private val updateHandler: Handler =
jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler)
/** Update a financial account */
override fun update(
params: FinancialAccountUpdateParams,
requestOptions: RequestOptions
): FinancialAccount {
val request =
HttpRequest.builder()
.method(HttpMethod.PATCH)
.addPathSegments("v1", "financial_accounts", params.getPathParam(0))
.putAllQueryParams(clientOptions.queryParams)
.putAllQueryParams(params.getQueryParams())
.putAllHeaders(clientOptions.headers)
.putAllHeaders(params.getHeaders())
.body(json(clientOptions.jsonMapper, params.getBody()))
.build()
return clientOptions.httpClient.execute(request, requestOptions).let { response ->
response
.use { updateHandler.handle(it) }
.apply {
if (requestOptions.responseValidation ?: clientOptions.responseValidation) {
validate()
}
}
}
}
private val listHandler: Handler =
jsonHandler(clientOptions.jsonMapper)
.withErrorHandler(errorHandler)
/** Retrieve information on your financial accounts including routing and account number. */
override fun list(
params: FinancialAccountListParams,
requestOptions: RequestOptions
): FinancialAccountListPage {
val request =
HttpRequest.builder()
.method(HttpMethod.GET)
.addPathSegments("v1", "financial_accounts")
.putAllQueryParams(clientOptions.queryParams)
.putAllQueryParams(params.getQueryParams())
.putAllHeaders(clientOptions.headers)
.putAllHeaders(params.getHeaders())
.build()
return clientOptions.httpClient.execute(request, requestOptions).let { response ->
response
.use { listHandler.handle(it) }
.apply {
if (requestOptions.responseValidation ?: clientOptions.responseValidation) {
validate()
}
}
.let { FinancialAccountListPage.of(this, params, it) }
}
}
}