description |
---|
This page describes the JWT authentication type |
A JSON Web Token (JWT) is an open method for representing claims securely between two parties. It is digitally signed using an HMAC shared key or RSA public/private key pair. The JWT authentication type ensures that a JWT issued by a third party is valid by verifying its signature and expiration date. Only applications with approved JWTs can access APIs associated with a JWT plan.
APIM uses client IDs to recognize applications that have subscribed to a JWT plan. The inbound JWT payload must include the client_id
claim to establish a connection between the JWT and the APIM application subscription.
A JWT plan presents the following configuration options:
JWT plan configuration
-
Signature: Select the algorithm used to hash and encrypt your JWT
-
JWKS resolver: Select a method to retrieve the JSON Web Key (JWK), which is often stored inside a JSON Web Key Set (JWKS) and required by the Gateway to validate the signature of the JWT:
-
GIVEN_KEY: Provide a signature key as a resolver parameter according to the signature algorithm (
ssh-rsa
,pem
,crt
orpublic-key
format -
GATEWAY_KEYS: Search for public keys set in the API Gateway
gravitee.yml
configuration that match the authorization serveriss
(issuer) andkid
(key ID) claims of the incoming JWT{% code title="gravitee.yml" %}
jwt: issuer: my.authorization.server: default: ssh-rsa myValidationKey [email protected] kid-2016: ssh-rsa myCurrentValidationKey [email protected]
{% endcode %}
-
JWKS_URL: Provide a URL ending with
/.well-known/jwks.json
from which the Gateway can retrieve the JWKS
-
-
Use system proxy: When using JWKS_URL, optionally make the HTTP call through a system-wide proxy configured in
gravitee.yml
-
Extract JWT Claims: Allow claims to be accessed in the
jwt.claims
context attribute during request/response via Gravitee Expression Language (EL), e.g., extract the issuer claim from the JWT:{#context.attributes['jwt.claims']['iss']}
-
Propagate Authorization header: Propagate the header containing the JWT token to the backend APIs
-
User claim: Set the payload claim where the user can be extracted. The default
sub
value is standard with JWTs. -
Client ID claim: Override the default claim where the client ID can be extracted. By default, the Gateway checks the
azp
claim, then theaud
claim, and finally theclient_id
claim. -
Ignore missing CNF: Ignores CNF validation if the token doesn't contain any CNF information
-
Enable certificate bound thumbprint validation: Validates the certificate thumbprint extracted from the
access_token
against the one provided by the client -
Extract client certificate from headers: Extracts the client certificate from the request header (provided in Header name field). Necessary when the mTLS connection is handled by a proxy.
-
Additional selection rule: Allows you to use the EL to filter by contextual data (request headers, tokens, attributes, etc.) for plans of the same type (e.g., for two JWT plans, you can set different selection rules on each plan to determine which plan handles each request)
Once JWT configuration is complete and the plan is created and published, your API will be JWT-secured and subscribed consumers must call the API with an Authorization: Bearer your-JWT
HTTP header.