Organizations
You should create an independent Auth0 Organization for each of the organizations you will support. In this case, we’ll create thehoekstra organization to represent Hoekstra & Associates in our example, and the metahexa organization to represent MetaHexa Bank. You can create organizations either manually via the  or programmatically via the use of the Auth0 .
Applications
Depending on how your Organization Tenant implementation is designed, you have different options when creating Application definitions within your Auth0 Tenant. Whichever option you choose, the Organization behavior is defined at the application level. If you provision a separate Organization Tenant for each of your customers, then you will typically need an independent Application definition in Auth0 for each. This arrangement will also usually involve sending both the Application-specificclient_id parameter and the organization parameter, which identifies which Auth0 Organization to use, as part of the call to the /authorize endpoint. To learn more, see Authentication.
Best PracticeFor ease of configuration and maximized security isolation, define Applications in Auth0 independently. Doing so allows items like allowed callback URLs to be configured independently and, following the principle of least privilege, minimizes the potential exposure of any Client ID and Client Secret information.
client_id, but the organization parameter will be omitted on the call to the /authorize endpoint.
Connections
Next, define the Connections that will be used to authenticate users. In this case, we’ll define a Database Connection for users associated with Hoekstra & Associates and an Enterprise Connection for users associated with MetaHexa Bank.Best PracticeFor Single Identity Provider (IdP) Organizations, create one Connection for each defined organization in order to provide flexibility for a number of use case scenarios. For example, a single Database or Custom Database Connection per organization allows you to easily delete users associated with organizations that get decommissioned and offers maximum flexibility for organizations that have differing requirements for password complexity.
Users
For users that are authenticated via Connections other than Database or Custom Database Connections, the user is provisioned to the external (IdP) independent of Auth0 and in the normal way. On the other hand, users that are authenticated via Database or Custom Database Connections can be provisioned in a number of different ways. The Auth0 Dashboard and Auth0 Management API can be used to create a user directly in your Auth0 Tenant. We also support Automatic Migration and Bulk Migration.For a user to be provisioned via the Management API or the Dashboard, you must directly enable a Database or Custom Database Connection for at least one Application. Enabling a Database or Custom Database Connection for an Organization only will not suffice.
For a user to be manually assigned Membership to an organization, that user must already have a User Profile defined in Auth0. You can manually assign Membership using either the Auth0 Tenant Dashboard or the Auth0 Management API.
Invitation
The Auth0 Organization feature also supports the use of Member Invitation. In the Member Invitation workflow, inviting a user to an application will result in the user being provisioned automatically and their user membership being generated automatically.Database Connection
Using our Hoekstra & Associates example, let’s see how this implementation might flow where a Database Connection is used as part of user invitation; most of the workflow described will typically be handled by using the relevant Auth0 SDK or library associated with your technology stack:
- 
Jennifer from Hoekstra & Associates receives an email sent from Travel0’s Auth0 Tenant on behalf of Hoekstra & Associates’ instance of Travel0 Corporate Booking.
- The email was sent as described in Invite Organization Members and may have been triggered using either the Auth0 Dashboard or the Auth0 Management API.
 
- 
Jennifer opens the email and clicks on its contained link. Doing so directs her browser to Hoekstra & Associates’ instance of Travel0 Corporate Booking. The base URL used in the link is specified as the Application Login URI, which forms part of Hoekstra & Associates’ instance of Travel0 Corporate Booking application definition in the Travel0 Auth0 Tenant.
- The link contains organizationandorganization_nameparameters. Theorganizationparameter is set to the ID of the corresponding Auth0 Organization definition in your Auth0 Tenant. This will be forwarded to the Auth0 Tenant as part of step 3.
- The link also contains the invitationparameter, which will also be forwarded as part of step 3.
 
- The link contains 
- 
Hoekstra & Associates’ instance of Travel0 Corporate Booking redirects to the Travel0 Auth0 Tenant using Authorization Code Flow (with or without PKCE) by calling the /authorizeendpoint and passing parameters similar to the following, typically via use of an Auth0 SDK or third-party library:- redirect_uri:- https://hoekstra.corp.travel0.net/login/callback
- response_type:- code
- state: Unique state generated in this session
- scope:- openid profile…
- any necessary additional OIDC Scopes, depending on the information required about the user.
- client_id: Client ID associated with the Application created in the Travel0 Auth0 Tenant for Hoekstra & Associates’ instance of Travel0 Corporate Booking.
- organization: ID of the inviting organization typically obtained via the link in the email described in step 2. Specified in the form- organization=organization_id, where organization_id is set to the identifier associated with the corresponding Auth0 Organization definition in your Auth0 Tenant.
- invitation: Additional- invitationparameter associated with the link in the email, as described in step 2.
 
