Auth

Single Sign-On with SAML 2.0 for Projects


Supabase Auth supports enterprise-level Single Sign-On (SSO) for any identity providers compatible with the SAML 2.0 protocol. This is a non-exclusive list of supported identity providers:

  • Google Workspaces (formerly known as GSuite)
  • Okta, Auth0
  • Microsoft Active Directory, Azure Active Directory, Microsoft Entra
  • PingIdentity
  • OneLogin

If you're having issues with identity provider software not on this list, please open a support ticket.

Prerequisites

This guide requires the use of the Supabase CLI. Please make sure you're using version v1.46.4 or higher. You can use supabase -v to see the currently installed version.

You can use the supabase sso subcommands to manage your project's configuration.

SAML 2.0 support is disabled by default on Supabase projects. You can configure this on the Auth Providers page on your project.

Please note that SAML 2.0 support is offered on plans Pro and above. Check the Pricing page for more information.

Terminology

The number of SAML and SSO acronyms can often be overwhelming. Here's a glossary which you can refer back to at any time:

  • Identity Provider, IdP, or IDP An identity provider is a service that manages user accounts at a company or organization. It can verify the identity of a user and exchange that information with your Supabase project and other applications. It acts as a single source of truth for user identities and access rights. Commonly used identity providers are: Microsoft Active Directory (Azure AD, Microsoft Entra), Okta, Google Workspaces (GSuite), PingIdentity, OneLogin, and many others. There are also self-hosted and on-prem versions of identity providers, and sometimes they are accessible only by having access to a company VPN or being in a specific building.
  • Service Provider, SP This is the software that is asking for user information from an identity provider. In Supabase, this is your project's Auth server.
  • Assertion An assertion is a statement issued by an identity provider that contains information about a user.
  • EntityID A globally unique ID (usually a URL) that identifies an Identity Provider or Service Provider across the world.
  • NameID A unique ID (usually an email address) that identifies a user at an Identity Provider.
  • Metadata An XML document that describes the features and configuration of an Identity Provider or Service Provider. It can be as a standalone document or as a URL. Usually (but not always) the EntityID is the URL at which you can access the Metadata.
  • Certificate Supabase Auth (the Service Provider) trusts assertions from an Identity Provider based on the signature attached to the assertion. The signature is verified according to the certificate present in the Metadata.
  • Assertion Consumer Service (ACS) URL This is one of the most important SAML URLs. It is the URL where Supabase Auth will accept assertions from an identity provider. Basically, once the identity provider verifies the user's identity it will redirect to this URL and the redirect request will contain the assertion.
  • Binding (Redirect, POST, or Artifact) This is a description of the way an identity provider communicates with Supabase Auth. When using the Redirect binding, the communication occurs using HTTP 301 redirects. When it's POST, it's using POST requests sent with <form> elements on a page. When using Artifact, it's using a more secure exchange over a Redirect or POST.
  • RelayState State used by Supabase Auth to hold information about a request to verify the identity of a user.

Important SAML 2.0 information

Below is information about your project's SAML 2.0 configuration which you can share with the company or organization that you're trying to on-board.

NameValue
EntityIDhttps://<project>.supabase.co/auth/v1/sso/saml/metadata
Metadata URLhttps://<project>.supabase.co/auth/v1/sso/saml/metadata
Metadata URL
(download)
https://<project>.supabase.co/auth/v1/sso/saml/metadata?download=true
ACS URLhttps://<project>.supabase.co/auth/v1/sso/saml/acs
SLO URLhttps://<project>.supabase.co/auth/v1/sso/slo
NameIDRequired emailAddress or persistent

Note that SLO (Single Logout) is not supported at this time with Supabase Auth as it is a rarely supported feature by identity providers. However, the URL is registered and advertised for when this does become available.

Append ?download=true to the Metadata URL to download the Metadata XML file. This is useful in cases where the identity provider requires a file.

Alternatively, you can use the supabase sso info --project-ref <your-project> command to get setup information for your project.

User accounts and identities

