data:image/s3,"s3://crabby-images/c7fbe/c7fbea652a6783e412006cb214eb1fda22d85e0d" alt="An example of the process of implementing Single Sign-On for a web client, explaining the SSO requirements and the function of clients in the process."
Using OpenID Connect for a Single Sign-On Solution in Web Clients
On this page
Overview
This article shows a basic example with two different sites that use SSO during authentication. It provides an understanding of the general process of implementing a web client.
Learn the basics of SSO
For a general overview of SSO, see the architectural overview of SSO article.
Overview of the SSO Process
The basic SSO process, stripped of most details, is fairly simple:
SITE A
- The user wants to login on Site A
- Site A sends an OpenID Connect authorization request
- The identity server (in this article we used the Curity Identity Server) authenticates the user
- The identity server establishes an SSO session
- The identity server responds with an ID token
- Site A validates and uses the ID token to setup a local session
SITE B
- The user accesses Site B
- Site B sends an OpenID Connect authorization request
- The identity server finds the existing SSO session and uses it
- The identity server sends a new ID token
- Site B validates and uses the token to setup a local session
Simplified Flow
There are a number of different variants of the OpenID Connect protocol that can be used for this flow. The diagram shows a simplified flow.
Web Sessions vs. SSO Sessions
Web sessions and SSO sessions are different things. The web session is entirely on the client side and has to do with requests, responses and cookies that have nothing to do with the authentication or SSO. The SSO session is the authentication session, and is managed by the identity server.
If you want to learn more about the different sessions see Sessions and SSO.
The Role of the Identity Server
In this scenario, the identity server acts as the single point of trust for authentication, often called an Identity Provider(IdP). It handles the login and creates sessions.
The identity server uses different authentication methods to verify the user's identity. Once it verifies the identity, the server sets up a session for the authenticated user.
If a returning user (browser) can be matched against an existing session, that session will be used, if that session is fresh enough, and matches the requirements provided in the request.
ACR - Authentication Context Class Reference
In the identity server, each authenticator has an identifier - an Authentication Context Class Reference, or ACR.
The ACR can have a form of URN; for example, it could look something like this:
urn:se:curity:authentication:html-form:html1
If the client requests one or many ACRs for authentication, the server will enforce that the user is authenticated using one of those, that is, the server will only reuse sessions that were established with at least one of the requested ACRs. If there is no such session, the server will try to authenticate the user with the requested authentication method.
SSO Requirements
In order for SSO to be established, there are a few requirements:
- Sites must be able to use the same authentication methods (identified by the same ACRs)
- SSO session must exist
- SSO session is fresh
- No client prompts
Shared ACRs
SSO only occurs if two applications have the same ACR in their requests and configuration. For example, if the user logs in with a username and password on the first site, and the second site requires a social login, SSO will not occur.
SSO Session Must Exist
There must exist an authenticated session (SSO session) for SSO to work. This might sound like pointing out the obvious, but there is a bit more to it, since the SSO session must also match the parameters provided in the client request.
SSO Session Should be Fresh Enough
The duration of the session is normally configured in the identity server, but the client can also specify in the request a desired freshness using the max_age
parameter. The identity server will reuse the SSO session if it is not older than the requested parameter; otherwise, the user will have to authenticate.
Avoiding SSO
The client may prompt for authentication by sending the prompt=login
request parameter, in which case SSO will not be allowed - the client explicitly asked for the user to login again.
The Role of the Client
The clients (in our example, each site) send the requests for authorization and provide the identity server with the parameters and required information. Afterwards, they make use of the returned ID token.
The Request Parameters for SSO
A few of the request parameters specifically affect SSO: acr_values
, max_age
and prompt
.
These parameters are optional in OpenID Connect. They allow the client to specify and modify the configured authentication behavior. You can think of them as instructions for the identity server.
Parameter | Description | Comment | Example |
---|---|---|---|
acr_values | Governs the allowed authentication method for SSO. | Requests that the identity server uses a certain authentication method. Multiple strings are separated with space. | acr_values=urn:se:curity:authentication:html-form:html1 |
max_age | Specifies a maximum allowed age for the SSO session (in seconds). | If the session is older, the user is prompted to log in again. | max_age=300 |
prompt | Informs the identity server it should require the user to log in. | Allows the client to force authentication. | prompt=login |
The Identity Server's Response
The OpenID Connect response from the server includes an id_token
that the site uses when it sets up its authenticated session.
auth_time
The auth_time claim is useful to verify a recent authentication since it shows the time of the last user login.
Validating the ID Token
Clients must validate the ID token before they use it. Read more about ID token validation here: Validating an ID Token.
Using the ID Token
Once the ID token has been validated, you can use the provided claims on your site.
OAuth vs OpenID Connect and SSO
The request parameters listed above are OpenID Connect parameters, to be used with OpenID Connect flows. The Curity Identity Server allows clients to request the same parameters even for OAuth flows. However, the ID Token is only issued for OpenID Connect flows, so it is not possible for the client to verify that the authentication happened as expected when not using OpenID Connect.
data:image/s3,"s3://crabby-images/c88ce/c88ce762b43b9496d858dcc65259866c5c8e120a" alt="Photo of Jacob Ideskog"
Jacob Ideskog
Identity Specialist and CTO at Curity
Join our Newsletter
Get the latest on identity management, API Security and authentication straight to your inbox.
Start Free Trial
Try the Curity Identity Server for Free. Get up and running in 10 minutes.
Start Free Trial