To create a Single Sign-On on AWS follow the steps below:
AZURE
- Open Azure Active Directory: https://aad.portal.azure.com and enter on Enterprise application:
data:image/s3,"s3://crabby-images/6ba7b/6ba7bb0cd8e701de2d6a8467b73cd04c70ba58aa" alt=""
- Click on “New application” search for AWS Single-Account Access and then click on “Create“
data:image/s3,"s3://crabby-images/e928e/e928e8e9972aac9dbcfa5e067aa914134cdb7a72" alt=""
- Once it´s done, access the new application
data:image/s3,"s3://crabby-images/cd117/cd1179f504a6c37fd4eef4d6b515e94155a8cbea" alt=""
- Click on the left menu, access “Single Sign-on” and select the SSO method to SAML
data:image/s3,"s3://crabby-images/71680/71680b19d0dfbd42b7b195077de7b6cb88f77675" alt=""
- As soon SAML is open you will receive a notification “Save single sign-on setting“. Click on Yes.
data:image/s3,"s3://crabby-images/73374/73374b88a2f55befc1a7a38b2480844711c58ba1" alt=""
After the warning of save successfully, refresh the page… It will display the Identifier and Reply URL correctly.
- Scroll down to step 03 and download Federation Metadata XML. We´ll use it on AWS. Don´t forget to double-check the notification email.
data:image/s3,"s3://crabby-images/02ee2/02ee2bdaad81626cd0831e5d21b0a91fc7029a10" alt=""
- Go back to AAD, and create an assigned security group. Assign the users to it and take note of the name of the group because we´ll use it with SSO on AWS.
data:image/s3,"s3://crabby-images/95aba/95aba3c516d9ea1ca4855e2a22de9cb64f48b973" alt=""
AWS
- It´s time to setup the AWS. Open the AWS console with your ROOT ACCOUNT https://aws.amazon.com/
- Once you are in, search for IAM
data:image/s3,"s3://crabby-images/97183/97183d586ff2203360436435a48701ec08c1477d" alt=""
- On left panel, open Identity providers
data:image/s3,"s3://crabby-images/9aa36/9aa36f3d97f88dd4c4366249c820fb91c5313207" alt=""
- Select on provider type select SAML,
- Give a name for your Provider – in my case, I called AzureAD
- From the Metadata document, choose the XML that you download from Azure
- and then click on Add Provider
data:image/s3,"s3://crabby-images/35c48/35c48c2f837870750a7923066285f642b01ec571" alt=""
- Access again the provider. Now we´ll add the IAM role to it.
data:image/s3,"s3://crabby-images/efcaa/efcaa235331af377e185c1f5db59670db5d1f319" alt=""
- Click on Assign role
data:image/s3,"s3://crabby-images/9b415/9b415df8afd3ae47e90a91d04a8c0e2f7407e5d7" alt=""
- Create a new role – > NEXT
data:image/s3,"s3://crabby-images/0a821/0a8213f14f953f82a0398233cc32f812eb7c2de8" alt=""
- Select SAM 2.0 Federation
- SAML Provider -> select the name of the Provider – in my case AzureAD
- Check “Allow programmatic and AWS Management Console Access“
data:image/s3,"s3://crabby-images/54c05/54c05245541b0bf584a1019c363e4146dda06dc4" alt=""
- On the next page search for the permission that you want to assign to users when they log in. I used the system administrator here.
data:image/s3,"s3://crabby-images/62784/62784bb88331566fff6dbe9108a3094281ccb949" alt=""
data:image/s3,"s3://crabby-images/39827/398278b661bb2a6901e3d72bdb4d69efbe3085db" alt=""
- At review page, write the role name
- Role name: THE-NAME-OF-GROUP-ON-AZURE-AD
- REMEMBER: If you don´t do it this way it won’t going to work…
data:image/s3,"s3://crabby-images/2898a/2898a145c1bb7c2cb4c780b53d648bdddd4383e3" alt=""
data:image/s3,"s3://crabby-images/22648/22648a8abb88dc73c467f5534d3fb5e6a2ef6e29" alt=""
- Now we need to create a new Policy.
- Select Policies from left menu
- and click on Create Policy:
data:image/s3,"s3://crabby-images/7221c/7221cf356f435ffa6804a443f959174675ce2ee9" alt=""
- Change the view to JSON and paste the data below:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "iam:ListRoles" ], "Resource": "*" } ] }
data:image/s3,"s3://crabby-images/66d4c/66d4c4907d11ec18aaee9679f3b99445f7749144" alt=""
data:image/s3,"s3://crabby-images/120f6/120f66babf7d0f8639380795acb89802359ca42f" alt=""
- Policy Name: AzureAD_SSOUserRole_Policy
data:image/s3,"s3://crabby-images/08539/085396be0934eb7b60fae4048997cc9ab08920ef" alt=""
data:image/s3,"s3://crabby-images/1981d/1981d052c721637f54bf29b1b5be8b968e45ee4f" alt=""
- Now we need to create a user with API access.
- On left menu click on Users and ADD USERS
data:image/s3,"s3://crabby-images/c9bcb/c9bcba1b4915570f6ca0cc3a8f468320ddfe22aa" alt=""
- User name: AzureADRoleManager
data:image/s3,"s3://crabby-images/4b233/4b233af6dfc1d66c5250fba6a9807b2a819dd7b2" alt=""
- Permission options: Attach policies directly
- Select the policy that we created before: AzureAD_SSO_user_role_Policy
data:image/s3,"s3://crabby-images/46220/4622024409f7ad3e068d39859da20e1a32584288" alt=""
- Click on next to review and create.
- Access the new user again
data:image/s3,"s3://crabby-images/18c8e/18c8eccafff91669359132d7edc02a8a22fa8c92" alt=""
- Go to Security Credentials and click on Create Access Key
data:image/s3,"s3://crabby-images/9e959/9e959acefcab5a0d2f1754dda9c7e9197d8e392f" alt=""
- Select the use case Other
data:image/s3,"s3://crabby-images/5c77a/5c77a2adec638d8287f4e397de522eea2d2ee7ad" alt=""
- Click on Create Access Key
data:image/s3,"s3://crabby-images/64a2c/64a2ceeeac33956623dc7fc123829501db692523" alt=""
- At the next screen, take note of the Access Key and Secret Access Key. We´ll use it back on Azure AD.
data:image/s3,"s3://crabby-images/977ae/977aedeeeb608a36c42bc489eb11c3592db63515" alt=""
AZURE
- Back to Azure -> Access the Enterprise Application and open the app AWS Single-Account Access
data:image/s3,"s3://crabby-images/1c7ff/1c7ff2130108f7b145fc9fc2600ee7a2aad7ecfc" alt=""
data:image/s3,"s3://crabby-images/349de/349deb9737fa1ff262c781bda675a7180da8abfb" alt=""
- Go to Provisioning -> Get- started
data:image/s3,"s3://crabby-images/d2082/d2082744877af971a956787540e8fd68a6ced898" alt=""
- Change the Provisioning Mode: Automatic
- Admin Credentials:
- clientsecret: AWS-ACCESS-KEY
- Secret Token: AWS-SECRET-ACCESS-KEY
- Both you get from user that you create on AWS
- Click on Test Connection -> Save
data:image/s3,"s3://crabby-images/a805d/a805dabc234b74bf316eb4a340491ce05fe487e5" alt=""
data:image/s3,"s3://crabby-images/343f2/343f2959045d2e23a5838f280e974728c2a7ca23" alt=""
- Go out from the Provisioning screen and access again – It´s necessary just to refresh the page.
- Now click on Edit Provisioning
data:image/s3,"s3://crabby-images/b18dc/b18dcb89dfb428be161bfcf956a0fe38dd3d6432" alt=""
- Turn on Provision Status
data:image/s3,"s3://crabby-images/bab59/bab5999067afc9a98a906d98f6791b8fc9f71d99" alt=""
- At last, Go to Users and Groups from the enterprise application and add who is going to have access.
- If you don´t have Azure AD Premium you cannot add a GROUP here.
- The users must be members of the security group even if it is added manually at Users and Groups from the enterprise application.
- The security group must be direct members
data:image/s3,"s3://crabby-images/7cad0/7cad0fad7816b8ae2ab0816071c6292882068c77" alt=""
data:image/s3,"s3://crabby-images/0f3ab/0f3ab5e1dbe588f0f04b577df2fcc5dd6907b866" alt=""
- You must wait the provision time of synchronization (could take up to 40min)
- To test, access the: https://myapplications.microsoft.com/ end click on AWS icon
data:image/s3,"s3://crabby-images/cf096/cf0965fde828533aec996b9a68810eeca3dd039f" alt=""
data:image/s3,"s3://crabby-images/663da/663dae44b4a9cb5e768c259134a1ad922ad58c90" alt=""