All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy