com.stripe.model.treasury.FinancialAccount Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.model.treasury;
import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.model.HasId;
import com.stripe.model.MetadataStore;
import com.stripe.model.StripeObject;
import com.stripe.net.ApiRequest;
import com.stripe.net.ApiRequestParams;
import com.stripe.net.ApiResource;
import com.stripe.net.BaseAddress;
import com.stripe.net.RequestOptions;
import com.stripe.net.StripeResponseGetter;
import com.stripe.param.treasury.FinancialAccountCreateParams;
import com.stripe.param.treasury.FinancialAccountListParams;
import com.stripe.param.treasury.FinancialAccountRetrieveFeaturesParams;
import com.stripe.param.treasury.FinancialAccountRetrieveParams;
import com.stripe.param.treasury.FinancialAccountUpdateFeaturesParams;
import com.stripe.param.treasury.FinancialAccountUpdateParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;
/**
* Stripe Treasury provides users with a container for money called a FinancialAccount that is
* separate from their Payments balance. FinancialAccounts serve as the source and destination of
* Treasury’s money movement APIs.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class FinancialAccount extends ApiResource
implements HasId, MetadataStore {
/** The array of paths to active Features in the Features hash. */
@SerializedName("active_features")
List activeFeatures;
/** Balance information for the FinancialAccount. */
@SerializedName("balance")
Balance balance;
/**
* Two-letter country code (ISO 3166-1
* alpha-2).
*/
@SerializedName("country")
String country;
/** Time at which the object was created. Measured in seconds since the Unix epoch. */
@SerializedName("created")
Long created;
/**
* Encodes whether a FinancialAccount has access to a particular Feature, with a {@code status}
* enum and associated {@code status_details}. Stripe or the platform can control Features via the
* requested field.
*/
@SerializedName("features")
FinancialAccountFeatures features;
/** The set of credentials that resolve to a FinancialAccount. */
@SerializedName("financial_addresses")
List financialAddresses;
/** Unique identifier for the object. */
@Getter(onMethod_ = {@Override})
@SerializedName("id")
String id;
/**
* Has the value {@code true} if the object exists in live mode or the value {@code false} if the
* object exists in test mode.
*/
@SerializedName("livemode")
Boolean livemode;
/**
* Set of key-value pairs that you can attach
* to an object. This can be useful for storing additional information about the object in a
* structured format.
*/
@Getter(onMethod_ = {@Override})
@SerializedName("metadata")
Map metadata;
/**
* String representing the object's type. Objects of the same type share the same value.
*
* Equal to {@code treasury.financial_account}.
*/
@SerializedName("object")
String object;
/** The array of paths to pending Features in the Features hash. */
@SerializedName("pending_features")
List pendingFeatures;
/** The set of functionalities that the platform can restrict on the FinancialAccount. */
@SerializedName("platform_restrictions")
PlatformRestrictions platformRestrictions;
/** The array of paths to restricted Features in the Features hash. */
@SerializedName("restricted_features")
List restrictedFeatures;
/**
* Status of this FinancialAccount.
*
* One of {@code closed}, or {@code open}.
*/
@SerializedName("status")
String status;
@SerializedName("status_details")
StatusDetails statusDetails;
/**
* The currencies the FinancialAccount can hold a balance in. Three-letter ISO currency code, in lowercase.
*/
@SerializedName("supported_currencies")
List supportedCurrencies;
/**
* Creates a new FinancialAccount. For now, each connected account can only have one
* FinancialAccount.
*/
public static FinancialAccount create(Map params) throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates a new FinancialAccount. For now, each connected account can only have one
* FinancialAccount.
*/
public static FinancialAccount create(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/treasury/financial_accounts";
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getGlobalResponseGetter().request(request, FinancialAccount.class);
}
/**
* Creates a new FinancialAccount. For now, each connected account can only have one
* FinancialAccount.
*/
public static FinancialAccount create(FinancialAccountCreateParams params)
throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates a new FinancialAccount. For now, each connected account can only have one
* FinancialAccount.
*/
public static FinancialAccount create(FinancialAccountCreateParams params, RequestOptions options)
throws StripeException {
String path = "/v1/treasury/financial_accounts";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, FinancialAccount.class);
}
/** Returns a list of FinancialAccounts. */
public static FinancialAccountCollection list(Map params) throws StripeException {
return list(params, (RequestOptions) null);
}
/** Returns a list of FinancialAccounts. */
public static FinancialAccountCollection list(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/treasury/financial_accounts";
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getGlobalResponseGetter().request(request, FinancialAccountCollection.class);
}
/** Returns a list of FinancialAccounts. */
public static FinancialAccountCollection list(FinancialAccountListParams params)
throws StripeException {
return list(params, (RequestOptions) null);
}
/** Returns a list of FinancialAccounts. */
public static FinancialAccountCollection list(
FinancialAccountListParams params, RequestOptions options) throws StripeException {
String path = "/v1/treasury/financial_accounts";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, FinancialAccountCollection.class);
}
/** Retrieves the details of a FinancialAccount. */
public static FinancialAccount retrieve(String financialAccount) throws StripeException {
return retrieve(financialAccount, (Map) null, (RequestOptions) null);
}
/** Retrieves the details of a FinancialAccount. */
public static FinancialAccount retrieve(String financialAccount, RequestOptions options)
throws StripeException {
return retrieve(financialAccount, (Map) null, options);
}
/** Retrieves the details of a FinancialAccount. */
public static FinancialAccount retrieve(
String financialAccount, Map params, RequestOptions options)
throws StripeException {
String path =
String.format(
"/v1/treasury/financial_accounts/%s", ApiResource.urlEncodeId(financialAccount));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getGlobalResponseGetter().request(request, FinancialAccount.class);
}
/** Retrieves the details of a FinancialAccount. */
public static FinancialAccount retrieve(
String financialAccount, FinancialAccountRetrieveParams params, RequestOptions options)
throws StripeException {
String path =
String.format(
"/v1/treasury/financial_accounts/%s", ApiResource.urlEncodeId(financialAccount));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, FinancialAccount.class);
}
/** Retrieves Features information associated with the FinancialAccount. */
public FinancialAccountFeatures retrieveFeatures() throws StripeException {
return retrieveFeatures((Map) null, (RequestOptions) null);
}
/** Retrieves Features information associated with the FinancialAccount. */
public FinancialAccountFeatures retrieveFeatures(Map params)
throws StripeException {
return retrieveFeatures(params, (RequestOptions) null);
}
/** Retrieves Features information associated with the FinancialAccount. */
public FinancialAccountFeatures retrieveFeatures(
Map params, RequestOptions options) throws StripeException {
String path =
String.format(
"/v1/treasury/financial_accounts/%s/features", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getResponseGetter().request(request, FinancialAccountFeatures.class);
}
/** Retrieves Features information associated with the FinancialAccount. */
public FinancialAccountFeatures retrieveFeatures(FinancialAccountRetrieveFeaturesParams params)
throws StripeException {
return retrieveFeatures(params, (RequestOptions) null);
}
/** Retrieves Features information associated with the FinancialAccount. */
public FinancialAccountFeatures retrieveFeatures(
FinancialAccountRetrieveFeaturesParams params, RequestOptions options)
throws StripeException {
String path =
String.format(
"/v1/treasury/financial_accounts/%s/features", ApiResource.urlEncodeId(this.getId()));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getResponseGetter().request(request, FinancialAccountFeatures.class);
}
/** Updates the details of a FinancialAccount. */
@Override
public FinancialAccount update(Map params) throws StripeException {
return update(params, (RequestOptions) null);
}
/** Updates the details of a FinancialAccount. */
@Override
public FinancialAccount update(Map params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/treasury/financial_accounts/%s", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getResponseGetter().request(request, FinancialAccount.class);
}
/** Updates the details of a FinancialAccount. */
public FinancialAccount update(FinancialAccountUpdateParams params) throws StripeException {
return update(params, (RequestOptions) null);
}
/** Updates the details of a FinancialAccount. */
public FinancialAccount update(FinancialAccountUpdateParams params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/treasury/financial_accounts/%s", ApiResource.urlEncodeId(this.getId()));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return getResponseGetter().request(request, FinancialAccount.class);
}
/** Updates the Features associated with a FinancialAccount. */
public FinancialAccountFeatures updateFeatures() throws StripeException {
return updateFeatures((Map) null, (RequestOptions) null);
}
/** Updates the Features associated with a FinancialAccount. */
public FinancialAccountFeatures updateFeatures(RequestOptions options) throws StripeException {
return updateFeatures((Map) null, options);
}
/** Updates the Features associated with a FinancialAccount. */
public FinancialAccountFeatures updateFeatures(Map params)
throws StripeException {
return updateFeatures(params, (RequestOptions) null);
}
/** Updates the Features associated with a FinancialAccount. */
public FinancialAccountFeatures updateFeatures(Map params, RequestOptions options)
throws StripeException {
String path =
String.format(
"/v1/treasury/financial_accounts/%s/features", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getResponseGetter().request(request, FinancialAccountFeatures.class);
}
/** Updates the Features associated with a FinancialAccount. */
public FinancialAccountFeatures updateFeatures(FinancialAccountUpdateFeaturesParams params)
throws StripeException {
return updateFeatures(params, (RequestOptions) null);
}
/** Updates the Features associated with a FinancialAccount. */
public FinancialAccountFeatures updateFeatures(
FinancialAccountUpdateFeaturesParams params, RequestOptions options) throws StripeException {
String path =
String.format(
"/v1/treasury/financial_accounts/%s/features", ApiResource.urlEncodeId(this.getId()));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return getResponseGetter().request(request, FinancialAccountFeatures.class);
}
/** Balance information for the FinancialAccount. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Balance extends StripeObject {
/** Funds the user can spend right now. */
@SerializedName("cash")
Map cash;
/** Funds not spendable yet, but will become available at a later time. */
@SerializedName("inbound_pending")
Map inboundPending;
/**
* Funds in the account, but not spendable because they are being held for pending outbound
* flows.
*/
@SerializedName("outbound_pending")
Map outboundPending;
}
/** FinancialAddresses contain identifying information that resolves to a FinancialAccount. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class FinancialAddress extends StripeObject {
/** ABA Records contain U.S. bank account details per the ABA format. */
@SerializedName("aba")
Aba aba;
/** The list of networks that the address supports. */
@SerializedName("supported_networks")
List supportedNetworks;
/**
* The type of financial address
*
* Equal to {@code aba}.
*/
@SerializedName("type")
String type;
/** ABA Records contain U.S. bank account details per the ABA format. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Aba extends StripeObject {
/** The name of the person or business that owns the bank account. */
@SerializedName("account_holder_name")
String accountHolderName;
/** The account number. */
@SerializedName("account_number")
String accountNumber;
/** The last four characters of the account number. */
@SerializedName("account_number_last4")
String accountNumberLast4;
/** Name of the bank. */
@SerializedName("bank_name")
String bankName;
/** Routing number for the account. */
@SerializedName("routing_number")
String routingNumber;
}
}
/** Restrictions that a Connect Platform has placed on this FinancialAccount. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class PlatformRestrictions extends StripeObject {
/**
* Restricts all inbound money movement.
*
*
One of {@code restricted}, or {@code unrestricted}.
*/
@SerializedName("inbound_flows")
String inboundFlows;
/**
* Restricts all outbound money movement.
*
*
One of {@code restricted}, or {@code unrestricted}.
*/
@SerializedName("outbound_flows")
String outboundFlows;
}
/**
* For more details about StatusDetails, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class StatusDetails extends StripeObject {
/** Details related to the closure of this FinancialAccount. */
@SerializedName("closed")
Closed closed;
/**
* For more details about Closed, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Closed extends StripeObject {
/** The array that contains reasons for a FinancialAccount closure. */
@SerializedName("reasons")
List reasons;
}
}
@Override
public void setResponseGetter(StripeResponseGetter responseGetter) {
super.setResponseGetter(responseGetter);
trySetResponseGetter(balance, responseGetter);
trySetResponseGetter(features, responseGetter);
trySetResponseGetter(platformRestrictions, responseGetter);
trySetResponseGetter(statusDetails, responseGetter);
}
}