OAuth2 Token Generator
- Introduction
- Prerequisites
- Generating an OAuth2 token
- Simulating from the automation editor
- Testing from curl
- Implementing in your app
Introduction
The OAuth2 Token Generator allows administrators to create access tokens for API authentication. These tokens provide secure access to Cerb’s API with specific worker permissions and scopes. While OAuth2 typically requires implementing a complete authentication flow, the token generator provides a simpler way to create tokens directly.
For detailed information about Cerb’s OAuth2 authentication system, see the API Authentication documentation. If you’re building custom integrations, you may also want to review:
-
OAuth2 Token Validation example - Examples of validating tokens in webhook automations.
-
Custom API guide - Build and authenticate APIs using webhook portals.
Prerequisites
To use OAuth tokens you need to create an app in Cerb from Search » OAuth Apps » (+).
This will generate a random Client ID and Client Secret for you. The Name: should reflect your integration.
If you want to allow Cerb workers to log in to your integration to generate tokens, the Callback URL: must be implemented by your app. If you’re using the token generator in Cerb then the callback URL can be any value (e.g. your website).
data:image/s3,"s3://crabby-images/1c6d1/1c6d11c259a125568fc2546a87d6f5e4df2df85d" alt=""
You can add your own scopes. The default provides an api
scope that allows all endpoints and methods. Your automation will need to validate scopes.
"api":
label: Make any API request on your behalf
endpoints:
- "*" #[GET, PATCH, POST, PUT, DELETE]
The scopes are set when a token is generated. If a worker logs in to Cerb from a third-party app, a confirmation screen will show them the requested scopes before they consent. If you use the token generator, you can pick a token’s scope.
Generating an OAuth2 token
Implementing OAuth2 for Link to Cerb in your app is outside the scope of this guide. We’ll be using the token generator for a simpler example.
Navigate to Setup » Developers » OAuth2 Token Generator.
Select the OAuth App you created above, a Worker linked to the token, Scopes, and an Expires duration.
You can generate a short-lived token for testing.
A long-lived token is vulnerable to being leaked or intercepted. It must be treated with the sensitivity of a password that you transit with each request. Do not commit it to a source code repository (e.g. use environment variables or a secrets vault). You should manually rotate the token at a reasonable interval.
Click the Create button and copy the Access Token.
data:image/s3,"s3://crabby-images/82b66/82b6625cf90d868991cb5ee2c00a4693a06f1f70" alt=""
Simulating from the automation editor
You can test a request from Input: in the lower left of the automation editor. Set the Authorization: Bearer
header to your token and click the play button.
request_headers:
authorization: Bearer eyJ0eXAiOi[...]
Testing from curl
curl -i -H "Authorization: Bearer eyJ0eXAiOi[...]" "https://cerb.example/portal/custom-api"
Implementing in your app
Use an OAuth2 library with the provided Client ID, Client Secret, and Refresh Token to refresh short-lived tokens at an interval (e.g. hourly). This helps protect against replay attacks from leaked or intercepted tokens.
An HTTP response status code of 401
(Unauthorized) is a hint you need to refresh an expired token.
You can find more information in the OAuth spec.