[Setting Up Single Sign-On With AWS SSO on Kibana Cloud]
The Elastic Stack supports SAML single-sign-on (SSO) in Kibana, using Elasticsearch as a backend service. In SAML terminology, the Elastic Stack is operating as a Service Provider.
The other component needed to enable SAML single-sign-on is the Identity Provider, a service that handles credentials and performs user authentication.
This article will describe setting up single sign-on in Kibana (Elastic Cloud), where AWS SSO (IAM Identity Center) will serve as the identity provider.
Elastic Cloud deployment version v8.12.0.
1. We prepare the SAML configuration from the IAM Identity Center.
In the AWS console, go to the "IAM Identity Center" section:
data:image/s3,"s3://crabby-images/f7093/f7093ac5a3c7a165621f5080c5bab6e4ee33721a" alt="AWS Console Home"
Next, go to the Application assignments section and select Applications:
data:image/s3,"s3://crabby-images/5379a/5379a1ee506dcdcde45e09c8dc3b70820c67d2f1" alt="Application assignments"
Select "Customer managed" in the "Applications" section and click "Add Application":
data:image/s3,"s3://crabby-images/ff262/ff262f63384ffa43b54ba4e9aeef5b298ef74a55" alt="Customer managed"
Fill in the required fields "Display name" and "Description." The "Display name" will subsequently be displayed in "Applications" when logging into AWS SSO:
data:image/s3,"s3://crabby-images/aff18/aff18c20d0a4271aba8561ad1ffa00956d792c2f" alt="Elastic Kibana Cloud"
In "Application metadata," place https://<kibana_url>/api/security/saml/callback
in the "Application ACS URL" field.
Place https://<kibana_url>/
in the "Application SAML audience" field and select Submit
data:image/s3,"s3://crabby-images/d04a7/d04a7eaf653e857f77fc828251e8b4b60a7c181f" alt="Application metadata"
Next, in the same configuration, you need to configure Attribute Mapping. IAM Identity Center uses these user attributes to populate SAML assertions (as SAML attributes) sent to the application. You can find more details in the documentation: https://docs.aws.amazon.com/singlesignon/latest/userguide/attributemappingsconcept.html
To configure Attribute Mapping, go to the Application you created:
data:image/s3,"s3://crabby-images/2b04e/2b04e9e72c5d912502968dc24ce9b9ba1b56f2d1" alt="Applications"
Select Action -> Edit Attribute Mapping:
data:image/s3,"s3://crabby-images/a42cc/a42cc780f769d78a28aa9a74c9f3afb586d1fbb6" alt="Kibana > Edit attribute"
Since we plan to differentiate permissions by user groups in Kibana, the 2 attributes shown in the screenshot will be enough. Save changes.
data:image/s3,"s3://crabby-images/4ade6/4ade669db3c1535965343ebe35de9810e00c2080" alt="Attribute mappings"
Let's immediately create several user groups in the IAM Identity Center:
Kibana_admins and Kibana_developers. To do this, go to the Groups -> Create group section in the IAM Identity Center. We set the Group name and Description and can immediately add users to the group.
data:image/s3,"s3://crabby-images/edd61/edd619eb866c22df359fe44396dd9472c79e39db" alt="Managing intance"
data:image/s3,"s3://crabby-images/80b7c/80b7c94ac8a279000ad11e22cac97991ee599fd1" alt="Create group"
We return to the settings of our Application and assign the created groups:
data:image/s3,"s3://crabby-images/4cce4/4cce4a2e837d3ac6389d7fd105b8a6571b8ddce7" alt="Application and assign the created groups"
2. Now, let's start setting up Elastic Cloud:
Go to https://www.elastic.co/cloud in the Deployment -> Actions -> Edit Deployment section:
data:image/s3,"s3://crabby-images/66383/66383a7e622db198e98958e65a770d0b00f05428" alt="Actions > Edit"
Select "Manage user settings and extensions (0)" in the ElasticSearch settings section:
data:image/s3,"s3://crabby-images/f31cb/f31cbb637370600f9af1d47b6ff5aa0b5c02e00e" alt="Manage user settings"
Adding the configuration:
xpack:
security:
authc:
realms:
saml:
saml-realm-name:
order: 2
attributes.principal: "nameid"
attributes.groups: "groups"
idp.metadata.path: "https://portal.sso.us-east-1.amazonaws.com/saml/metadata/XXXXXX"
idp.entity_id: "https://portal.sso.us-east-1.amazonaws.com/saml/assertion/XXXXXX"
sp.entity_id: "https://<kibana_url>/"
sp.acs: "https://<kibana_url>/api/security/saml/callback"
sp.logout: "https://<kibana_url>/logout"
data:image/s3,"s3://crabby-images/a48d2/a48d279c4dda6b32b0f88ddf41a024fc9ccb1a9e" alt="User settings"
You can get the idp.metadata.path and idp.entity_id values in the previously prepared Application in the IAM Identity Center metadata section.
Select "Back" and go to the Kibana configuration.
data:image/s3,"s3://crabby-images/217f7/217f79b433e53aaba69170dbc635135a1af4d08f" alt="Kibana > Edit user settings"
data:image/s3,"s3://crabby-images/648f3/648f3a7a40c5bc75334b7b9c442610a198b53cd5" alt="Settings code"
xpack.security.authc.providers:
saml.saml1:
order: 0
realm: saml-realm-name
description: "Log in with my AWS SSO"
basic.basic1:
order: 1
After adding the Kibana settings, select "Save," after which we confirm that we want to apply this configuration. We wait for the settings to be applied within 15-30 minutes.
data:image/s3,"s3://crabby-images/d7a32/d7a321a334c78c42affd944faa10540e3a77e33d" alt="Save button"
You can find more detailed settings in the documentation: https://www.elastic.co/guide/en/cloud/current/ec-securing-clusters-SAML.html
Next, we configure "Map Roles" at the Kibana level.
Go to the Kibana web interface in the section Management -> Stack Management -> Security -> Create Role Mapping.
data:image/s3,"s3://crabby-images/1e9bc/1e9bc0c063c51f663c085cd419bcaf878e6037a0" alt="Role mapping"
data:image/s3,"s3://crabby-images/8169d/8169d981a4f009ef8e655a375dc59f8cad046948" alt="Mapping rules"
The screenshots above show the creation of 2 Maps Roles: Kibana_developers_aws_sso_saml and Kibana_admins_aws_sso_saml.
The name of the Maps Role can be anything. In the Roles section, we set roles with the necessary rights for users, for example, for Kibana_admins_aws_sso_saml - the superuser role, for Kibana_developers_aws_sso_saml the developer, apm_user roles.
In the Mapping rules section, the User field "realm.name" must match the saml-realm-name.
The User field "Groups" must match the user group ID in the AWS Identity Center. You can find this in AWS Identity Center ->Groups -> Select the desired group -> Copy Group ID in the General Information section.
After applying all the specified settings, you can proceed to testing.
When we open the Kibana start page, we see a new login item.
data:image/s3,"s3://crabby-images/3d7b6/3d7b65c7921ef403eda3c94f57caa082a6c618f5" alt="Welcome to Elastic"
When authorizing via AWS SSO in Kibana, the user will have access to the rights granted in "Role Mapping."
data:image/s3,"s3://crabby-images/0cdd5/0cdd58979f838fd401398a13bf7a389f6f2aa6ff" alt="Profile in Elastic"