- 
The Travel0 Auth0 Tenant redirects to /signup/invitationto collect a password credential from the user.- 
A Universal Login Page, which you can configure to display organization-specific brand collateral as described in Branding, is displayed.
The invitation workflow associated with the Auth0 Organizations feature does not consider any SSO session held with Auth0. If a user is invited to sign up and they are already signed in, clicking the link in the email will always result in the display of the associated Universal Login Page.
 
- 
A Universal Login Page, which you can configure to display organization-specific brand collateral as described in Branding, is displayed.
- The user enters their password (and any additional credentials, such as user name) and clicks continue. The user ID is set to the email address associated with the user and cannot be changed.
- 
The Travel0 Auth0 Tenant checks credentials. If valid, the user is provisioned and Auth0 Organization Membership is set. The user is implicitly authenticated, and the Rules pipeline executes. Rules can be used to handle access control, as described in Authorization.
- If credentials for the user are invalid, then the user will be prompted to re-enter them.
 
- 
Upon successful credential checking and Rules execution, the user is redirected to the redirect_uri(https://hoekstra.corp.travel0.net/login/callback) with thestatepassed in step 3, as well as acode.
- 
Hoekstra & Associates’ instance of Travel0 Corporate Booking validates the stateand then calls the Travel0 Auth0 Tenant athttps://auth.travel0.net/oauth/token, passing thecodeand itsclient idandclient secretin exchange for the ID Token. The ID token is then used to generate a session forhttps://hoekstra.corp.travel0.net.
- Hoekstra & Associates’ instance of Travel0 Corporate Booking instance displays the appropriate page to the user.
Enterprise Connection
Using our MetaHexa Bank example, let’s see how this implementation might flow where an Enterprise Connection is used as part of user invitation; again, most of the workflow described will typically be handled by using the relevant Auth0 SDK or library associated with your technology stack:
- 
Amintha from MetaHexa Bank receives an email sent from Travel0’s Auth0 Tenant on behalf of MetaHexa Bank’s instance of Travel0 Corporate Booking.
- The email was sent as described in Invite Organization Members and may have been triggered using either the Auth0 Dashboard or the Auth0 Management API.
 
- 
Amintha opens the email and clicks on its contained link. Doing so directs her browser to MetaHexa Bank’s instance of Travel0 Corporate Booking. The base URL used in the link is specified as the Application Login URI, which forms part of MetaHexa Bank’s instance of Travel0 Corporate Booking application definition in the Travel0 Auth0 Tenant.
- The link contains organizationandorganization_nameparameters. Theorganizationparameter is set to the ID of the corresponding Auth0 Organization definition in your Auth0 Tenant. This will be forwarded to the Auth0 Tenant as part of step 3.
- The link also contains the invitationparameter, which will also be forwarded as part of step 3.
 
- The link contains 
- 
MetaHexa Bank’s instance of Travel0 Corporate Booking redirects to the Travel0 Auth0 Tenant using Authorization Code Flow (with or without PKCE) by calling the /authorizeendpoint and passing parameters similar to the following, typically via use of an Auth0 SDK or third-party library:- redirect_uri:- https://metahexa.corp.travel0.net/login/callback
- response_type:- code
- state: Unique state generated in this session
- scope:- openid profile…
- any necessary additional OIDC Scopes, depending on the information required about the user.
- client_id: Client ID associated with the Application created in the Travel0 Auth0 Tenant for MetaHexa Bank’s instance of Travel0 Corporate Booking.
- organization: ID of the inviting organization typically obtained via the link in the email described in step 2. Specified in the form- organization=organization_id, where organization_id is set to the identifier associated with the corresponding Auth0 Organization definition in your Auth0 Tenant.
- invitation: Additional- invitationparameter associated with the link in the email, as described in step 2.
 
- 
The Travel0 Auth0 Tenant redirects to /invitation, where Amintha is informed that she will be redirected to the MetaHexa IdP to authenticate first-factor credentials.- The user confirms, and
- Auth0 redirects to the MetaHexa Bank IdP instance, where
- The login page is displayed, and the user enters credentials and clicks login.
 
- If successful, the Auth0 Organization Membership is set, the user is implicitly authenticated, and the Rules pipeline executes. Rules can be used to handle access control as described in Authorization.
metahexa.corp.travel0.net) will be used in place of Hoekstra & Associates.