Plane API Documentation

The Plane API is organized around REST. Our API has predictable resource-oriented URLs, accepts application/json request bodies, returns JSON responses, and uses standard HTTP response codes, authentication, and verbs.



This API uses an API key for authentication. The API key should be included in the header of each request to verify the client's identity and permissions. The key should be passed as the value of the X-API-Key header.

  • Registration: Users must register for an account to obtain an API key.
  • Key Generation: Upon successful registration, users will receive an API key. This key uniquely identifies the user and should be kept secure.

Using the API Key

To authenticate an API request, include your API key in the request header:

X-API-Key: <Your-API-Key>

It is important to keep your API key confidential to prevent unauthorized access to your account.

Example of an Authenticated API Request

Here's an example of making a GET request to the API with the API key:


GET /api/v1/workspaces/:slug/projects/:project_id/issues/
  X-API-Key: plane_api_<token>


  [ ... ],

Error Handling

  • Missing API Key: If the X-API-Key header is not included, the API will return an error indicating that authentication is required.
  • Invalid API Key: If the provided API key is invalid or expired, the API will return an error message indicating an authentication failure.

Security Recommendations

  • Keep the API Key Secret: Treat your API key like a password. Do not share it or expose it in client-side code.
  • Regenerate Key If Compromised: If you suspect that your API key has been compromised, generate a new one immediately and update your applications.

Status codes

HTTP Methods

HTTP defines a set of request methods, also known as HTTP verbs, to indicate the desired action for a given resource.

Given below is the list of methods commonly adopted by Plane's APIs:

GETRequests a representation of the specified resourceFetch all issues from a project
POSTSubmits an entity to the specified resourceCreate a project
DELETEDeletes the specified resourceDelete a module-issue
PATCHApplies partial modifications to a resourceEdit a module

Given below is the list of the most commonly encountered success responses:

Status CodeDescription
200 OKThe request succeeded, and a new resource was created, generally sent in GET or PATCH requests.
201 CreatedThe request is succeeded, and a new resource was created, generally sent in POST or PATCH requests.
204 No ContentThe request is succeeded, and no body is sent, generally comes from the DELETE request.

Error Response

Given below is the list of the most commonly encountered error responses:

Status CodeDescription
400 Bad RequestThe server cannot or will not process the request due to something that is perceived to be a client error.
401 UnauthorizedAlthough the HTTP standard specifies "unauthorized", semantically, this response means "unauthenticated". That is, the client must authenticate itself to get the requested response.
404 Not FoundThe server cannot find the requested resource. This means the URL is not recognized.
429 Throttling ErrorThe server is processing too many requests at once and is unable to process your request. Retry the request after some time. You can read our rate-limit doc.
500 Internal Server ErrorThe server has encountered a situation it does not know how to handle.
502 Bad GatewayThis error response means that the server got an invalid response while working as a gateway to get a response needed to handle the request.
503 Service UnavailableThe server is not ready to handle the request. Common causes are a server that is down for maintenance or is overloaded.
504 Gateway TimeoutThis error response is given when the server acts as a gateway and cannot get a timely response.

Pagination Documentation


This API implements a cursor-based pagination system, allowing clients to efficiently navigate through large datasets. The system uses a cursor parameter to manage the position and direction of pagination.

Cursor Format

The cursor is a string formatted as value:offset:is_prev, where:

  • value represents the page size (number of items per page).
  • offset is the current page number (starting from 0).
  • is_prev indicates whether the cursor is moving to the previous page (1) or to the next page (0).

Request Parameters

  • per_page (optional): Number of items to display per page. Defaults to 100. The maximum allowed value specified by the server is 100.
  • cursor (optional): Cursor string to navigate to a specific page. If not provided, pagination starts from the first page.


The paginated response includes the following fields:

  • next_cursor: Cursor string for the next page.
  • prev_cursor: Cursor string for the previous page.
  • next_page_results: Boolean indicating if there are more results after the current page.
  • prev_page_results: Boolean indicating if there are results before the current page.
  • count: Total number of items on the current page.
  • total_pages: Estimated total number of pages.
  • extra_stats: Additional statistics, if any.
  • results: Array of items for the current page.

Request: Fetching the First Page

GET /api/v1/workspaces/:slug/projects/:project_id/issues/?per_page=20

Response: First Page

  "next_cursor": "20:1:0",
  "prev_cursor": "",
  "next_page_results": true,
  "prev_page_results": false,
  "count": 20,
  "total_pages": 50,
  "extra_stats": {},
  "results": [ ... items ... ]

Request: Fetching the Next Page

GET /api/v1/workspaces/:slug/projects/:project_id/issues?per_page=20&cursor=20:1:0

Response: Second Page

  "next_cursor": "20:2:0",
  "prev_cursor": "20:0:1",
  "next_page_results": true,
  "prev_page_results": true,
  "count": 20,
  "total_pages": 50,
  "extra_stats": {},
  "results": [ ... items ... ]

Error Handling

  • Invalid Cursor Format: If the provided cursor string is not in the correct format, the API will respond with an error message indicating an invalid cursor format.
  • Pagination Limits: Requests exceeding the maximum per_page limit will receive an error response detailing the maximum allowed value.

Rate Limit


To ensure fair usage and maintain the quality of service for all users, our API implements rate limiting. Rate limiting restricts the number of requests a client can make within a certain time frame.

Rate Limit Details

  • Limit: Each client is limited to 60 requests per minute.
  • Reset Interval: The rate limit counter resets every minute.
  • Scope of Limitation: The rate limit applies to all requests made with a given API key.

Identifying Your Rate Limit Status

Rate limit status is communicated in the response headers of each API request:

  • X-RateLimit-Remaining: The number of requests remaining in the current rate limit window.
  • X-RateLimit-Reset: The time at which the current rate limit window resets (in UTC epoch seconds).

Example Response Headers

X-RateLimit-Remaining: 45
X-RateLimit-Reset: 1700327957

Fields and Expand Query Parameters

Our API provides flexible data retrieval capabilities through two powerful query parameters: fields and expand. These parameters allow clients to tailor the response data to their specific needs, optimizing both the payload size and the clarity of the response.

Fields Parameter


The fields parameter enables clients to selectively retrieve only a subset of fields for a given resource. This is particularly useful for minimizing response size and bandwidth consumption, especially when the client requires only specific pieces of data.


  • The fields parameter accepts a comma-separated list of field names that the client wants to be included in the response.
  • Syntax: ?fields=field1,field2,field3
GET /api/v1/workspaces/:slug/projects/:project_id/issues/?fields=id,name,description

In this example, the API will return only the id, name, and description fields of the resource.

Expand Parameter


The expand parameter allows clients to request additional related information to be included in the response. This is useful for retrieving detailed information about nested resources without making separate API calls.


  • The expand parameter can be used to include details of related resources or nested objects in the response.
  • Syntax: ?expand=field1,field2


GET /api/v1/workspaces/:slug/projects/:project_id/issues/?expand=assignees,state

This request will return the resource data along with expanded information about the assignees and state.

Error Handling

  • Invalid or unrecognized field names passed in the fields parameter will result in an error response, indicating which fields are invalid.
  • Similarly, if expand is used on fields that cannot be expanded, an appropriate error message will be returned.