Boards (post categories) organize feedback into distinct containers with their own settings.
Featurebase API (2026-01-01.nova)
Welcome to the Featurebase API. This API allows you to programmatically interact with your Featurebase organization.
This documentation reflects API version 2026-01-01.nova.
This API uses date-based versioning. Each version is identified by a release date and slug, e.g., 2026-01-01.nova.
Specifying a Version
Include the version in the request header:
Featurebase-Version: 2026-01-01.novaOr set a default version for your organization in the dashboard settings.
Version Compatibility
- Newer versions may add new fields to responses (always backwards-compatible)
- Breaking changes (removed/renamed fields, changed behavior) only occur in new versions
- Your integration will continue to work as long as you pin to a specific version
All API requests require authentication via API key.
Include in headers:
Authorization: Bearer <api-key>Create and manage your API keys in the Featurebase dashboard.
The API uses conventional HTTP response codes to indicate success or failure:
2xx- Success4xx- Client errors (bad request, unauthorized, not found, etc.)5xx- Server errors (internal error)
Error Response Format
All errors follow a consistent format:
{
"error": {
"type": "invalid_request_error",
"code": "resource_not_found",
"message": "Post not found",
"param": "id",
"status": 404
}
}Error Types
| Type | Description |
|---|---|
authentication_error | Authentication failed (401) |
authorization_error | Permission denied (403) |
invalid_request_error | Invalid request parameters or resource not found (400, 404, 410) |
api_error | Server-side error (500) |
rate_limit_error | Too many requests (429) |
- Mock serverhttps://docs.featurebase.app/_mock/rest-api/v2/tickets/categories/{id}
- Productionhttps://do.featurebase.app/v2/tickets/categories/{id}
- curl
- JavaScript
- Node.js
- Python
- Java
- C#
- PHP
- Go
- Ruby
- R
- Payload
curl -i -X GET \
https://docs.featurebase.app/_mock/rest-api/v2/tickets/categories/507f1f77bcf86cd799439011 \
-H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
-H 'Featurebase-Version: 2026-01-01.nova'Success
The board's icon. Can be one of three types:
- emoji: A single emoji character (e.g., 💡, 🚀, ⭐)
- icon: A predefined icon from the built-in library (e.g., lightbulb, bug, star)
- url: A custom image URL (HTTPS required)
Can be null if no icon is set.
The board's icon. Can be one of three types:
- emoji: A single emoji character (e.g., 💡, 🚀, ⭐)
- icon: A predefined icon from the built-in library (e.g., lightbulb, bug, star)
- url: A custom image URL (HTTPS required)
Can be null if no icon is set.
Custom field IDs attached to this board
Localized board name (language code → text)
Localized description
Placeholder text in the post creation form
Hero title shown on the board page
Hero description/subtitle
{ "object": "board", "id": "507f1f77bcf86cd799439011", "name": "Feature Requests", "icon": { "type": "emoji", "value": "💡" }, "access": { "adminOnly": false, "segments": [], "allowedRoles": [], "deniedRoles": [ … ] }, "features": { "postingEnabled": true, "commentsEnabled": true, "createdDatesVisible": true }, "postDefaults": { "visibility": "public" }, "customFields": [ "cf_priority", "cf_category" ], "localization": { "name": { … }, "description": { … }, "formPlaceholder": { … }, "heroTitle": { … }, "heroDescription": null, "submitButtonText": { … } }, "createdAt": "2023-12-12T00:00:00.000Z" }
Request
Returns all ticket statuses for the authenticated organization.
Ticket statuses define workflow stages. Each status has:
- A display name and color
- A type indicating the workflow stage (reviewing, unstarted, active, completed, canceled)
- A flag indicating if it's the default status for new tickets
This endpoint returns all statuses without pagination.
- Mock serverhttps://docs.featurebase.app/_mock/rest-api/v2/tickets/statuses
- Productionhttps://do.featurebase.app/v2/tickets/statuses
- curl
- JavaScript
- Node.js
- Python
- Java
- C#
- PHP
- Go
- Ruby
- R
- Payload
curl -i -X GET \
https://docs.featurebase.app/_mock/rest-api/v2/tickets/statuses \
-H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
-H 'Featurebase-Version: 2026-01-01.nova'[ { "object": "post_status", "id": "507f1f77bcf86cd799439011", "name": "In Progress", "color": "Blue", "type": "active", "isDefault": false } ]
- Mock serverhttps://docs.featurebase.app/_mock/rest-api/v2/tickets/statuses/{id}
- Productionhttps://do.featurebase.app/v2/tickets/statuses/{id}
- curl
- JavaScript
- Node.js
- Python
- Java
- C#
- PHP
- Go
- Ruby
- R
- Payload
curl -i -X GET \
https://docs.featurebase.app/_mock/rest-api/v2/tickets/statuses/507f1f77bcf86cd799439011 \
-H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
-H 'Featurebase-Version: 2026-01-01.nova'{ "object": "post_status", "id": "507f1f77bcf86cd799439011", "name": "In Progress", "color": "Blue", "type": "active", "isDefault": false }
Comments
Threaded discussions on posts and changelogs. Comments support voting, moderation, and privacy controls.