User accounts and identities created via SSO differ from regular (email, phone, password, social login...) accounts in these ways:

  • No automatic linking. Each user account verified using a SSO identity provider will not be automatically linked to existing user accounts in the system. That is, if a user valid.email@supabase.io had signed up with a password, and then uses their company SSO login with your project, there will be two valid.email@supabase.io user accounts in the system.
  • Emails are not necessarily unique. Given the behavior with no automatic linking, email addresses are no longer a unique identifier for a user account. Please always use the user's UUID to correctly reference user accounts.
  • Sessions may have a maximum duration. Depending on the configuration of the identity provider, a login session established with SSO may forcibly log out a user after a certain period of time.

Row Level Security

You can use information about the SSO identity provider in Row Level Security policies.

Here are some commonly used statements to extract SSO related information from the user's JWT:

  • auth.jwt()#>>'{amr,0,method}' Returns the name of the last method used to verify the identity of this user. With SAML SSO this is sso/saml.
  • auth.jwt()#>>'{amr,0,provider}' Returns the UUID of the SSO identity provider used by the user to sign-in.
  • auth.jwt()#>>'{user_metadata,iss}' Returns the identity provider's SAML 2.0 EntityID

A common use case with SSO is to use the UUID of the identity provider as the identifier for the organization the user belongs to -- frequently known as a tenant. By associating the identity provider's UUID with your tenants, you can use restrictive RLS policies to scope down actions and data that a user is able to access.

For example, let's say you have a table like:


_10
create table organization_settings (
_10
-- the organization's unique ID
_10
id uuid not null primary key,
_10
-- the organization's SSO identity provider
_10
sso_provider_id uuid unique,
_10
-- name of the organization
_10
name text,
_10
-- billing plan (paid, Free, Enterprise)
_10
billing_plan text
_10
);

You can use the information present in the user's JWT to scope down which rows from this table the user can see, without doing any additional user management:


_10
CREATE POLICY "View organization settings."
_10
ON organization_settings
_10
AS RESTRICTIVE
_10
USING (
_10
sso_provider_id = (select auth.jwt()#>>'{amr,0,provider}')
_10
);

Managing SAML 2.0 connections

Once you've enabled SAML 2.0 support on your project via the Auth Providers page in the dashboard, you can use the Supabase CLI to add, update, remove and view information about identity providers.

Add a connection

To establish a connection to a SAML 2.0 Identity Provider (IdP) you will need:

  • A SAML 2.0 Metadata XML file, or a SAML 2.0 Metadata URL pointing to an XML file
  • (Optional) Email domains that the organization's IdP uses
  • (Optional) Attribute mappings between the user properties of the IdP and the claims stored by Supabase Auth

You should obtain the SAML 2.0 Metadata XML file or URL from the organization whose IdP you wish to connect. Most SAML 2.0 Identity Providers support the Metadata URL standard, and we recommend using a URL if this is available.

Commonly used SAML 2.0 Identity Providers that support Metadata URLs:

  • Okta
  • Azure AD (Microsoft Entra)
  • PingIdentity

Commonly used SAML 2.0 Identity Providers that only support Metadata XML files:

  • Google Workspaces (GSuite)
  • Any self-hosted or on-prem identity provider behind a VPN

Once you've obtained the SAML 2.0 Metadata XML file or URL you can establish a connection with your project's Supabase Auth server by running:


_10
supabase sso add --type saml --project-ref <your-project> \
_10
--metadata-url 'https://company.com/idp/saml/metadata' \
_10
--domains company.com

If you wish to use a Metadata XML file instead, you can use:


_10
supabase sso add --type saml --project-ref <your-project> \
_10
--metadata-file /path/to/saml/metadata.xml \
_10
--domains company.com

This command will register a new identity provider with your project's Auth server. When successful, you will see the details of the provider such as it's SAML information and registered domains.

Please note that only persons with write access to the project can register, update or remove identity providers.

Once you've added an identity provider, users who have access to it can sign in to your application. With SAML 2.0 there are two ways that users can sign in to your project:

  • By signing-in from your application's user interface, commonly known as SP (Service Provider) Initiated Flow
  • By clicking on an icon in the application menu on the company intranet or identity provider page, commonly known as Identity Provider Initiated (IdP) Flow

To initiate a sign-in request from your application's user interface (i.e. the SP Initiated Flow), you can use:


_10
supabase.auth.signInWithSSO({
_10
domain: 'company.com',
_10
})

Calling signInWithSSO starts the sign-in process using the identity provider registered for the company.com domain name. It is not required that identity providers be assigned one or multiple domain names, in which case you can use the provider's unique ID instead.

Understanding attribute mappings

When a user signs in using the SAML 2.0 Single Sign-On protocol, an XML document called the SAML Assertion is exchanged between the identity provider and Supabase Auth.

This assertion contains information about the user's identity and other authentication information, such as:

  • Unique ID of the user (called NameID in SAML)
  • Email address
  • Name of the user
  • Department or organization
  • Other attributes present in the users directory managed by the identity provider

With exception of the unique user ID, SAML does not require any other attributes in the assertion. Identity providers can be configured so that only select user information is shared with your project.

Your project can be configured to recognize these attributes and map them into your project's database using a JSON structure. This process is called attribute mapping, and varies according to the configuration of the identity provider.

For example, the following JSON structure configures attribute mapping for the email and first_name user identity properties.


_10
{
_10
"keys": {
_10
"email": {
_10
"name": "mail"
_10
},
_10
"first_name": {
_10
"name": "givenName"
_10
}
_10
}
_10
}

When creating or updating an identity provider with the Supabase CLI you can include this JSON as a file with the --attribute-mapping-file /path/to/attribute/mapping.json flag.

For example, to change the attribute mappings to an existing provider you can use:


_10
supabase sso update <provider-uuid> --project-ref <your-project> \
_10
--attribute-mapping-file /path/to/attribute/mapping.json

Given a SAML 2.0 assertion that includes these attributes:


_21
<saml:AttributeStatement>
_21
<!-- will be mapped to the email key -->
_21
<saml:Attribute
_21
Name="mail"
_21
NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"
_21
>
_21
<saml:AttributeValue xsi:type="xs:string">
_21
valid.email@supabase.io
_21
</saml:AttributeValue>
_21
</saml:Attribute>
_21
_21
<!-- will be mapped to the first_name key -->
_21
<saml:Attribute
_21
Name="givenName"
_21
NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"
_21
>
_21
<saml:AttributeValue xsi:type="xs:string">
_21
Jane Doe
_21
</saml:AttributeValue>
_21
</saml:Attribute>
_21
</saml:AttributeStatement>

Will result in the following claims in the user's identity in the database and JWT:


_10
{
_10
"email": "valid.email@supabase.io",
_10
"custom_claims": {
_10
"first_name": "Jane Doe"
_10
}
_10
}

Supabase Auth does not require specifying attribute mappings if you only need access to the user's email. It will attempt to find an email attribute specified in the assertion. All other properties will not be automatically included, and it is those you need to map.

At this time it is not possible to have users without an email address, so SAML assertions without one will be rejected.

Most SAML 2.0 identity providers use Lightweight Directory Access Protocol (LDAP) attribute names. However, due to their variability and complexity operators of identity providers are able to customize both the Name and attribute value that is sent to Supabase Auth in an assertion. Please refer to the identity provider's documentation and contact the operator for details on what attributes are mapped for your project.

Accessing the stored attributes

The stored attributes, once mapped, show up in the access token (a JWT) of the user. If you need to look these values up in the database, you can find them in the auth.identities table under the identity_data JSON column. Identities created for SSO providers have sso:<uuid-of-provider> in the provider column, while id contains the unique NameID of the user account.

Furthermore, you can find the same identity data under raw_app_meta_data inside auth.users.

Remove a connection

Once a connection to an identity provider is established, you can remove it by running:


_10
supabase sso remove <provider-id> --project-ref <your-project>

If successful, the details of the removed identity provider will be shown. All user accounts from that identity provider will be immediately logged out. User information will remain in the system, but it will no longer be possible for any of those accounts to be accessed in the future, even if you add the connection again.

If you need to reassign those user accounts to another identity provider, please open a support ticket.

A list of all registered identity providers can be displayed by running:


_10
supabase sso list --project-ref <your-project>

Update a connection

You may wish to update settings about a connection to a SAML 2.0 identity provider.

Commonly this is necessary when:

  • Cryptographic keys are rotated or have expired
  • Metadata URL has changed, but is the same identity provider
  • Other SAML 2.0 Metadata attributes have changed, but it is still the same identity provider
  • You are updating the domains or attribute mapping

You can use this command to update the configuration of an identity provider:


_10
supabase sso update <provider-id> --project-ref <your-project>

Please use --help to see all available flags.

It is not possible to change the unique SAML identifier of the identity provider, known as EntityID. Everything else can be updated. If the SAML EntityID of your identity provider has changed, it is regarded as a new identity provider and you will have to register it like a new connection.

Retrieving information about a connection

You can always obtain a list of all registered providers using:


_10
supabase sso list --project-ref <your-project>

This list will only include basic information about each provider. To see all of the information about a provider you can use:


_10
supabase sso show <provider-id> --project-ref <your-project>

You can use the -o json flag to output the information as JSON, should you need to. Other formats may be supported, please use --help to see all available options.

Frequently asked questions

How do I publish my application to an identity provider's marketplace?

Many cloud-based identity providers offer a marketplace where you can register your application for easy on-boarding with customers. When you use Supabase Auth's SAML 2.0 support you can register your project in any one of these marketplaces.

Please refer to the relevant documentation for each cloud-based identity provider on how you can do this. Some common marketplaces are:

Why do some users get: SAML assertion does not contain email address?

Identity providers do not have to send back and email address for the user, though they often do. Supabase Auth requires that an email address is present.

The following list of commonly used SAML attribute names is inspected, in order of appearance, to discover the email address in the assertion:

  • urn:oid:0.9.2342.19200300.100.1.3
  • http://schemas.xmlsoap.org/ws/2005/05/identity/claims/emailaddress
  • http://schemas.xmlsoap.org/claims/EmailAddress
  • mail
  • email

Finally if there is no such attribute, it will use the SAML NameID value but only if the format is advertised as urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress.

Should you run into this problem, it is most likely a misconfiguration issue on the identity provider side. Please instruct your contact at the company to map the user's email address to one of the above listed attribute names, typically email.

How do I access the private key used for SAML in my project?

At this time it is not possible to extract the RSA private key used by your project's Supabase Auth server. This is done to keep the private key as secure as possible, given that SAML does not offer an easy way to rotate keys without disrupting service. (Please use a SAML 2.0 Metadata URL whenever possible for this reason!)

If you really need access to the key, please open a support ticket and we'll try to support you as best as possible.

Is multi-tenant SSO with SAML supported?

Yes, Supabase supports multi-tenant Single Sign-On (SSO) using SAML 2.0. While the dashboard displays only one SAML field, you can set up multiple SAML connections using the Supabase CLI. Each connection is assigned a unique sso_provider_id, which is included in the user's JWT and can be used in Row Level Security (RLS) policies. You can configure custom attribute mappings for each connection to include tenant-specific information, such as roles. This setup allows you to implement multi-tenant SSO for multiple clients or organizations within a single application. For example, if you have an app with multiple clients using different Azure Active Directories, you can create separate SAML connections for each and use the sso_provider_id to manage access and apply appropriate security policies.

Is multi-subdomain SSO with SAML supported?

Yes, also referred to as cross-origin authentication within the same site. To redirect to a URL other than the Site URL, following the SAML response from the IdP, the redirectTo option can be added to signInWithSSO.


_10
const { data, error } = await supabase.auth.signInWithSSO({
_10
domain: 'company.com'
_10
options: {
_10
redirectTo: `https://app.company.com/callback`,
_10
},
_10
})

When redirecting to a URL other than the Site URL, a /callback endpoint is necessary to process the auth code from the IdP and exchange it for a session. This assumes the Supabase SSR client has already been configured.


_18
import { error, redirect } from '@sveltejs/kit'
_18
import type { RequestHandler } from './$types'
_18
_18
export const GET: RequestHandler = async ({ url, locals }) => {
_18
const code = url.searchParams.get('code')
_18
_18
if (!code) {
_18
error(400, 'No authorization code provided')
_18
}
_18
_18
const { error: tokenExchangeError } = await locals.supabase.auth.exchangeCodeForSession(code)
_18
_18
if (tokenExchangeError) {
_18
error(400, 'Failed to exchange authorization code for session')
_18
}
_18
_18
redirect(303, '/')
_18
}