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

com.stripe.model.identity.VerificationSession Maven / Gradle / Ivy

There is a newer version: 28.2.0
Show newest version
// 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; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy