Kong plugin that performs authorization based on custom role claim in JWT
Based on the project of bjwschaap https://github.com/bjwschaap/kong-plugin-jwt-auth
This plugin is typically used on routes to authorize access to a specific route by checking the roles claimed in the JWT.
This plugin is designed to work alongside the standard JWT plugin provided by Kong. The default Kong JWT plugin will validate the JWT and authenticate the consumer. This plugin will use the validated token from the Nginx context and check a custom roles claim in the JWT to contain at least one of the roles given in the plugin configuration.
Parameter | Type | Optional | Default | Description |
---|---|---|---|---|
roles_claim_name | string | X | roles |
Name of the claim/attribute in the JWT that contains the roles to check |
roles | array | - | List of 1 or more roles that are allowed to use the resource (route, service, etc) | |
msg error any | string | X | To be able to use this service you must have at least one of the roles configured |
Customize the error message based on policy any |
msg error all | string | X | In order to use this service you must match all the roles configured with the associated ones in the JWT token |
Customize the error message based on policy all |
msg error not roles in claims | string | X | The claim roles are not informed in the JWT token |
Customize the error message In case the claim roles do not exist |
policy | string | X | any |
Determines if at least one, or all roles should match. One of: any or all |
Configure this plugin on a route with:
$ curl -X POST http://kong:8001/routes/{route_id}/plugins \
--data "name=kong-plugin-jwt-auth-rbac" \
--data "conf.roles_claim_name=Groups" \
--data "conf.roles=role1,role2,role3" \
--data "conf.msg_error_any=You do not have the necessary role to use this service" \
--data "conf.msg_error_all=You do not have the necessary role to use this service" \
--data "conf.msg_error_not_roles_claimed=You do not have the necessary role to use this service" \
--data "conf.policy=all
The roles claim in the JWT can be either an array or a (optionally comma-separated) string.
Multiple roles in a claim called roles
as a single comma-separated string:
{
"iss": "rVV0Atsoj7QwSX803D4sbBvFRu2EoTLo",
"iat": 1539775565,
"exp": 1571311565,
"aud": "www.example.com",
"sub": "[email protected]",
"roles": "A,B,C,D"
}
Single role in a claim called perm
as a single simple string:
{
"iss": "rVV0Atsoj7QwSX803D4sbBvFRu2EoTLo",
"iat": 1539775565,
"exp": 1571311565,
"aud": "www.acme.com",
"sub": "[email protected]",
"perm": "write"
}
Multiple roles in a claim called roles
as an array of strings:
{
"iss": "rVV0Atsoj7QwSX803D4sbBvFRu2EoTLo",
"iat": 1539775565,
"exp": 1571311565,
"aud": "www.acme.com",
"sub": "[email protected]",
"roles": [
"Editor",
"Viewer",
"Admin"
]
}