Create product
Create a new product. Requires 'products:write' scope.
Related endpoints
GET /products— List productsGET /products/{id}— Get product by IDPATCH /products/{id}— Update productPUT /products/external/{source}/{externalId}— Upsert product by external IDPUT /products/external/batch— Batch upsert products by external ID
Common errors
400 invalid_request— malformed payload or failed validation.401 unauthenticated— missing, malformed, or revoked API key.
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
Product creation details
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/products" \ -H "x-api-key: $REVKEEN_API_KEY" \ -H "Content-Type: application/json" \ -d '{ "product_id": "string", "name": "string", "description": null, "kind": "subscription", "pricing_model": "one_time", "amount_minor": 0, "currency": "USD", "interval": null, "interval_count": null, "trial_days": 0, "usage_meter_id": null, "slug": "string", "fulfillment_type": "none", "billing_anchor_rule": "same_day", "billing_anchor_day": null, "first_charge_behavior": "immediate", "end_behavior": "until_canceled", "max_payments": null, "metadata": {} }'{
"data": {
"id": "497f6eca-6276-4993-bfeb-53cbbbba6f08",
"object": "product",
"product_id": "string",
"name": "string",
"description": "string",
"kind": "subscription",
"pricing_model": "one_time",
"amount_minor": 0,
"currency": "string",
"interval": "string",
"interval_count": 0,
"trial_days": 0,
"fulfillment_type": "none",
"billing_anchor_rule": "same_day",
"billing_anchor_day": 0,
"first_charge_behavior": "immediate",
"end_behavior": "until_canceled",
"max_payments": 0,
"usage_meter_id": "string",
"slug": "string",
"is_active": true,
"is_archived": true,
"image_url": "string",
"tax_behavior": "string",
"tax_code": "string",
"metadata": {},
"created_at": "2019-08-24T14:15:22Z",
"updated_at": "2019-08-24T14:15:22Z"
}
}{
"error": "string"
}{
"error": "string"
}