com.stripe.param.AccountCreateParams Maven / Gradle / Ivy
// Generated by delombok at Tue Apr 16 18:06:13 PDT 2019
// Generated by com.stripe.generator.entity.SdkBuilder
package com.stripe.param;
import com.google.gson.annotations.SerializedName;
import com.stripe.net.ApiRequestParams;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class AccountCreateParams extends ApiRequestParams {
/**
* An [account token](https://stripe.com/docs/api#create_account_token), used to securely provide
* details to the account.
*/
@SerializedName("account_token")
String accountToken;
/**
* Non-essential business information about the account.
*/
@SerializedName("business_profile")
BusinessProfile businessProfile;
/**
* The business type. Can be `individual` or `company`.
*/
@SerializedName("business_type")
String businessType;
/**
* Information about the company or business. This field is null unless `business_type` is set to
* `company`.
*/
@SerializedName("company")
Company company;
/**
* The country in which the account holder resides, or in which the business is legally
* established. This should be an ISO 3166-1 alpha-2 country code. For example, if you are in the
* United States and the business for which you're creating an account is legally represented in
* Canada, you would use `CA` as the country for the account being created.
*/
@SerializedName("country")
String country;
/**
* Three-letter ISO currency code representing the default currency for the account. This must be
* a currency that [Stripe supports in the account's country](https://stripe.com/docs/payouts).
*/
@SerializedName("default_currency")
String defaultCurrency;
/**
* The email address of the account holder. For Custom accounts, this is only to make the account
* easier to identify to you: Stripe will never directly email your users.
*/
@SerializedName("email")
String email;
/**
* Specifies which fields in the response should be expanded.
*/
@SerializedName("expand")
List expand;
/**
* A card or bank account to attach to the account. You can provide either a token, like the ones
* returned by [Stripe.js](https://stripe.com/docs/stripe.js), or a dictionary, as documented in
* the `external_account` parameter for [bank
* account](https://stripe.com/docs/api#account_create_bank_account) creation.
*
* By default, providing an external account sets it as the new default external account for its
* currency, and deletes the old default if one exists. To add additional external accounts
* without replacing the existing default for the currency, use the bank account or card creation
* API.
*/
@SerializedName("external_account")
String externalAccount;
/**
* Information about the person represented by the account. This field is null unless
* `business_type` is set to `individual`.
*/
@SerializedName("individual")
Individual individual;
/**
* A set of key-value pairs that you can attach to an `Account` object. This can be useful for
* storing additional information about the account in a structured format.
*/
@SerializedName("metadata")
Map metadata;
/**
* The set of capabilities you want to unlock for this account (US only). Each capability will be
* inactive until you have provided its specific requirements and Stripe has verified them. An
* account may have some of its requested capabilities be active and some be inactive.
*/
@SerializedName("requested_capabilities")
List requestedCapabilities;
/**
* Options for customizing how the account functions within Stripe.
*/
@SerializedName("settings")
Settings settings;
/**
* Details on the account's acceptance of the [Stripe Services
* Agreement](https://stripe.com/docs/connect/updating-accounts#tos-acceptance).
*/
@SerializedName("tos_acceptance")
TosAcceptance tosAcceptance;
/**
* The type of Stripe account to create. Currently must be `custom`, as only [Custom
* accounts](https://stripe.com/docs/connect/custom-accounts) may be created via the API.
*/
@SerializedName("type")
Type type;
private AccountCreateParams(String accountToken, BusinessProfile businessProfile, String businessType, Company company, String country, String defaultCurrency, String email, List expand, String externalAccount, Individual individual, Map metadata, List requestedCapabilities, Settings settings, TosAcceptance tosAcceptance, Type type) {
this.accountToken = accountToken;
this.businessProfile = businessProfile;
this.businessType = businessType;
this.company = company;
this.country = country;
this.defaultCurrency = defaultCurrency;
this.email = email;
this.expand = expand;
this.externalAccount = externalAccount;
this.individual = individual;
this.metadata = metadata;
this.requestedCapabilities = requestedCapabilities;
this.settings = settings;
this.tosAcceptance = tosAcceptance;
this.type = type;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Builder();
}
public static class Builder {
private String accountToken;
private BusinessProfile businessProfile;
private String businessType;
private Company company;
private String country;
private String defaultCurrency;
private String email;
private List expand;
private String externalAccount;
private Individual individual;
private Map metadata;
private List requestedCapabilities;
private Settings settings;
private TosAcceptance tosAcceptance;
private Type type;
/**
* Finalize and obtain parameter instance from this builder.
*/
public AccountCreateParams build() {
return new AccountCreateParams(this.accountToken, this.businessProfile, this.businessType, this.company, this.country, this.defaultCurrency, this.email, this.expand, this.externalAccount, this.individual, this.metadata, this.requestedCapabilities, this.settings, this.tosAcceptance, this.type);
}
/**
* An [account token](https://stripe.com/docs/api#create_account_token), used to securely
* provide details to the account.
*/
public Builder setAccountToken(String accountToken) {
this.accountToken = accountToken;
return this;
}
/**
* Non-essential business information about the account.
*/
public Builder setBusinessProfile(BusinessProfile businessProfile) {
this.businessProfile = businessProfile;
return this;
}
/**
* The business type. Can be `individual` or `company`.
*/
public Builder setBusinessType(String businessType) {
this.businessType = businessType;
return this;
}
/**
* Information about the company or business. This field is null unless `business_type` is set
* to `company`.
*/
public Builder setCompany(Company company) {
this.company = company;
return this;
}
/**
* The country in which the account holder resides, or in which the business is legally
* established. This should be an ISO 3166-1 alpha-2 country code. For example, if you are in
* the United States and the business for which you're creating an account is legally
* represented in Canada, you would use `CA` as the country for the account being created.
*/
public Builder setCountry(String country) {
this.country = country;
return this;
}
/**
* Three-letter ISO currency code representing the default currency for the account. This must
* be a currency that [Stripe supports in the account's
* country](https://stripe.com/docs/payouts).
*/
public Builder setDefaultCurrency(String defaultCurrency) {
this.defaultCurrency = defaultCurrency;
return this;
}
/**
* The email address of the account holder. For Custom accounts, this is only to make the
* account easier to identify to you: Stripe will never directly email your users.
*/
public Builder setEmail(String email) {
this.email = email;
return this;
}
/**
* Add an element to `expand` list. A list is initialized for the first `add/addAll` call, and
* subsequent calls adds additional elements to the original list. See {@link
* AccountCreateParams#expand} for the field documentation.
*/
public Builder addExpand(String element) {
if (this.expand == null) {
this.expand = new ArrayList<>();
}
this.expand.add(element);
return this;
}
/**
* Add all elements to `expand` list. A list is initialized for the first `add/addAll` call, and
* subsequent calls adds additional elements to the original list. See {@link
* AccountCreateParams#expand} for the field documentation.
*/
public Builder addAllExpand(List elements) {
if (this.expand == null) {
this.expand = new ArrayList<>();
}
this.expand.addAll(elements);
return this;
}
/**
* A card or bank account to attach to the account. You can provide either a token, like the
* ones returned by [Stripe.js](https://stripe.com/docs/stripe.js), or a dictionary, as
* documented in the `external_account` parameter for [bank
* account](https://stripe.com/docs/api#account_create_bank_account) creation.
*
* By default, providing an external account sets it as the new default external account for its
* currency, and deletes the old default if one exists. To add additional external accounts
* without replacing the existing default for the currency, use the bank account or card
* creation API.
*/
public Builder setExternalAccount(String externalAccount) {
this.externalAccount = externalAccount;
return this;
}
/**
* Information about the person represented by the account. This field is null unless
* `business_type` is set to `individual`.
*/
public Builder setIndividual(Individual individual) {
this.individual = individual;
return this;
}
/**
* Add a key/value pair to `metadata` map. A map is initialized for the first `put/putAll` call,
* and subsequent calls add additional key/value pairs to the original map. See {@link
* AccountCreateParams#metadata} for the field documentation.
*/
public Builder putMetadata(String key, String value) {
if (this.metadata == null) {
this.metadata = new HashMap<>();
}
this.metadata.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `metadata` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original map.
* See {@link AccountCreateParams#metadata} for the field documentation.
*/
public Builder putAllMetadata(Map map) {
if (this.metadata == null) {
this.metadata = new HashMap<>();
}
this.metadata.putAll(map);
return this;
}
/**
* Add an element to `requestedCapabilities` list. A list is initialized for the first
* `add/addAll` call, and subsequent calls adds additional elements to the original list. See
* {@link AccountCreateParams#requestedCapabilities} for the field documentation.
*/
public Builder addRequestedCapability(RequestedCapability element) {
if (this.requestedCapabilities == null) {
this.requestedCapabilities = new ArrayList<>();
}
this.requestedCapabilities.add(element);
return this;
}
/**
* Add all elements to `requestedCapabilities` list. A list is initialized for the first
* `add/addAll` call, and subsequent calls adds additional elements to the original list. See
* {@link AccountCreateParams#requestedCapabilities} for the field documentation.
*/
public Builder addAllRequestedCapability(List elements) {
if (this.requestedCapabilities == null) {
this.requestedCapabilities = new ArrayList<>();
}
this.requestedCapabilities.addAll(elements);
return this;
}
/**
* Options for customizing how the account functions within Stripe.
*/
public Builder setSettings(Settings settings) {
this.settings = settings;
return this;
}
/**
* Details on the account's acceptance of the [Stripe Services
* Agreement](https://stripe.com/docs/connect/updating-accounts#tos-acceptance).
*/
public Builder setTosAcceptance(TosAcceptance tosAcceptance) {
this.tosAcceptance = tosAcceptance;
return this;
}
/**
* The type of Stripe account to create. Currently must be `custom`, as only [Custom
* accounts](https://stripe.com/docs/connect/custom-accounts) may be created via the API.
*/
public Builder setType(Type type) {
this.type = type;
return this;
}
}
public static class BusinessProfile {
/**
* The merchant category code for the account. MCCs are used to classify businesses based on the
* goods or services they provide.
*/
@SerializedName("mcc")
String mcc;
/**
* The customer-facing business name.
*/
@SerializedName("name")
String name;
/**
* Internal-only description of the product sold by, or service provided by, the business. Used
* by Stripe for risk and underwriting purposes.
*/
@SerializedName("product_description")
String productDescription;
/**
* A publicly available email address for sending support issues to.
*/
@SerializedName("support_email")
String supportEmail;
/**
* A publicly available phone number to call with support issues.
*/
@SerializedName("support_phone")
String supportPhone;
/**
* A publicly available website for handling support issues.
*/
@SerializedName("support_url")
String supportUrl;
/**
* The business's publicly available website.
*/
@SerializedName("url")
String url;
private BusinessProfile(String mcc, String name, String productDescription, String supportEmail, String supportPhone, String supportUrl, String url) {
this.mcc = mcc;
this.name = name;
this.productDescription = productDescription;
this.supportEmail = supportEmail;
this.supportPhone = supportPhone;
this.supportUrl = supportUrl;
this.url = url;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.BusinessProfile.Builder();
}
public static class Builder {
private String mcc;
private String name;
private String productDescription;
private String supportEmail;
private String supportPhone;
private String supportUrl;
private String url;
/** Finalize and obtain parameter instance from this builder. */
public BusinessProfile build() {
return new BusinessProfile(this.mcc, this.name, this.productDescription, this.supportEmail, this.supportPhone, this.supportUrl, this.url);
}
/**
* The merchant category code for the account. MCCs are used to classify businesses based on
* the goods or services they provide.
*/
public Builder setMcc(String mcc) {
this.mcc = mcc;
return this;
}
/** The customer-facing business name. */
public Builder setName(String name) {
this.name = name;
return this;
}
/**
* Internal-only description of the product sold by, or service provided by, the business.
* Used by Stripe for risk and underwriting purposes.
*/
public Builder setProductDescription(String productDescription) {
this.productDescription = productDescription;
return this;
}
/** A publicly available email address for sending support issues to. */
public Builder setSupportEmail(String supportEmail) {
this.supportEmail = supportEmail;
return this;
}
/** A publicly available phone number to call with support issues. */
public Builder setSupportPhone(String supportPhone) {
this.supportPhone = supportPhone;
return this;
}
/** A publicly available website for handling support issues. */
public Builder setSupportUrl(String supportUrl) {
this.supportUrl = supportUrl;
return this;
}
public Builder setUrl(String url) {
this.url = url;
return this;
}
}
}
/**
* The business's publicly available website.
*/
public static class Company {
/**
* The company's primary address.
*/
@SerializedName("address")
Address address;
/**
* The Kana variation of the company's primary address (Japan only).
*/
@SerializedName("address_kana")
AddressKana addressKana;
/**
* The Kanji variation of the company's primary address (Japan only).
*/
@SerializedName("address_kanji")
AddressKanji addressKanji;
/**
* Whether the company's directors have been provided. Set this Boolean to `true` after creating
* all the company's directors with [the Persons API](https://stripe.com/docs/api/persons) for
* accounts with a `relationship.director` requirement. This value is not automatically set to
* `true` after creating directors, so it needs to be updated to indicate all directors have
* been provided.
*/
@SerializedName("directors_provided")
Boolean directorsProvided;
/**
* The company's legal name.
*/
@SerializedName("name")
String name;
/**
* The Kana variation of the company's legal name (Japan only).
*/
@SerializedName("name_kana")
String nameKana;
/**
* The Kanji variation of the company's legal name (Japan only).
*/
@SerializedName("name_kanji")
String nameKanji;
/**
* Whether the company's owners have been provided. Set this Boolean to `true` after creating
* all the company's owners with [the Persons API](https://stripe.com/docs/api/persons) for
* accounts with a `relationship.owner` requirement.
*/
@SerializedName("owners_provided")
Boolean ownersProvided;
/**
* The company's phone number (used for verification).
*/
@SerializedName("phone")
String phone;
/**
* The business ID number of the company, as appropriate for the company’s country. (Examples
* are an Employer ID Number in the U.S., a Business Number in Canada, or a Company Number in
* the UK.)
*/
@SerializedName("tax_id")
String taxId;
/**
* The jurisdiction in which the `tax_id` is registered (Germany-based companies only).
*/
@SerializedName("tax_id_registrar")
String taxIdRegistrar;
/**
* The VAT number of the company.
*/
@SerializedName("vat_id")
String vatId;
private Company(Address address, AddressKana addressKana, AddressKanji addressKanji, Boolean directorsProvided, String name, String nameKana, String nameKanji, Boolean ownersProvided, String phone, String taxId, String taxIdRegistrar, String vatId) {
this.address = address;
this.addressKana = addressKana;
this.addressKanji = addressKanji;
this.directorsProvided = directorsProvided;
this.name = name;
this.nameKana = nameKana;
this.nameKanji = nameKanji;
this.ownersProvided = ownersProvided;
this.phone = phone;
this.taxId = taxId;
this.taxIdRegistrar = taxIdRegistrar;
this.vatId = vatId;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Company.Builder();
}
public static class Builder {
private Address address;
private AddressKana addressKana;
private AddressKanji addressKanji;
private Boolean directorsProvided;
private String name;
private String nameKana;
private String nameKanji;
private Boolean ownersProvided;
private String phone;
private String taxId;
private String taxIdRegistrar;
private String vatId;
/**
* Finalize and obtain parameter instance from this builder.
*/
public Company build() {
return new Company(this.address, this.addressKana, this.addressKanji, this.directorsProvided, this.name, this.nameKana, this.nameKanji, this.ownersProvided, this.phone, this.taxId, this.taxIdRegistrar, this.vatId);
}
/**
* The company's primary address.
*/
public Builder setAddress(Address address) {
this.address = address;
return this;
}
/**
* The Kana variation of the company's primary address (Japan only).
*/
public Builder setAddressKana(AddressKana addressKana) {
this.addressKana = addressKana;
return this;
}
/**
* The Kanji variation of the company's primary address (Japan only).
*/
public Builder setAddressKanji(AddressKanji addressKanji) {
this.addressKanji = addressKanji;
return this;
}
/**
* Whether the company's directors have been provided. Set this Boolean to `true` after
* creating all the company's directors with [the Persons
* API](https://stripe.com/docs/api/persons) for accounts with a `relationship.director`
* requirement. This value is not automatically set to `true` after creating directors, so it
* needs to be updated to indicate all directors have been provided.
*/
public Builder setDirectorsProvided(Boolean directorsProvided) {
this.directorsProvided = directorsProvided;
return this;
}
/**
* The company's legal name.
*/
public Builder setName(String name) {
this.name = name;
return this;
}
/**
* The Kana variation of the company's legal name (Japan only).
*/
public Builder setNameKana(String nameKana) {
this.nameKana = nameKana;
return this;
}
/**
* The Kanji variation of the company's legal name (Japan only).
*/
public Builder setNameKanji(String nameKanji) {
this.nameKanji = nameKanji;
return this;
}
/**
* Whether the company's owners have been provided. Set this Boolean to `true` after creating
* all the company's owners with [the Persons API](https://stripe.com/docs/api/persons) for
* accounts with a `relationship.owner` requirement.
*/
public Builder setOwnersProvided(Boolean ownersProvided) {
this.ownersProvided = ownersProvided;
return this;
}
/**
* The company's phone number (used for verification).
*/
public Builder setPhone(String phone) {
this.phone = phone;
return this;
}
/**
* The business ID number of the company, as appropriate for the company’s country. (Examples
* are an Employer ID Number in the U.S., a Business Number in Canada, or a Company Number in
* the UK.)
*/
public Builder setTaxId(String taxId) {
this.taxId = taxId;
return this;
}
/**
* The jurisdiction in which the `tax_id` is registered (Germany-based companies only).
*/
public Builder setTaxIdRegistrar(String taxIdRegistrar) {
this.taxIdRegistrar = taxIdRegistrar;
return this;
}
/**
* The VAT number of the company.
*/
public Builder setVatId(String vatId) {
this.vatId = vatId;
return this;
}
}
public static class Address {
/**
* City, district, suburb, town, or village.
*/
@SerializedName("city")
String city;
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
@SerializedName("country")
String country;
/**
* Address line 1 (e.g., street, PO Box, or company name).
*/
@SerializedName("line1")
String line1;
/**
* Address line 2 (e.g., apartment, suite, unit, or building).
*/
@SerializedName("line2")
String line2;
/**
* ZIP or postal code.
*/
@SerializedName("postal_code")
String postalCode;
/**
* State, county, province, or region.
*/
@SerializedName("state")
String state;
private Address(String city, String country, String line1, String line2, String postalCode, String state) {
this.city = city;
this.country = country;
this.line1 = line1;
this.line2 = line2;
this.postalCode = postalCode;
this.state = state;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Company.Address.Builder();
}
public static class Builder {
private String city;
private String country;
private String line1;
private String line2;
private String postalCode;
private String state;
/** Finalize and obtain parameter instance from this builder. */
public Address build() {
return new Address(this.city, this.country, this.line1, this.line2, this.postalCode, this.state);
}
/** City, district, suburb, town, or village. */
public Builder setCity(String city) {
this.city = city;
return this;
}
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
public Builder setCountry(String country) {
this.country = country;
return this;
}
/** Address line 1 (e.g., street, PO Box, or company name). */
public Builder setLine1(String line1) {
this.line1 = line1;
return this;
}
/** Address line 2 (e.g., apartment, suite, unit, or building). */
public Builder setLine2(String line2) {
this.line2 = line2;
return this;
}
/** ZIP or postal code. */
public Builder setPostalCode(String postalCode) {
this.postalCode = postalCode;
return this;
}
public Builder setState(String state) {
this.state = state;
return this;
}
}
}
/**
* State, county, province, or region.
*/
public static class AddressKana {
/**
* City or ward.
*/
@SerializedName("city")
String city;
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
@SerializedName("country")
String country;
/**
* Block or building number.
*/
@SerializedName("line1")
String line1;
/**
* Building details.
*/
@SerializedName("line2")
String line2;
/**
* Postal code.
*/
@SerializedName("postal_code")
String postalCode;
/**
* Prefecture.
*/
@SerializedName("state")
String state;
/**
* Town or cho-me.
*/
@SerializedName("town")
String town;
private AddressKana(String city, String country, String line1, String line2, String postalCode, String state, String town) {
this.city = city;
this.country = country;
this.line1 = line1;
this.line2 = line2;
this.postalCode = postalCode;
this.state = state;
this.town = town;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Company.AddressKana.Builder();
}
public static class Builder {
private String city;
private String country;
private String line1;
private String line2;
private String postalCode;
private String state;
private String town;
/** Finalize and obtain parameter instance from this builder. */
public AddressKana build() {
return new AddressKana(this.city, this.country, this.line1, this.line2, this.postalCode, this.state, this.town);
}
/** City or ward. */
public Builder setCity(String city) {
this.city = city;
return this;
}
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
public Builder setCountry(String country) {
this.country = country;
return this;
}
/** Block or building number. */
public Builder setLine1(String line1) {
this.line1 = line1;
return this;
}
/** Building details. */
public Builder setLine2(String line2) {
this.line2 = line2;
return this;
}
/** Postal code. */
public Builder setPostalCode(String postalCode) {
this.postalCode = postalCode;
return this;
}
/** Prefecture. */
public Builder setState(String state) {
this.state = state;
return this;
}
public Builder setTown(String town) {
this.town = town;
return this;
}
}
}
/**
* Town or cho-me.
*/
public static class AddressKanji {
/** City or ward. */
@SerializedName("city")
String city;
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
@SerializedName("country")
String country;
/** Block or building number. */
@SerializedName("line1")
String line1;
/** Building details. */
@SerializedName("line2")
String line2;
/** Postal code. */
@SerializedName("postal_code")
String postalCode;
/** Prefecture. */
@SerializedName("state")
String state;
/** Town or cho-me. */
@SerializedName("town")
String town;
private AddressKanji(String city, String country, String line1, String line2, String postalCode, String state, String town) {
this.city = city;
this.country = country;
this.line1 = line1;
this.line2 = line2;
this.postalCode = postalCode;
this.state = state;
this.town = town;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Company.AddressKanji.Builder();
}
public static class Builder {
private String city;
private String country;
private String line1;
private String line2;
private String postalCode;
private String state;
private String town;
/** Finalize and obtain parameter instance from this builder. */
public AddressKanji build() {
return new AddressKanji(this.city, this.country, this.line1, this.line2, this.postalCode, this.state, this.town);
}
/** City or ward. */
public Builder setCity(String city) {
this.city = city;
return this;
}
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
public Builder setCountry(String country) {
this.country = country;
return this;
}
/** Block or building number. */
public Builder setLine1(String line1) {
this.line1 = line1;
return this;
}
/** Building details. */
public Builder setLine2(String line2) {
this.line2 = line2;
return this;
}
/** Postal code. */
public Builder setPostalCode(String postalCode) {
this.postalCode = postalCode;
return this;
}
/** Prefecture. */
public Builder setState(String state) {
this.state = state;
return this;
}
public Builder setTown(String town) {
this.town = town;
return this;
}
}
}
}
/**
* Town or cho-me.
*/
public static class Individual {
/**
* The individual's primary address.
*/
@SerializedName("address")
Address address;
/**
* The Kana variation of the the individual's primary address (Japan only).
*/
@SerializedName("address_kana")
AddressKana addressKana;
/**
* The Kanji variation of the the individual's primary address (Japan only).
*/
@SerializedName("address_kanji")
AddressKanji addressKanji;
/**
* The individual's date of birth.
*/
@SerializedName("dob")
Dob dob;
@SerializedName("email")
String email;
/**
* The individual's first name.
*/
@SerializedName("first_name")
String firstName;
/**
* The Kana variation of the the individual's first name (Japan only).
*/
@SerializedName("first_name_kana")
String firstNameKana;
/**
* The Kanji variation of the individual's first name (Japan only).
*/
@SerializedName("first_name_kanji")
String firstNameKanji;
/**
* The individual's gender (International regulations require either "male" or "female").
*/
@SerializedName("gender")
String gender;
/**
* The government-issued ID number of the individual, as appropriate for the representative’s
* country. (Examples are a Social Security Number in the U.S., or a Social Insurance Number in
* Canada). Instead of the number itself, you can also provide a [PII token created with
* Stripe.js](https://stripe.com/docs/stripe.js#collecting-pii-data).
*/
@SerializedName("id_number")
String idNumber;
/**
* The individual's last name.
*/
@SerializedName("last_name")
String lastName;
/**
* The Kana varation of the individual's last name (Japan only).
*/
@SerializedName("last_name_kana")
String lastNameKana;
/**
* The Kanji varation of the individual's last name (Japan only).
*/
@SerializedName("last_name_kanji")
String lastNameKanji;
/**
* The individual's maiden name.
*/
@SerializedName("maiden_name")
String maidenName;
/**
* 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. Individual keys can be unset
* by posting an empty value to them. All keys can be unset by posting an empty value to
* `metadata`.
*/
@SerializedName("metadata")
Map metadata;
/**
* The individual's phone number.
*/
@SerializedName("phone")
String phone;
/**
* The last four digits of the individual's Social Security Number (U.S. only).
*/
@SerializedName("ssn_last_4")
String ssnLast4;
/**
* The individual's verification document information.
*/
@SerializedName("verification")
Verification verification;
private Individual(Address address, AddressKana addressKana, AddressKanji addressKanji, Dob dob, String email, String firstName, String firstNameKana, String firstNameKanji, String gender, String idNumber, String lastName, String lastNameKana, String lastNameKanji, String maidenName, Map metadata, String phone, String ssnLast4, Verification verification) {
this.address = address;
this.addressKana = addressKana;
this.addressKanji = addressKanji;
this.dob = dob;
this.email = email;
this.firstName = firstName;
this.firstNameKana = firstNameKana;
this.firstNameKanji = firstNameKanji;
this.gender = gender;
this.idNumber = idNumber;
this.lastName = lastName;
this.lastNameKana = lastNameKana;
this.lastNameKanji = lastNameKanji;
this.maidenName = maidenName;
this.metadata = metadata;
this.phone = phone;
this.ssnLast4 = ssnLast4;
this.verification = verification;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Individual.Builder();
}
public static class Builder {
private Address address;
private AddressKana addressKana;
private AddressKanji addressKanji;
private Dob dob;
private String email;
private String firstName;
private String firstNameKana;
private String firstNameKanji;
private String gender;
private String idNumber;
private String lastName;
private String lastNameKana;
private String lastNameKanji;
private String maidenName;
private Map metadata;
private String phone;
private String ssnLast4;
private Verification verification;
/**
* Finalize and obtain parameter instance from this builder.
*/
public Individual build() {
return new Individual(this.address, this.addressKana, this.addressKanji, this.dob, this.email, this.firstName, this.firstNameKana, this.firstNameKanji, this.gender, this.idNumber, this.lastName, this.lastNameKana, this.lastNameKanji, this.maidenName, this.metadata, this.phone, this.ssnLast4, this.verification);
}
/**
* The individual's primary address.
*/
public Builder setAddress(Address address) {
this.address = address;
return this;
}
/**
* The Kana variation of the the individual's primary address (Japan only).
*/
public Builder setAddressKana(AddressKana addressKana) {
this.addressKana = addressKana;
return this;
}
/**
* The Kanji variation of the the individual's primary address (Japan only).
*/
public Builder setAddressKanji(AddressKanji addressKanji) {
this.addressKanji = addressKanji;
return this;
}
/**
* The individual's date of birth.
*/
public Builder setDob(Dob dob) {
this.dob = dob;
return this;
}
public Builder setEmail(String email) {
this.email = email;
return this;
}
/**
* The individual's first name.
*/
public Builder setFirstName(String firstName) {
this.firstName = firstName;
return this;
}
/**
* The Kana variation of the the individual's first name (Japan only).
*/
public Builder setFirstNameKana(String firstNameKana) {
this.firstNameKana = firstNameKana;
return this;
}
/**
* The Kanji variation of the individual's first name (Japan only).
*/
public Builder setFirstNameKanji(String firstNameKanji) {
this.firstNameKanji = firstNameKanji;
return this;
}
/**
* The individual's gender (International regulations require either "male" or "female").
*/
public Builder setGender(String gender) {
this.gender = gender;
return this;
}
/**
* The government-issued ID number of the individual, as appropriate for the representative’s
* country. (Examples are a Social Security Number in the U.S., or a Social Insurance Number
* in Canada). Instead of the number itself, you can also provide a [PII token created with
* Stripe.js](https://stripe.com/docs/stripe.js#collecting-pii-data).
*/
public Builder setIdNumber(String idNumber) {
this.idNumber = idNumber;
return this;
}
/**
* The individual's last name.
*/
public Builder setLastName(String lastName) {
this.lastName = lastName;
return this;
}
/**
* The Kana varation of the individual's last name (Japan only).
*/
public Builder setLastNameKana(String lastNameKana) {
this.lastNameKana = lastNameKana;
return this;
}
/**
* The Kanji varation of the individual's last name (Japan only).
*/
public Builder setLastNameKanji(String lastNameKanji) {
this.lastNameKanji = lastNameKanji;
return this;
}
/**
* The individual's maiden name.
*/
public Builder setMaidenName(String maidenName) {
this.maidenName = maidenName;
return this;
}
/**
* Add a key/value pair to `metadata` map. A map is initialized for the first `put/putAll`
* call, and subsequent calls add additional key/value pairs to the original map. See {@link
* Individual#metadata} for the field documentation.
*/
public Builder putMetadata(String key, String value) {
if (this.metadata == null) {
this.metadata = new HashMap<>();
}
this.metadata.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `metadata` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original map.
* See {@link Individual#metadata} for the field documentation.
*/
public Builder putAllMetadata(Map map) {
if (this.metadata == null) {
this.metadata = new HashMap<>();
}
this.metadata.putAll(map);
return this;
}
/**
* The individual's phone number.
*/
public Builder setPhone(String phone) {
this.phone = phone;
return this;
}
/**
* The last four digits of the individual's Social Security Number (U.S. only).
*/
public Builder setSsnLast4(String ssnLast4) {
this.ssnLast4 = ssnLast4;
return this;
}
/**
* The individual's verification document information.
*/
public Builder setVerification(Verification verification) {
this.verification = verification;
return this;
}
}
public static class Address {
/**
* City, district, suburb, town, or village.
*/
@SerializedName("city")
String city;
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
@SerializedName("country")
String country;
/**
* Address line 1 (e.g., street, PO Box, or company name).
*/
@SerializedName("line1")
String line1;
/**
* Address line 2 (e.g., apartment, suite, unit, or building).
*/
@SerializedName("line2")
String line2;
/**
* ZIP or postal code.
*/
@SerializedName("postal_code")
String postalCode;
/**
* State, county, province, or region.
*/
@SerializedName("state")
String state;
private Address(String city, String country, String line1, String line2, String postalCode, String state) {
this.city = city;
this.country = country;
this.line1 = line1;
this.line2 = line2;
this.postalCode = postalCode;
this.state = state;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Individual.Address.Builder();
}
public static class Builder {
private String city;
private String country;
private String line1;
private String line2;
private String postalCode;
private String state;
/** Finalize and obtain parameter instance from this builder. */
public Address build() {
return new Address(this.city, this.country, this.line1, this.line2, this.postalCode, this.state);
}
/** City, district, suburb, town, or village. */
public Builder setCity(String city) {
this.city = city;
return this;
}
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
public Builder setCountry(String country) {
this.country = country;
return this;
}
/** Address line 1 (e.g., street, PO Box, or company name). */
public Builder setLine1(String line1) {
this.line1 = line1;
return this;
}
/** Address line 2 (e.g., apartment, suite, unit, or building). */
public Builder setLine2(String line2) {
this.line2 = line2;
return this;
}
/** ZIP or postal code. */
public Builder setPostalCode(String postalCode) {
this.postalCode = postalCode;
return this;
}
public Builder setState(String state) {
this.state = state;
return this;
}
}
}
/**
* State, county, province, or region.
*/
public static class AddressKana {
/**
* City or ward.
*/
@SerializedName("city")
String city;
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
@SerializedName("country")
String country;
/**
* Block or building number.
*/
@SerializedName("line1")
String line1;
/**
* Building details.
*/
@SerializedName("line2")
String line2;
/**
* Postal code.
*/
@SerializedName("postal_code")
String postalCode;
/**
* Prefecture.
*/
@SerializedName("state")
String state;
/**
* Town or cho-me.
*/
@SerializedName("town")
String town;
private AddressKana(String city, String country, String line1, String line2, String postalCode, String state, String town) {
this.city = city;
this.country = country;
this.line1 = line1;
this.line2 = line2;
this.postalCode = postalCode;
this.state = state;
this.town = town;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Individual.AddressKana.Builder();
}
public static class Builder {
private String city;
private String country;
private String line1;
private String line2;
private String postalCode;
private String state;
private String town;
/** Finalize and obtain parameter instance from this builder. */
public AddressKana build() {
return new AddressKana(this.city, this.country, this.line1, this.line2, this.postalCode, this.state, this.town);
}
/** City or ward. */
public Builder setCity(String city) {
this.city = city;
return this;
}
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
public Builder setCountry(String country) {
this.country = country;
return this;
}
/** Block or building number. */
public Builder setLine1(String line1) {
this.line1 = line1;
return this;
}
/** Building details. */
public Builder setLine2(String line2) {
this.line2 = line2;
return this;
}
/** Postal code. */
public Builder setPostalCode(String postalCode) {
this.postalCode = postalCode;
return this;
}
/** Prefecture. */
public Builder setState(String state) {
this.state = state;
return this;
}
public Builder setTown(String town) {
this.town = town;
return this;
}
}
}
/**
* Town or cho-me.
*/
public static class AddressKanji {
/**
* City or ward.
*/
@SerializedName("city")
String city;
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
@SerializedName("country")
String country;
/**
* Block or building number.
*/
@SerializedName("line1")
String line1;
/**
* Building details.
*/
@SerializedName("line2")
String line2;
/**
* Postal code.
*/
@SerializedName("postal_code")
String postalCode;
/**
* Prefecture.
*/
@SerializedName("state")
String state;
/**
* Town or cho-me.
*/
@SerializedName("town")
String town;
private AddressKanji(String city, String country, String line1, String line2, String postalCode, String state, String town) {
this.city = city;
this.country = country;
this.line1 = line1;
this.line2 = line2;
this.postalCode = postalCode;
this.state = state;
this.town = town;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Individual.AddressKanji.Builder();
}
public static class Builder {
private String city;
private String country;
private String line1;
private String line2;
private String postalCode;
private String state;
private String town;
/** Finalize and obtain parameter instance from this builder. */
public AddressKanji build() {
return new AddressKanji(this.city, this.country, this.line1, this.line2, this.postalCode, this.state, this.town);
}
/** City or ward. */
public Builder setCity(String city) {
this.city = city;
return this;
}
/**
* Two-letter country code ([ISO 3166-1
* alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)).
*/
public Builder setCountry(String country) {
this.country = country;
return this;
}
/** Block or building number. */
public Builder setLine1(String line1) {
this.line1 = line1;
return this;
}
/** Building details. */
public Builder setLine2(String line2) {
this.line2 = line2;
return this;
}
/** Postal code. */
public Builder setPostalCode(String postalCode) {
this.postalCode = postalCode;
return this;
}
/** Prefecture. */
public Builder setState(String state) {
this.state = state;
return this;
}
public Builder setTown(String town) {
this.town = town;
return this;
}
}
}
/**
* Town or cho-me.
*/
public static class Dob {
/**
* The day of birth, between 1 and 31.
*/
@SerializedName("day")
Long day;
/**
* The month of birth, between 1 and 12.
*/
@SerializedName("month")
Long month;
/**
* The four-digit year of birth.
*/
@SerializedName("year")
Long year;
private Dob(Long day, Long month, Long year) {
this.day = day;
this.month = month;
this.year = year;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Individual.Dob.Builder();
}
public static class Builder {
private Long day;
private Long month;
private Long year;
/** Finalize and obtain parameter instance from this builder. */
public Dob build() {
return new Dob(this.day, this.month, this.year);
}
/** The day of birth, between 1 and 31. */
public Builder setDay(Long day) {
this.day = day;
return this;
}
/** The month of birth, between 1 and 12. */
public Builder setMonth(Long month) {
this.month = month;
return this;
}
public Builder setYear(Long year) {
this.year = year;
return this;
}
}
}
/**
* The four-digit year of birth.
*/
public static class Verification {
/** An identifying document, either a passport or local ID card. */
@SerializedName("document")
Document document;
private Verification(Document document) {
this.document = document;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Individual.Verification.Builder();
}
public static class Builder {
private Document document;
/** Finalize and obtain parameter instance from this builder. */
public Verification build() {
return new Verification(this.document);
}
/** An identifying document, either a passport or local ID card. */
public Builder setDocument(Document document) {
this.document = document;
return this;
}
}
public static class Document {
/**
* The back of an ID returned by a [file upload](#create_file) with a `purpose` value of
* `identity_document`.
*/
@SerializedName("back")
String back;
/**
* The front of an ID returned by a [file upload](#create_file) with a `purpose` value of
* `identity_document`.
*/
@SerializedName("front")
String front;
private Document(String back, String front) {
this.back = back;
this.front = front;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Individual.Verification.Document.Builder();
}
public static class Builder {
private String back;
private String front;
/** Finalize and obtain parameter instance from this builder. */
public Document build() {
return new Document(this.back, this.front);
}
/**
* The back of an ID returned by a [file upload](#create_file) with a `purpose` value of
* `identity_document`.
*/
public Builder setBack(String back) {
this.back = back;
return this;
}
public Builder setFront(String front) {
this.front = front;
return this;
}
}
}
}
}
/**
* The front of an ID returned by a [file upload](#create_file) with a `purpose` value of
* `identity_document`.
*/
public static class Settings {
/**
* Settings used to apply the account's branding to email receipts, invoices, Checkout, and
* other products.
*/
@SerializedName("branding")
Branding branding;
/**
* Settings specific to card charging on the account.
*/
@SerializedName("card_payments")
CardPayments cardPayments;
/**
* Settings that apply across payment methods for charging on the account.
*/
@SerializedName("payments")
Payments payments;
/**
* Settings specific to the account's payouts.
*/
@SerializedName("payouts")
Payouts payouts;
private Settings(Branding branding, CardPayments cardPayments, Payments payments, Payouts payouts) {
this.branding = branding;
this.cardPayments = cardPayments;
this.payments = payments;
this.payouts = payouts;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Settings.Builder();
}
public static class Builder {
private Branding branding;
private CardPayments cardPayments;
private Payments payments;
private Payouts payouts;
/**
* Finalize and obtain parameter instance from this builder.
*/
public Settings build() {
return new Settings(this.branding, this.cardPayments, this.payments, this.payouts);
}
/**
* Settings used to apply the account's branding to email receipts, invoices, Checkout, and
* other products.
*/
public Builder setBranding(Branding branding) {
this.branding = branding;
return this;
}
/**
* Settings specific to card charging on the account.
*/
public Builder setCardPayments(CardPayments cardPayments) {
this.cardPayments = cardPayments;
return this;
}
/**
* Settings that apply across payment methods for charging on the account.
*/
public Builder setPayments(Payments payments) {
this.payments = payments;
return this;
}
/**
* Settings specific to the account's payouts.
*/
public Builder setPayouts(Payouts payouts) {
this.payouts = payouts;
return this;
}
}
public static class Branding {
/**
* (ID of a [file upload](https://stripe.com/docs/guides/file-upload)) An icon for the
* account. Must be square and at least 128px x 128px.
*/
@SerializedName("icon")
String icon;
/**
* (ID of a [file upload](https://stripe.com/docs/guides/file-upload)) A logo for the account
* that will be used in Checkout instead of the icon and without the account's name next to it
* if provided. Must be at least 128px x 128px.
*/
@SerializedName("logo")
String logo;
/**
* A CSS hex color value representing the primary branding color for this account.
*/
@SerializedName("primary_color")
String primaryColor;
private Branding(String icon, String logo, String primaryColor) {
this.icon = icon;
this.logo = logo;
this.primaryColor = primaryColor;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Settings.Branding.Builder();
}
public static class Builder {
private String icon;
private String logo;
private String primaryColor;
/** Finalize and obtain parameter instance from this builder. */
public Branding build() {
return new Branding(this.icon, this.logo, this.primaryColor);
}
/**
* (ID of a [file upload](https://stripe.com/docs/guides/file-upload)) An icon for the
* account. Must be square and at least 128px x 128px.
*/
public Builder setIcon(String icon) {
this.icon = icon;
return this;
}
/**
* (ID of a [file upload](https://stripe.com/docs/guides/file-upload)) A logo for the
* account that will be used in Checkout instead of the icon and without the account's name
* next to it if provided. Must be at least 128px x 128px.
*/
public Builder setLogo(String logo) {
this.logo = logo;
return this;
}
public Builder setPrimaryColor(String primaryColor) {
this.primaryColor = primaryColor;
return this;
}
}
}
/**
* A CSS hex color value representing the primary branding color for this account.
*/
public static class CardPayments {
/**
* Automatically declines certain charge types regardless of whether the card issuer accepted
* or declined the charge.
*/
@SerializedName("decline_on")
DeclineOn declineOn;
/**
* The default text that appears on credit card statements when a charge is made. This field
* prefixes any dynamic `statement_descriptor` specified on the charge.
* `statement_descriptor_prefix` is useful for maximizing descriptor space for the dynamic
* portion.
*/
@SerializedName("statement_descriptor_prefix")
String statementDescriptorPrefix;
private CardPayments(DeclineOn declineOn, String statementDescriptorPrefix) {
this.declineOn = declineOn;
this.statementDescriptorPrefix = statementDescriptorPrefix;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Settings.CardPayments.Builder();
}
public static class Builder {
private DeclineOn declineOn;
private String statementDescriptorPrefix;
/**
* Finalize and obtain parameter instance from this builder.
*/
public CardPayments build() {
return new CardPayments(this.declineOn, this.statementDescriptorPrefix);
}
/**
* Automatically declines certain charge types regardless of whether the card issuer
* accepted or declined the charge.
*/
public Builder setDeclineOn(DeclineOn declineOn) {
this.declineOn = declineOn;
return this;
}
/**
* The default text that appears on credit card statements when a charge is made. This field
* prefixes any dynamic `statement_descriptor` specified on the charge.
* `statement_descriptor_prefix` is useful for maximizing descriptor space for the dynamic
* portion.
*/
public Builder setStatementDescriptorPrefix(String statementDescriptorPrefix) {
this.statementDescriptorPrefix = statementDescriptorPrefix;
return this;
}
}
public static class DeclineOn {
/**
* Whether Stripe automatically declines charges with an incorrect ZIP or postal code. This
* setting only applies when a ZIP or postal code is provided and they fail bank
* verification.
*/
@SerializedName("avs_failure")
Boolean avsFailure;
/**
* Whether Stripe automatically declines charges with an incorrect CVC. This setting only
* applies when a CVC is provided and it fails bank verification.
*/
@SerializedName("cvc_failure")
Boolean cvcFailure;
private DeclineOn(Boolean avsFailure, Boolean cvcFailure) {
this.avsFailure = avsFailure;
this.cvcFailure = cvcFailure;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Settings.CardPayments.DeclineOn.Builder();
}
public static class Builder {
private Boolean avsFailure;
private Boolean cvcFailure;
/** Finalize and obtain parameter instance from this builder. */
public DeclineOn build() {
return new DeclineOn(this.avsFailure, this.cvcFailure);
}
/**
* Whether Stripe automatically declines charges with an incorrect ZIP or postal code.
* This setting only applies when a ZIP or postal code is provided and they fail bank
* verification.
*/
public Builder setAvsFailure(Boolean avsFailure) {
this.avsFailure = avsFailure;
return this;
}
public Builder setCvcFailure(Boolean cvcFailure) {
this.cvcFailure = cvcFailure;
return this;
}
}
}
}
/**
* Whether Stripe automatically declines charges with an incorrect CVC. This setting only
* applies when a CVC is provided and it fails bank verification.
*/
public static class Payments {
/**
* The default text that appears on credit card statements when a charge is made. This field
* prefixes any dynamic `statement_descriptor` specified on the charge.
*/
@SerializedName("statement_descriptor")
String statementDescriptor;
private Payments(String statementDescriptor) {
this.statementDescriptor = statementDescriptor;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Settings.Payments.Builder();
}
public static class Builder {
private String statementDescriptor;
/** Finalize and obtain parameter instance from this builder. */
public Payments build() {
return new Payments(this.statementDescriptor);
}
public Builder setStatementDescriptor(String statementDescriptor) {
this.statementDescriptor = statementDescriptor;
return this;
}
}
}
/**
* The default text that appears on credit card statements when a charge is made. This field
* prefixes any dynamic `statement_descriptor` specified on the charge.
*/
public static class Payouts {
/**
* A Boolean indicating whether Stripe should try to reclaim negative balances from an
* attached bank account. For details, see [Understanding Connect Account
* Balances](https://stripe.com/docs/connect/account-balances).
*/
@SerializedName("debit_negative_balances")
Boolean debitNegativeBalances;
/**
* Details on when funds from charges are available, and when they are paid out to an external
* account. For details, see our [Setting Bank and Debit Card
* Payouts](https://stripe.com/docs/connect/bank-transfers#payout-information) documentation.
*/
@SerializedName("schedule")
Schedule schedule;
/**
* The text that appears on the bank account statement for payouts. If not set, this defaults
* to the platform's bank descriptor as set in the Dashboard.
*/
@SerializedName("statement_descriptor")
String statementDescriptor;
private Payouts(Boolean debitNegativeBalances, Schedule schedule, String statementDescriptor) {
this.debitNegativeBalances = debitNegativeBalances;
this.schedule = schedule;
this.statementDescriptor = statementDescriptor;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Settings.Payouts.Builder();
}
public static class Builder {
private Boolean debitNegativeBalances;
private Schedule schedule;
private String statementDescriptor;
/** Finalize and obtain parameter instance from this builder. */
public Payouts build() {
return new Payouts(this.debitNegativeBalances, this.schedule, this.statementDescriptor);
}
/**
* A Boolean indicating whether Stripe should try to reclaim negative balances from an
* attached bank account. For details, see [Understanding Connect Account
* Balances](https://stripe.com/docs/connect/account-balances).
*/
public Builder setDebitNegativeBalances(Boolean debitNegativeBalances) {
this.debitNegativeBalances = debitNegativeBalances;
return this;
}
/**
* Details on when funds from charges are available, and when they are paid out to an
* external account. For details, see our [Setting Bank and Debit Card
* Payouts](https://stripe.com/docs/connect/bank-transfers#payout-information)
* documentation.
*/
public Builder setSchedule(Schedule schedule) {
this.schedule = schedule;
return this;
}
/**
* The text that appears on the bank account statement for payouts. If not set, this
* defaults to the platform's bank descriptor as set in the Dashboard.
*/
public Builder setStatementDescriptor(String statementDescriptor) {
this.statementDescriptor = statementDescriptor;
return this;
}
}
public static class Schedule {
/**
* The number of days charge funds are held before being paid out. May also be set to
* `minimum`, representing the lowest available value for the account country. Default is
* `minimum`. The `delay_days` parameter does not apply when the `interval` is `manual`.
*/
@SerializedName("delay_days")
Object delayDays;
/**
* How frequently available funds are paid out. One of: `daily`, `manual`, `weekly`, or
* `monthly`. Default is `daily`.
*/
@SerializedName("interval")
Interval interval;
/**
* The day of the month when available funds are paid out. Required and applicable only if
* `interval` is `monthly`.
*/
@SerializedName("monthly_anchor")
Long monthlyAnchor;
/**
* The day of the week when available funds are paid out, specified as `monday`, `tuesday`,
* etc. (required and applicable only if `interval` is `weekly`.)
*/
@SerializedName("weekly_anchor")
WeeklyAnchor weeklyAnchor;
private Schedule(Object delayDays, Interval interval, Long monthlyAnchor, WeeklyAnchor weeklyAnchor) {
this.delayDays = delayDays;
this.interval = interval;
this.monthlyAnchor = monthlyAnchor;
this.weeklyAnchor = weeklyAnchor;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.Settings.Payouts.Schedule.Builder();
}
public static class Builder {
private Object delayDays;
private Interval interval;
private Long monthlyAnchor;
private WeeklyAnchor weeklyAnchor;
/** Finalize and obtain parameter instance from this builder. */
public Schedule build() {
return new Schedule(this.delayDays, this.interval, this.monthlyAnchor, this.weeklyAnchor);
}
/**
* The number of days charge funds are held before being paid out. May also be set to
* `minimum`, representing the lowest available value for the account country. Default is
* `minimum`. The `delay_days` parameter does not apply when the `interval` is `manual`.
*/
public Builder setDelayDays(DelayDays delayDays) {
this.delayDays = delayDays;
return this;
}
/**
* The number of days charge funds are held before being paid out. May also be set to
* `minimum`, representing the lowest available value for the account country. Default is
* `minimum`. The `delay_days` parameter does not apply when the `interval` is `manual`.
*/
public Builder setDelayDays(Long delayDays) {
this.delayDays = delayDays;
return this;
}
/**
* How frequently available funds are paid out. One of: `daily`, `manual`, `weekly`, or
* `monthly`. Default is `daily`.
*/
public Builder setInterval(Interval interval) {
this.interval = interval;
return this;
}
/**
* The day of the month when available funds are paid out. Required and applicable only if
* `interval` is `monthly`.
*/
public Builder setMonthlyAnchor(Long monthlyAnchor) {
this.monthlyAnchor = monthlyAnchor;
return this;
}
public Builder setWeeklyAnchor(WeeklyAnchor weeklyAnchor) {
this.weeklyAnchor = weeklyAnchor;
return this;
}
}
public enum DelayDays implements ApiRequestParams.EnumParam {
@SerializedName("minimum")
MINIMUM("minimum");
private final String value;
DelayDays(String value) {
this.value = value;
}
@Override
@java.lang.SuppressWarnings("all")
@lombok.Generated
public String getValue() {
return this.value;
}
}
public enum Interval implements ApiRequestParams.EnumParam {
@SerializedName("daily")
DAILY("daily"), @SerializedName("manual")
MANUAL("manual"), @SerializedName("monthly")
MONTHLY("monthly"), @SerializedName("weekly")
WEEKLY("weekly");
private final String value;
Interval(String value) {
this.value = value;
}
@Override
@java.lang.SuppressWarnings("all")
@lombok.Generated
public String getValue() {
return this.value;
}
}
public enum WeeklyAnchor implements ApiRequestParams.EnumParam {
@SerializedName("friday")
FRIDAY("friday"), @SerializedName("monday")
MONDAY("monday"), @SerializedName("saturday")
SATURDAY("saturday"), @SerializedName("sunday")
SUNDAY("sunday"), @SerializedName("thursday")
THURSDAY("thursday"), @SerializedName("tuesday")
TUESDAY("tuesday"), @SerializedName("wednesday")
WEDNESDAY("wednesday");
private final String value;
WeeklyAnchor(String value) {
this.value = value;
}
@Override
@java.lang.SuppressWarnings("all")
@lombok.Generated
public String getValue() {
return this.value;
}
}
}
}
}
/**
* The day of the week when available funds are paid out, specified as `monday`,
* `tuesday`, etc. (required and applicable only if `interval` is `weekly`.)
*/
public static class TosAcceptance {
/**
* The Unix timestamp marking when the account representative accepted the Stripe Services
* Agreement.
*/
@SerializedName("date")
Long date;
/**
* The IP address from which the account representative accepted the Stripe Services Agreement.
*/
@SerializedName("ip")
String ip;
/**
* The user agent of the browser from which the account representative accepted the Stripe
* Services Agreement.
*/
@SerializedName("user_agent")
String userAgent;
private TosAcceptance(Long date, String ip, String userAgent) {
this.date = date;
this.ip = ip;
this.userAgent = userAgent;
}
public static Builder builder() {
return new com.stripe.param.AccountCreateParams.TosAcceptance.Builder();
}
public static class Builder {
private Long date;
private String ip;
private String userAgent;
/** Finalize and obtain parameter instance from this builder. */
public TosAcceptance build() {
return new TosAcceptance(this.date, this.ip, this.userAgent);
}
/**
* The Unix timestamp marking when the account representative accepted the Stripe Services
* Agreement.
*/
public Builder setDate(Long date) {
this.date = date;
return this;
}
/**
* The IP address from which the account representative accepted the Stripe Services
* Agreement.
*/
public Builder setIp(String ip) {
this.ip = ip;
return this;
}
public Builder setUserAgent(String userAgent) {
this.userAgent = userAgent;
return this;
}
}
}
/**
* The user agent of the browser from which the account representative accepted the Stripe
* Services Agreement.
*/
public enum RequestedCapability implements ApiRequestParams.EnumParam {
@SerializedName("card_payments")
CARD_PAYMENTS("card_payments"), @SerializedName("platform_payments")
PLATFORM_PAYMENTS("platform_payments");
private final String value;
RequestedCapability(String value) {
this.value = value;
}
@Override
@java.lang.SuppressWarnings("all")
@lombok.Generated
public String getValue() {
return this.value;
}
}
public enum Type implements ApiRequestParams.EnumParam {
@SerializedName("custom")
CUSTOM("custom"), @SerializedName("express")
EXPRESS("express"), @SerializedName("standard")
STANDARD("standard");
private final String value;
Type(String value) {
this.value = value;
}
@Override
@java.lang.SuppressWarnings("all")
@lombok.Generated
public String getValue() {
return this.value;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy