com.stripe.model.identity.VerificationSession Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.model.identity;
import com.google.gson.annotations.SerializedName;
import com.stripe.Stripe;
import com.stripe.exception.StripeException;
import com.stripe.model.Address;
import com.stripe.model.ExpandableField;
import com.stripe.model.HasId;
import com.stripe.model.MetadataStore;
import com.stripe.model.StripeObject;
import com.stripe.net.ApiResource;
import com.stripe.net.RequestOptions;
import com.stripe.param.identity.VerificationSessionCancelParams;
import com.stripe.param.identity.VerificationSessionCreateParams;
import com.stripe.param.identity.VerificationSessionListParams;
import com.stripe.param.identity.VerificationSessionRedactParams;
import com.stripe.param.identity.VerificationSessionRetrieveParams;
import com.stripe.param.identity.VerificationSessionUpdateParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;
/**
* A VerificationSession guides you through the process of collecting and verifying the identities
* of your users. It contains details about the type of verification, such as what verification check to perform.
* Only create one VerificationSession for each verification in your system.
*
* A VerificationSession transitions through multiple statuses throughout its
* lifetime as it progresses through the verification flow. The VerificationSession contains the
* user's verified data after verification checks are complete.
*
*
Related guide: The
* Verification Sessions API
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class VerificationSession extends ApiResource
implements HasId, MetadataStore {
/**
* The short-lived client secret used by Stripe.js to show a verification modal inside your app.
* This client secret expires after 24 hours and can only be used once. Don’t store it, log it,
* embed it in a URL, or expose it to anyone other than the user. Make sure that you have TLS
* enabled on any page that includes the client secret. Refer to our docs on passing the client
* secret to the frontend to learn more.
*/
@SerializedName("client_secret")
String clientSecret;
/** Time at which the object was created. Measured in seconds since the Unix epoch. */
@SerializedName("created")
Long created;
/** Unique identifier for the object. */
@Getter(onMethod_ = {@Override})
@SerializedName("id")
String id;
/**
* If present, this property tells you the last error encountered when processing the
* verification.
*/
@SerializedName("last_error")
LastError lastError;
/**
* ID of the most recent VerificationReport. Learn more about
* accessing detailed verification results.
*/
@SerializedName("last_verification_report")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField lastVerificationReport;
/**
* Has the value {@code true} if the object exists in live mode or the value {@code false} if the
* object exists in test mode.
*/
@SerializedName("livemode")
Boolean livemode;
/**
* Set of key-value pairs that you can attach
* to an object. This can be useful for storing additional information about the object in a
* structured format.
*/
@Getter(onMethod_ = {@Override})
@SerializedName("metadata")
Map metadata;
/**
* String representing the object's type. Objects of the same type share the same value.
*
* Equal to {@code identity.verification_session}.
*/
@SerializedName("object")
String object;
/** A set of options for the session’s verification checks. */
@SerializedName("options")
Options options;
/**
* Redaction status of this VerificationSession. If the VerificationSession is not redacted, this
* field will be null.
*/
@SerializedName("redaction")
Redaction redaction;
/**
* Status of this VerificationSession. Learn more about the lifecycle of
* sessions.
*
*
One of {@code canceled}, {@code processing}, {@code requires_input}, or {@code verified}.
*/
@SerializedName("status")
String status;
/**
* The type of verification
* check to be performed.
*
*
One of {@code document}, or {@code id_number}.
*/
@SerializedName("type")
String type;
/**
* The short-lived URL that you use to redirect a user to Stripe to submit their identity
* information. This URL expires after 48 hours and can only be used once. Don’t store it, log it,
* send it in emails or expose it to anyone other than the user. Refer to our docs on verifying
* identity documents to learn how to redirect users to Stripe.
*/
@SerializedName("url")
String url;
/** The user’s verified data. */
@SerializedName("verified_outputs")
VerifiedOutputs verifiedOutputs;
/** Get ID of expandable {@code lastVerificationReport} object. */
public String getLastVerificationReport() {
return (this.lastVerificationReport != null) ? this.lastVerificationReport.getId() : null;
}
public void setLastVerificationReport(String id) {
this.lastVerificationReport = ApiResource.setExpandableFieldId(id, this.lastVerificationReport);
}
/** Get expanded {@code lastVerificationReport}. */
public VerificationReport getLastVerificationReportObject() {
return (this.lastVerificationReport != null) ? this.lastVerificationReport.getExpanded() : null;
}
public void setLastVerificationReportObject(VerificationReport expandableObject) {
this.lastVerificationReport =
new ExpandableField(expandableObject.getId(), expandableObject);
}
/**
* A VerificationSession object can be canceled when it is in {@code requires_input} status.
*
* Once canceled, future submission attempts are disabled. This cannot be undone. Learn more.
*/
public VerificationSession cancel() throws StripeException {
return cancel((Map) null, (RequestOptions) null);
}
/**
* A VerificationSession object can be canceled when it is in {@code requires_input} status.
*
* Once canceled, future submission attempts are disabled. This cannot be undone. Learn more.
*/
public VerificationSession cancel(RequestOptions options) throws StripeException {
return cancel((Map) null, options);
}
/**
* A VerificationSession object can be canceled when it is in {@code requires_input} status.
*
* Once canceled, future submission attempts are disabled. This cannot be undone. Learn more.
*/
public VerificationSession cancel(Map params) throws StripeException {
return cancel(params, (RequestOptions) null);
}
/**
* A VerificationSession object can be canceled when it is in {@code requires_input} status.
*
* Once canceled, future submission attempts are disabled. This cannot be undone. Learn more.
*/
public VerificationSession cancel(Map params, RequestOptions options)
throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format(
"/v1/identity/verification_sessions/%s/cancel",
ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(
ApiResource.RequestMethod.POST, url, params, VerificationSession.class, options);
}
/**
* A VerificationSession object can be canceled when it is in {@code requires_input} status.
*
* Once canceled, future submission attempts are disabled. This cannot be undone. Learn more.
*/
public VerificationSession cancel(VerificationSessionCancelParams params) throws StripeException {
return cancel(params, (RequestOptions) null);
}
/**
* A VerificationSession object can be canceled when it is in {@code requires_input} status.
*
*
Once canceled, future submission attempts are disabled. This cannot be undone. Learn more.
*/
public VerificationSession cancel(VerificationSessionCancelParams params, RequestOptions options)
throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format(
"/v1/identity/verification_sessions/%s/cancel",
ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(
ApiResource.RequestMethod.POST, url, params, VerificationSession.class, options);
}
/**
* Creates a VerificationSession object.
*
*
After the VerificationSession is created, display a verification modal using the session
* {@code client_secret} or send your users to the session’s {@code url}.
*
*
If your API key is in test mode, verification checks won’t actually process, though
* everything else will occur as if in live mode.
*
*
Related guide: Verify
* your users’ identity documents.
*/
public static VerificationSession create(Map params) throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates a VerificationSession object.
*
* After the VerificationSession is created, display a verification modal using the session
* {@code client_secret} or send your users to the session’s {@code url}.
*
*
If your API key is in test mode, verification checks won’t actually process, though
* everything else will occur as if in live mode.
*
*
Related guide: Verify
* your users’ identity documents.
*/
public static VerificationSession create(Map params, RequestOptions options)
throws StripeException {
String url =
ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/identity/verification_sessions");
return ApiResource.request(
ApiResource.RequestMethod.POST, url, params, VerificationSession.class, options);
}
/**
* Creates a VerificationSession object.
*
* After the VerificationSession is created, display a verification modal using the session
* {@code client_secret} or send your users to the session’s {@code url}.
*
*
If your API key is in test mode, verification checks won’t actually process, though
* everything else will occur as if in live mode.
*
*
Related guide: Verify
* your users’ identity documents.
*/
public static VerificationSession create(VerificationSessionCreateParams params)
throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates a VerificationSession object.
*
*
After the VerificationSession is created, display a verification modal using the session
* {@code client_secret} or send your users to the session’s {@code url}.
*
*
If your API key is in test mode, verification checks won’t actually process, though
* everything else will occur as if in live mode.
*
*
Related guide: Verify
* your users’ identity documents.
*/
public static VerificationSession create(
VerificationSessionCreateParams params, RequestOptions options) throws StripeException {
String url =
ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/identity/verification_sessions");
return ApiResource.request(
ApiResource.RequestMethod.POST, url, params, VerificationSession.class, options);
}
/** Returns a list of VerificationSessions. */
public static VerificationSessionCollection list(Map params)
throws StripeException {
return list(params, (RequestOptions) null);
}
/** Returns a list of VerificationSessions. */
public static VerificationSessionCollection list(
Map params, RequestOptions options) throws StripeException {
String url =
ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/identity/verification_sessions");
return ApiResource.requestCollection(url, params, VerificationSessionCollection.class, options);
}
/** Returns a list of VerificationSessions. */
public static VerificationSessionCollection list(VerificationSessionListParams params)
throws StripeException {
return list(params, (RequestOptions) null);
}
/** Returns a list of VerificationSessions. */
public static VerificationSessionCollection list(
VerificationSessionListParams params, RequestOptions options) throws StripeException {
String url =
ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/identity/verification_sessions");
return ApiResource.requestCollection(url, params, VerificationSessionCollection.class, options);
}
/**
* Redact a VerificationSession to remove all collected information from Stripe. This will redact
* the VerificationSession and all objects related to it, including VerificationReports, Events,
* request logs, etc.
*
* A VerificationSession object can be redacted when it is in {@code requires_input} or {@code
* verified} status. Redacting a
* VerificationSession in {@code requires_action} state will automatically cancel it.
*
*
The redaction process may take up to four days. When the redaction process is in progress,
* the VerificationSession’s {@code redaction.status} field will be set to {@code processing};
* when the process is finished, it will change to {@code redacted} and an {@code
* identity.verification_session.redacted} event will be emitted.
*
*
Redaction is irreversible. Redacted objects are still accessible in the Stripe API, but all
* the fields that contain personal data will be replaced by the string {@code [redacted]} or a
* similar placeholder. The {@code metadata} field will also be erased. Redacted objects cannot be
* updated or used for any purpose.
*
*
Learn more.
*/
public VerificationSession redact() throws StripeException {
return redact((Map) null, (RequestOptions) null);
}
/**
* Redact a VerificationSession to remove all collected information from Stripe. This will redact
* the VerificationSession and all objects related to it, including VerificationReports, Events,
* request logs, etc.
*
* A VerificationSession object can be redacted when it is in {@code requires_input} or {@code
* verified} status. Redacting a
* VerificationSession in {@code requires_action} state will automatically cancel it.
*
*
The redaction process may take up to four days. When the redaction process is in progress,
* the VerificationSession’s {@code redaction.status} field will be set to {@code processing};
* when the process is finished, it will change to {@code redacted} and an {@code
* identity.verification_session.redacted} event will be emitted.
*
*
Redaction is irreversible. Redacted objects are still accessible in the Stripe API, but all
* the fields that contain personal data will be replaced by the string {@code [redacted]} or a
* similar placeholder. The {@code metadata} field will also be erased. Redacted objects cannot be
* updated or used for any purpose.
*
*
Learn more.
*/
public VerificationSession redact(RequestOptions options) throws StripeException {
return redact((Map) null, options);
}
/**
* Redact a VerificationSession to remove all collected information from Stripe. This will redact
* the VerificationSession and all objects related to it, including VerificationReports, Events,
* request logs, etc.
*
* A VerificationSession object can be redacted when it is in {@code requires_input} or {@code
* verified} status. Redacting a
* VerificationSession in {@code requires_action} state will automatically cancel it.
*
*
The redaction process may take up to four days. When the redaction process is in progress,
* the VerificationSession’s {@code redaction.status} field will be set to {@code processing};
* when the process is finished, it will change to {@code redacted} and an {@code
* identity.verification_session.redacted} event will be emitted.
*
*
Redaction is irreversible. Redacted objects are still accessible in the Stripe API, but all
* the fields that contain personal data will be replaced by the string {@code [redacted]} or a
* similar placeholder. The {@code metadata} field will also be erased. Redacted objects cannot be
* updated or used for any purpose.
*
*
Learn more.
*/
public VerificationSession redact(Map params) throws StripeException {
return redact(params, (RequestOptions) null);
}
/**
* Redact a VerificationSession to remove all collected information from Stripe. This will redact
* the VerificationSession and all objects related to it, including VerificationReports, Events,
* request logs, etc.
*
* A VerificationSession object can be redacted when it is in {@code requires_input} or {@code
* verified} status. Redacting a
* VerificationSession in {@code requires_action} state will automatically cancel it.
*
*
The redaction process may take up to four days. When the redaction process is in progress,
* the VerificationSession’s {@code redaction.status} field will be set to {@code processing};
* when the process is finished, it will change to {@code redacted} and an {@code
* identity.verification_session.redacted} event will be emitted.
*
*
Redaction is irreversible. Redacted objects are still accessible in the Stripe API, but all
* the fields that contain personal data will be replaced by the string {@code [redacted]} or a
* similar placeholder. The {@code metadata} field will also be erased. Redacted objects cannot be
* updated or used for any purpose.
*
*
Learn more.
*/
public VerificationSession redact(Map params, RequestOptions options)
throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format(
"/v1/identity/verification_sessions/%s/redact",
ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(
ApiResource.RequestMethod.POST, url, params, VerificationSession.class, options);
}
/**
* Redact a VerificationSession to remove all collected information from Stripe. This will redact
* the VerificationSession and all objects related to it, including VerificationReports, Events,
* request logs, etc.
*
* A VerificationSession object can be redacted when it is in {@code requires_input} or {@code
* verified} status. Redacting a
* VerificationSession in {@code requires_action} state will automatically cancel it.
*
*
The redaction process may take up to four days. When the redaction process is in progress,
* the VerificationSession’s {@code redaction.status} field will be set to {@code processing};
* when the process is finished, it will change to {@code redacted} and an {@code
* identity.verification_session.redacted} event will be emitted.
*
*
Redaction is irreversible. Redacted objects are still accessible in the Stripe API, but all
* the fields that contain personal data will be replaced by the string {@code [redacted]} or a
* similar placeholder. The {@code metadata} field will also be erased. Redacted objects cannot be
* updated or used for any purpose.
*
*
Learn more.
*/
public VerificationSession redact(VerificationSessionRedactParams params) throws StripeException {
return redact(params, (RequestOptions) null);
}
/**
* Redact a VerificationSession to remove all collected information from Stripe. This will redact
* the VerificationSession and all objects related to it, including VerificationReports, Events,
* request logs, etc.
*
*
A VerificationSession object can be redacted when it is in {@code requires_input} or {@code
* verified} status. Redacting a
* VerificationSession in {@code requires_action} state will automatically cancel it.
*
*
The redaction process may take up to four days. When the redaction process is in progress,
* the VerificationSession’s {@code redaction.status} field will be set to {@code processing};
* when the process is finished, it will change to {@code redacted} and an {@code
* identity.verification_session.redacted} event will be emitted.
*
*
Redaction is irreversible. Redacted objects are still accessible in the Stripe API, but all
* the fields that contain personal data will be replaced by the string {@code [redacted]} or a
* similar placeholder. The {@code metadata} field will also be erased. Redacted objects cannot be
* updated or used for any purpose.
*
*
Learn more.
*/
public VerificationSession redact(VerificationSessionRedactParams params, RequestOptions options)
throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format(
"/v1/identity/verification_sessions/%s/redact",
ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(
ApiResource.RequestMethod.POST, url, params, VerificationSession.class, options);
}
/**
* Retrieves the details of a VerificationSession that was previously created.
*
*
When the session status is {@code requires_input}, you can use this method to retrieve a
* valid {@code client_secret} or {@code url} to allow re-submission.
*/
public static VerificationSession retrieve(String session) throws StripeException {
return retrieve(session, (Map) null, (RequestOptions) null);
}
/**
* Retrieves the details of a VerificationSession that was previously created.
*
* When the session status is {@code requires_input}, you can use this method to retrieve a
* valid {@code client_secret} or {@code url} to allow re-submission.
*/
public static VerificationSession retrieve(String session, RequestOptions options)
throws StripeException {
return retrieve(session, (Map) null, options);
}
/**
* Retrieves the details of a VerificationSession that was previously created.
*
* When the session status is {@code requires_input}, you can use this method to retrieve a
* valid {@code client_secret} or {@code url} to allow re-submission.
*/
public static VerificationSession retrieve(
String session, Map params, RequestOptions options) throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format(
"/v1/identity/verification_sessions/%s", ApiResource.urlEncodeId(session)));
return ApiResource.request(
ApiResource.RequestMethod.GET, url, params, VerificationSession.class, options);
}
/**
* Retrieves the details of a VerificationSession that was previously created.
*
* When the session status is {@code requires_input}, you can use this method to retrieve a
* valid {@code client_secret} or {@code url} to allow re-submission.
*/
public static VerificationSession retrieve(
String session, VerificationSessionRetrieveParams params, RequestOptions options)
throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format(
"/v1/identity/verification_sessions/%s", ApiResource.urlEncodeId(session)));
return ApiResource.request(
ApiResource.RequestMethod.GET, url, params, VerificationSession.class, options);
}
/**
* Updates a VerificationSession object.
*
*
When the session status is {@code requires_input}, you can use this method to update the
* verification check and options.
*/
@Override
public VerificationSession update(Map params) throws StripeException {
return update(params, (RequestOptions) null);
}
/**
* Updates a VerificationSession object.
*
* When the session status is {@code requires_input}, you can use this method to update the
* verification check and options.
*/
@Override
public VerificationSession update(Map params, RequestOptions options)
throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format(
"/v1/identity/verification_sessions/%s", ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(
ApiResource.RequestMethod.POST, url, params, VerificationSession.class, options);
}
/**
* Updates a VerificationSession object.
*
* When the session status is {@code requires_input}, you can use this method to update the
* verification check and options.
*/
public VerificationSession update(VerificationSessionUpdateParams params) throws StripeException {
return update(params, (RequestOptions) null);
}
/**
* Updates a VerificationSession object.
*
*
When the session status is {@code requires_input}, you can use this method to update the
* verification check and options.
*/
public VerificationSession update(VerificationSessionUpdateParams params, RequestOptions options)
throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format(
"/v1/identity/verification_sessions/%s", ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(
ApiResource.RequestMethod.POST, url, params, VerificationSession.class, options);
}
/** Shows last VerificationSession error. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class LastError extends StripeObject {
/**
* A short machine-readable string giving the reason for the verification or user-session
* failure.
*
*
One of {@code abandoned}, {@code consent_declined}, {@code country_not_supported}, {@code
* device_not_supported}, {@code document_expired}, {@code document_type_not_supported}, {@code
* document_unverified_other}, {@code id_number_insufficient_document_data}, {@code
* id_number_mismatch}, {@code id_number_unverified_other}, {@code
* selfie_document_missing_photo}, {@code selfie_face_mismatch}, {@code selfie_manipulated},
* {@code selfie_unverified_other}, or {@code under_supported_age}.
*/
@SerializedName("code")
String code;
/** A message that explains the reason for verification or user-session failure. */
@SerializedName("reason")
String reason;
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Options extends StripeObject {
@SerializedName("document")
Document document;
@SerializedName("id_number")
IdNumber idNumber;
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Document extends StripeObject {
/**
* Array of strings of allowed identity document types. If the provided identity document
* isn’t one of the allowed types, the verification check will fail with a
* document_type_not_allowed error code.
*/
@SerializedName("allowed_types")
List allowedTypes;
/**
* Collect an ID number and perform an ID number
* check with the document’s extracted name and date of birth.
*/
@SerializedName("require_id_number")
Boolean requireIdNumber;
/**
* Disable image uploads, identity document images have to be captured using the device’s
* camera.
*/
@SerializedName("require_live_capture")
Boolean requireLiveCapture;
/**
* Capture a face image and perform a selfie check
* comparing a photo ID and a picture of your user’s face. Learn more.
*/
@SerializedName("require_matching_selfie")
Boolean requireMatchingSelfie;
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class IdNumber extends StripeObject {}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Redaction extends StripeObject {
/**
* Indicates whether this object and its related objects have been redacted or not.
*
* One of {@code processing}, or {@code redacted}.
*/
@SerializedName("status")
String status;
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class VerifiedOutputs extends StripeObject {
/** The user's verified address. */
@SerializedName("address")
Address address;
/** The user’s verified date of birth. */
@SerializedName("dob")
Dob dob;
/** The user's verified first name. */
@SerializedName("first_name")
String firstName;
/** The user's verified id number. */
@SerializedName("id_number")
String idNumber;
/**
* The user's verified id number type.
*
*
One of {@code br_cpf}, {@code sg_nric}, or {@code us_ssn}.
*/
@SerializedName("id_number_type")
String idNumberType;
/** The user's verified last name. */
@SerializedName("last_name")
String lastName;
/** Point in Time. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Dob extends StripeObject {
/** Numerical day between 1 and 31. */
@SerializedName("day")
Long day;
/** Numerical month between 1 and 12. */
@SerializedName("month")
Long month;
/** The four-digit year. */
@SerializedName("year")
Long year;
}
}
}