# `Stripe.Resources.Identity.VerificationSession`
[🔗](https://github.com/jeffhuen/tiger_stripe/blob/main/lib/stripe/resources/identity/verification_session.ex#L2)

GelatoVerificationSession

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](https://docs.stripe.com/docs/identity/verification-checks) to perform. Only create one VerificationSession for
each verification in your system.

A VerificationSession transitions through [multiple
statuses](https://docs.stripe.com/docs/identity/how-sessions-work) 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](https://docs.stripe.com/identity/verification-sessions)

# `t`

```elixir
@type t() :: %Stripe.Resources.Identity.VerificationSession{
  client_reference_id: String.t(),
  client_secret: String.t(),
  created: integer(),
  id: String.t(),
  last_error: Stripe.Resources.Identity.VerificationSession.LastError.t(),
  last_verification_report:
    String.t() | Stripe.Resources.Identity.VerificationReport.t(),
  livemode: boolean(),
  metadata: %{required(String.t()) =&gt; String.t()},
  object: String.t(),
  options: Stripe.Resources.Identity.VerificationSession.Options.t(),
  provided_details:
    Stripe.Resources.Identity.VerificationSession.ProvidedDetails.t() | nil,
  redaction: Stripe.Resources.Identity.VerificationSession.Redaction.t(),
  related_customer: String.t(),
  related_customer_account: String.t(),
  related_person:
    Stripe.Resources.Identity.VerificationSession.RelatedPerson.t() | nil,
  status: String.t(),
  type: String.t(),
  url: String.t(),
  verification_flow: String.t() | nil,
  verified_outputs:
    Stripe.Resources.Identity.VerificationSession.VerifiedOutputs.t() | nil
}
```

* `client_reference_id` - A string to reference this user. This can be a customer ID, a session ID, or similar, and can be used to reconcile this verification with your internal systems. Max length: 5000. Nullable.
* `client_secret` - The short-lived client secret used by Stripe.js to [show a verification modal](https://docs.stripe.com/js/identity/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](https://docs.stripe.com/identity/verification-sessions#client-secret) to learn more. Max length: 5000. Nullable.
* `created` - Time at which the object was created. Measured in seconds since the Unix epoch. Format: Unix timestamp.
* `id` - Unique identifier for the object. Max length: 5000.
* `last_error` - If present, this property tells you the last error encountered when processing the verification. Nullable. Expandable.
* `last_verification_report` - ID of the most recent VerificationReport. [Learn more about accessing detailed verification results.](https://docs.stripe.com/identity/verification-sessions#results) Nullable. Expandable.
* `livemode` - Has the value `true` if the object exists in live mode or the value `false` if the object exists in test mode.
* `metadata` - Set of [key-value pairs](https://docs.stripe.com/api/metadata) that you can attach to an object. This can be useful for storing additional information about the object in a structured format.
* `object` - String representing the object's type. Objects of the same type share the same value. Possible values: `identity.verification_session`.
* `options` - A set of options for the session’s verification checks. Nullable. Expandable.
* `provided_details` - Details provided about the user being verified. These details may be shown to the user. Nullable. Expandable.
* `redaction` - Redaction status of this VerificationSession. If the VerificationSession is not redacted, this field will be null. Nullable. Expandable.
* `related_customer` - Customer ID Max length: 5000. Nullable.
* `related_customer_account` - The ID of the Account representing a customer. Max length: 5000. Nullable.
* `related_person` - Expandable.
* `status` - Status of this VerificationSession. [Learn more about the lifecycle of sessions](https://docs.stripe.com/identity/how-sessions-work). Possible values: `canceled`, `processing`, `requires_input`, `verified`.
* `type` - The type of [verification check](https://docs.stripe.com/identity/verification-checks) to be performed. Possible values: `document`, `id_number`, `verification_flow`.
* `url` - 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](https://docs.stripe.com/identity/verify-identity-documents?platform=web&type=redirect) to learn how to redirect users to Stripe. Max length: 5000. Nullable.
* `verification_flow` - The configuration token of a verification flow from the dashboard. Max length: 5000.
* `verified_outputs` - The user’s verified data. Nullable. Expandable.

# `expandable_fields`

# `object_name`

---

*Consult [api-reference.md](api-reference.md) for complete listing*
