JWT
JSON Web Tokens configurations
Global Configuration
Here is the default configuration for our JSON Web Tokens integration:
issuer
issuer
The issuer authority for the tokens is placed in the iss
claim of the token. If empty, we will use the event.buildLink()
to create the issuer. By default, our validators also check that tokens are created by the same issuer.
secretKey
secretKey
The secret key is used to sign the JWT tokens. By default, it will try to load an environment variable called JWT_SECRET
, if that setting is also empty, we will auto-generate a secret token that will last as long as the ColdFusion application scope lasts. So technically, your secret will rotate only if a secret is not specified.
Also, this key is ignored in modules. To specify a fixed key to be used in your modules, you will have to configure it by adding a cbsecurity key settings in the moduleSettings
structure within the config/Coldbox.cfc
.
Your secret key will auto-rotate every application scope rotation. Please note that all tokens used after that scope rotation will automatically become invalid.
Please note that we use the jwt-cfml
library for encoding/decoding tokens. Please refer to it's documentation in order to leverage RS and ES algorithms with certificates.
customAuthHeader
customAuthHeader
By default, our jwt services will look into the authorization
header for a bearer token. However, it can also look in a custom header by this name, which defaults to x-auth-token
. Finally, if not found, it will also look into the rc
scope for a rc[ 'x-auth-token' ]
as well.
expiration
expiration
The default expiration in minutes for the JWT tokens. Defaults to 60 minutes
algorithm
algorithm
The encryption algorithm to use for the tokens. The default is HS512, but the available ones for are:
HS256
HS384
HS512
RS256
RS384
RS512
ES256
ES384
ES512
In the case of the RS
and ES
algorithms, asymmetric keys are expected to be provided in unencrypted PEM or JWK format (in the latter case, first deserialize the JWK to a CFML struct). When using PEM, private keys must be encoded in PKCS#8 format.
If your private key is not currently in this format, conversion should be straightforward:
When decoding tokens, either a public key or certificate can be provided. (If a certificate is provided, the public key will be extracted.)
requiredClaims
requiredClaims
This is an array of claim names that each token MUST have in order to be authenticated. If a token comes in but does not have these claims in the payload structure, it will be deemed invalid.
tokenStorage
tokenStorage
By default, our JWT services will store tokens in CacheBox for you in order to be able to invalidate them. We ship with two providers for token storage: db
and cachebox
.
Enabled
Enabled
By default, the token storage is enabled.
KeyPrefix
KeyPrefix
The key prefix to use when storing the keys in permanent storage. Defaults to cbjwt_
Driver
Driver
The driver to use. It can be either db or cachebox or your own WireBox Id for using custom storage.
Properties
Properties
A struct of properties to configure each storage with.
Refresh Token Configuration
Refresh tokens have several configuration items; check them out in our refresh token configuration section.
Last updated