Joget DX 8 Stable Released
The stable release for Joget DX 8 is now available, with a focus on UX and Governance.
The 'SAML Service Provider Directory Manager' plugin facilitates effortless Single Sign-On (SSO) integration with Joget by enabling compatibility with various Identity Providers (IdPs). With this plugin, users can seamlessly authenticate and access Joget through their chosen IdP, enhancing the user experience and security of the platform.
Plugin Available in the Bundle:
SAML Service Provider Directory Manager
This plugin bundle is compatible with Joget DX 8.
To successfully perform Single Sign On (SSO) to Joget using Identity Provider (IDP). For this article we are using OKTA as Identity Provider.
The prerequisite for this plugin is to have a account with desired Identify Provider (IDP) and setup the App integration and obtain the IDP metadata and certificate. In this article we will using OKTA as the Identity Provider.
Please refer to following to read and understand more on Okta.
Okta
Identity Providers (IdPs): What They Are and Why You Need One
Okta Documentation
Create Developer Account at https://developer.okta.com/signup/ and compete the signup process. For this the setup in this article, we will be using Workforce Identify Cloud Account.
Figure 1: Okta Developer Account Sign up
Login at https://developer.okta.com/login/
Go to your Okta developer account, and navigate to Applications > Create App Integration.
Figure 2: Okta Developer Dashboard - Creating App Integration
Figure 3: App Integration - SAML 2.0
After selecting SAML 2.0, pick a meaningful app name to represent Joget.
You may click on "Do not display application icon to users" if you do not want this app to appear in Okta's end user interfaces.
Figure 4: General Settings
In the next screen, we will be required to provide SSO URL and SP Entity ID.
Figure 5: SAML Settings
Here we will need Single sign-on URL & Audience URI (SP Entity ID). Please key in the following in both the fields
[server]:[port]/jw/web/json/plugin/org.joget.marketplace.SpSamlDirectoryManager/service
Replace the server and port with actual server credentials. For example localhost:8080
For this article we are using localhost as server and 9443 as port.
Change Name ID format onto EmailAddress.
Figure 6: SAML Setting (General)
Scroll down to Attribute Statements (optional) and fill up the attribute mappings. The mappings are needed to identify the users that will be logging in.
Figure 7: Attribute Statements
Attribute Statements
Click Add Another to create an extra attribute statements.
Name | Value |
---|---|
firstName | user.firstName |
lastName | user.lastName |
user.email |
Complete the rest of the steps by clicking on Next and Finish. You may choose "I'm an Okta customer adding an internal app" for your testing purpose.
In this, we will get IDP Metadata and Certificate.
IDP Metadata and Certificate
We will need IDP Metadata and Certificate to configure this plugin in later steps.
Edit the app integration that we have just created on Okta.
Figure 8: Obtaining Metadata
Copy the Metadata URL and open it in a new window. Copy the entire content.
Figure 9: Metadata
Scroll down to look for SHA-2 cert and download certificate.
Figure 10: Download Certificate
Figure 11: Okta Certificate
We will need to assign user(s) to the app. Navigate to Applications > Assignments > Assign.
Figure 12: Assign Users to App
Once assigned, the selected users are now able to SSO into Joget using their identity in Okta.
We are done with setting up OKTA Developer Account and obtains the required items such as IDP Metadata and Certificate. We will not proceed to setup this plugin in Joget.
Get the plugin jar file from https://github.com/jogetoss/sp-saml-directory-manager
Upload the plugin jar file in Joget by going to Settings → Manage Plugins → Upload Plugin
Once the plugin in uploaded, go to Settings → Directory Manager Settings → choose SAML Service Provider Directory Manager - 8.0.0 and click Select.
Figure 13: Select Plugin
Open the certificate with your text editor and copy the value and paste it into Joget.
Figure 14: Paste the Cert Content
Paste the content into Metadata in Joget.
Figure 15: Paste Metadata
User Provisioning
You may want to check on User Provisioning Enabled so that if it is the first time an user SSO into Joget, an user account would be created in Joget and the user would be able to continue to log in to Joget.
Configure the user attributes.
Figure 16: Configure User Attributes
Configure User Attributes based on the mappings below.
Name | Value |
---|---|
First Name Attribute | firstName |
Last Name Attribute | lastName |
Email Attribute |
The "Value" here corresponds with "Name" column that we have declared in Figure 6 earlier.
Configure the Login Button. This login button will be shown at the Joget Login Screen to enable use to perform Single Sign On (SSO) using OKTA.
Figure 17: Configure Login Button
Up to this point, we have successfully created app integration in Okta and configured the SAML Service Provider Directory Manager plugin in Joget.
To login using this plugin, you have to logout from Joget. Go to Joget Login Page, you will see the following login screen with the login button to perform SSO using OKTA.
Login Screen
Login screen may differ as show below depending on the App Center but login button will be shown.
Figure 18: Joget Login screen
Upon clicking on the blue login button, the user will be redirected to Okta.
Figure 19: OKTA Login Screen
Upon successfully login in Okta with your registered email you would be redirected back to Joget and will be logged in.