Api reference
List products
List products with pagination and optional search.
Related endpoints
POST /products— Create productGET /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.
Pagination
Offset-based with limit (default 25, max 100) and offset. The response pagination block includes total and hasMore. See the pagination guide for SDK auto-paging helpers.
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
Query Parameters
page?integer
Page number
Default
1Range
1 <= valuelimit?integer
Maximum number of results (1-100)
Default
20Range
1 <= value <= 100search?string
Search term to filter products
Response Body
application/json
application/json
application/json
curl "https://api.revkeen.com/v2/products" \ -H "x-api-key: $REVKEEN_API_KEY"{
"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"
}
],
"pagination": {
"kind": "offset",
"page": 0,
"limit": 0,
"total": 0,
"totalPages": 0
}
}{
"error": "string"
}{
"error": "string"
}