Skip to content

Create Checkout API

Initialize a payment session for cross-chain cryptocurrency payments. This is the first step in the CyberPay payment flow.

Endpoint

POST /v1/checkout/create

Authentication

This endpoint requires API key authentication:

Authorization: Bearer YOUR_API_KEY

Request Parameters

ParameterTypeRequiredDescription
merchantIdstringYour merchant identifier
amountstringPayment amount in the specified currency
currencystringTarget settlement currency (e.g., "USDC", "USDT")
productInfoobjectProduct or service details
returnUrlstringURL to redirect after payment completion
cancelUrlstringURL to redirect if payment is cancelled
webhookUrlstringURL for payment status notifications
metadataobjectCustom data to associate with this payment
expiresAtnumberSession expiration timestamp (Unix)

ProductInfo Object

interface ProductInfo {
  name: string;           // Product/service name
  description?: string;   // Detailed description
  imageUrl?: string;      // Product image URL
  category?: string;      // Product category
  sku?: string;          // Stock keeping unit
}

Example Request

{
  "merchantId": "merchant_abc123",
  "amount": "99.99",
  "currency": "USDC",
  "productInfo": {
    "name": "Premium Subscription",
    "description": "1-year premium access to our platform",
    "imageUrl": "https://example.com/product.jpg",
    "category": "subscription"
  },
  "returnUrl": "https://yourstore.com/payment/success",
  "cancelUrl": "https://yourstore.com/payment/cancel",
  "webhookUrl": "https://yourstore.com/webhooks/cyberpay",
  "metadata": {
    "orderId": "order_xyz789",
    "customerId": "customer_456",
    "source": "web"
  },
  "expiresAt": 1759234785
}

Response Format

Success Response

{
  "success": true,
  "data": {
    "checkoutId": "checkout_1759231185333_abc123",
    "status": "created",
    "amount": "99.99",
    "currency": "USDC",
    "productInfo": {
      "name": "Premium Subscription",
      "description": "1-year premium access to our platform",
      "imageUrl": "https://example.com/product.jpg",
      "category": "subscription"
    },
    "availablePaymentMethods": [
      {
        "chainId": 1,
        "chainName": "Ethereum",
        "tokens": [
          {
            "symbol": "ETH",
            "address": "0x0000000000000000000000000000000000000000",
            "decimals": 18,
            "name": "Ethereum"
          },
          {
            "symbol": "USDC",
            "address": "0xA0b86a33E6441b8e776f89d2b5B977c737C5e0b6",
            "decimals": 6,
            "name": "USD Coin"
          }
        ]
      },
      {
        "chainId": 137,
        "chainName": "Polygon",
        "tokens": [
          {
            "symbol": "MATIC",
            "address": "0x0000000000000000000000000000000000000000",
            "decimals": 18,
            "name": "Polygon"
          },
          {
            "symbol": "USDC",
            "address": "0x3c499c542cEF5E3811e1192ce70d8cC03d5c3359",
            "decimals": 6,
            "name": "USD Coin"
          }
        ]
      }
    ],
    "paymentUrl": "https://pay.cyberpay.org/checkout/checkout_1759231185333_abc123",
    "qrCode": "...",
    "returnUrl": "https://yourstore.com/payment/success",
    "cancelUrl": "https://yourstore.com/payment/cancel",
    "metadata": {
      "orderId": "order_xyz789",
      "customerId": "customer_456",
      "source": "web"
    },
    "createdAt": 1759231185,
    "expiresAt": 1759234785
  },
  "timestamp": "2024-01-01T00:00:00Z"
}

Response Fields

FieldTypeDescription
checkoutIdstringUnique checkout session identifier
statusstringCurrent checkout status (created, expired, completed)
amountstringPayment amount
currencystringSettlement currency
availablePaymentMethodsarraySupported payment tokens by network
paymentUrlstringHosted payment page URL
qrCodestringQR code for mobile payments (base64 encoded)
createdAtnumberCreation timestamp
expiresAtnumberExpiration timestamp

Error Responses

Invalid Parameters

{
  "success": false,
  "error": {
    "code": "INVALID_PARAMETERS",
    "message": "Invalid request parameters",
    "details": {
      "field": "amount",
      "reason": "Amount must be a positive number"
    }
  },
  "timestamp": "2024-01-01T00:00:00Z"
}

Unsupported Currency

{
  "success": false,
  "error": {
    "code": "UNSUPPORTED_CURRENCY",
    "message": "Currency not supported",
    "details": {
      "currency": "XYZ",
      "supportedCurrencies": ["USDC", "USDT", "DAI", "ETH"]
    }
  },
  "timestamp": "2024-01-01T00:00:00Z"
}

Merchant Not Found

{
  "success": false,
  "error": {
    "code": "MERCHANT_NOT_FOUND",
    "message": "Merchant ID not found or inactive",
    "details": {
      "merchantId": "merchant_abc123"
    }
  },
  "timestamp": "2024-01-01T00:00:00Z"
}

Code Examples

JavaScript/TypeScript

