If you need to integrate OKTA SSO with AEM, you will need following things from the OKTA application-
1. Go to Self service App for OKTA
2. Click on Register new application
3. Fill in required details. Below are few important fields which must be configured carefully-
1. Create certificate file
Copy the certificate string in a text file and save it as idp_cert.cert in your local computer
- IDP certificate
- Single sign-on URL (also called IDP URL)
- Okta Logout URL (If your application need to support logout)
OKTA Configuration
Below are the things which need to be done at OKTA side:1. Go to Self service App for OKTA
2. Click on Register new application
3. Fill in required details. Below are few important fields which must be configured carefully-
- SAML Reciept: This is the returning URL to AEM after successful user authentication in OKTA. This URL is generally in this format- https://youraemsitedomain.com/saml_login
It is Frequently found issue that this URL is not setup properly. So while trouble shooting validate that after successful authentication from OKTA user must return to exactly /saml_login page. Validate this in SAML XML response too. No ending slashes or any other page. If user is not returning to /saml_login then there is an issue at OKTA side or at your web server side. In the most cases, correcting the SAML receipt URL at OKTA side fixes this issue. In worst case, check rewrite rules at your webserver if they are not screwing it up. - SAML Audience: This is your AEM domain name. Example value- youraemsitedomain.com Ensure no http or https or www.
- SAML Name Id: Use EmailAddress here.
AEM Configuration
Below are the key steps to configure OKTA SSO at AEM side:1. Create certificate file
Copy the certificate string in a text file and save it as idp_cert.cert in your local computer
2. Upload certificate in crx under path /etc/key using blow steps
idp_cert- Binary
Save the node
3. Now, Go to AEM admin console and navigate to: Tools > Security > Users
- Go to crxde
- Create a node "saml" under /etc/key:
idp_cert- Binary
Save the node
- Double click on binary type for the property name "idp_cert" and upload the certificate file that was created in step 1 above.
3. Now, Go to AEM admin console and navigate to: Tools > Security > Users
- Open user - "Administrator", Scroll down for Account settings
- Click on Create KeyStore, Enter a value for the password in both text boxes (Note down this password, this will be required to setup the SAML OSGi configuration)
- Click on Manage TrustStore. Click on Add Certificate from CER file
- Click on Select Certificate file, Navigate to idp_cert.cert file that you created in step 1 and uncheck Map Certificate to user
- Click on Submit.
Screen should look like this-
Note down the Alias Value on the left colum. This will be required to setup the SAML OSGi configuration.
4. At Tools > Security > Users
- Open user - "authentication-service", Scroll down for Account settings
- Click on Create KeyStore and provide the same password . Click OK.
5. Configure Saml Authentication Service
- Go to /system/console/configMgr
- Open "SAML 2.0 Authentication Handler"
- Add required details
- On the System console configMgr, Open "Apache Sling Referrer filter"
- Add the Okta domain name e.g. "mysite.okta.com"
Other things you may need to setup this functionality is:
- Create new user group- for default user group configured in step 5
- Create CUG for the path (May be this can be skipped, as it worked for me without CUG setup)
This article is specifically articulated for OKTA integration. Refer the Adobe documentation for integrating SSO with other SAML providers - https://helpx.adobe.com/experience-manager/using/aem63_saml.html
Howdy!! Great Blog!! You have really explained the concept of single sign on solutions (SSO) integration in a simple manner.
ReplyDeleteHi Vivek, one question - after this okta integration why is it that the profile node under the user node in /home/users is not created when a user logs in through okta. So how will be able to get all the data like firstname, lastname, etc.
ReplyDeleteI had no issues with the user property creation in AEM with the integration. In OKTA app, there is setup for profile field mapping which will be sent SAML response. Kindly ensure the mapping has correct values.
DeleteThank you for sharing your experience the process thus it is very much interesting and i got more information from your blog.
ReplyDeleteAdobe Experience Manager (AEM) is an application segment of the Adobe Marketing Cloud suite by Adobe Systems. It sorts out, oversees, and conveys contents with the reason for making promoting. From Amazon Web Services where it is hosted,it gives clients formats for making focused on substance and which can later be distributed safely from the AWS cloud.
Wow it is really wonderful and awesome thus it is very much useful for me to understand many concepts and helped me a lot. it is really explainable very well and i got more information from your blog.
ReplyDeleteInformatica Online Training
Java Online Training