OKTA Integration
Secure search can also be used through OKTA, which is an enterprise-grade, identity management service built for the cloud, but compatible with many on-premises applications. Click HERE for more Information on OKTA.
Configuring OKTA in SearchBlox
Follow these steps to use OKTA secure search:
- Select Enable OKTA.
data:image/s3,"s3://crabby-images/44aaf/44aaf533f60cce05eb6e13e73f8859021e77955c" alt="OKTA - 9.2.3.jpeg 1439"
- Enter the required details regarding OKTA.
Field | Details |
---|---|
OKTA URL | Full-qualified base URL for your OKTA organization. |
API Key | The API key you generated as part of prerequisites from OKTA. |
Custom Attribute | Attribute that you use to filter search results. By default, it is Collection. |
Attribute Separator | The separator for the attributes that are given in OKTA. |
Authorization by LDAP/AD | OKTA user authentication with LDAP/AD search authorization. This is an advanced collection-level security mechanism that can be supported. |
- Test the connection.
data:image/s3,"s3://crabby-images/d6103/d6103587c2f8ad951c40342e1b4690bb7151a44c" alt="OKTA - 9.2.3.jpeg 1439"
Configuration and API token
- Login to OKTA
data:image/s3,"s3://crabby-images/152e6/152e67565cd1e592d4a626336cbd2135da2d429d" alt="cokta1.png 808"
- Click Create an API token
You can otherwise access this token generation page by going to Security > API > Click Token tab.
The API key and URL are required from OKTA to use a secure search.
http://developer.okta.com/docs/api/getting_started/getting_a_token.html
data:image/s3,"s3://crabby-images/10b0e/10b0e0eb8a39aa79d630508be6ad7f7092ce419f" alt="cokta2.png 572"
-
Please save this token locally as it cannot be viewed again.
-
Use this token in OKTA settings in Searchblox Admin > Search > Security
data:image/s3,"s3://crabby-images/2a1d6/2a1d67d156b9fa177c40a9cec33a93f380c0b1e0" alt="OKTA - 9.2.3.jpeg 1439"
- On testing the connection, it should be successful.
Important Note:
- If you are setting up OKTA for SearchBlox for the first time, please set up your collection attribute mentioned below and then try testing the connection.
Setting up collection attributes
- Navigate to Directory/Profile Editor.
data:image/s3,"s3://crabby-images/a45b1/a45b186cb8cc92452782387b52af94ce6401de63" alt="secsearch9.png 1070"
- Edit The OKTA profile and add a new attribute named “collection”, or any other name. This is a user profile so whenever a user is created you will be able to see the collection attribute.
data:image/s3,"s3://crabby-images/72fd0/72fd064f9e04bcdecf7565066c7943879e872486" alt="secsearch10.png 956"
Limiting collections based on users
- Once the attribute is set, you can provide access to collections based on user access.
- If you want user1 to have access to collections 1 & 2, then you can limit the same by going to Directory > People > click the user > go to the Profile tab.
- In the user profile, you can limit the collections that can be accessed by the user.
- If you give the collections attribute as 1:2, only collections 1 and 2 would be accessible by the user, where ":" is the attribute separator given in Searchblox OKTA secure search settings.
data:image/s3,"s3://crabby-images/1f907/1f907f127fdb3f6e81deba2c6fca0e4d3a9aa59d" alt="secsearch11.png 659"
data:image/s3,"s3://crabby-images/ffe04/ffe04f62dfcd113426011a01b08bf0f9ff216a17" alt="secsearch12.png 639"
- In the SearchBlox Settings for OTKA, custom attributes and attribute separators work as follows:
Custom Attribute: The collection attribute created previously to filter the collections based on users.
Custom Attribute Separator: This is used to separate the collection IDs. For example, if you give the value of the collection as “1:2:3:”, the attribute separator is “:” Use this format for collections that are to be accessible by the user.
data:image/s3,"s3://crabby-images/cd08d/cd08dc5bf25f8c000e3f395ade165ad82a313caa" alt="OKTA - 9.2.3.jpeg 1439"
Accessing Secure Search using OKTA
You can log in using OKTA credentials and perform a secure search from this link:
https://localhost:8443/searchblox/plugin/index.html.
data:image/s3,"s3://crabby-images/059af/059afd45926654d1be0619442f76f75e85e45b84" alt="Image 2020-07-24 at 7.39.16 PM (2).png 638"
data:image/s3,"s3://crabby-images/04ef3/04ef329ec4eefc2fa34e0ce3a17a37bbcbcd4fd5" alt="okta2.png 1074"
OKTA SSO with LDAP Authorization
Create an OKTA SSO
- Signup for OKTA (https://developer.okta.com/signup/) using React Stack for SearchBlox (If you have an OKTA account ready, please skip this step and login to your OKTA account)
data:image/s3,"s3://crabby-images/c8214/c821415d3a67fdcaf492d0f2422a519cb9def48a" alt="image16.png 1526"
- Go to Applications tab and then click on the Add Application button. Choose Single Page App and click Next.
data:image/s3,"s3://crabby-images/81918/81918d2cb2d294d9be4418133e4566eabb51f646" alt="image2.png 1587"
- In the Application Settings, fill in the Name of the Application, Base URIs, Login Redirect URIs and Logout Redirect URIs. Click on the “Implicit” checkbox and click Done. “Authorization Code” is checked by default.
For example:
Base URI - https://test.searchblox.com
Login redirect URI - https://test.searchblox.com/searchblox/test/index.html
Logout redirect URI - https://test.searchblox.com/searchblox/test/index.html
data:image/s3,"s3://crabby-images/b8a16/b8a16dd4a0017719a1db2d8e6d81d50c74e4f8f2" alt="image7.png 804"
- Click on Edit in General Settings and configure Initiate Login URI. Check Allow ID token and Allow Access token. Select Login Initiated By Either OKTA or APP. Once completed, click on Save.
For example:
Initiate Login URI - https://test.searchblox.com/searchblox/test/index.html?login=true
data:image/s3,"s3://crabby-images/42f79/42f7980072e541258ffec2b9fc46f6aa6a632a68" alt="Image 6.png 1118"
- You can also add a logo for the application you created. Click on the edit icon, click on browse, choose the necessary file and click on Update Logo.
Click HERE to download the SearchBlox logo as shown below.
data:image/s3,"s3://crabby-images/6f77b/6f77bc28fe784655718259c46369c094948d0f93" alt="image12.png 1444"
- Once you update the logo for SearchBlox, the chiclet will look as shown below.
data:image/s3,"s3://crabby-images/2ea36/2ea361aafd8c3d1b32671a7a465bd2ecfee861c8" alt="image4.png 429"
Add Users/Group Claims
- Once the application is successfully configured, you can add Users/Group Claims.
- To add a new User, click on People under the Users tab. Click on Add Person and enter the necessary details. You can choose to set a password by admin or allow the user to set a new password for themself.
data:image/s3,"s3://crabby-images/bba29/bba29c870f3aede9fbbed71a0767496b7dab7b44" alt="image9.png 1810"
- To create a new Group, click on Groups under the Users tab. Click on Add Group, give a name and description. Now you can add Users to the created Groups.
data:image/s3,"s3://crabby-images/f7581/f7581487f86e782ad263269846f262fb24b7c5e1" alt="image15.png 1200"
- Add your SearchBlox OKTA Users to the created group.
data:image/s3,"s3://crabby-images/0a701/0a701b45000eedbebb6ddd8f0fe63c4994afa0fe" alt="image3.png 1810"
- To assign the application to the created group, click on the group name, click on Manage Apps and then click Assign on the app. Click Done.
data:image/s3,"s3://crabby-images/65a9d/65a9d0d05c5c45ceef2b61d3ac3e149cd27a8879" alt="image8.png 824"
- To add Claims, go to Authorization Servers under the API tab. Click on the default server and the click on the Claims section.
- Click on Add Claim. Give a name, change “Include in token type” to “ID Token”, change Value type to “Groups” and change filter to Matches regex and give value as “.*”. Once complete, click on Create.
data:image/s3,"s3://crabby-images/76b4f/76b4fb398ca80cc7b4e81a3f186cdda1e14ed8a4" alt="image11.png 1230"
- Login to your SearchBlox Admin Console and configure your LDAP settings and security groups. Then, you can configure your OKTA settings. For the OKTA API, go to Tokens under the API section and click on Create Token.
data:image/s3,"s3://crabby-images/4a727/4a727879e1ddc94390f14c1001475e6ad941cbfa" alt="image1.png 1768"
- Configure OKTA in SearchBlox Admin Dashboard > Search > Security > OKTA as shown.
data:image/s3,"s3://crabby-images/5091a/5091a9441460327ecbbcf239add8de41f1592524" alt="image10.png 1566"
- Click on Test Connection in both LDAP and OKTA to verify if the configurations were successful
Configure Custom UI
- Download the SearchBlox Custom UI plugin, which is given on request. Extract the file and edit the facet.js file.
- Update the Issuer URI, ClientID, Plugin Name and Plugin Domain values, according to your OKTA setup, in the Custom UI facet.js file.
- To get the Issuer URI, click on Authorization Servers under the API tab.
data:image/s3,"s3://crabby-images/55bf4/55bf460b14e13589e8b7ac79ada9d70e029f2f24" alt="image14.png 1814"
- To get the ClientID, go to your OKTA SearchBlox application. Under the General tab, you’ll find it in Client Credentials.
data:image/s3,"s3://crabby-images/80f2a/80f2ae9acb9a19835c7959e9ebe8eff54a4ab84e" alt="image5.png 1158"
- Make the necessary changes as shown below. Save the new facet.js file and copy and paste the new CustomUI folder into the filepath:
<SearchBlox-Installation-Directory>/webapps/searchblox/<custom-ui-name>/
data:image/s3,"s3://crabby-images/b79de/b79deb455d988aa156d00145760e44f36be98ce6" alt="image13.png 1166"
- Now you can access SearchBlox's custom UI with valid users to test the OKTA SSO. You’ll see that a valid user can only access the private collection assigned by the LDAP security groups along with any public collections (if any).
data:image/s3,"s3://crabby-images/e2504/e25041e4dea662ff02ac4f29be41cbe52acb9846" alt="image17.png 1883"
Note:
- Private collections can be accessible only through secure search authentication.
- Public collections are accessible with/without secure search authentication.
- Make sure to whitelist your SearchBlox domain to prevent CORS errors and access the Custom UI. Click HERE to see how to enable CORS.
- Secure search logging is performed in the file
securesearch.log
file found inwebapps/searchblox/logs
filepath.- Configure the LDAP/AD Realm Security groups before integrating it with OKTA set up. OKTA can be configured by enabling "Authorization by LDAP/AD".
- When an OKTA user tries to login, secure search authentication will be done for the OKTA user and the authorization will be done by the LDAP/AD security group searchbase.
Updated almost 4 years ago