- ASAPP is the Service Provider (SP) with the customer acting as the Identity Provider (IDP).
- The customer’s authentication system performs user authentication using their existing customer credentials.
- ASAPP supports Service Provider Initiated SSO. Customers will provide the SSO URL to the agents and admins.
- The URL points to the customer’s SSO service, which will authenticate the users via their authentication system.
- Once the user is authenticated, the customer’s SSO service will send a SAML assertion, which includes some user information to ASAPP’s SSO service.
- ASAPP uses the information inside the SAML assertion to identify the user and redirect them to the appropriate application.

Configuring Single Sign-On via SAML
Environments
ASAPP supports SSO in non-production and production environments. It is strongly recommended that customers configure SSO in both environments as well.Exchange of SAML metadata
Both ASAPP and the customer generate their respective SAML metadata and send the metadata files to one another. The metadata will be different for each environment, therefore they need to be generated once per environment. Sample metadata file content:SAML Profile Configuration
Next, ASAPP and the customer configures their respective SSO service with each other’s SAML profile. This can be achieved by importing the SAML metadata into the SSO service (if it supports a metadata import feature).SAML Attributes Configuration
SAML Attributes are key-value fields within the SAML message (also called SAML assertion) that is being sent from the Identity Provider (IDP) to the Service Provider (SP). ASAPP requires the following fields to be included with the SAML assertion| Attribute Name | Required | Description | Example | 
|---|---|---|---|
| userId | yes | user’s unique identifier used for authentication. Can be a unique readable value such as user’s email or an opaque identifier such as a customer’s internal user ID. | jdoe@company.com | 
| firstName | yes | user’s first name | John | 
| lastName | yes | user’s last name | Doe | 
| nameAlias | yes | user’s display name. Allows an agent, based on their personal preference or company’s privacy policy, to set an alias to show to the customers they are chatting with. If this is not sent then the agent firstName will be displayed. | John Doe | 
| roles | yes | the roles the user has within the ASAPP platform. Typically mapped to one or more AD Security Groups on the IDP. | representative|manager | 
| Attribute Name | Required | Description | Example | 
|---|---|---|---|
| groups | no | group(s) the user belongs to. This attribute controls the queue(s) that a user is assigned to. Not to be confused with the AD Security Groups (see the roles attribute above) | residential|business | 
| concurrency | no | number of concurrent chats the user can handle | 5 | 
Sending User Data via SAML
ASAPP uses the SAML attribute fields to keep the user data up-to-date in our system. It also allows us to register a new user automatically when a new user logs into the ASAPP application for the first time. In addition to the required fields that ASAPP needs to identify the user, customers can send additional fields in the SAML assertion that can be used for other purposes such as Reporting. An example can be the Agent Location. These fields are specific per customers. The name and possible values of these fields need to be agreed upon and configured prior to the SAML implementation.SSO Testing
SSO testing between the customer and ASAPP must be a coordinated effort due to the nature of the IDP-initiated SSO flow. The customer must provide several user accounts to be used for testing. Generally, the test scenarios are as follows:- An agent logs in for the first time. ASAPP observes that a new user record is created and the agent lands on the correct ASAPP application for their role (Desk for a rep, Admin for supervisor/manager).
- The same agent logs out and logs back in. The agent observes that the correct application still opens.
- Repeat the same test for another user account, ideally with different roles.