Authenticate Routes
There are 5 different ways to authenticate your REST routes. Each is different in terms of complexity and flexibility; you should choose the simplest method for your use-case.
API Key
Static token to be used as a bearer token. Only the latest token is valid at any time.
data:image/s3,"s3://crabby-images/67717/67717fae36589ca866a922d70648f17f8d5289a7" alt=""
App User Credentials with Basic Auth
Use the same credentials as the Flow Director app login. Authenticated via HTTP Basic Auth.
data:image/s3,"s3://crabby-images/b925a/b925a8943df2ad012aafac8a454000502aa89de5" alt=""
App User Credentials with JSON Web Token
Use the same credentials as the Flow Director app login. Authenticated via JWT (bearer token).
data:image/s3,"s3://crabby-images/128f7/128f78d6b6e82f48c7d1078ec0a6916edadfa7fc" alt=""
To retrieve a token, make a POST request to /api/<app>/auth/token
with the body's username
and password
.
{
"username": "admin",
"password": "changeme"
}
If the credentials were correct, you would receive a token in the response.
{
"token_type": "bearer",
"access_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VybmFtZSI6ImFkbWluIiwiaWF0IjoxNjg4ODE2NzQ0LCJleHAiOjE2ODg4MzQ3NDR9.1jMGsDILVAik6KIM2z1xqalITxiCEDYNeViSlmYvQ_M",
"refresh_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VybmFtZSI6ImFkbWluIiwidHlwZSI6InJlZnJlc2giLCJpYXQiOjE2ODg4MTY3NDQsImV4cCI6MTY5MDAyNjM0NCwic3ViIjoicmVmcmVzaCJ9.qE7LbudFYXjwb-LKWNbX3C3bAUT9iVDrfSLBmxzWCL4"
}
Include the access_token
in your request to an authenticated route.
Within the request handler flow, you can access the token information under _token
. Every token includes the username
.
{
"_token": {
"username":"admin"
}
}
Custom Flow with Basic Auth
Validate the username
and password
using your own custom logic, for example, against a user database.
data:image/s3,"s3://crabby-images/917a6/917a67c0053b05070addfd18604dcd9fdb1054fd" alt=""
You need to validate each request. The credentials are included in the request body under _token
:
{
"_token": {
"username":"admin",
"password":"changeme"
}
}
Custom Flow with JSON Web Token
This allows you to validate your own custom payload.
data:image/s3,"s3://crabby-images/b7e4f/b7e4f66bb269bcc688f208d6f317b7ca263fdb9f" alt=""
First create your auth validation flow that will listen at <app>.auth.custom
.
data:image/s3,"s3://crabby-images/75033/75033dd59e48240c30db3a128ef32715e7b86105" alt=""
On a successful response, you can specify your custom token payload.
data:image/s3,"s3://crabby-images/5b722/5b722ac976a82965257f809ee707ed1b7029698b" alt=""
To get a token, make a POST request to /api/<app>/auth/token
with your custom JSON body.
For the above example:
{
"fruit": "cantaloupe"
}
This will return an access_token
you can use to authenticate protected routes (bearer token).
{
"token_type": "bearer",
"access_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VybmFtZSI6Im11ZWxsaSIsImlhdCI6MTY4ODgxOTgwOCwiZXhwIjoxNjg4ODM3ODA4fQ.MXFj36hLULmUFVlLNtD4PVuqoKzvufwS82Qm8DLsvbI",
"refresh_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VybmFtZSI6Im11ZWxsaSIsInR5cGUiOiJyZWZyZXNoIiwiaWF0IjoxNjg4ODE5ODA4LCJleHAiOjE2OTAwMjk0MDgsInN1YiI6InJlZnJlc2gifQ.EfbAkdZjVOnZKPkz8Hl577GyZ0svUqgkm6Pa099GVBI"
}
The original payload returned from the authentication flow is included within the request handler flow of the protected route.
The above token would contain the following under _token
in the request body.
{
"is_awesome" : true,
"fruit" : "cantaloupe"
}
If a http status of 4XX
is returned from the authentication flow or the protected route, the body will contain a message why the authentication failed.
An access_token can be refreshed any time before expiration (5 hours). Do do that, send a request to route api/<app/refresh_token
which will return a new access_token
and refresh_token
.