Fizzy has an API that allows you to integrate your application with it or to create a bot to perform various actions for you.
There are two ways to authenticate with the Fizzy API:
- Personal access tokens - Long-lived tokens for scripts and integrations
- Magic link authentication - Session-based authentication for native apps
To use the API you'll need an access token. To get one, go to your profile, then, in the API section, click on "Personal access tokens" and then click on "Generate new access token".
Give it a description and pick what kind of permission you want the access token to have:
Read: allows reading data from your accountRead + Write: allows reading and writing data to your account on your behalf
Then click on "Generate access token".
Access token generation guide with screenshots
| Step | Description | Screenshot |
|---|---|---|
| 1 | Go to your profile | ![]() |
| 2 | In the API section click on "Personal access token" | ![]() |
| 3 | Click on "Generate a new access token" | ![]() |
| 4 | Give it a description and assign it a permission | ![]() |
Important
An access token is like a password, keep it secret and do not share it with anyone. Any person or application that has your access token can perform actions on your behalf.
To authenticate a request using your access token, include it in the Authorization header:
curl -H "Authorization: Bearer put-your-access-token-here" -H "Accept: application/json" https://app.fizzy.do/my/identityFor native apps, you can authenticate users via magic links. This is a two-step process:
Send the user's email address to request a magic link be sent to them:
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"email_address": "user@example.com"}' \
https://app.fizzy.do/sessionResponse:
HTTP/1.1 201 Created
Set-Cookie: pending_authentication_token=...; HttpOnly; SameSite=Lax
{
"pending_authentication_token": "eyJfcmFpbHMi..."
}The response includes a pending_authentication_token both in the JSON body and as a cookie.
Native apps should store this token and include it as a cookie when submitting the magic link code.
Error responses:
| Status Code | Description |
|---|---|
422 Unprocessable entity |
Invalid email address, if sign ups are enabled and the value isn't a valid email address |
429 Too Many Requests |
Rate limit exceeded |
Once the user receives the magic link email, they'll have a 6-character code. Submit it to complete authentication:
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-H "Cookie: pending_authentication_token=eyJfcmFpbHMi..." \
-d '{"code": "ABC123"}' \
https://app.fizzy.do/session/magic_linkResponse:
{
"session_token": "eyJfcmFpbHMi..."
}The session_token can be used to authenticate subsequent requests by including it as a cookie:
curl -H "Cookie: session_token=eyJfcmFpbHMi..." \
-H "Accept: application/json" \
https://app.fizzy.do/my/identityError responses:
| Status Code | Description |
|---|---|
401 Unauthorized |
Invalid pending_authentication_token or code |
429 Too Many Requests |
Rate limit exceeded |
Most endpoints return ETag and Cache-Control headers. You can use these to avoid re-downloading unchanged data.
When you make a request, the response includes an ETag header:
HTTP/1.1 200 OK
ETag: "abc123"
Cache-Control: max-age=0, private, must-revalidate
On subsequent requests, include the ETag value in the If-None-Match header:
GET /1234567/cards/42.json
If-None-Match: "abc123"
If the resource hasn't changed, you'll receive a 304 Not Modified response with no body, saving bandwidth and processing time:
HTTP/1.1 304 Not Modified
ETag: "abc123"
If the resource has changed, you'll receive the full response with a new ETag.
Example in Ruby:
# Store the ETag from the response
etag = response.headers["ETag"]
# On next request, send it back
headers = { "If-None-Match" => etag }
response = client.get("/1234567/cards/42.json", headers: headers)
if response.status == 304
# Nothing to do, the card hasn't changed
else
# The card has changed, process the new data
endWhen a request fails, the API response will communicate the source of the problem through the HTTP status code.
| Status Code | Description |
|---|---|
400 Bad Request |
The request was malformed or missing required parameters |
401 Unauthorized |
Authentication failed or access token is invalid |
403 Forbidden |
You don't have permission to perform this action |
404 Not Found |
The requested resource doesn't exist or you don't have access to it |
422 Unprocessable Entity |
Validation failed (see error response format above) |
500 Internal Server Error |
An unexpected error occurred on the server |
If a request contains invalid data for fields, such as entering a string into a number field, in most cases the API will respond with a 500 Internal Server Error. Clients are expected to perform some validation on their end before making a request.
A validation error will produce a 422 Unprocessable Entity response, which will sometimes be accompanied by details about the error:
{
"avatar": ["must be a JPEG, PNG, GIF, or WebP image"]
}All endpoints that return a list of items are paginated. The page size can vary from endpoint to endpoint, and we use a dynamic page size where initial pages return fewer results than later pages.
If there are more results to fetch, the response will include a Link header with a rel="next" link to the next page of results:
curl -H "Authorization: Bearer put-your-access-token-here" -H "Accept: application/json" -v http://fizzy.localhost:3006/686465299/cards
# ...
< link: <http://fizzy.localhost:3006/686465299/cards?page=2>; rel="next"
# ...When an endpoint accepts a list of values as a parameter, you can provide multiple values by repeating the parameter name:
?tag_ids[]=tag1&tag_ids[]=tag2&tag_ids[]=tag3
List parameters always end with [].
Some endpoints accept file uploads. To upload a file, send a multipart/form-data request instead of JSON.
You can combine file uploads with other parameters in the same request.
Example using curl:
curl -X PUT \
-H "Authorization: Bearer put-your-access-token-here" \
-F "user[name]=David H. Hansson" \
-F "user[avatar]=@/path/to/avatar.jpg" \
http://fizzy.localhost:3006/686465299/users/03f5v9zjw7pz8717a4no1h8a7Some fields accept rich text content. These fields accept HTML input, which will be sanitized to remove unsafe tags and attributes.
{
"card": {
"title": "My card",
"description": "<p>This is <strong>bold</strong> and this is <em>italic</em>.</p><ul><li>Item 1</li><li>Item 2</li></ul>"
}
}To attach files (images, documents) to rich text fields, use ActionText's direct upload flow:
First, request a direct upload URL by sending file metadata:
curl -X POST \
-H "Authorization: Bearer put-your-access-token-here" \
-H "Content-Type: application/json" \
-d '{
"blob": {
"filename": "screenshot.png",
"byte_size": 12345,
"checksum": "GQ5SqLsM7ylnji0Wgd9wNA==",
"content_type": "image/png"
}
}' \
https://app.fizzy.do/123456/rails/active_storage/direct_uploadsThe checksum is a Base64-encoded MD5 hash of the file content.
The direct upload endpoint is scoped to your account (replace /123456 with your account slug).
Response:
{
"id": "abc123",
"key": "abc123def456",
"filename": "screenshot.png",
"content_type": "image/png",
"byte_size": 12345,
"checksum": "GQ5SqLsM7ylnji0Wgd9wNA==",
"direct_upload": {
"url": "https://storage.example.com/...",
"headers": {
"Content-Type": "image/png",
"Content-MD5": "GQ5SqLsM7ylnji0Wgd9wNA=="
}
},
"signed_id": "eyJfcmFpbHMi..."
}Upload the file directly to the provided URL with the specified headers:
curl -X PUT \
-H "Content-Type: image/png" \
-H "Content-MD5: GQ5SqLsM7ylnji0Wgd9wNA==" \
--data-binary @screenshot.png \
"https://storage.example.com/..."Use the signed_id from step 1 to embed the file in your rich text using an <action-text-attachment> tag:
{
"card": {
"title": "Card with image",
"description": "<p>Here's a screenshot:</p><action-text-attachment sgid=\"eyJfcmFpbHMi...\"></action-text-attachment>"
}
}The sgid attribute should contain the signed_id returned from the direct upload response.
An Identity represents a person using Fizzy.
Returns a list of accounts the identity has access to, including the user for each account.
{
"accounts": [
{
"id": "03f5v9zjskhcii2r45ih3u1rq",
"name": "37signals",
"slug": "/897362094",
"created_at": "2025-12-05T19:36:35.377Z",
"user": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/users/03f5v9zjw7pz8717a4no1h8a7"
}
},
{
"id": "03f5v9zpko7mmhjzwum3youpp",
"name": "Honcho",
"slug": "/686465299",
"created_at": "2025-12-05T19:36:36.746Z",
"user": {
"id": "03f5v9zppzlksuj4mxba2nbzn",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:36.783Z",
"url": "http://fizzy.localhost:3006/users/03f5v9zppzlksuj4mxba2nbzn"
}
}
]
}Boards are where you organize your work - they contain your cards.
Returns a list of boards that you can access in the specified account.
Response:
[
{
"id": "03f5v9zkft4hj9qq0lsn9ohcm",
"name": "Fizzy",
"all_access": true,
"created_at": "2025-12-05T19:36:35.534Z",
"url": "http://fizzy.localhost:3006/897362094/boards/03f5v9zkft4hj9qq0lsn9ohcm",
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
}
}
]Returns the specified board.
Response:
{
"id": "03f5v9zkft4hj9qq0lsn9ohcm",
"name": "Fizzy",
"all_access": true,
"created_at": "2025-12-05T19:36:35.534Z",
"url": "http://fizzy.localhost:3006/897362094/boards/03f5v9zkft4hj9qq0lsn9ohcm",
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
}
}Creates a new Board in the account.
| Parameter | Type | Required | Description |
|---|---|---|---|
name |
string | Yes | The name of the board |
all_access |
boolean | No | Whether any user in the account can access this board. Defaults to true |
auto_postpone_period |
integer | No | Number of days of inactivity before cards are automatically postponed |
public_description |
string | No | Rich text description shown on the public board page |
Request:
{
"board": {
"name": "My new board",
}
}Response:
Returns 201 Created with a Location header pointing to the new board:
HTTP/1.1 201 Created
Location: /897362094/boards/03f5v9zkft4hj9qq0lsn9ohcm.json
Updates a Board. Only board administrators can update a board.
| Parameter | Type | Required | Description |
|---|---|---|---|
name |
string | No | The name of the board |
all_access |
boolean | No | Whether any user in the account can access this board |
auto_postpone_period |
integer | No | Number of days of inactivity before cards are automatically postponed |
public_description |
string | No | Rich text description shown on the public board page |
user_ids |
array | No | Array of all user IDs who should have access to this board (only applicable when all_access is false) |
Request:
{
"board": {
"name": "Updated board name",
"auto_postpone_period": 14,
"public_description": "This is a **public** description of the board.",
"all_access": false,
"user_ids": [
"03f5v9zppzlksuj4mxba2nbzn",
"03f5v9zjw7pz8717a4no1h8a7"
]
}
}Response:
Returns 204 No Content on success.
Deletes a Board. Only board administrators can delete a board.
Response:
Returns 204 No Content on success.
Cards are tasks or items of work on a board. They can be organized into columns, tagged, assigned to users, and have comments.
Returns a paginated list of cards you have access to. Results can be filtered using query parameters.
Query Parameters:
| Parameter | Description |
|---|---|
board_ids[] |
Filter by board ID(s) |
tag_ids[] |
Filter by tag ID(s) |
assignee_ids[] |
Filter by assignee user ID(s) |
creator_ids[] |
Filter by card creator ID(s) |
closer_ids[] |
Filter by user ID(s) who closed the cards |
card_ids[] |
Filter to specific card ID(s) |
indexed_by |
Filter by: all (default), closed, not_now, stalled, postponing_soon, golden |
sorted_by |
Sort order: latest (default), newest, oldest |
assignment_status |
Filter by assignment status: unassigned |
creation |
Filter by creation date: today, yesterday, thisweek, lastweek, thismonth, lastmonth, thisyear, lastyear |
closure |
Filter by closure date: today, yesterday, thisweek, lastweek, thismonth, lastmonth, thisyear, lastyear |
terms[] |
Search terms to filter cards |
Response:
[
{
"id": "03f5vaeq985jlvwv3arl4srq2",
"number": 1,
"title": "First!",
"status": "published",
"description": "Hello, World!",
"description_html": "<div class=\"action-text-content\"><p>Hello, World!</p></div>",
"image_url": null,
"tags": ["programming"],
"golden": false,
"last_active_at": "2025-12-05T19:38:48.553Z",
"created_at": "2025-12-05T19:38:48.540Z",
"url": "http://fizzy.localhost:3006/897362094/cards/4",
"board": {
"id": "03f5v9zkft4hj9qq0lsn9ohcm",
"name": "Fizzy",
"all_access": true,
"created_at": "2025-12-05T19:36:35.534Z",
"url": "http://fizzy.localhost:3006/897362094/boards/03f5v9zkft4hj9qq0lsn9ohcm",
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
}
},
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
},
"comments_url": "http://fizzy.localhost:3006/897362094/cards/4/comments"
},
]Returns a specific card by its number.
Response:
{
"id": "03f5vaeq985jlvwv3arl4srq2",
"number": 1,
"title": "First!",
"status": "published",
"description": "Hello, World!",
"description_html": "<div class=\"action-text-content\"><p>Hello, World!</p></div>",
"image_url": null,
"tags": ["programming"],
"golden": false,
"last_active_at": "2025-12-05T19:38:48.553Z",
"created_at": "2025-12-05T19:38:48.540Z",
"url": "http://fizzy.localhost:3006/897362094/cards/4",
"board": {
"id": "03f5v9zkft4hj9qq0lsn9ohcm",
"name": "Fizzy",
"all_access": true,
"created_at": "2025-12-05T19:36:35.534Z",
"url": "http://fizzy.localhost:3006/897362094/boards/03f5v9zkft4hj9qq0lsn9ohcm",
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
}
},
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
},
"comments_url": "http://fizzy.localhost:3006/897362094/cards/4/comments",
"steps": [
{
"id": "03f8huu0sog76g3s975963b5e",
"content": "This is the first step",
"completed": false
},
{
"id": "03f8huu0sog76g3s975969734",
"content": "This is the second step",
"completed": false
}
]
}Creates a new card in a board.
| Parameter | Type | Required | Description |
|---|---|---|---|
title |
string | Yes | The title of the card |
description |
string | No | Rich text description of the card |
status |
string | No | Initial status: published (default), drafted |
image |
file | No | Header image for the card |
tag_ids |
array | No | Array of tag IDs to apply to the card |
created_at |
datetime | No | Override creation timestamp (ISO 8601 format) |
last_active_at |
datetime | No | Override last activity timestamp (ISO 8601 format) |
Request:
{
"card": {
"title": "Add dark mode support",
"description": "We need to add dark mode to the app"
}
}Response:
Returns 201 Created with a Location header pointing to the new card.
Updates a card.
| Parameter | Type | Required | Description |
|---|---|---|---|
title |
string | No | The title of the card |
description |
string | No | Rich text description of the card |
status |
string | No | Card status: drafted, published |
image |
file | No | Header image for the card |
tag_ids |
array | No | Array of tag IDs to apply to the card |
last_active_at |
datetime | No | Override last activity timestamp (ISO 8601 format) |
Request:
{
"card": {
"title": "Add dark mode support (Updated)"
}
}Response:
Returns the updated card.
Deletes a card. Only the card creator or board administrators can delete cards.
Response:
Returns 204 No Content on success.
Closes a card.
Response:
Returns 204 No Content on success.
Reopens a closed card.
Response:
Returns 204 No Content on success.
Moves a card to "Not Now" status.
Response:
Returns 204 No Content on success.
Moves a card from triage into a column.
| Parameter | Type | Required | Description |
|---|---|---|---|
column_id |
string | Yes | The ID of the column to move the card into |
Response:
Returns 204 No Content on success.
Sends a card back to triage.
Response:
Returns 204 No Content on success.
Toggles a tag on or off for a card. If the tag doesn't exist, it will be created.
| Parameter | Type | Required | Description |
|---|---|---|---|
tag_title |
string | Yes | The title of the tag (leading # is stripped) |
Response:
Returns 204 No Content on success.
Toggles assignment of a user to/from a card.
| Parameter | Type | Required | Description |
|---|---|---|---|
assignee_id |
string | Yes | The ID of the user to assign/unassign |
Response:
Returns 204 No Content on success.
Subscribes the current user to notifications for this card.
Response:
Returns 204 No Content on success.
Unsubscribes the current user from notifications for this card.
Response:
Returns 204 No Content on success.
Comments are attached to cards and support rich text.
Returns a paginated list of comments on a card, sorted chronologically (oldest first).
Response:
[
{
"id": "03f5v9zo9qlcwwpyc0ascnikz",
"created_at": "2025-12-05T19:36:35.534Z",
"updated_at": "2025-12-05T19:36:35.534Z",
"body": {
"plain_text": "This looks great!",
"html": "<div class=\"action-text-content\">This looks great!</div>"
},
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
},
"card": {
"id": "03f5v9zo9qlcwwpyc0ascnikz",
"url": "http://fizzy.localhost:3006/897362094/cards/03f5v9zo9qlcwwpyc0ascnikz"
},
"reactions_url": "http://fizzy.localhost:3006/897362094/cards/3/comments/03f5v9zo9qlcwwpyc0ascnikz/reactions",
"url": "http://fizzy.localhost:3006/897362094/cards/3/comments/03f5v9zo9qlcwwpyc0ascnikz"
}
]Returns a specific comment.
Response:
{
"id": "03f5v9zo9qlcwwpyc0ascnikz",
"created_at": "2025-12-05T19:36:35.534Z",
"updated_at": "2025-12-05T19:36:35.534Z",
"body": {
"plain_text": "This looks great!",
"html": "<div class=\"action-text-content\">This looks great!</div>"
},
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
},
"card": {
"id": "03f5v9zo9qlcwwpyc0ascnikz",
"url": "http://fizzy.localhost:3006/897362094/cards/03f5v9zo9qlcwwpyc0ascnikz"
},
"reactions_url": "http://fizzy.localhost:3006/897362094/cards/3/comments/03f5v9zo9qlcwwpyc0ascnikz/reactions",
"url": "http://fizzy.localhost:3006/897362094/cards/3/comments/03f5v9zo9qlcwwpyc0ascnikz"
}Creates a new comment on a card.
| Parameter | Type | Required | Description |
|---|---|---|---|
body |
string | Yes | The comment body (supports rich text) |
created_at |
datetime | No | Override creation timestamp (ISO 8601 format) |
Request:
{
"comment": {
"body": "This looks great!"
}
}Response:
Returns 201 Created with a Location header pointing to the new comment.
Updates a comment. Only the comment creator can update their comments.
| Parameter | Type | Required | Description |
|---|---|---|---|
body |
string | Yes | The updated comment body |
Request:
{
"comment": {
"body": "This looks even better now!"
}
}Response:
Returns the updated comment.
Deletes a comment. Only the comment creator can delete their comments.
Response:
Returns 204 No Content on success.
Reactions are short (16-character max) responses to comments.
Returns a list of reactions on a comment.
Response:
[
{
"id": "03f5v9zo9qlcwwpyc0ascnikz",
"content": "π",
"reacter": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
},
"url": "http://fizzy.localhost:3006/897362094/cards/3/comments/03f5v9zo9qlcwwpyc0ascnikz/reactions/03f5v9zo9qlcwwpyc0ascnikz"
}
]Adds a reaction to a comment.
| Parameter | Type | Required | Description |
|---|---|---|---|
content |
string | Yes | The reaction text |
Request:
{
"reaction": {
"content": "Great π"
}
}Response:
Returns 201 Created on success.
Removes your reaction from a comment.
Response:
Returns 204 No Content on success.
Steps are to-do items on a card.
Returns a specific step.
Response:
{
"id": "03f5v9zo9qlcwwpyc0ascnikz",
"content": "Write tests",
"completed": false
}Creates a new step on a card.
| Parameter | Type | Required | Description |
|---|---|---|---|
content |
string | Yes | The step text |
completed |
boolean | No | Whether the step is completed (default: false) |
Request:
{
"step": {
"content": "Write tests"
}
}Response:
Returns 201 Created with a Location header pointing to the new step.
Updates a step.
| Parameter | Type | Required | Description |
|---|---|---|---|
content |
string | No | The step text |
completed |
boolean | No | Whether the step is completed |
Request:
{
"step": {
"completed": true
}
}Response:
Returns the updated step.
Deletes a step.
Response:
Returns 204 No Content on success.
Tags are labels that can be applied to cards for organization and filtering.
Returns a list of all tags in the account, sorted alphabetically.
Response:
[
{
"id": "03f5v9zo9qlcwwpyc0ascnikz",
"title": "bug",
"created_at": "2025-12-05T19:36:35.534Z",
"url": "http://fizzy.localhost:3006/897362094/cards?tag_ids[]=03f5v9zo9qlcwwpyc0ascnikz"
},
{
"id": "03f5v9zo9qlcwwpyc0ascnilz",
"title": "feature",
"created_at": "2025-12-05T19:36:35.534Z",
"url": "http://fizzy.localhost:3006/897362094/cards?tag_ids[]=03f5v9zo9qlcwwpyc0ascnilz"
}
]Columns represent stages in a workflow on a board. Cards move through columns as they progress.
Returns a list of columns on a board, sorted by position.
Response:
[
{
"id": "03f5v9zkft4hj9qq0lsn9ohcm",
"name": "Recording",
"color": "var(--color-card-default)",
"created_at": "2025-12-05T19:36:35.534Z"
},
{
"id": "03f5v9zkft4hj9qq0lsn9ohcn",
"name": "Published",
"color": "var(--color-card-4)",
"created_at": "2025-12-05T19:36:35.534Z"
}
]Returns the specified column.
Response:
{
"id": "03f5v9zkft4hj9qq0lsn9ohcm",
"name": "In Progress",
"color": "var(--color-card-default)",
"created_at": "2025-12-05T19:36:35.534Z"
}Creates a new column on the board.
| Parameter | Type | Required | Description |
|---|---|---|---|
name |
string | Yes | The name of the column |
color |
string | No | The column color. One of: var(--color-card-default) (Blue), var(--color-card-1) (Gray), var(--color-card-2) (Tan), var(--color-card-3) (Yellow), var(--color-card-4) (Lime), var(--color-card-5) (Aqua), var(--color-card-6) (Violet), var(--color-card-7) (Purple), var(--color-card-8) (Pink) |
Request:
{
"column": {
"name": "In Progress",
"color": "var(--color-card-4)"
}
}Response:
Returns 201 Created with a Location header pointing to the new column.
Updates a column.
| Parameter | Type | Required | Description |
|---|---|---|---|
name |
string | No | The name of the column |
color |
string | No | The column color |
Request:
{
"column": {
"name": "Done"
}
}Response:
Returns 204 No Content on success.
Deletes a column.
Response:
Returns 204 No Content on success.
Users represent people who have access to an account.
Returns a list of active users in the account.
Response:
[
{
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
},
{
"id": "03f5v9zjysoy0fqs9yg0ei3hq",
"name": "Jason Fried",
"role": "member",
"active": true,
"email_address": "jason@example.com",
"created_at": "2025-12-05T19:36:35.419Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjysoy0fqs9yg0ei3hq"
},
{
"id": "03f5v9zk1dtqduod5bkhv3k8m",
"name": "Jason Zimdars",
"role": "member",
"active": true,
"email_address": "jz@example.com",
"created_at": "2025-12-05T19:36:35.435Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zk1dtqduod5bkhv3k8m"
},
{
"id": "03f5v9zk3nw9ja92e7s4h2wbe",
"name": "Kevin Mcconnell",
"role": "member",
"active": true,
"email_address": "kevin@example.com",
"created_at": "2025-12-05T19:36:35.451Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zk3nw9ja92e7s4h2wbe"
}
]Returns the specified user.
Response:
{
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
}Updates a user. You can only update users you have permission to change.
| Parameter | Type | Required | Description |
|---|---|---|---|
name |
string | No | The user's display name |
avatar |
file | No | The user's avatar image |
Request:
{
"user": {
"name": "David H. Hansson"
}
}Response:
Returns 204 No Content on success.
Deactivates a user. You can only deactivate users you have permission to change.
Response:
Returns 204 No Content on success.
Notifications inform users about events that happened in the account, such as comments, assignments, and card updates.
Returns a list of notifications for the current user. Unread notifications are returned first, followed by read notifications.
Response:
[
{
"id": "03f5va03bpuvkcjemcxl73ho2",
"read": false,
"read_at": null,
"created_at": "2025-11-19T04:03:58.000Z",
"title": "Plain text mentions",
"body": "Assigned to self",
"creator": {
"id": "03f5v9zjw7pz8717a4no1h8a7",
"name": "David Heinemeier Hansson",
"role": "owner",
"active": true,
"email_address": "david@example.com",
"created_at": "2025-12-05T19:36:35.401Z",
"url": "http://fizzy.localhost:3006/897362094/users/03f5v9zjw7pz8717a4no1h8a7"
},
"card": {
"id": "03f5v9zo9qlcwwpyc0ascnikz",
"title": "Plain text mentions",
"status": "published",
"url": "http://fizzy.localhost:3006/897362094/cards/3"
},
"url": "http://fizzy.localhost:3006/897362094/notifications/03f5va03bpuvkcjemcxl73ho2"
}
]Marks a notification as read.
Response:
Returns 204 No Content on success.
Marks a notification as unread.
Response:
Returns 204 No Content on success.
Marks all unread notifications as read.
Response:
Returns 204 No Content on success.



