Generates an OAuth 2.0 authorization URL to authenticate a user with SSO.
| curl "https://api.workos.com/sso/authorize" \ | |
| -G \ | |
| -d response_type=code \ | |
| -d client_id=client_01HZBC6N1EB1ZY7KG32X \ | |
| -d redirect_uri=https://your-app.com/callback \ | |
| -d state=dj1kUXc0dzlXZ1hjUQ== \ | |
| -d connection=conn_01E4ZCR3C56J083X43JQXF3JK5 |
| import { WorkOS } from '@workos-inc/node'; | |
| const workos = new WorkOS('sk_example_123456789'); | |
| const authorizationUrl = workos.sso.getAuthorizationUrl({ | |
| connection: 'conn_01E4ZCR3C56J083X43JQXF3JK5', | |
| clientId: 'client_123456789', | |
| redirectUri: 'https://your-app.com/callback', | |
| state: 'dj1kUXc0dzlXZ1hjUQ==', | |
| }); |
| require "workos" | |
| WorkOS.configure do |config| | |
| config.key = "sk_example_123456789" | |
| end | |
| WorkOS::SSO.authorization_url( | |
| connection: "conn_01E4ZCR3C56J083X43JQXF3JK5", | |
| client_id: "client_123456789", | |
| redirect_uri: "https://your-app.com/callback", | |
| state: "dj1kUXc0dzlXZ1hjUQ==" | |
| ) |
| from workos import WorkOSClient | |
| workos_client = WorkOSClient( | |
| api_key="sk_example_123456789", client_id="client_123456789" | |
| ) | |
| authorization_url = workos_client.sso.get_authorization_url( | |
| connection_id="conn_01E4ZCR3C56J083X43JQXF3JK5", | |
| redirect_uri="https://your-app.com/callback", | |
| state="dj1kUXc0dzlXZ1hjUQ==", | |
| ) |
| package main | |
| import ( | |
| "github.com/workos/workos-go/v3/pkg/sso" | |
| ) | |
| func main() { | |
| sso.Configure( | |
| "sk_example_123456789", | |
| "client_123456789", | |
| ) | |
| url, err := sso.GetAuthorizationURL( | |
| sso.GetAuthorizationURLOpts{ | |
| Connection: "conn_01E4ZCR3C56J083X43JQXF3JK5", | |
| RedirectURI: "https://your-app.com/callback", | |
| State: "dj1kUXc0dzlXZ1hjUQ==", | |
| }, | |
| ) | |
| } |
| <?php | |
| WorkOS\WorkOS::setApiKey("sk_example_123456789"); | |
| WorkOS\WorkOS::setClientId("client_123456789"); | |
| $sso = new WorkOS\SSO(); | |
| $authorizationUrl = $sso->getAuthorizationUrl( | |
| redirectUri: "https://your-app.com/callback", | |
| state: "dj1kUXc0dzlXZ1hjUQ==", | |
| connection: "conn_01E4ZCR3C56J083X43JQXF3JK5", | |
| ); |
| import com.workos.WorkOS; | |
| WorkOS workos = new WorkOS("sk_example_123456789"); | |
| String clientId = "client_123456789"; | |
| String redirectUri = "https://your-app.com/callback"; | |
| String connectionId = "conn_01E4ZCR3C56J083X43JQXF3JK5"; | |
| String state = "dj1kUXc0dzlXZ1hjUQ=="; | |
| String url = workos.sso.getAuthorizationUrl(clientId, redirectUri) | |
| .connection(connectionId) | |
| .state(state) | |
| .build(); |
| WorkOS.SetApiKey("sk_example_123456789"); | |
| var ssoService = new SSOService(); | |
| var options = new GetAuthorizationURLOptions { | |
| ClientId = "client_123456789", | |
| Connection = "conn_01E4ZCR3C56J083X43JQXF3JK5", | |
| RedirectURI = "https://your-app.com/callback", | |
| State = "dj1kUXc0dzlXZ1hjUQ==", | |
| }; | |
| string url = ssoService.GetAuthorizationURL(options); |
| https://api.workos.com/sso/authorize? | |
| response_type=code& | |
| client_id=client_123456789& | |
| redirect_uri=https://your-app.com/callback& | |
| state=dj1kUXc0dzlXZ1hjUQ==& | |
| connection=conn_01E4ZCR3C56J083X43JQXF3JK5 |
GET/sso /authorize
Parameters
Returns
You’ll have to specify the user’s connection, organization, or OAuth provider as a parameter. These connection selectors are mutually exclusive, and exactly one must be provided. The generated URL automatically directs the user to their identity provider. Once the user authenticates with their identity provider, WorkOS then issues a redirect to your redirect URI to complete the sign-in flow.
In the OAuth 2.0 protocol, a redirect URI is the location that the user is redirected to once they have successfully authenticated with their identity provider.
When redirecting the user, WorkOS will generate an authorization code and pass it to your redirect URI as a code query parameter, your app will use this code to get the user’s profile. Additionally, WorkOS can pass a state parameter back to your application that you may use to encode arbitrary information to restore your application state between the redirects.
You’ll need to configure the allowed redirect URIs for your application in the Applications section of the WorkOS Dashboard. Open your application and go to the Redirects tab. Without a valid redirect URI, your users will be unable to sign in. Make sure that the redirect URI you use as a parameter to get the authorization URL matches one of the redirect URIs configured for the application.
Redirect URIs follow stricter requirements in production environments:
HTTPSprotocol is required in production environmentsHTTPandlocalhostare allowed in staging environments- The sole exception is the use of
http://127.0.0.1in production environments to support native clients.
Wildcards
WorkOS supports using wildcard characters (*) in Redirect URIs to handle dynamic subdomains or variable ports during development.
Subdomains
The * symbol can be used as a wildcard for subdomains; however, it must be used in accordance with the following rules:
- The protocol of the URL must not be
http:in production environments. - The wildcard must be located in the subdomain furthest from the root domain (e.g.,
https://*.sub.example.comwill work, buthttps://sub.*.example.comwill not). - The URL must not contain more than one wildcard.
- A wildcard character may be prefixed and/or suffixed (e.g.,
https://prefix-*-suffix.example.com). - A wildcard will not match across multiple subdomain levels (e.g.,
https://*.example.comwill not matchhttps://sub1.sub2.example.com). - Wildcards cannot be used with public suffix domains (e.g.,
https://*.ngrok-free.appwill not work). - The wildcard will match letters, digits, hyphens, and underscores.
- A URL with a wildcard cannot be set as the default redirect URI.
Ports
To support RFC 8252 (“OAuth 2.0 for Native Apps”) and local development, a wildcard may be used in place of the port number.
- This is strictly limited to
localhostand loopback IP addresses (e.g.,127.0.0.1). - Example:
http://localhost:*/auth/callbackis valid.
If there is an issue generating an authorization URL, the API will return the original redirect URI with error and error_description query parameters. If provided, the state value will also be included.
Possible error codes and the corresponding descriptions are listed below.
| Error code | Description |
|---|---|
access_denied | The identity provider denied the user’s access to the client application, or the user declined the OAuth authorization request at the identity provider. |
ambiguous_connection_selector | A connection could not be uniquely identified using the provided connection selector (e.g., organization). This can occur when there are multiple SSO connections under the same organization. If you need multiple SSO connections for an organization, use the connection parameter to identify which connection to use for SSO. |
connection_domain_invalid | There is no connection for the provided domain. |
connection_invalid | There is no connection for the provided ID. |
connection_strategy_invalid | The provider has multiple strategies associated per environment. |
connection_unlinked | The connection associated with the request is unlinked. |
domain_connection_selector_not_allowed | This is a legacy error code that only applies if using the deprecated “domain” query parameter which is no longer valid for this endpoint. Use the “organization” or “connection” query parameters to target a connection instead. |
idp_initiated_sso_disabled | IdP-initiated SSO is disabled for the connection (see Disable IdP-initiated SSO). |
invalid_connection_selector | A valid connection selector query parameter must be provided in order to correctly determine the proper connection to return an authorization URL for. Valid connection selectors are either connection, organization, or provider. |
organization_invalid | There is no organization matching the provided ID. |
oauth_failed | An OAuth authorization request failed for a user. |
profile_not_allowed_outside_organization | A profile was received that has an email that is outside the organization’s domain and the organization does not allow this. To resolve this, add the missing domain to the organization’s Domains. You can read about other options in the SSO Domains guide. |
server_error | The SSO authentication failed for the user. More detailed errors and steps to resolve are available in the Sessions tab on the connection page in the WorkOS Dashboard. |
signin_consent_denied | The user rejected the sign-in consent screen. This screen prompts the user to verify the email provided by the identity provider to confirm the legitimacy of the sign-in attempt. |