Single Sign-On
Single Sign-On (SSO) is a technology that lets corporate networks use external user authentication services (also known as identity providers or IdPs) and significantly simplifies the process of managing access to corporate systems and resources. It is used to authenticate the user and then configure access to corporate services through authorization. The main benefits of SSO are to improve the user experience and reduce the risks associated with password management.
Key points of SSO using IdP:
- Authentication via IdPs. An IdP is responsible for verifying the user's identity using their login and password. Active Directory (AD) or similar services are usually used for this.
- Trust between IdPs and services. Applications and servers configured to trust IdPs accept the fact of authentication performed by an IdP and do not ask the user to re-enter their login and password.
- Authorization process. After successfully logging in via an IdP (for example, ADFS), the user gains access to related applications saving their context (settings, roles, group membership, and others).
- Access without re-entering data. Until the end of the session in an IdP, the user can automatically log in to systems without entering credentials.
Example of operation:
- When logging in to SimpleOne for the first time, the user is redirected to the ADFS authentication page.
- After successfully entering the Active Directory login and password, the user gains access to the SimpleOne system.
- Until the end of the session in ADFS, the user will not need to enter credentials again to access SimpleOne.
Configure SSO
In SimpleOne, SSO relies on ADFS 2.0+ as the IdP and the XML-based Security Assertion Markup Language (SAML) 2.0 to exchange data with it. Therefore, as an administrator, you should complete the following tasks before enabling SSO on your instance:
- Create a SAML connection.
- Enable the SSO property.
- Create ADFS Relying Party Trust:
- through import from XML.
- manually.
- Create a SAML Assertion Consumer and Logout Endpoints.
- Create ADFS relying party claim party rules.
- Test SAML connection.
Create SAML connection
To configure a SAML connection, complete the steps below:
- Navigate to Single Sign-On → SAML Settings.
- Click New and fill in the fields.
- Click Save or Save and exit to apply the changes.
If you have problems connecting SSO and contact technical support, it is recommended to use the debugging extension for viewing SAML messages (for example, SAML-trace for Google Chrome) to take informative screenshots.
- General
- SAML Server Metadata
- Additional Information
Field | Mandatory | Description |
---|---|---|
Name | N | Specify a SAML connection name. |
User field | Y | Specify a field in the User table containing information for user identification. Available options:
|
Query field | N | Specify the name of a custom attribute on the identity provider side to map the value of the User field. |
Active | N | Select this checkbox to make this connection active. |
Example of the correlation of the values User field = Login and Query field = SAM-Account-Name for the XML-responses collapse
<saml:Attribute FriendlyName="username"
Name="SAM-Account-Name"
NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri">
<saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:type="xs:string">ad.viewer</saml:AttributeValue>
</saml:Attribute>
Field | Mandatory | Description |
---|---|---|
Metadata URL | Y | Specify the external URL provided by a service provider for authentication. By this address, an XML file containing the federation metadata is located. In most cases, this file is named federationmetada.xml. Most catalog services, like Active Directory, provide a link to this file via their management tools. Provide a public link to the file in this field. In case of a SimpleOne SAML connection, the link should look as follows: |
Metadata | N | This field contains an external service answer (SAML federation metadata) and is populated automatically by the federationmetadata.xml file content. |
This tab contains record service information (who and when created or updated the record, and other).
When the record is created, the Open metadata UI action appears at the bottom of the form. Click it to open the https://instance.simpleone.ru/v1/saml/metadata
page that allows you to download a metadata file. Import this file when creating a Relying Party Trust.
Enable SSO
To enable SSO for your instance, do the following:
- Configure at least one SAML connection as described above.
- Change the simple.sso.active property value to true.
Until the steps above are completed, the authentication proceeds with the use of the local profile storage.
- The simple.sso.active property cannot be activated until you configure at least one SAML connection and turn it on.
- Once you turn off all your SAML connections, the simple.sso.active value automatically changes to false.
- Only one active SAML connection is possible at a time.
Use the simple.sso.active property to disable SSO and to make your instance to authenticate users by logins and passwords from the local profile storage. This may be required, for example, if user authentication data stops coming from the IdP, and users are unable to access the instance.
A user with the admin role can bypass SSO by logging in to the instance with the local login and password at https://instance.simpleone.ru/side-door
, and change the simple.sso.active value to false.
Create an ADFS relying party trust
Import settings from XML file
To use a preset configuration data, prepare a metadata file. To do so, complete the steps below:
- Navigate to
https://instance.simpleone.ru/v1/saml/metadata
. - To copy the metadata into a new file with the '.xml' extension (for example, ExampleComSSOMetadata.xml), right-click the page and select Save as.
- Save the file.
To configure ADFS relying party, you need to:
- Log in to your ADFS server and open the management console.
- Select Relying Party Trusts.
- Click Add Relying Party Trust on the top right, and then click Start.
- Select the Import data about the relying party from a file option and attach the file with the metadata info that you previously saved. For example, ExampleComSSOMetadata.xml.
- Specify a display name and type some notes if needed.
- Do not select any encryption certificate.
- Specify user permissions for this relying party. By default, all users are permitted. Click Next.
- Click Next again, and click Close. A new relying party trust appears.
Field | Description |
---|---|
Import data about the relying party from file | Select the option to import the metadata file you saved earlier. |
Federation metadata file location | Attach the metadata .xml file on your device. For example, ExampleComSSOMetadata.xml. |
Display name | Specify the name of the relying party. |
Notes | Type notes for the relying party you are creating. |
Policy | Select the access control type. By default, all users have access to the application. |
You can get a metadata link like https://instance.simpleone.ru/v1/saml/metadata
on every instance with the active SSO, regardless of any SAML connection existing.
Create relying party trust manually
To create relying party trust manually, complete the steps below:
- Log into your ADFS server and open the management console.
- Select Relying Party Trusts.
- Click Add Relying Party Trust at the top right corner and click Start with the Claims aware option selected.
- Select the Enter data about the relying party manually option.
- Specify a display name and type some notes if needed.
- From the Configure Certificate step, click Next. Do not select any encryption certificate.
- On the Configure URL step, select the Enable support for the SAML 2.0 WebSSO protocol.
- Type
https://instance.simpleone.ru
- Type
- Specify Relying party trust identifiers.
- Relying party identifiers =
https://instance.simpleone.ru
. Click Add.
- Relying party identifiers =
- Specify user permissions for this relying party. By default, the Permit everyone option is selected. Click Next.
- Click Next again, and click Close. A new relying party trust appears.
Field | Description |
---|---|
Enter data about the relying party manually | Select the option to input the data about the relying party organization manually. |
Display name | Specify the name of the relying party. |
Notes | Type notes for the relying party you are creating. |
Relying party trust identifier | Specify the instance URL and click Add. |
Policy | Select the access control type. By default, all users have access for the application. |
You also need to configure the created party trust. To do so, complete the following steps:
- Open the created trust in the ADFS management tool.
- In the Monitoring tab fill in the following fields:
- Monitoring relying party = true
- Relying party's federation metadata URL =
https://instance.simpleone.ru/v1/saml/metadata
- Automaticaly update relying party = false
- In the Endpoints tab you need to create endpoints. Instructions for creating endpoints are given below.
Create SAML endpoints
Generally, SAML endpoints are created automatically when the relying party trust is created via the setting import. You can create or edit them manually if needed. To create SAML Assertion Consumer Endpoint, complete the steps below:
- Log into your ADFS server and open the management console.
- Right-click the relying party trust created earlier.
- Select the Endpoints tab.
- Click Add SAML.
- Enter values as listed below:
- Endpoint type = SAML
- Binding = Redirect
- Trusted URL =
https://instance.simpleone.ru/auth-sso
- Click OK.
To create SAML Logout Endpoint, complete the following steps:
- Log into your ADFS server and open the management console.
- Right-click the relying party trust created earlier.
- Select the Endpoints tab.
- Click Add SAML.
- Enter values as listed below:
- Endpoint type = SAML Logout
- Binding = Redirect
- Trusted URL =
https://instance.simpleone.ru/logout
- Click OK.
List of endpoints specific to SSO
An instance configured to use SSO has the following endpoints available for HTTP requests related to signing users in and out:
Endpoint URL | HTTP method | Purpose |
---|---|---|
https://instance.simpleone.ru/v1/saml/metadata | GET | Metadata .xml file. |
https://instance.simpleone.ru/auth-sso | HTTP-Redirect (GET) | User authorization with SSO. |
https://instance.simpleone.ru/logout | HTTP-Redirect (GET) | User logout with SSO. |
https://instance.simpleone.ru/v1/saml/post | POST | The authentication request. |
Create ADFS relying party claim rules
Relying party claim rules allow the system to establish communication with ADFS infrastructure.
There are two main claim rules that should be configured:
- Send LDAP Attribute as Claims – select attributes from the Active Directory to send as claim to the relying party.
- Transform an Incoming Claim – select an incoming claim, change its claim type and its claim value.
Send LDAP Attribute as Claims
To configure the Send LDAP Attribute as Claims rule, complete the steps below:
-
Log into your ADFS server and open the management console.
-
Right-click the relying party trust created earlier.
-
Select the Edit Claim Issuance Policy item.
-
Click Add Rule.
-
Select the Send LDAP Attribute as Claims option in the Claim rule template field and click Next.
-
Name the claim. For example, Get LDAP Attributes.
-
Enter values as listed below:
- Attribute store = Active directory
- LDAP Attribute = SAM-Account-Name
- Outgoing Claim Type = SAM-Account-Name
noteYou can specify more attributes to be retrieved from AD.
-
Click Finish.
Transform an Incoming Claim
To configure the Transform an Incoming Claim rule, complete the steps below:
- Click Add Rule again.
- Select the Transform an Incoming Claim option in the Claim rule template field and click Next.
- Name the claim. For example, Email2Name.
- Set the Incoming claim type equal to the outgoing claim type in the previous rule. For example, E-mail Address.
- Set the values as listed below:
- Outgoing claim type = Name ID
- Outgoing name ID format = Email
- Select the Pass through all claim values option.
- Click Finish.
- Click Apply and then OK to close the window.
Test an Incoming Claim
To test the configuration, complete the steps below:
- Navigate to your SimpleOne instance. For example,
https://instance.simpleone.ru
. If all configurations are set correctly, the system redirects you tohttps://adfs.example.com/adfs/ls/IdpInitiatedSignon.aspx?logintoRP=https://instance.simpleone.ru/
. - Sign in to your instance. If the configuration is correct, you will be logged in automatically.
- Select Logout from the profile menu to test the logout endpoint functionality.