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 chargesGET /charges/{id}— Get chargePOST /charges/{id}/capture— Capture chargePOST /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.
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"
}{
"error": "string",
"existingChargeId": "string"
}