RevKeen Docs
Api reference

Update product

Update an existing product. Requires 'products:write' scope.


Related endpoints

  • GET /products — List products
  • POST /products — Create product
  • GET /products/{id} — Get product by ID
  • PUT /products/external/{source}/{externalId} — Upsert product by external ID
  • PUT /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.
  • 404 resource_missing — the referenced resource does not exist or is not visible to your key.

Idempotency

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

PATCH
/products/{id}
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

Path Parameters

id*string
Formatuuid

Request Body

application/json

Product update details

TypeScript Definitions

Use the request body type in TypeScript.

Response Body

application/json

application/json

application/json

application/json

curl -X PATCH "https://api.revkeen.com/v2/products/prod_123" \  -H "x-api-key: $REVKEEN_API_KEY" \  -H "Content-Type: application/json" \  -d '{    "name": "string",    "description": null,    "amount_minor": 0,    "currency": "string",    "interval": null,    "interval_count": null,    "trial_days": 0,    "is_active": false,    "is_archived": false,    "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"
}
{
  "error": "string"
}