import { CyberPaySDK } from '@cyberpay/sdk';
 
const sdk = new CyberPaySDK({
  apiKey: 'YOUR_API_KEY',
  environment: 'production' // or 'testnet'
});
 
async function createCheckout() {
  try {
    const checkout = await sdk.checkout.create({
      merchantId: 'merchant_abc123',
      amount: '99.99',
      currency: 'USDC',
      productInfo: {
        name: 'Premium Subscription',
        description: '1-year premium access to our platform'
      },
      returnUrl: 'https://yourstore.com/payment/success',
      metadata: {
        orderId: 'order_xyz789',
        customerId: 'customer_456'
      }
    });
    
    console.log('Checkout created:', checkout);
    
    // Redirect user to payment page
    window.location.href = checkout.paymentUrl;
    
    return checkout;
  } catch (error) {
    console.error('Error creating checkout:', error);
  }
}

cURL

curl -X POST https://api.cyberpay.org/v1/checkout/create \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "merchantId": "merchant_abc123",
    "amount": "99.99",
    "currency": "USDC",
    "productInfo": {
      "name": "Premium Subscription",
      "description": "1-year premium access to our platform"
    },
    "returnUrl": "https://yourstore.com/payment/success",
    "metadata": {
      "orderId": "order_xyz789",
      "customerId": "customer_456"
    }
  }'

Python

import requests
 
def create_checkout():
    url = "https://api.cyberpay.org/v1/checkout/create"
    headers = {
        "Authorization": "Bearer YOUR_API_KEY",
        "Content-Type": "application/json"
    }
    data = {
        "merchantId": "merchant_abc123",
        "amount": "99.99",
        "currency": "USDC",
        "productInfo": {
            "name": "Premium Subscription",
            "description": "1-year premium access to our platform"
        },
        "returnUrl": "https://yourstore.com/payment/success",
        "metadata": {
            "orderId": "order_xyz789",
            "customerId": "customer_456"
        }
    }
    
    response = requests.post(url, headers=headers, json=data)
    return response.json()

Integration Patterns

Hosted Payment Page

The simplest integration redirects users to CyberPay's hosted payment page:

// Create checkout and redirect
const checkout = await sdk.checkout.create({...});
window.location.href = checkout.paymentUrl;

Embedded Payment Widget

For a more integrated experience, embed the payment widget:

<div id="cyberpay-widget"></div>
 
<script>
CyberPay.embed({
  checkoutId: 'checkout_1759231185333_abc123',
  container: '#cyberpay-widget',
  onSuccess: (payment) => {
    console.log('Payment successful:', payment);
    window.location.href = '/success';
  },
  onError: (error) => {
    console.error('Payment failed:', error);
  }
});
</script>

Mobile Deep Links

For mobile apps, use deep links to popular wallets:

const checkout = await sdk.checkout.create({...});
 
// Generate wallet-specific deep links
const deepLinks = {
  metamask: `https://metamask.app.link/dapp/${checkout.paymentUrl}`,
  trust: `https://link.trustwallet.com/open_url?coin_id=60&url=${checkout.paymentUrl}`,
  coinbase: `https://go.cb-w.com/dapp?cb_url=${checkout.paymentUrl}`
};

Webhook Integration

Set up webhooks to receive real-time payment updates:

// Webhook endpoint on your server
app.post('/webhooks/cyberpay', (req, res) => {
  const signature = req.headers['x-cyberpay-signature'];
  const payload = req.body;
  
  // Verify webhook signature
  if (!sdk.webhooks.verify(payload, signature)) {
    return res.status(401).send('Invalid signature');
  }
  
  // Handle payment events
  switch (payload.event) {
    case 'checkout.completed':
      console.log('Payment completed:', payload.data);
      // Update your database, send confirmation email, etc.
      break;
    case 'checkout.failed':
      console.log('Payment failed:', payload.data);
      // Handle failed payment
      break;
  }
  
  res.status(200).send('OK');
});

Best Practices

Security

  • Always validate webhook signatures
  • Use HTTPS for all URLs (returnUrl, cancelUrl, webhookUrl)
  • Store sensitive data in metadata only if encrypted
  • Implement proper API key management

User Experience

  • Set reasonable expiration times (typically 15-30 minutes)
  • Provide clear product information and images
  • Handle payment failures gracefully
  • Show payment progress to users

Error Handling

  • Implement retry logic for network failures
  • Validate all parameters before API calls
  • Provide meaningful error messages to users
  • Log errors for debugging

Performance

  • Cache available payment methods when possible
  • Use appropriate timeout values
  • Implement proper loading states
  • Consider using webhooks instead of polling

Rate Limits

  • Standard: 100 requests per minute
  • Premium: 1000 requests per minute
  • Enterprise: Custom limits available

Next Steps

After creating a checkout:

  1. Get Quote - Get real-time pricing for payment routes
  2. Create Order - Lock in pricing and create payment order
  3. Execute Payment - Process the cross-chain transaction
  4. Query Status - Monitor payment progress

Support