Entra ID SSO Integration
This page teaches you how to integrate Entra ID into Cognito.
Last updated
This page teaches you how to integrate Entra ID into Cognito.
Last updated
Capture the Congito User Pool ID
In the AWS Console, navigate to the User Pool created by your application. It'll generally look like "CloudStorageSecUserPool-{appid}".
Copy the User Pool ID.
Create a Cognito Domain
In the User Pool, navigate to Domain and select 'Create Cognito Domain'.
Create the domain of your choice.
Create a New Application
Navigate to Microsoft Entra ID in your Azure console and select 'Enterprise Applications'. Select 'New Application'.
Select 'Create your own application' and enter in a name of your choice.
Set up SSO for your application
After this application is created, select 'Set up single sign on'.
Select SAML and select 'edit' on the Basic SAML Configuration, entering in the following:
Identifier (Entity ID) as 'urn:amazon:cognito:sp:' plus your Cognito user pool ID that you copied earlier
Reply URL (Assertion Consumer Service URL) as your Cognito domain name that you created earlier (it should end in ...auth.{region}.amazoncognito.com)
Save this configuration.
In the 'SAML Certificates' box, copy the 'App Federation Metadata URL'.
In the AWS Console:
Navigate back to your Cognito User Pool and select 'Social and external providers'.
Select 'Add Identity Provider'
Select 'SAML' and enter in a provider name. Do not add spaces.
Select 'Enter metadata document endpoint URL' and paste in the App Federation Metadata URL that you copied from Azure.
Add the identity provider.
In Cognito, navigate to App Clients -> {your user pool} and select 'Login pages'.
Select the 'Edit' button and enter in the following:
Allowed callback URLs: CSS Console URL
Allowed sign-out URLs: CSS Console URL
Identity Providers: Identity Provider you just created
Oauth 2.0 grant types: 'Authorization code grant', 'implicit grant'
OpenID Connect scopes: 'OpenID, 'Email'
Select 'Save changes'.
In the Azure console:
Navigate back to your Enterprise Application and select 'Users and groups'.
Select 'Add user/group'.
Select 'None Selected' and choose your Azure user.
After selecting the user, click 'Assign'.
In the CSS Console:
View the sign-in page and note that your Azure-created application now appears.
Click on the 'Sign In With {sso}' button. This will create a user in Cognito but permissions need to be initiated first.
Log in as a user that has Admin permissions.
Go to Access Management -> Manage Users. There will be a new user created with the the format {provider_name}_{entra_user_email} in the Manage Users page.
Click the 3 buttons next the Status and choose Groups. Select Primary and assign the user to the group.
Enable the user by clicking the button with 3 dots on the rightmost column and selecting 'Enable User'.
(Optional) Click the 3 buttons next to the Status and choose 'Change Role'. The user defaults at 'User' permissions and can be adjusted to another role if needed.
Your user is now set up! Log out and click the SSO button. You are now logged in as the SSO user!