Skip to main content
Checkout sessions represent an individual payment attempt. You can create sessions server-side to generate unique checkout URLs for each customer, pre-fill payment details, and track conversions with your own reference IDs.
Checkout sessions expire after 30 minutes by default. Use the expires_in parameter to customize the expiration window (minimum 5 minutes, maximum 24 hours).

The Checkout Session object

id
string
Unique identifier for the checkout session (e.g., cs_abc123).
url
string
The checkout URL to redirect the customer to.
status
string
Current status of the session. One of: open, processing, completed, expired, failed.
Associated payment link ID, if the session was created from a payment link.
product_id
string | null
Associated product ID.
token_address
string
Contract address of the token to receive.
chain_id
number
Chain ID where you want to receive payment.
recipient_address
string
Wallet address that receives the payment.
amount
string
Payment amount in the token’s smallest unit.
amount_usd
string | null
USD equivalent at the time of session creation.
success_url
string | null
URL the customer is redirected to after successful payment. Supports template variables.
cancel_url
string | null
URL the customer is redirected to if they cancel.
client_reference_id
string | null
Your internal reference ID for this session.
metadata
object | null
Arbitrary key-value pairs passed through to webhooks and the transaction.
customer_email
string | null
Email address of the customer. Encrypted at rest, included in webhook payloads.
customer_name
string | null
Name of the customer. Encrypted at rest, included in webhook payloads.
payer_address
string | null
Wallet address of the payer (populated after connection).
tx_hash
string | null
On-chain transaction hash (populated after submission).
customer_id
string | null
Associated customer ID (populated after payment).
form_data
object | null
Custom form data submitted by the customer.
shipping_address
object | null
Shipping address provided by the customer.
utm_source
string | null
UTM source parameter for attribution.
utm_medium
string | null
UTM medium parameter for attribution.
utm_campaign
string | null
UTM campaign parameter for attribution.
expires_at
string
ISO 8601 expiration timestamp.
created_at
string
ISO 8601 creation timestamp.
completed_at
string | null
ISO 8601 completion timestamp.

Session statuses

StatusDescription
openSession is active and waiting for the customer to pay.
processingCustomer has initiated payment; transaction is being processed on-chain.
completedPayment confirmed and received by the recipient.
expiredSession expired before the customer completed payment.
failedPayment failed due to on-chain error or timeout.

URL template variables

The success_url and cancel_url fields support template variables that are replaced with actual values when the customer is redirected:
VariableDescriptionExample
{SESSION_ID}The checkout session IDcs_abc123
Use template variables to look up session details on your server after redirect: https://example.com/success?session_id={SESSION_ID}

List checkout sessions

Retrieve a paginated list of checkout sessions.
status
string
Filter by session status: open, processing, completed, expired, failed.
Filter by payment link ID.
page
number
default:1
Page number for pagination.
limit
number
default:20
Number of results per page (max 100).
curl -X GET "https://platform-api.anyspend.com/api/v1/checkout-sessions?status=completed&page=1&limit=20" \
  -H "Authorization: Bearer asp_xxx"
{
  "data": [
    {
      "id": "cs_abc123",
      "url": "https://pay.anyspend.com/s/cs_abc123",
      "status": "completed",
      "payment_link_id": "pl_abc123",
      "product_id": null,
      "token_address": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
      "chain_id": 1,
      "recipient_address": "0x1234567890abcdef1234567890abcdef12345678",
      "amount": "50000000",
      "amount_usd": "50.00",
      "success_url": "https://example.com/success?session_id=cs_abc123",
      "cancel_url": "https://example.com/cancel",
      "client_reference_id": "order_12345",
      "metadata": {
        "order_id": "12345"
      },
      "payer_address": "0xaabb1234ccdd5678eeff9900aabb1234ccdd5678",
      "tx_hash": "0x9f8e7d6c5b4a3f2e1d0c9b8a7f6e5d4c3b2a1f0e",
      "customer_id": "cust_abc123",
      "form_data": null,
      "shipping_address": null,
      "utm_source": "twitter",
      "utm_medium": "social",
      "utm_campaign": "launch_feb_2026",
      "expires_at": "2026-02-25T08:45:00Z",
      "created_at": "2026-02-25T08:15:00Z",
      "completed_at": "2026-02-25T08:16:30Z"
    }
  ],
  "pagination": {
    "page": 1,
    "limit": 20,
    "total": 340,
    "total_pages": 17,
    "has_more": true
  }
}

Create a checkout session

Create a server-side checkout session with a unique payment URL. Use this for programmatic integrations where you control the checkout flow from your backend.
Create the session from an existing payment link. This inherits the link’s configuration. Either payment_link_id or the manual fields (token_address, chain_id, recipient_address, amount) are required.
token_address
string
Contract address of the token to receive. Required if payment_link_id is not provided.
chain_id
number
Chain ID where you want to receive payment. Required if payment_link_id is not provided.
recipient_address
string
Wallet address that receives the payment. Required if payment_link_id is not provided.
amount
string
Payment amount in the token’s smallest unit. Required if payment_link_id is not provided.
product_id
string
Associate the session with a product.
success_url
string
URL to redirect the customer to after successful payment. Supports {SESSION_ID} template variable.
cancel_url
string
URL to redirect the customer to if they cancel.
client_reference_id
string
Your internal reference ID (e.g., order ID). Maximum 200 characters.
metadata
object
Arbitrary key-value pairs passed through to webhooks and the resulting transaction. Up to 50 keys, 500 character values.
customer_email
string
Customer email address. Encrypted at rest and included in webhook payloads for order fulfillment.
customer_name
string
Customer name. Encrypted at rest and included in webhook payloads for order fulfillment.
expires_in
number
default:1800
Session expiration time in seconds. Minimum 300 (5 minutes), maximum 86400 (24 hours). Default: 1800 (30 minutes).
utm_source
string
UTM source for attribution tracking.
utm_medium
string
UTM medium for attribution tracking.
utm_campaign
string
UTM campaign for attribution tracking.
# Create from a payment link
curl -X POST "https://platform-api.anyspend.com/api/v1/checkout-sessions" \
  -H "Authorization: Bearer asp_xxx" \
  -H "Content-Type: application/json" \
  -d '{
    "payment_link_id": "pl_abc123",
    "success_url": "https://example.com/success?session_id={SESSION_ID}",
    "cancel_url": "https://example.com/cancel",
    "client_reference_id": "order_12345",
    "metadata": {
      "order_id": "12345"
    },
    "customer_email": "alice@example.com",
    "customer_name": "Alice Smith",
    "expires_in": 3600
  }'

# Create with manual configuration
curl -X POST "https://platform-api.anyspend.com/api/v1/checkout-sessions" \
  -H "Authorization: Bearer asp_xxx" \
  -H "Content-Type: application/json" \
  -d '{
    "token_address": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
    "chain_id": 1,
    "recipient_address": "0x1234567890abcdef1234567890abcdef12345678",
    "amount": "25000000",
    "success_url": "https://example.com/success?session_id={SESSION_ID}",
    "cancel_url": "https://example.com/cancel",
    "client_reference_id": "inv_67890",
    "utm_source": "email",
    "utm_medium": "newsletter",
    "utm_campaign": "february_promo"
  }'
{
  "id": "cs_newSession123",
  "url": "https://pay.anyspend.com/s/cs_newSession123",
  "status": "open",
  "payment_link_id": "pl_abc123",
  "product_id": null,
  "token_address": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
  "chain_id": 1,
  "recipient_address": "0x1234567890abcdef1234567890abcdef12345678",
  "amount": "50000000",
  "amount_usd": "50.00",
  "success_url": "https://example.com/success?session_id={SESSION_ID}",
  "cancel_url": "https://example.com/cancel",
  "client_reference_id": "order_12345",
  "metadata": {
    "order_id": "12345",
    "user_email": "alice@example.com"
  },
  "payer_address": null,
  "tx_hash": null,
  "customer_id": null,
  "form_data": null,
  "shipping_address": null,
  "utm_source": null,
  "utm_medium": null,
  "utm_campaign": null,
  "expires_at": "2026-02-27T11:30:00Z",
  "created_at": "2026-02-27T10:30:00Z",
  "completed_at": null
}

