On This Page
External Identity Providers
As a developer building a custom application, you want to give your users the freedom to choose which Identity Provider that they use to sign in to your application. But first you should understand how various Identity Providers connect to Okta.
What is an Identity Provider? It is a service that creates and maintains identity information and then provides authentication services to your applications. Identity Providers can significantly reduce sign-in and registration friction, which allows your users to easily access applications without needing to create new passwords or remember usernames.
The big picture
Okta manages connections to other Identity Providers for your application and sits between your application and the Identity Provider that authenticates your users.
When you use Okta as the user store for your applications, users can sign in with their email and password by default. See our guides for how to sign in users to your web, mobile, and single-page apps.
You can add connections to Identity Providers like Twitter or Facebook. This is called social login or social authentication. It allows your users to sign in to your app using credentials from their existing Identity Providers. After users authenticate, you sync their existing Identity Provider credentials into your Okta Universal Directory while continuing to use that Identity Provider for user authentication. This eliminates the need to store an additional username and password for that user.
You can add connections to Identity Providers that you build in-house that support OpenID Connect or SAML protocols, also referred to as inbound federation or inbound SAML. The SAML flow is initiated with the service provider (in this case, Okta) that redirects the user to the Identity Provider for authentication. After authentication, a user is created inside Okta, and the user is redirected back to your application along with an ID token. This allows you to use Okta to proxy between SAML-only Identity Providers and OpenID Connect-only applications that normally are incompatible.
Note: Social and OpenID Connect Identity Providers store access tokens that allow subsequent calls to Identity Providers after the user is authorized. For example, the token may contain the permission to add events to a user's Google calendar. After the user is authorized, the token can be used on additional calls to add events to a user's Google calendar on the user's behalf.
- You can also configure federation between Okta orgs using OpenID Connect or SAML.
Adding any of these Identity Providers allows users to sign in to your application using their credentials from a specific Identity Provider.
Benefits of using Okta to manage Identity Providers
You could connect your application directly to an Identity Provider (for example, using an SDK to add a button for Sign in with Google). However, using Okta as the user store for your application and letting Okta manage the Identity Provider connections has some benefits:
No custom code: Your application only needs to talk to Okta, and Okta does the rest.
One protocol: Your application uses OpenID Connect to talk to Okta. Okta handles whatever protocols the other Identity Providers use, and this is transparent to your application.
Single user store: All users are stored in Okta. You can capture the profile attributes from an Identity Provider user and store those attributes in Okta's Universal Directory.
Profile sync: If a user updates their profile at the Identity Provider, those changes can be reflected inside Okta the next time that they use the provider to sign in.
Account linking: Users can use multiple Identity Providers to sign in, and Okta links those profiles to a single Okta user.
Group sync: Okta supports group sync between Okta and enterprise SAML Identity Providers. This allows you to specify the groups that users should be added to.
How Okta connects to external Identity Providers
Okta sits between your application and the external provider. Your application only needs to talk to Okta, and Okta does the rest.
Sign-in process
The sign-in process starts at the /authorize
endpoint, and then goes out to the provider and back:
- In your application, the user clicks a button similar to: Sign in with (Identity Provider).
- Your application redirects the browser to Okta.
- Okta redirects the browser to the Identity Provider.
- The user is prompted to sign in at the Identity Provider (if they aren't already) and to accept the permissions required by your app.
- The Identity Provider redirects the browser back to Okta.
- Okta processes the sign-in request and adds the user to your Okta organization's Universal Directory.
- Okta redirects the browser back to your application, just like any other sign-in request.
Account Linking and Just-in-Time Provisioning
When you allow your users to sign in to your app using their choice of Identity Providers, you can use account linking to help create a unified view of your users within your org. Additionally, you can use Just-In-Time (JIT) provisioning to create a seamless experience for users that sign-in to your application for the first time using their credentials from another Identity Provider.
Account Linking
Users can use multiple Identity Providers to sign in, and Okta can link all of those profiles to a single Okta user. This is called account linking. If, for example, a user signs in to your app using a different Identity Provider than they used for registration, account linking can establish that the user owns both identities, allowing the user to sign in from either account.
Account linking is configured at the Identity Provider level. When you create an Identity Provider using the Developer Console, these values are set by default:
- Account Link Policy — Automatic
- Match Against — Okta Username
- IdP Username — idpuser.email
With these defaults, when any validated OpenID Connect JWT is provided, Okta searches the Universal Directory for a user's profile where the email
attribute value passed by the Identity Provider (the IdP Username value) matches the username
attribute value (the Match Against value). If there is a match, then the user is linked by mapping the required, static sub
claim provided in the JWT to that user.
See Authentication Settings for more information on these attributes.
Important: After an account is linked, any validated JWT token with the same
sub
claim (which is mapped to theidp.externalId
in the Identity Provider profile) is automatically mapped to the same user regardless of the content of the claims in the JWT or if the values for IdP Username and Match Against no longer result in a match.
To remove an existing account link or validate account linking on every sign in, we recommend that you make a DELETE call to the /api/v1/idps/${idpId}/users/${userId}
endpoint to remove the link between the Okta user and the Identity Provider user before authentication.
If the Account Link Policy is disabled, no account linking occurs. You can manually create an account link without a transaction by making a POST call to the /api/v1/idps/${idps}/users/${userId}
endpoint prior to Okta receiving a validated JWT from an Identity Provider.
Note: See Add an Identity Provider for examples of creating an Identity Provider and the parameter values needed to configure account linking.
JIT provisioning
If a user signs in to your application for the first time using another Identity Provider, you can implement JIT provisioning to automatically create an Okta account for them. JIT account creation and activation only works for end users who aren't already Okta users.
Additionally, you can apply granular control over account linking and JIT by defining a policy and then rules for the policy. You can base a policy on a variety of factors, such as location, group definitions, and authentication type. A specific policy rule can then be created for groups that have been assigned to your application. You can create multiple policies with more or less restrictive rules and apply them to different groups.
You can also set up group sync to specify the groups that users should be added to and enable profile mastering so that a user's profile gets updated each time that the user signs in. This allows you to always have the most recent data about your users.
IdP Discovery
If you have more than one Identity Provider configured in your org (which can mean just one external Identity Provider, in addition to Okta itself also serving as an Identity Provider), you can define logic to determine which Identity Provider individual end users are routed to when they authenticate. This functionality is called IdP Discovery, or IdP Routing Rules, and is configured by means of the IdP Discovery Policy.
The Okta Sign-In Widget (version 2.5.0 or above) interacts with the IdP Discovery policy to redirect end users as needed to the IdP determined by the policy.
If you don't use the Okta Sign-In Widget, instead interacting directly with the Okta Authentication API to implement sign-in yourself, you can integrate IdP Discovery into your flow by including a call to Okta's WebFinger endpoint. That endpoint returns the name of the IdP that should be used for a given end user, as determined by the org's defined IdP Discovery Policy.
See also
See the following guides for information on how to set up various IdPs: