Skip to main content

Unified Login

Paid Feature

This is a paid feature.

You can click on the Enable Paid Features button on our dashboard, and follow the steps from there on. Once enabled, this feature is free on the provided development environment.

If your use case involves having to authenticate different types of applications using a common Authorization Server you can achieve this by using SuperTokens.

The implementation will involve configuring an OAuth2 Provider that will authenticate and authorize your existing clients.

When to use Unified Login

There are a couple of common scenarios in which the Unified Login approach can be used. They are outlined below and we provide separate guides for each of them.

For these specific instances we expose recipes that allow you to complete your setup.

caution

There are a few limitations with the OAuth2 recipes:

  • It is only available for the SuperTokens Managed Service. This feature is not included in the Self-Hosted version.
  • Only the supertokens-node backend SDK supports it as of yet. So if you are using our golang or python SDK, you will have to wait for the next releases or configure a separate NodeJS Authorization Service.
  • We do not support magic link based login. However, you can switch to email/SMS OTP instead. This method offers the same level of security.
  • Step Up Authentication is not available out of the box. You will have to use customizations in order to support the flow.

OAuth2 Basics

Before we explore the guides let's first recap some common terms and concepts that are the base of the framework. We will use them throughout the next pages.

OAuth2, Open Authorization, is an industry-standard authorization framework that enables third-party applications to obtain limited access to a user's resources without exposing their credentials.

Roles

In OAuth, roles define the different responsibilities of entities involved in the process of granting and obtaining access to protected resources. There are four roles defined in the specification:

Resource Owner

The Resource Owner is an entity capable of granting access to a protected resource. In most cases, this is an actual person that uses an application.

Client

An OAuth 2.0 Client is an application that wants to access protected resources. In order to do so it needs to get an OAuth2 Access Token from the Authorization Server. With that token the client can perform authorized operations on behalf of the Resource Owner.

The term client does not imply any particular implementation characteristics (e.g. whether the application executes on a server, a desktop, or other devices).

Resource Server

The server hosting the protected resources, capable of accepting and responding to protected resource requests using OAuth2 Access Tokens. Some real-world examples in this case would be things like:

  • A file storage service that allows users to access only their files
  • A social media application that allows users to access only posts from their friends
  • A chat app that shows only messages from conversations in which the user is a participant

Authorization Server

The server issuing OAuth2 Access Tokens to the Client after successfully authenticating the Resource Owner.

Tokens

Tokens are strings that represent the authorization issued to the Client. They are mainly used to access to protected resources, on behalf of the Resource Owner. At the same time, tokens can be used to get more information about who the owner is.

OAuth2 Access Token

This is the main token that is used to provide temporary access to protected resources. The OAuth2 Access Token is meant to be read and validated only by the Resource Server.

info

This token is different from the SuperTokens Session Access Token. The latter is used in the OAuth 2.0 authentication flows to maintain a session between the authorization frontend and the authorization backend server.

OAuth2 Refresh Token

A token that can be used to get a new OAuth2 Access Token when the current one has expired. Using the refresh token will not require the user to re-authenticate.

info

This token is different from the SuperTokens Session Refresh Token. The latter is used in the OAuth 2.0 authentication flows to maintain a session between the authorization frontend and the authorization backend server.

ID Token

This token provides identity information about the Resource Owner. Unlike OAuth2 Access Tokens, the ID Tokens are meant to be read only by the Client.

Scopes

Scopes define the range of access that the Client is requesting on behalf of the Resource Owner. They specify what portions of the Resource Owner’s data the Client can access and what actions it can perform.

For example, when a user grants a web application permission to read their email, the application might request the email scope.

In a general authentication flow scopes get used in the following way:

  1. When the Client gets created a series of scopes will be specified to the Authorization Server
  2. The Autorization Server authenticates the Resource Owner and uses the scopes to generate an OAuth2 Access Token.
  3. The Resource Server will check the scopes of the OAuth2 Access Token and will only allow the requested actions.

Authorization Flows

The OAuth 2.0 protocol defines several flows to accommodate different use cases. They are a set of steps an OAuth Client has to perform in order to obtain an access token.

Our implementation supports the following flow types:

Authorization Code Grant

Authorization Code Grant

This flow is best suited for scenarios that involve web applications. It consists of the following steps:

  1. The Client redirects the Resource Owner to the Authorization Server’s authorization endpoint.
  2. If the Resource Owner grants permission, the Authorization Server redirects their browser back to the specified Redirect URI and includes an Authorization Code as a query parameter.
  3. The Client then sends a request to the Authorization Server’s token endpoint, including the Authorization Code.
  4. The Authorization Server verifies the information sent by the Client and, if valid, issues an OAuth2 Access Token.
  5. The token can now be used to make requests to the Resource Server to access the protected resources on behalf of the Resource Owner.
Authorization Code

An Authorization Code is a short-lived code that the Authorization Server provides to the Client, via a Redirect URI, after authorization has been granted. This code then gets exchanged for an OAuth2 Access Token. The Authorization Code flow enhances security by keeping tokens out of the user-agent and letting the Client manage the backend communication with the Authorization Server.

Proof Key for Code Exchange (PKCE)

In order to prevent CSRF and code injection attacks, the Authorization Code flow can be enhanced with PKCE.

At the beginning of the authentication flow the Client will generate a random string called a code verifier. This gets used to ensure that, even if the Authorization Code is intercepted, it cannot be exchanged for a token without also including the initial code.

Client Credentials

Client Credentials Grant

This flow is best suited for machine-to-machine (M2M) interactions where there is no end-user. It consists of the following steps:

  1. The Client authenticates with the Authorization Server using its own credentials.
  2. The Authorization Server verifies the credentials.
  3. The Authorization Server returns an OAuth2 Access Token.
  4. The Client uses the OAuth2 Access Token to access protected resources.
  5. The Resource Server validates the OAuth2 Access Token.
  6. If the validation is successful, the Resource Server returns the requested resources.