OIDC Authenticated Group Mapping

    After starting Kong Gateway with the desired configuration, you can create new admins whose usernames match those in your IdP. Those users will then be able to accept invitations to join Kong Manager and log in with their IdP credentials.

    If an admin’s group changes in the IdP, their Kong admin account’s associated role also changes in Kong Gateway the next time they log in through Kong Manager. The mapping removes the task of manually managing access in Kong Gateway, as it makes the IdP the system of record.

    Here’s how OIDC authenticaticated group mapping works:

    1. Create roles in Kong Gateway using either the Kong Admin API or Kong Manager.
    2. Create groups and associate roles with the groups.
    3. Configure the OIDC plugin to connect with your IdP.
    4. When users log in to Kong Manager, they get permissions based on the IdP group(s) they belong to.
    • An IdP with an authorization server and users with groups assigned
    • Kong Manager enabled
    • RBAC enabled
    • (If using Kubernetes) Helm installed

    Note: The following examples assume that you have RBAC enabled with Basic Auth and are transitioning to OpenID Connect.

    Kong Manager

    Kong Admin API

    Create a group and assign a role to it:

    1. Open Teams from the top navigation.
    2. Click the Groups tab.
    3. Click Create New Group.
    4. Set the Group Name to match your IdP group.

      Note: Group names are case-sensitive. Make sure to match your IdP group name exactly.

    5. (Optional) In the Comment field, enter a description for the group.

    6. Click on Add/Edit Roles, then choose a workspace and a role.
    7. Save the role assignment, then click Create.

    Create an admin for the group:

    1. Open the Teams from the top navigation.
    2. Click the Admins tab.
    3. Click Invite Admin.
    4. Note: Make sure the username exactly matches the admin’s name in your IdP.

    5. Ensure the Enable RBAC token checkbox is checked.

    6. Save the role assignment, then click Invite Admin.

    7. Create a group, making sure the group parameter matches your IdP group name:

      Note: Group names are case-sensitive. Make sure to match your IdP group name exactly.

    8. Assign a role to the group:

      1. $ curl -X POST --url http://<admin-hostname>:8001/groups/{group-id}/roles \
      2. --header 'content-type: application/json' \
      3. --header 'kong-admin-token: <yourtoken>' \
      4. --data '{
      5. "rbac_role_id": "e948171e-699c-4035-9b74-2b2b576d9644",
      6. }'

      Where:

      • : UUID of the role you want to assign.
      • workspace_id: UUID of the workspace to add the role to.
    9. Create an admin for the group:

      1. $ curl -X POST --url http://<admin-hostname>:8001/admins \
      2. --header 'content-type: application/json' \
      3. --header 'kong-admin-token: <yourtoken>' \
      4. --data '{
      5. "username": "<someusername>",
      6. "custom_id": "<examplename>",
      7. "email": "<your-email@company.com>",
      8. "rbac_token_enabled": true
      9. }'

    Notice how in the instructions above, you did not assign a role to your admin. The role will be matched with the role assigned to them in the IdP.

    Kubernetes with Helm

    Docker

    1. Create a configuration file for the OIDC plugin and save it as admin_gui_auth_conf. For group mapping, you must include the authenticated_groups_claim parameter as part of this configuration.

      For example, the configuration should look something like this:

      For detailed descriptions of all the parameters used here, and many other customization options, see the .

    2. Create a secret from the file you just created:

      1. $ kubectl create secret generic kong-idp-conf --from-file=admin_gui_auth_conf -n kong
    3. Update the RBAC section of the deployment values.yml file with the following parameters:

      1. rbac:
      2. enabled: true
      3. session_conf_secret: kong-session-conf
      4. admin_gui_auth_conf_secret: kong-idp-conf
    4. Using Helm, upgrade the deployment with your YAML filename:

    If you have a Docker installation, run the following command to set the needed environment variables and reload the Kong Gateway configuration.

    Substitute all variables in angled brackets (< >) with your own values:

    1. $ echo "
    2. KONG_ENFORCE_RBAC=on \
    3. KONG_ADMIN_GUI_AUTH=openid-connect \
    4. KONG_ADMIN_GUI_AUTH_CONF='{
    5. \"issuer\": \"<https://my-auth-url>\",
    6. \"client_id\": [\"<someid>\"],
    7. \"client_secret\": [\"<somesecret>\"],
    8. \"consumer_by\": [\"username\",\"custom_id\"],
    9. \"ssl_verify\": false,
    10. \"leeway\": 60,
    11. \"redirect_uri\": [\"<http://manager.admin-hostname.com>\"],
    12. \"login_redirect_uri\": [\"<http://manager.admin-hostname.com>\"],
    13. \"logout_methods\": [\"GET\", \"DELETE\"],
    14. \"logout_query_arg\": \"logout\",
    15. \"logout_redirect_uri\": [\"<http://manager.admin-hostname.com>\"],
    16. \"scopes\": [\"openid\",\"profile\",\"email\",\"offline_access\"],
    17. \"authenticated_groups_claim\": [\"groups\"],
    18. \"auth_methods\": [\"authorization_code\"]

    Replace <kong-container-id> with the ID of your container.

    1. Navigate to your kong.conf file.

    2. With RBAC enabled, add the admin_gui_auth and admin_gui_auth_conf properties to the file:

      1. enforce_rbac = on
      2. admin_gui_auth = openid-connect
      3. admin_gui_auth_conf = {
      4. "issuer": "<https://my-auth-url>",
      5. "client_id": ["<someid>"],
      6. "client_secret": ["<somesecret>"],
      7. "consumer_by": ["username","custom_id"],
      8. "ssl_verify": false,
      9. "consumer_claim": ["sub"],
      10. "leeway": 60,
      11. "redirect_uri": ["<http://manager.admin-hostname.com>"],
      12. "login_redirect_uri": ["<http://manager.admin-hostname.com>"],
      13. "logout_methods": ["GET", "DELETE"],
      14. "logout_query_arg": "logout",
      15. "logout_redirect_uri": ["<http://manager.admin-hostname.com>"],
      16. "scopes": ["openid","profile","email","offline_access"],
      17. "authenticated_groups_claim": ["groups"],
      18. "auth_methods": ["authorization_code"]
    3. Restart Kong Gateway to apply the file.