Trello's API uses token-based authentication to grant third-party applications access to the Trello API. Once a Trello user has granted an application access to their Trello account and data, the application is given a token that can be used to make requests to the Trello API on behalf of the user.
There are two ways to authorize a client and receive a User Token. The first is
via our 1/authorize
route, the second is via basic OAuth1.0. We'll cover the
former now. If you'd rather use OAuth, you can skip ahead to Using Basic
OAuth.
To begin the authentication process, you need an API key. As an API key is tied to a Power-Up, you can visit the https://trello.com/power-ups/admin page, access your Power-Up, navigate to the API Key tab and select the option Generate a new API Key if you haven't generated the API key yet.
Once you have an API key, you will use it to ask a Trello user to grant access to your application. To do so, you should direct a user to the authorize URL and pass along the query parameters needed as documented below. The authorize prompt can be opened in a number of different ways and with a number of different options.
When you kick off the authorization flow, the user will see the following screen:
The name of the application, length of access, and scope of permissions are all configurable via query params (documented below).
For instance, if you're just getting started with Trello's API and you'd like to explore what is possible, you can generate a token for yourself using your API key and the following URL: https://trello.com/1/authorize?expiration=1day&name=MyPersonalToken&scope=read&response_type=token&key={YourAPIKey}
After visiting this page and clicking the green Allow button, you'll be redirected to a page with your token. You can now use that token and your API key to make a request to the Trello API. You can give it a try with: https://api.trello.com/1/members/me/?key={yourAPIKey}&token={yourAPIToken}. This should return an object containing information about your Trello user.
Tokens for users should always be securely stored as they grant access to the entire user's account! It is ok for your API key to be publicly available, but a token should never be publicly available. If a token becomes public, it should be revoked immediately by the user.
If you’re authorizing a web client, you may want to check out client.js, a wrapper for the API in javascript. It includes built-in authorization methods that you may find useful. However, it uses the same route as is documented below.
Parameter | Valid Values | Description |
---|---|---|
return_url string | A valid URL that the token should be returned to. | If the token is being passed by postMessage, this will be used as the origin for the postMessage. If the token is being passed by fragment, this is where the user will be redirected after authorization. |
callback_method string | postMessage or fragment | Defines how the token is returned to the you. postMessage should be used for popups. When postMessage is passed, Trello will use window.postMessage to send the token to the popup's opener (i.e. your Power-Ups iframe). fragment should be used for redirects. When fragment is passed, Trello redirects the user to the specified return_url with the token in the URL's hash. |
scope string | Comma-separated list of one or more of read , write , account . | Read: reading of boards, organizations, etc. on behalf of the user Write: writing of boards, organizations, etc. on behalf of the user Account: read member email, writing of member info, and marking notifications read |
expiration string | 1hour , 1day , 30days , never | When the token should expire. |
name string | Name of the application. | Displayed during the authorization process |
key string | Valid Trello API key. | Used to generate the user's token. |
response_type string | token or fragment | The response_type of token will return the full user token. |
Member emails can only be accessed when the account
scope is requested. Once
granted, the token generated can only be used to access the email address of
the user who granted access.
Batch email access is only available to enterprises via the SCIM API.
Depending on the response_type
you are using, Trello will do one of two things when a user clicks "Deny" from the authorization flow's prompt.
response_type | Trello's Response |
---|---|
fragment | Trello will now add an empty token= query parameter and error= parameter with error message to the fragment when redirecting back to the return_url specified. |
postMessage | Trello will postMessage an error key in the postMessage with the error message being the value. This will be sent to the return_url specified. |
Trello users can view metadata regarding the applications they have authorized and granted a token by visiting their account settings page: https://trello.com/{username}/account. There, under the Applications heading, they will see a list of every application they've granted access to, the scope of the access, the date access was approved, and the date that the token expires.
Users are able to revoke a token by clicking on the Revoke button next to the listing. Revoking the token removes the token's access to the user's account and it can no longer be used to make requests to Trello's API on behalf of the user.
Tokens can also be deleted via the API. There is a /1/tokens resource that includes a DELETE action.
Applications and Power-Ups should handle token revocation gracefully. If a token has been revoked, the API will respond with a 401 HTTP status and the message: invalid token
. At that point in time, the Power-Up or integration should ask the user to re-authorize the application.
Your API key's allowed origins define which origins Trello can redirect to after a user gives consent for your application.
If the URL in the return_url
parameter does not match one of your API key's allowed origins, the redirect is blocked. This prevents malicious actors from using your API key and secretly redirecting users to their application instead.
For example, if you wanted users to be redirected to https://myapplication.com/authorize
, you can add https://myapplication.com
to your allowed origins. You can also use the wildcard symbol *
in these origins, e.g. https://*.myapplication.com
. When developing locally, you may also use http//localhost:3000
as an allowed origin.
You can manage your API key's allowed origins via the https://trello.com/power-ups/admin page, then access your Power-Up and navigate to the API Key tab.
Note: If your API key has no allowed origins set, then no redirect URL will work.
The Trello API supports basic OAuth 1.0; you can use an OAuth library and the following URLs:
1 2https://trello.com/1/OAuthGetRequestToken https://trello.com/1/OAuthAuthorizeToken https://trello.com/1/OAuthGetAccessToken
You’ll also need your application secret (used to sign your requests). That’s listed in the API Key tab on your Power-Up management page https://trello.com/power-ups/admin.
We've put together an example project in node that demonstrates the basic routes and configuration necessary to use OAuth to access Trello's API. You can view the Glitch project here. You may need to remix the project in order to view it.
Once you have an API key and a user's token, you can pass authorization information to Trello one of three ways:
Authorization
headerThe easiest and quickest way to pass authorization to Trello is via query parameters.
You can include a key=
and token=
query parameter in your request.
For instance, here is a simple request passing authorization via query parameters:
1 2curl https://api.trello.com/1/members/me?key={{apiKey}}&token={{apiToken}}
Authorization
headerThe Trello API will also accept authorization via an Authorization
header
with the format: OAuth oauth_consumer_key="{{apiKey}}", oauth_token="{{apiToken}}"
.
For instance, here is the same request as above, but using an Authorization
header:
1 2curl -H "Authorization: OAuth oauth_consumer_key=\"{{apiKey}}\", oauth_token=\"{{apiToken}}\"" https://api.trello.com/1/members/me
If you are making a PUT or POST request to Trello's API, you may also include the key and token in the request's body:
1 2curl -X PUT \ https://api.trello.com/1/cards/5e568d33e9b5e88bb99996d0/name \ -H "Content-Type: application/json" \ -d '{"key": "{{apiKey}}", "token": "{{apiToken}}", "value": "Finish Final Presentation" }'
Rate this page: