com.stripe.model.Person Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.model;
import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
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.PersonUpdateParams;
import java.math.BigDecimal;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;
/**
* This is an object representing a person associated with a Stripe account.
*
* A platform cannot access a person for an account where account.controller.requirement_collection
* is {@code stripe}, which includes Standard and Express accounts, after creating an Account Link
* or Account Session to start Connect onboarding.
*
*
See the Standard onboarding or Express onboarding documentation for
* information about prefilling information and account onboarding steps. Learn more about handling identity
* verification with the API.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class Person extends ApiResource implements HasId, MetadataStore {
/** The account the person is associated with. */
@SerializedName("account")
String account;
@SerializedName("additional_tos_acceptances")
AdditionalTosAcceptances additionalTosAcceptances;
@SerializedName("address")
Address address;
/** The Kana variation of the person's address (Japan only). */
@SerializedName("address_kana")
AddressKana addressKana;
/** The Kanji variation of the person's address (Japan only). */
@SerializedName("address_kanji")
AddressKanji addressKanji;
/** Time at which the object was created. Measured in seconds since the Unix epoch. */
@SerializedName("created")
Long created;
/** Always true for a deleted object. */
@SerializedName("deleted")
Boolean deleted;
@SerializedName("dob")
Dob dob;
/** The person's email address. */
@SerializedName("email")
String email;
/** The person's first name. */
@SerializedName("first_name")
String firstName;
/** The Kana variation of the person's first name (Japan only). */
@SerializedName("first_name_kana")
String firstNameKana;
/** The Kanji variation of the person's first name (Japan only). */
@SerializedName("first_name_kanji")
String firstNameKanji;
/** A list of alternate names or aliases that the person is known by. */
@SerializedName("full_name_aliases")
List fullNameAliases;
/**
* Information about the upcoming new
* requirements for this person, including what information needs to be collected, and by
* when.
*/
@SerializedName("future_requirements")
FutureRequirements futureRequirements;
/** The person's gender. */
@SerializedName("gender")
String gender;
/** Unique identifier for the object. */
@Getter(onMethod_ = {@Override})
@SerializedName("id")
String id;
/**
* Whether the person's {@code id_number} was provided. True if either the full ID number was
* provided or if only the required part of the ID number was provided (ex. last four of an
* individual's SSN for the US indicated by {@code ssn_last_4_provided}).
*/
@SerializedName("id_number_provided")
Boolean idNumberProvided;
/** Whether the person's {@code id_number_secondary} was provided. */
@SerializedName("id_number_secondary_provided")
Boolean idNumberSecondaryProvided;
/** The person's last name. */
@SerializedName("last_name")
String lastName;
/** The Kana variation of the person's last name (Japan only). */
@SerializedName("last_name_kana")
String lastNameKana;
/** The Kanji variation of the person's last name (Japan only). */
@SerializedName("last_name_kanji")
String lastNameKanji;
/** The person'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.
*/
@Getter(onMethod_ = {@Override})
@SerializedName("metadata")
Map metadata;
/** The country where the person is a national. */
@SerializedName("nationality")
String nationality;
/**
* String representing the object's type. Objects of the same type share the same value.
*
* Equal to {@code person}.
*/
@SerializedName("object")
String object;
/** The person's phone number. */
@SerializedName("phone")
String phone;
/**
* Indicates if the person or any of their representatives, family members, or other closely
* related persons, declares that they hold or have held an important public job or function, in
* any jurisdiction.
*
*
One of {@code existing}, or {@code none}.
*/
@SerializedName("political_exposure")
String politicalExposure;
@SerializedName("registered_address")
Address registeredAddress;
@SerializedName("relationship")
Relationship relationship;
/**
* Information about the requirements for this person, including what information needs to be
* collected, and by when.
*/
@SerializedName("requirements")
Requirements requirements;
/**
* Whether the last four digits of the person's Social Security number have been provided (U.S.
* only).
*/
@SerializedName("ssn_last_4_provided")
Boolean ssnLast4Provided;
@SerializedName("verification")
Verification verification;
/**
* Deletes an existing person’s relationship to the account’s legal entity. Any person with a
* relationship for an account can be deleted through the API, except if the person is the {@code
* account_opener}. If your integration is using the {@code executive} parameter, you cannot
* delete the only verified {@code executive} on file.
*/
public Person delete() throws StripeException {
return delete((Map) null, (RequestOptions) null);
}
/**
* Deletes an existing person’s relationship to the account’s legal entity. Any person with a
* relationship for an account can be deleted through the API, except if the person is the {@code
* account_opener}. If your integration is using the {@code executive} parameter, you cannot
* delete the only verified {@code executive} on file.
*/
public Person delete(RequestOptions options) throws StripeException {
return delete((Map) null, options);
}
/**
* Deletes an existing person’s relationship to the account’s legal entity. Any person with a
* relationship for an account can be deleted through the API, except if the person is the {@code
* account_opener}. If your integration is using the {@code executive} parameter, you cannot
* delete the only verified {@code executive} on file.
*/
public Person delete(Map params) throws StripeException {
return delete(params, (RequestOptions) null);
}
/**
* Deletes an existing person’s relationship to the account’s legal entity. Any person with a
* relationship for an account can be deleted through the API, except if the person is the {@code
* account_opener}. If your integration is using the {@code executive} parameter, you cannot
* delete the only verified {@code executive} on file.
*/
public Person delete(Map params, RequestOptions options) throws StripeException {
String path =
String.format(
"/v1/accounts/%s/persons/%s",
ApiResource.urlEncodeId(this.getAccount()), ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.DELETE, path, params, options);
return getResponseGetter().request(request, Person.class);
}
/** Updates an existing person. */
@Override
public Person update(Map params) throws StripeException {
return update(params, (RequestOptions) null);
}
/** Updates an existing person. */
@Override
public Person update(Map params, RequestOptions options) throws StripeException {
String path =
String.format(
"/v1/accounts/%s/persons/%s",
ApiResource.urlEncodeId(this.getAccount()), ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getResponseGetter().request(request, Person.class);
}
/** Updates an existing person. */
public Person update(PersonUpdateParams params) throws StripeException {
return update(params, (RequestOptions) null);
}
/** Updates an existing person. */
public Person update(PersonUpdateParams params, RequestOptions options) throws StripeException {
String path =
String.format(
"/v1/accounts/%s/persons/%s",
ApiResource.urlEncodeId(this.getAccount()), 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, Person.class);
}
/**
* For more details about AdditionalTosAcceptances, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AdditionalTosAcceptances extends StripeObject {
/** Details on the legal guardian's acceptance of the main Stripe service agreement. */
@SerializedName("account")
Account account;
/**
* For more details about Account, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Account extends StripeObject {
/** The Unix timestamp marking when the legal guardian accepted the service agreement. */
@SerializedName("date")
Long date;
/** The IP address from which the legal guardian accepted the service agreement. */
@SerializedName("ip")
String ip;
/**
* The user agent of the browser from which the legal guardian accepted the service agreement.
*/
@SerializedName("user_agent")
String userAgent;
}
}
/**
* For more details about AddressKana, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AddressKana extends StripeObject {
/** City/Ward. */
@SerializedName("city")
String city;
/**
* Two-letter country code (ISO
* 3166-1 alpha-2).
*/
@SerializedName("country")
String country;
/** Block/Building number. */
@SerializedName("line1")
String line1;
/** Building details. */
@SerializedName("line2")
String line2;
/** ZIP or postal code. */
@SerializedName("postal_code")
String postalCode;
/** Prefecture. */
@SerializedName("state")
String state;
/** Town/cho-me. */
@SerializedName("town")
String town;
}
/**
* For more details about AddressKanji, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AddressKanji extends StripeObject {
/** City/Ward. */
@SerializedName("city")
String city;
/**
* Two-letter country code (ISO
* 3166-1 alpha-2).
*/
@SerializedName("country")
String country;
/** Block/Building number. */
@SerializedName("line1")
String line1;
/** Building details. */
@SerializedName("line2")
String line2;
/** ZIP or postal code. */
@SerializedName("postal_code")
String postalCode;
/** Prefecture. */
@SerializedName("state")
String state;
/** Town/cho-me. */
@SerializedName("town")
String town;
}
/**
* For more details about Dob, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Dob extends StripeObject {
/** 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;
}
/**
* For more details about FutureRequirements, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class FutureRequirements extends StripeObject {
/**
* Fields that are due and can be satisfied by providing the corresponding alternative fields
* instead.
*/
@SerializedName("alternatives")
List alternatives;
/**
* Fields that need to be collected to keep the person's account enabled. If not collected by
* the account's {@code future_requirements[current_deadline]}, these fields will transition to
* the main {@code requirements} hash, and may immediately become {@code past_due}, but the
* account may also be given a grace period depending on the account's enablement state prior to
* transition.
*/
@SerializedName("currently_due")
List currentlyDue;
/**
* Fields that are {@code currently_due} and need to be collected again because validation or
* verification failed.
*/
@SerializedName("errors")
List errors;
/**
* Fields you must collect when all thresholds are reached. As they become required, they appear
* in {@code currently_due} as well, and the account's {@code
* future_requirements[current_deadline]} becomes set.
*/
@SerializedName("eventually_due")
List eventuallyDue;
/**
* Fields that weren't collected by the account's {@code requirements.current_deadline}. These
* fields need to be collected to enable the person's account. New fields will never appear
* here; {@code future_requirements.past_due} will always be a subset of {@code
* requirements.past_due}.
*/
@SerializedName("past_due")
List pastDue;
/**
* Fields that might become required depending on the results of verification or review. It's an
* empty array unless an asynchronous verification is pending. If verification fails, these
* fields move to {@code eventually_due} or {@code currently_due}. Fields might appear in {@code
* eventually_due} or {@code currently_due} and in {@code pending_verification} if verification
* fails but another verification is still pending.
*/
@SerializedName("pending_verification")
List pendingVerification;
/**
* For more details about Alternative, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Alternative extends StripeObject {
/** Fields that can be provided to satisfy all fields in {@code original_fields_due}. */
@SerializedName("alternative_fields_due")
List alternativeFieldsDue;
/**
* Fields that are due and can be satisfied by providing all fields in {@code
* alternative_fields_due}.
*/
@SerializedName("original_fields_due")
List originalFieldsDue;
}
/**
* For more details about Errors, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Errors extends StripeObject {
/**
* The code for the type of error.
*
* One of {@code invalid_address_city_state_postal_code}, {@code
* invalid_address_highway_contract_box}, {@code invalid_address_private_mailbox}, {@code
* invalid_business_profile_name}, {@code invalid_business_profile_name_denylisted}, {@code
* invalid_company_name_denylisted}, {@code invalid_dob_age_over_maximum}, {@code
* invalid_dob_age_under_18}, {@code invalid_dob_age_under_minimum}, {@code
* invalid_product_description_length}, {@code invalid_product_description_url_match}, {@code
* invalid_representative_country}, {@code invalid_statement_descriptor_business_mismatch},
* {@code invalid_statement_descriptor_denylisted}, {@code
* invalid_statement_descriptor_length}, {@code
* invalid_statement_descriptor_prefix_denylisted}, {@code
* invalid_statement_descriptor_prefix_mismatch}, {@code invalid_street_address}, {@code
* invalid_tax_id}, {@code invalid_tax_id_format}, {@code invalid_tos_acceptance}, {@code
* invalid_url_denylisted}, {@code invalid_url_format}, {@code invalid_url_length}, {@code
* invalid_url_web_presence_detected}, {@code
* invalid_url_website_business_information_mismatch}, {@code invalid_url_website_empty},
* {@code invalid_url_website_inaccessible}, {@code
* invalid_url_website_inaccessible_geoblocked}, {@code
* invalid_url_website_inaccessible_password_protected}, {@code
* invalid_url_website_incomplete}, {@code
* invalid_url_website_incomplete_cancellation_policy}, {@code
* invalid_url_website_incomplete_customer_service_details}, {@code
* invalid_url_website_incomplete_legal_restrictions}, {@code
* invalid_url_website_incomplete_refund_policy}, {@code
* invalid_url_website_incomplete_return_policy}, {@code
* invalid_url_website_incomplete_terms_and_conditions}, {@code
* invalid_url_website_incomplete_under_construction}, {@code invalid_url_website_other},
* {@code invalid_value_other}, {@code verification_directors_mismatch}, {@code
* verification_document_address_mismatch}, {@code verification_document_address_missing},
* {@code verification_document_corrupt}, {@code verification_document_country_not_supported},
* {@code verification_document_directors_mismatch}, {@code
* verification_document_dob_mismatch}, {@code verification_document_duplicate_type}, {@code
* verification_document_expired}, {@code verification_document_failed_copy}, {@code
* verification_document_failed_greyscale}, {@code verification_document_failed_other}, {@code
* verification_document_failed_test_mode}, {@code verification_document_fraudulent}, {@code
* verification_document_id_number_mismatch}, {@code verification_document_id_number_missing},
* {@code verification_document_incomplete}, {@code verification_document_invalid}, {@code
* verification_document_issue_or_expiry_date_missing}, {@code
* verification_document_manipulated}, {@code verification_document_missing_back}, {@code
* verification_document_missing_front}, {@code verification_document_name_mismatch}, {@code
* verification_document_name_missing}, {@code verification_document_nationality_mismatch},
* {@code verification_document_not_readable}, {@code verification_document_not_signed},
* {@code verification_document_not_uploaded}, {@code verification_document_photo_mismatch},
* {@code verification_document_too_large}, {@code verification_document_type_not_supported},
* {@code verification_extraneous_directors}, {@code verification_failed_address_match},
* {@code verification_failed_business_iec_number}, {@code
* verification_failed_document_match}, {@code verification_failed_id_number_match}, {@code
* verification_failed_keyed_identity}, {@code verification_failed_keyed_match}, {@code
* verification_failed_name_match}, {@code verification_failed_other}, {@code
* verification_failed_representative_authority}, {@code
* verification_failed_residential_address}, {@code verification_failed_tax_id_match}, {@code
* verification_failed_tax_id_not_issued}, {@code verification_missing_directors}, {@code
* verification_missing_executives}, {@code verification_missing_owners}, {@code
* verification_requires_additional_memorandum_of_associations}, {@code
* verification_requires_additional_proof_of_registration}, or {@code
* verification_supportability}.
*/
@SerializedName("code")
String code;
/**
* An informative message that indicates the error type and provides additional details about
* the error.
*/
@SerializedName("reason")
String reason;
/**
* The specific user onboarding requirement field (in the requirements hash) that needs to be
* resolved.
*/
@SerializedName("requirement")
String requirement;
}
}
/**
* For more details about Relationship, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Relationship extends StripeObject {
/** Whether the person is the authorizer of the account's representative. */
@SerializedName("authorizer")
Boolean authorizer;
/**
* Whether the person is a director of the account's legal entity. Directors are typically
* members of the governing board of the company, or responsible for ensuring the company meets
* its regulatory obligations.
*/
@SerializedName("director")
Boolean director;
/**
* Whether the person has significant responsibility to control, manage, or direct the
* organization.
*/
@SerializedName("executive")
Boolean executive;
/** Whether the person is the legal guardian of the account's representative. */
@SerializedName("legal_guardian")
Boolean legalGuardian;
/** Whether the person is an owner of the account’s legal entity. */
@SerializedName("owner")
Boolean owner;
/** The percent owned by the person of the account's legal entity. */
@SerializedName("percent_ownership")
BigDecimal percentOwnership;
/**
* Whether the person is authorized as the primary representative of the account. This is the
* person nominated by the business to provide information about themselves, and general
* information about the account. There can only be one representative at any given time. At the
* time the account is created, this person should be set to the person responsible for opening
* the account.
*/
@SerializedName("representative")
Boolean representative;
/** The person's title (e.g., CEO, Support Engineer). */
@SerializedName("title")
String title;
}
/**
* For more details about Requirements, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Requirements extends StripeObject {
/**
* Fields that are due and can be satisfied by providing the corresponding alternative fields
* instead.
*/
@SerializedName("alternatives")
List alternatives;
/**
* Fields that need to be collected to keep the person's account enabled. If not collected by
* the account's {@code current_deadline}, these fields appear in {@code past_due} as well, and
* the account is disabled.
*/
@SerializedName("currently_due")
List currentlyDue;
/**
* Fields that are {@code currently_due} and need to be collected again because validation or
* verification failed.
*/
@SerializedName("errors")
List errors;
/**
* Fields you must collect when all thresholds are reached. As they become required, they appear
* in {@code currently_due} as well, and the account's {@code current_deadline} becomes set.
*/
@SerializedName("eventually_due")
List eventuallyDue;
/**
* Fields that weren't collected by the account's {@code current_deadline}. These fields need to
* be collected to enable the person's account.
*/
@SerializedName("past_due")
List pastDue;
/**
* Fields that might become required depending on the results of verification or review. It's an
* empty array unless an asynchronous verification is pending. If verification fails, these
* fields move to {@code eventually_due}, {@code currently_due}, or {@code past_due}. Fields
* might appear in {@code eventually_due}, {@code currently_due}, or {@code past_due} and in
* {@code pending_verification} if verification fails but another verification is still pending.
*/
@SerializedName("pending_verification")
List pendingVerification;
/**
* For more details about Alternative, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Alternative extends StripeObject {
/** Fields that can be provided to satisfy all fields in {@code original_fields_due}. */
@SerializedName("alternative_fields_due")
List alternativeFieldsDue;
/**
* Fields that are due and can be satisfied by providing all fields in {@code
* alternative_fields_due}.
*/
@SerializedName("original_fields_due")
List originalFieldsDue;
}
/**
* For more details about Errors, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Errors extends StripeObject {
/**
* The code for the type of error.
*
* One of {@code invalid_address_city_state_postal_code}, {@code
* invalid_address_highway_contract_box}, {@code invalid_address_private_mailbox}, {@code
* invalid_business_profile_name}, {@code invalid_business_profile_name_denylisted}, {@code
* invalid_company_name_denylisted}, {@code invalid_dob_age_over_maximum}, {@code
* invalid_dob_age_under_18}, {@code invalid_dob_age_under_minimum}, {@code
* invalid_product_description_length}, {@code invalid_product_description_url_match}, {@code
* invalid_representative_country}, {@code invalid_statement_descriptor_business_mismatch},
* {@code invalid_statement_descriptor_denylisted}, {@code
* invalid_statement_descriptor_length}, {@code
* invalid_statement_descriptor_prefix_denylisted}, {@code
* invalid_statement_descriptor_prefix_mismatch}, {@code invalid_street_address}, {@code
* invalid_tax_id}, {@code invalid_tax_id_format}, {@code invalid_tos_acceptance}, {@code
* invalid_url_denylisted}, {@code invalid_url_format}, {@code invalid_url_length}, {@code
* invalid_url_web_presence_detected}, {@code
* invalid_url_website_business_information_mismatch}, {@code invalid_url_website_empty},
* {@code invalid_url_website_inaccessible}, {@code
* invalid_url_website_inaccessible_geoblocked}, {@code
* invalid_url_website_inaccessible_password_protected}, {@code
* invalid_url_website_incomplete}, {@code
* invalid_url_website_incomplete_cancellation_policy}, {@code
* invalid_url_website_incomplete_customer_service_details}, {@code
* invalid_url_website_incomplete_legal_restrictions}, {@code
* invalid_url_website_incomplete_refund_policy}, {@code
* invalid_url_website_incomplete_return_policy}, {@code
* invalid_url_website_incomplete_terms_and_conditions}, {@code
* invalid_url_website_incomplete_under_construction}, {@code invalid_url_website_other},
* {@code invalid_value_other}, {@code verification_directors_mismatch}, {@code
* verification_document_address_mismatch}, {@code verification_document_address_missing},
* {@code verification_document_corrupt}, {@code verification_document_country_not_supported},
* {@code verification_document_directors_mismatch}, {@code
* verification_document_dob_mismatch}, {@code verification_document_duplicate_type}, {@code
* verification_document_expired}, {@code verification_document_failed_copy}, {@code
* verification_document_failed_greyscale}, {@code verification_document_failed_other}, {@code
* verification_document_failed_test_mode}, {@code verification_document_fraudulent}, {@code
* verification_document_id_number_mismatch}, {@code verification_document_id_number_missing},
* {@code verification_document_incomplete}, {@code verification_document_invalid}, {@code
* verification_document_issue_or_expiry_date_missing}, {@code
* verification_document_manipulated}, {@code verification_document_missing_back}, {@code
* verification_document_missing_front}, {@code verification_document_name_mismatch}, {@code
* verification_document_name_missing}, {@code verification_document_nationality_mismatch},
* {@code verification_document_not_readable}, {@code verification_document_not_signed},
* {@code verification_document_not_uploaded}, {@code verification_document_photo_mismatch},
* {@code verification_document_too_large}, {@code verification_document_type_not_supported},
* {@code verification_extraneous_directors}, {@code verification_failed_address_match},
* {@code verification_failed_business_iec_number}, {@code
* verification_failed_document_match}, {@code verification_failed_id_number_match}, {@code
* verification_failed_keyed_identity}, {@code verification_failed_keyed_match}, {@code
* verification_failed_name_match}, {@code verification_failed_other}, {@code
* verification_failed_representative_authority}, {@code
* verification_failed_residential_address}, {@code verification_failed_tax_id_match}, {@code
* verification_failed_tax_id_not_issued}, {@code verification_missing_directors}, {@code
* verification_missing_executives}, {@code verification_missing_owners}, {@code
* verification_requires_additional_memorandum_of_associations}, {@code
* verification_requires_additional_proof_of_registration}, or {@code
* verification_supportability}.
*/
@SerializedName("code")
String code;
/**
* An informative message that indicates the error type and provides additional details about
* the error.
*/
@SerializedName("reason")
String reason;
/**
* The specific user onboarding requirement field (in the requirements hash) that needs to be
* resolved.
*/
@SerializedName("requirement")
String requirement;
}
}
/**
* For more details about Verification, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Verification extends StripeObject {
/**
* A document showing address, either a passport, local ID card, or utility bill from a
* well-known utility company.
*/
@SerializedName("additional_document")
AdditionalDocument additionalDocument;
/**
* A user-displayable string describing the verification state for the person. For example, this
* may say "Provided identity information could not be verified".
*/
@SerializedName("details")
String details;
/**
* One of {@code document_address_mismatch}, {@code document_dob_mismatch}, {@code
* document_duplicate_type}, {@code document_id_number_mismatch}, {@code
* document_name_mismatch}, {@code document_nationality_mismatch}, {@code
* failed_keyed_identity}, or {@code failed_other}. A machine-readable code specifying the
* verification state for the person.
*/
@SerializedName("details_code")
String detailsCode;
@SerializedName("document")
Document document;
/**
* The state of verification for the person. Possible values are {@code unverified}, {@code
* pending}, or {@code verified}.
*/
@SerializedName("status")
String status;
/**
* For more details about AdditionalDocument, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AdditionalDocument extends StripeObject {
/**
* The back of an ID returned by a file
* upload with a {@code purpose} value of {@code identity_document}.
*/
@SerializedName("back")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField back;
/**
* A user-displayable string describing the verification state of this document. For example,
* if a document is uploaded and the picture is too fuzzy, this may say "Identity
* document is too unclear to read".
*/
@SerializedName("details")
String details;
/**
* One of {@code document_corrupt}, {@code document_country_not_supported}, {@code
* document_expired}, {@code document_failed_copy}, {@code document_failed_other}, {@code
* document_failed_test_mode}, {@code document_fraudulent}, {@code document_failed_greyscale},
* {@code document_incomplete}, {@code document_invalid}, {@code document_manipulated}, {@code
* document_missing_back}, {@code document_missing_front}, {@code document_not_readable},
* {@code document_not_uploaded}, {@code document_photo_mismatch}, {@code document_too_large},
* or {@code document_type_not_supported}. A machine-readable code specifying the verification
* state for this document.
*/
@SerializedName("details_code")
String detailsCode;
/**
* The front of an ID returned by a file
* upload with a {@code purpose} value of {@code identity_document}.
*/
@SerializedName("front")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField front;
/** Get ID of expandable {@code back} object. */
public String getBack() {
return (this.back != null) ? this.back.getId() : null;
}
public void setBack(String id) {
this.back = ApiResource.setExpandableFieldId(id, this.back);
}
/** Get expanded {@code back}. */
public File getBackObject() {
return (this.back != null) ? this.back.getExpanded() : null;
}
public void setBackObject(File expandableObject) {
this.back = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code front} object. */
public String getFront() {
return (this.front != null) ? this.front.getId() : null;
}
public void setFront(String id) {
this.front = ApiResource.setExpandableFieldId(id, this.front);
}
/** Get expanded {@code front}. */
public File getFrontObject() {
return (this.front != null) ? this.front.getExpanded() : null;
}
public void setFrontObject(File expandableObject) {
this.front = new ExpandableField(expandableObject.getId(), expandableObject);
}
}
/**
* For more details about Document, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Document extends StripeObject {
/**
* The back of an ID returned by a file
* upload with a {@code purpose} value of {@code identity_document}.
*/
@SerializedName("back")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField back;
/**
* A user-displayable string describing the verification state of this document. For example,
* if a document is uploaded and the picture is too fuzzy, this may say "Identity
* document is too unclear to read".
*/
@SerializedName("details")
String details;
/**
* One of {@code document_corrupt}, {@code document_country_not_supported}, {@code
* document_expired}, {@code document_failed_copy}, {@code document_failed_other}, {@code
* document_failed_test_mode}, {@code document_fraudulent}, {@code document_failed_greyscale},
* {@code document_incomplete}, {@code document_invalid}, {@code document_manipulated}, {@code
* document_missing_back}, {@code document_missing_front}, {@code document_not_readable},
* {@code document_not_uploaded}, {@code document_photo_mismatch}, {@code document_too_large},
* or {@code document_type_not_supported}. A machine-readable code specifying the verification
* state for this document.
*/
@SerializedName("details_code")
String detailsCode;
/**
* The front of an ID returned by a file
* upload with a {@code purpose} value of {@code identity_document}.
*/
@SerializedName("front")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField front;
/** Get ID of expandable {@code back} object. */
public String getBack() {
return (this.back != null) ? this.back.getId() : null;
}
public void setBack(String id) {
this.back = ApiResource.setExpandableFieldId(id, this.back);
}
/** Get expanded {@code back}. */
public File getBackObject() {
return (this.back != null) ? this.back.getExpanded() : null;
}
public void setBackObject(File expandableObject) {
this.back = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code front} object. */
public String getFront() {
return (this.front != null) ? this.front.getId() : null;
}
public void setFront(String id) {
this.front = ApiResource.setExpandableFieldId(id, this.front);
}
/** Get expanded {@code front}. */
public File getFrontObject() {
return (this.front != null) ? this.front.getExpanded() : null;
}
public void setFrontObject(File expandableObject) {
this.front = new ExpandableField(expandableObject.getId(), expandableObject);
}
}
}
@Override
public void setResponseGetter(StripeResponseGetter responseGetter) {
super.setResponseGetter(responseGetter);
trySetResponseGetter(additionalTosAcceptances, responseGetter);
trySetResponseGetter(address, responseGetter);
trySetResponseGetter(addressKana, responseGetter);
trySetResponseGetter(addressKanji, responseGetter);
trySetResponseGetter(dob, responseGetter);
trySetResponseGetter(futureRequirements, responseGetter);
trySetResponseGetter(registeredAddress, responseGetter);
trySetResponseGetter(relationship, responseGetter);
trySetResponseGetter(requirements, responseGetter);
trySetResponseGetter(verification, responseGetter);
}
}