Retrieve a checkout session

id
string
required
The checkout session ID (e.g., cs_abc123).
Use this endpoint in your success_url handler to verify payment status and retrieve transaction details after the customer is redirected back to your site.
curl -X GET "https://platform-api.anyspend.com/api/v1/checkout-sessions/cs_abc123" \
  -H "Authorization: Bearer asp_xxx"
Returns the full Checkout Session object.

Expire a checkout session

Manually expire an open checkout session. This is useful when the underlying order is cancelled or the payment is no longer needed.
id
string
required
The checkout session ID.
Only sessions with status: "open" can be expired. Attempting to expire a session in any other status will return a 400 Bad Request error.
curl -X POST "https://platform-api.anyspend.com/api/v1/checkout-sessions/cs_abc123/expire" \
  -H "Authorization: Bearer asp_xxx"
{
  "id": "cs_abc123",
  "url": "https://pay.anyspend.com/s/cs_abc123",
  "status": "expired",
  "payment_link_id": "pl_abc123",
  "product_id": null,
  "token_address": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
  "chain_id": 1,
  "recipient_address": "0x1234567890abcdef1234567890abcdef12345678",
  "amount": "50000000",
  "amount_usd": "50.00",
  "success_url": "https://example.com/success?session_id=cs_abc123",
  "cancel_url": "https://example.com/cancel",
  "client_reference_id": "order_12345",
  "metadata": {
    "order_id": "12345",
    "user_email": "alice@example.com"
  },
  "payer_address": null,
  "tx_hash": null,
  "customer_id": null,
  "form_data": null,
  "shipping_address": null,
  "utm_source": null,
  "utm_medium": null,
  "utm_campaign": null,
  "expires_at": "2026-02-27T10:35:00Z",
  "created_at": "2026-02-27T10:30:00Z",
  "completed_at": null
}

Common patterns

Server-side checkout flow

A typical server-side integration creates a checkout session on your backend and redirects the customer to the session URL:
// 1. Your server creates a session
app.post("/create-checkout", async (req, res) => {
  const session = await anyspend.checkoutSessions.create({
    paymentLinkId: "pl_abc123",
    successUrl: "https://yoursite.com/success?session_id={SESSION_ID}",
    cancelUrl: "https://yoursite.com/cart",
    clientReferenceId: req.body.orderId,
    metadata: {
      user_id: req.user.id,
    },
    expiresIn: 1800, // 30 minutes
  });

  // 2. Redirect customer to pay
  res.redirect(303, session.url);
});

// 3. Handle the redirect after payment
app.get("/success", async (req, res) => {
  const session = await anyspend.checkoutSessions.retrieve(
    req.query.session_id
  );

  if (session.status === "completed") {
    // Fulfill the order
    await fulfillOrder(session.client_reference_id, {
      txHash: session.tx_hash,
      payer: session.payer_address,
    });
  }

  res.render("success", { session });
});
Always verify the session status server-side after redirect. Do not rely solely on the redirect to confirm payment — use webhooks for reliable payment confirmation.

Polling for session completion

If you prefer polling over webhooks, you can check the session status periodically:
async function waitForPayment(sessionId: string, timeoutMs = 300000) {
  const startTime = Date.now();

  while (Date.now() - startTime < timeoutMs) {
    const session = await anyspend.checkoutSessions.retrieve(sessionId);

    if (session.status === "completed") {
      return session;
    }

    if (session.status === "expired" || session.status === "failed") {
      throw new Error(`Session ${session.status}: ${sessionId}`);
    }

    // Wait 3 seconds before polling again
    await new Promise((resolve) => setTimeout(resolve, 3000));
  }

  throw new Error(`Timeout waiting for payment: ${sessionId}`);
}
For production use, we strongly recommend using webhooks instead of polling. Webhooks provide real-time notifications and do not require keeping a connection open.