RevKeen Docs
Api reference

Create a one-time charge

Create a one-time charge for an existing customer. This is for ad-hoc charges like setup fees, overages, or one-time services. For recurring billing, use subscriptions instead.

The charge will be processed immediately using the customer's default payment method, unless a specific payment method ID is provided.


Related endpoints

  • GET /charges — List charges
  • GET /charges/{id} — Get charge
  • POST /charges/{id}/capture — Capture charge
  • POST /charges/{id}/refund — Refund charge

Common errors

  • 400 invalid_request — malformed payload or failed validation.
  • 401 unauthenticated — missing, malformed, or revoked API key.
  • 404 resource_missing — the referenced resource does not exist or is not visible to your key.
  • 409 conflict — Idempotency-Key collision with a different body, or a concurrent state-transition conflict.

Idempotency

Pass an Idempotency-Key header (UUID v4 recommended) to make retries safe. Keys are valid for 24 hours; see the idempotency guide.

POST
/charges
x-api-key<token>

Your RevKeen API key (powered by Unkey). Get it from Dashboard > Settings > API Keys. Use rk_sandbox_* for test mode and rk_live_* for production.

In: header

Request Body

application/json

TypeScript Definitions

Use the request body type in TypeScript.

Response Body

application/json

application/json

application/json

curl -X POST "https://api.revkeen.com/v2/charges" \  -H "x-api-key: $REVKEEN_API_KEY" \  -H "Content-Type: application/json" \  -d '{    "customerId": "00000000-0000-0000-0000-000000000000",    "amountMinor": 0,    "description": "string"  }'
{
  "data": {
    "id": "string",
    "customerId": "string",
    "invoiceId": "string",
    "paymentMethodId": "string",
    "amountMinor": 0,
    "amountCapturedMinor": 0,
    "amountRefundedMinor": 0,
    "currency": "str",
    "status": "pending",
    "description": "string",
    "statementDescriptor": "string",
    "failureCode": "string",
    "failureMessage": "string",
    "gatewayTransactionId": "string",
    "receiptUrl": "string",
    "captured": true,
    "metadata": {
      "property1": null,
      "property2": null
    },
    "createdAt": "2019-08-24T14:15:22Z",
    "updatedAt": "2019-08-24T14:15:22Z"
  }
}
{
  "error": "string",
  "code": "string"
}
Empty
Empty
{
  "error": "string",
  "existingChargeId": "string"
}