Handling errors | Stripe API Reference (original) (raw)

Our Client libraries raise exceptions for many reasons, such as a failed charge, invalid parameters, authentication errors, and network unavailability. We recommend writing code that gracefully handles all possible API exceptions.


# Select a client library to see examples of

# handling different kinds of errors.

Expanding Responses

Many objects allow you to request additional information as an expanded response by using the expand request parameter. This parameter is available on all API requests, and applies to the response of that request only. You can expand responses in two ways.

In many cases, an object contains the ID of a related object in its response properties. For example, a Charge might have an associated Customer ID. You can expand these objects in line with the expand request parameter. The expandable label in this documentation indicates ID fields that you can expand into objects.

Some available fields aren’t included in the responses by default, such as the number and cvc fields for the Issuing Card object. You can request these fields as an expanded response by using the expand request parameter.

You can expand recursively by specifying nested fields after a dot (.). For example, requesting payment_intent.customer on a charge expands the payment_intent property into a full Customer object, then expands the customer property on that payment intent into a full Customer object.

You can use the expand parameter on any endpoint that returns expandable fields, including list, create, and update endpoints.

Expansions on list requests start with the data property. For example, you can expand data.customers on a request to list charges and associated customers. Performing deep expansions on numerous list requests might result in slower processing times.

Expansions have a maximum depth of four levels (for example, the deepest expansion allowed when listing charges is data.payment_intent.customer.default_source).

You can expand multiple objects at the same time by identifying multiple items in the expand array.


curl https://api.stripe.com/v1/charges/ch_3LmzzQ2eZvKYlo2C0XjzUzJV \

  -u sk_test_BQokikJ...2HlWgH4olfQ2sk_test_BQokikJOvBiI2HlWgH4olfQ2: \

  -d "expand[]"=customer \

  -d "expand[]"="payment_intent.customer" \

  -G


{

  "id": "ch_3LmzzQ2eZvKYlo2C0XjzUzJV",

  "object": "charge",

  "customer": {

    "id": "cu_14HOpH2eZvKYlo2CxXIM7Pb2",

    "object": "customer",

    // ...

  },

  "payment_intent": {

    "id": "pi_3MtwBwLkdIwHu7ix28a3tqPa",

    "object": "payment_intent",

    "customer": {

      "id": "cus_NffrFeUfNV2Hib",

      "object": "customer",

      // ...

    },

    // ...

  },

  // ...

}

Idempotent requests

The API supports idempotency for safely retrying requests without accidentally performing the same operation twice. When creating or updating an object, use an idempotency key. Then, if a connection error occurs, you can safely repeat the request without risk of creating a second object or performing the update twice.

To perform an idempotent request, provide an additional IdempotencyKey element to the request options.

Stripe’s idempotency works by saving the resulting status code and body of the first request made for any given idempotency key, regardless of whether it succeeds or fails. Subsequent requests with the same key return the same result, including 500 errors.

A client generates an idempotency key, which is a unique key that the server uses to recognize subsequent retries of the same request. How you create unique keys is up to you, but we suggest using V4 UUIDs, or another random string with enough entropy to avoid collisions. Idempotency keys are up to 255 characters long.

You can remove keys from the system automatically after they’re at least 24 hours old. We generate a new request if a key is reused after the original is pruned. The idempotency layer compares incoming parameters to those of the original request and errors if they’re not the same to prevent accidental misuse.

We save results only after the execution of an endpoint begins. If incoming parameters fail validation, or the request conflicts with another request that’s executing concurrently, we don’t save the idempotent result because no API endpoint initiates the execution. You can retry these requests. Learn more about when you can retry idempotent requests.

All POST requests accept idempotency keys. Don’t send idempotency keys in GET and DELETE requests because it has no effect. These requests are idempotent by definition.


curl https://api.stripe.com/v1/customers \

  -u sk_test_BQokikJ...2HlWgH4olfQ2sk_test_BQokikJOvBiI2HlWgH4olfQ2: \

  -H "Idempotency-Key: KG5LxwFBepaKHyUD" \

  -d description="My First Test Customer (created for API docs at https://docs.stripe.com/api)"

Metadata

Updateable Stripe objects—including Account, Charge, Customer, PaymentIntent, Refund, Subscription, and Transfer have a metadata parameter. You can use this parameter to attach key-value data to these Stripe objects.

You can specify up to 50 keys, with key names up to 40 characters long and values up to 500 characters long. Keys and values are stored as strings and can contain any characters with one exception: you can’t use square brackets ([ and ]) in keys.

You can use metadata to store additional, structured information on an object. For example, you could store your user’s full name and corresponding unique identifier from your system on a Stripe Customer object. Stripe doesn’t use metadata—for example, we don’t use it to authorize or decline a charge and it won’t be seen by your users unless you choose to show it to them.

Some of the objects listed above also support a description parameter. You can use the description parameter to annotate a charge-for example, a human-readable description such as 2 shirts for test@example.com. Unlike metadata, description is a single string, which your users might see (for example, in email receipts Stripe sends on your behalf).

Don’t store any sensitive information (bank account numbers, card details, and so on) as metadata or in the description parameter.

Sample metadata use cases


curl https://api.stripe.com/v1/customers \

  -u "sk_test_BQokikJ...2HlWgH4olfQ2sk_test_BQokikJOvBiI2HlWgH4olfQ2:" \

  -d "metadata[order_id]"=6735


{

  "id": "cus_123456789",

  "object": "customer",

  "address": {

    "city": "city",

    "country": "US",

    "line1": "line 1",

    "line2": "line 2",

    "postal_code": "90210",

    "state": "CA"

  },

  "balance": 0,

  "created": 1483565364,

  "currency": null,

  "default_source": null,

  "delinquent": false,

  "description": null,

  "discount": null,

  "email": null,

  "invoice_prefix": "C11F7E1",

  "invoice_settings": {

    "custom_fields": null,

    "default_payment_method": null,

    "footer": null,

    "rendering_options": null

  },

  "livemode": false,

  "metadata": {

    "order_id": "6735"

  },

  "name": null,

  "next_invoice_sequence": 1,

  "phone": null,

  "preferred_locales": [],

  "shipping": null,

  "tax_exempt": "none"

}