OAuth 2.0 / OpenID Connect
Example setup
Prerequisites
The prerequisites for using OpenID authentication with a Spectra appliance (Analyze or Manager) are the following:
- Configured AD FS (ActiveDirectory Federation Services) on Windows Server 2016 or newer in the customer’s organization. Although AD FS is a free feature on Windows Server, commissioning it requires a Windows Server license and a server to host the AD FS service.
- AD FS servers need to be patched, updated and backed up on a regular basis.
Configuration
The configuration procedure consists of two parts:
- Configuring AD FS on Windows Server 2016 in the customer’s organization
- Configuring OpenID Connect on the Spectra appliance
Part 1 - Configuring AD FS on Windows Server 2016
This guide describes only the specific configuration options required for setting up OpenID connect to work with a Spectra appliance.
Customers should consult the official Microsoft documentation for all details regarding the AD FS setup.
1.1 Create an Application Group
The first step is to create an application group on AD FS 2016 in the customer’s organization.
- Access the AD FS Management configuration page. Right-click the Application Groups option and select Add Application Group. This should start the Add Application Group Wizard.
- In the Welcome step of the wizard, enter “ADFSSSO” into the Name field. In the Template section, select the Standalone applications > Server application or website option, and click Next.
- In the Server application step of the wizard, enter “ADFSSSO - Server application” into the Name field. In the Redirect URI field, enter the URL to the Spectra appliance that will use the OpenID authentication (
http://<a1000-hostname>/oidc/callback
).
While in this step of the wizard, make sure to copy the value from the Client Identifier field and save it into a text file. This value will have to be provided later in the configuration process.
After copying the value, click Next to proceed with configuration.
- In the Configure Application Credentials step of the wizard, select the Generate a shared secret checkbox. When the value is generated in the Secret field, copy it and save it to a text file. This value will be required later in the configuration process.
- After copying the value, click Next to proceed to the Summary step of the wizard. This step only displays an overview of values configured in previous steps, and allows going back to change the values if necessary by clicking the Previous button.
- If all the values listed in the Summary step are accurate for the customer’s setup, click Next to complete the configuration and exit the wizard.
The Application Groups page should now display the newly created “ADFSSSO” group.
1.2 Configure the Web API for the Application Group
- On the Application Groups page, right-click the name of the newly created “ADFSSSO” group and select Properties. This will open the properties configuration dialog.
The Applications section of the properties dialog should list the “ADFSSSO - Server application” configured previously.
- In the properties dialog, click the Add application button. This will open the Add a new application to ADFSSSO configuration dialog.
- In the Welcome step of the dialog, select Web API in the Template section. Click Next to proceed with configuration.
- In the Configure Web API step of the dialog, enter “ADFSSSO - Web API” into the Name field.
- Find the Client Identifier value previously saved and copied from the Add Application Group Wizard. Make sure to add the exact Client Identifier value into the Identifier field, and click Add. The added value will be displayed in the list below Identifier.
Click Next to proceed with configuration.
- The Apply Access Control Policy step of the dialog allows setting permissions for accessing the application. Customers should select the policy that corresponds with their internal organization rules. Only one policy can be selected here.
After selecting an appropriate policy in the Choose an access control policy list, click Next to proceed with configuration.
- In the Configure Application Permissions step of the dialog, the “ADFSSSO - Server application” should be displayed in the Client application (caller) list.
In the Permitted scopes section, the following checkboxes must be selected:
- allatclaims (Requests the access token claims in the identity token.)
- email (Request the email claim for the signed in user.)
- openid (Request use of the OpenID Connect authorization protocol.)
- After selecting the required scopes, click Next to proceed to the Summary step of the dialog. This step only displays an overview of values configured in previous steps, and allows going back to change the values if necessary by clicking the Previous button.
- If all the values listed in the Summary step are accurate for the customer’s setup, click Next to complete the configuration and exit the dialog.
1.3 Customize ID Token Claims
To allow user accounts to authenticate on the Spectra appliance using the OpenID Connect protocol, the OpenID Connect provider must be able to return the following claim values:
- unique username
- case-insensitive: for example, "john" and "John" cannot coexist
- email address
- the same value can be used for username and email
- the email address doesn't have to be unique (but then it can't be used as the unique username)
- first name (optionally)
- last name (optionally)
Note: the claim names are configurable and can differ from the values.
User access control for authenticating to the appliance (e.g., which users can authenticate, which ones cannot, and which users are administrators) is controlled by group membership. To control user access, the OpenID Connect provider must be able to return the groups claim, which contains the list of user groups.
Because the AD FS UserInfo Endpoint is only able to return the subject claim and not any other requested claims, it is necessary to configure AD FS and customize the ID Token so that it is able to provide additional claims. Access tokens will contain the claims users specify in Issuance Transform Rules (see 1.4 Configure Transform Rules for Claims).
Prerequisites: the patch KB4019472 for Windows Server 2016 should be installed
Refer to the official Microsoft documentation for the full description of how to customize ID tokens.
Example of a customized ID Token
{
"nonce":"ABkXHQas12vBBlfABvncNIclABRvFZDx",
"upn":"user1@devdomain.local",
"appid":"4b090259-3e43-45c8-b4b2-4f944ba501be",
"unique_name":"example.com\\john.doe",
"email":"john.doe@example.com",
"given_name":"John",
"family_name":"Doe",
"group":[
"rl-appliance-user",
"rl-appliance-admin"
],
"aud":"4b090259-3e43-45c8-b4b2-4f944ba501be",
"apptype":"Confidential",
"iss":"https://auth.example.com/adfs",
"sid":"S-1-5-21-bf88fae7-83e9-4202-bdd8-c00875e59a78",
"authmethod":"urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport",
"scp":"allatclaims openid",
"exp":1550231610,
"auth_time":1550221010,
"iat":1550228010,
"ver":"1.0",
"sub":"8rsysTk+d1Y/o4AsZE03Zub63tttX6OiW1iYqa+W6/0="
}
1.4 Configure Transform Rules for Claims
In AD FS Management on the Application Groups page, right-click the name of the “ADFSSSO” group and select Properties. This will open the properties configuration dialog.
1.4.1 Add a Rule for LDAP Claims
- In the Applications section, open the properties dialog for the “ADFSSSO - Web API” application configured previously.
- In the “ADFSSSO - Web API Properties” dialog, access the Issuance Transform Rules tab. Click the Add Rule button to create a new transform rule for sending custom claims.
This will open the Add Transform Claim Rule Wizard that allows selecting rule templates.
- In the Choose Rule Type step of the wizard, select Send LDAP Attributes as Claims in the Claim rule template pull-down menu.
Click Next to proceed with configuration.
- In the Configure Claim Rule step of the wizard, enter LDAP claims into the Claim rule name field.
In the Attribute store pull-down menu, Active Directory should be selected.
The following LDAP attributes have to be mapped to corresponding outgoing claim types.
LDAP Attribute | Outgoing Claim Type |
---|---|
E-Mail-Addresses | E-Mail Address |
Display-Name | Given Name |
Surname | Surname |
Note: if the upn (User-Principal-Name) value corresponds to the email address of each user, the User-Principal-Name LDAP attribute has to be mapped to the E-Mail Address claim.
- When all the attributes are mapped to the claims correctly, click the Finish button to complete configuration and exit the wizard.
1.4.2 Add Custom Rules
- In the Applications section, open the properties dialog for the “ADFSSSO - Web API” application configured previously.
- In the “ADFSSSO - Web API Properties” dialog, access the Issuance Transform Rules tab. Click the Add Rule button to create a new transform rule for sending custom claims.
This will open the Add Transform Claim Rule Wizard that allows selecting rule templates.
- In the Choose Rule Type step of the wizard, select Send Claims Using a Custom Rule in the Claim rule template pull-down menu.
Click Next to proceed with configuration.
- In the Configure Claim Rule step of the wizard, enter any name into the Claim rule name field.
In the Custom rule field, enter the following rule:
c:[Type ==
"http://schemas.microsoft.com/ws/2008/06/identity/claims/windowsaccountname",
Issuer == "AD AUTHORITY"]
=> add(store = "Active Directory", types =
("http://schemas.xmlsoap.org/claims/Group"), query = ";tokenGroups;{0}", param
= c.Value);
- Click Finish to complete configuration and exit the wizard.
To add another rule, start the wizard again from ADFSSSO - Web API Properties > Issuance Transform Rules > Add Rule as described previously.
In the Choose Rule Type step of the wizard, select Send Claims Using a Custom Rule in the Claim rule template pull-down menu and click Next.
In the Configure Claim Rule step of the wizard, enter any name into the Claim rule name field.
In the Custom rule field, enter the following rule:
c:[Type == "http://schemas.xmlsoap.org/claims/Group", Value =~ "(?i)rl-"]
=> issue(claim = c);
Click Finish to complete configuration and exit the wizard.
1.4.3 Confirm Changes to Transform Rules
After adding the LDAP claims rule and two custom rules, make sure that they are all listed in the ADFSSSO - Web API Properties > Issuance Transform Rules tab.
Click OK to confirm and save the newly added rules. This will close the ADFSSSO - Web API Properties dialog.
1.5 Access the OpenID Configuration Endpoint
If AD FS has been configured successfully, the openid-configuration endpoint should be accessible in the customer’s network via the web browser. It is represented as a metadata document in JSON that contains information required for authenticating applications.
This information is required for the Part 2 of the configuration procedure, which is setting up OpenID Connect on the Spectra appliance.
https://<auth-server>/adfs/.well-known/openid-configuration
Example response
{
"issuer":"https://auth.example.com/adfs",
"authorization_endpoint":"https://auth.example.com/adfs/oauth2/authorize/",
"token_endpoint":"https://auth.example.com/adfs/oauth2/token/",
"jwks_uri":"https://auth.example.com/adfs/discovery/keys",
"id_token_signing_alg_values_supported":["RS256"],
"token_endpoint_auth_signing_alg_values_supported":["RS256"],
"access_token_issuer":"http://auth.example.com/adfs/services/trust",
"userinfo_endpoint":"https://auth.example.com/adfs/userinfo",
...
}
For full details about the endpoint and how to use it, refer to the official Microsoft documentation (chapter “Fetch the OpenID Connect Metadata Document”).
Part 2 - Configuring OpenID Connect on Spectra Analyze or Spectra Detect Manager
To configure OpenID Connect on the Spectra appliance, access the Administration > Configuration > Authentication dialog.
In the dialog, select the OAuth 2.0/OpenID Connect option. This will expand the dialog and display additional configuration options divided into sections - OpenID Connect client, OpenID Connect provider, Signature verification, Claim mapping, User access, Miscellaneous.
2.1 OpenID Connect client
In this section of the dialog, the values configured in 1.1 Create an Application Group should be provided.
Find the Client Identifier value previously copied and saved, and enter it into the Client ID field.
Select the type of client (public or confidential). If confidential is selected, find the Secret value previously copied and saved, and enter it into the Client secret field.
Configure the remaining options:
- Check Verify SSL certificate if the OIDC client needs to verify the SSL certificate of the authorization server
- Fill the Config URL field if you have previously configured an OpenID Connect discovery document (using the .well-known/openid-configuration endpoint)
- Select the source from which claims about the user will be taken:
- ID Token
- UserInfo endpoint
- Access Token
If Access Token is selected, additional options are available:
- Audience: Identifies the intended recipient of the token. This corresponds to the
aud
value in the token. - Relying Party ID/Resource: In the AD FS management console, under Trust Relationships, select Relying Party Trusts. Copy the value for Spectra listed in the Identifier column and paste it here.
- Issuer: Corresponds to the
iss
value in the token.
Finally, check Enable PKCE in case your authentication provider requires PKCE as additional verification.
2.2 OpenID Connect provider
This section of the dialog requires the endpoint URLs that can be retrieved from the openid-configuration metadata document described in 1.5 Access the OpenID Configuration Endpoint part of this guide.
Example values
Authorization Endpoint: https://auth.example.com/adfs/oauth2/authorize/
Token Endpoint: https://auth.example.com/adfs/oauth2/token/
UserInfo Endpoint: https://auth.example.com/userinfo
Values listed in the Scopes field refer to the OpenID Connect scopes that will be requested during login. The scopes were previously configured in the 1.2 Configure the Web API for the Application Group part of this guide. The allatclaims scope should be included to allow access to the claims of the customized ID Token.
Enter the following values into the Scopes field: openid allatclaims
2.3 Signature verification
In the Signature algorithm pull-down menu, select the algorithm used to sign the ID token. Supported options are RS256 and HS256.
To check which algorithm is supported on AD FS, refer to the openid-configuration metadata document described in 1.5 Access the OpenID Configuration Endpoint part of this guide. The algorithm is represented as the value assigned to the id_token_signing_alg_values_supported parameter in the metadata document.
If RS256 is selected as the algorithm, the Signature public key or the JWKS Endpoint must also be configured.
If the JWKS Endpoint has to be used, its URL can be found in the openid-configuration metadata document as the value assigned to the jwks_uri parameter. This URL should then be entered into the JWKS Endpoint field in the dialog.
2.4 Claim mapping
This section allows mapping OpenID Connect claims to internal user attributes on the appliance.
ID Token or Access Token must be selected in the OpenID Connect client section to retrieve additional claims from customized tokens (as described in Part 1).
Since claim names are configurable and can be modified by AD FS administrators, it is advisable to check and copy the correct claim names from the AD FS Management tool on Windows Server (check the AD FS > Service > Claim Descriptions section).
The short name of each claim should be entered into the corresponding field. In the Username field, it is possible to enter unique_name to use the unique name claim; email to use the email address claim; or any other short name to use a particular claim.
2.5 User access
All fields in this section are optional. Each field accepts only one value (the name of just one group). If a field is left blank, it will be ignored (treated as if it is not configured).
The prerequisite for setting up any of the fields in this section is that the groups claim must be configured on AD FS to allow user access control. This is described in the 1.3 Customize ID Token Claims part of this guide.
The Active flag group field accepts the name of the group containing active users. If a user is not in this group, they will be marked as inactive.
The Superuser flag group field accepts the name of the group containing superusers (administrators). Users will be marked as superusers only if they are in this group.
The Require group field accepts the name of the group containing users who have access to the appliance. Authentication will fail for every user that is not in this group.
The Deny group field accepts the name of the group containing users who are not allowed to access the appliance. Authentication will fail for every user that is in this group.
2.6 Miscellaneous
This section can be used to require the authorization server to always re-authenticate the user, even if the user is already authenticated.
To enable this option, select the “Always prompt for login” checkbox.
Important notes:
- If this option is enabled, the “prompt=login” parameter will be added to the authentication query as described in the official documentation.
- This parameter is not intended and should not be used as a security feature, because it can be removed by users to avoid re-authentication.
- If this parameter is used, the “Keep me signed in” checkbox will not be visible in the AD FS login form.
Configuration reference
Administration > Configuration > Authentication > User Directory: OAuth 2.0/OpenID Connect
OpenID Connect client | |
---|---|
Client ID | Client Identifier value for the application that was previously registered with Active Directory Federation Services (AD FS). This should be provided to the appliance administrator by the OpenID Connect provider. |
Client Type | Specifies if the appliance will be configured as a public or a confidential application. Possible values are Public (do not use Client Secret) and Confidential (use Client Secret). If set to Confidential, the Client secret must be provided in the next field. |
Client secret | Visible only if Client Type is set to Confidential (use Client Secret). The value used by the application to authenticate to the authorization server. Generated when configuring application credentials on AD FS. This should be provided to the appliance administrator by the OpenID Connect provider. |
Verify SSL certificate | If this checkbox is selected, the OpenID Connect client will verify the SSL certificate of the provider responses. |
Config URL | Can be optionally used to populate configuration fields by providing the URI discovery mechanism URL of the Identity Provider and clicking the Get button. |
Claim Source | Specifies which source will be used to authenticate and authorize users. Supported values are Use ID Token (OpenID), Use UserInfo endpoint (OpenID) and Use Access Token. |
Audience | Visible only if Claim Source is set to Use Access Token. Specifies the expected value of the Audience (aud) field in the token to confirm its validity. |
Relying Party ID/Resource | Visible only if Claim Source is set to Use Access Token. The ID of the application requesting user authentication from the Identity Provider. In this case, it should be set to the identifier assigned to the appliance in the Identity Provider’s configuration. |
Issuer | Visible only if Claim Source is set to Use Access Token. Specifies the expected value of the Issuer (iss) field in the token to confirm its validity. |
Enable PKCE | Additional verification method used by some identity providers. The code challenge method used by the Spectra appliance is always S256 . |
OpenID Connect provider | |
Authorization Endpoint | URL of the OpenID Connect provider authorization endpoint. This endpoint handles authentication and authorization of users. |
Token Endpoint | URL of the OpenID Connect provider token endpoint. This endpoint can be used by a client application to request and obtain ID, refresh, and access tokens. |
UserInfo endpoint | Visible only if Claim Source is set to Use UserInfo endpoint (OpenID). URL of the OpenID Connect provider UserInfo endpoint. The UserInfo endpoint is a protected resource from which client applications can retrieve information about claims for the logged-in user. |
Scopes | Provide one or more scopes that should be requested during login. |
Signature verification | |
Signature algorithm | Select which algorithm should be used to sign ID tokens. Supported options are RS265 and HS256. If RS256 is selected as the algorithm, the Signature public key or the JWKS Endpoint must also be configured. |
Signature public key | The key used to sign ID tokens when using the RS256 signature algorithm. |
JWKS Endpoint | URL of the JWKS (JSON Web Key Set) endpoint configured by the OpenID Connect provider. |
Claim mapping | |
Username | Short name of the claim containing the unique username for identifying the user. Usernames are case-insensitive. For example, "john" and "John" cannot coexist. |
Short name of the claim containing the email address of the user. The address itself doesn't have to be unique - multiple users can have the same email. | |
First name | Short name of the claim containing the first name of the user. |
Last name | Short name of the claim containing the last name of the user. |
Groups | Name of the claim that contains a list of user groups. |
Groups Delimiter | (Optional) Character to split the Groups string on. |
User access | |
Active flag group | Accepts names of one or more groups containing active users. If a user is not in one of these groups, they will be marked as inactive. |
Superuser flag group | Accepts names of one or more groups containing superusers (administrators). Users will be marked as superusers only if they are in one of these groups. |
Require group | Accepts names of one or more groups containing users who have access to the appliance. Authentication will fail for every user that is not in one of these groups. |
Deny group | Accepts names of one or more groups containing users who are not allowed to access the appliance. Authentication will fail for every user that is in one of these groups. |
Access Groups Delimiter | Character to split the User Access Groups on. Characters entered in this field must not be used in any access group name. Max length of delimiter is 2 characters. |
Miscellaneous | |
Always prompt for login | Select the checkbox to require the authorization server to always re-authenticate the user, even if the user is already authenticated. If this option is enabled, the prompt=login parameter will be added to the authentication query. The “Keep me signed in” checkbox will not be visible in the AD FS login form. This option should not be used as a security measure, because the parameter can be removed by users to bypass re-authentication. |