- Authentication: the process of determining if a principal (a user or application) is who or what they say they are.
- Authorization: the process of determining what is allowed, based on the principal, what permissions they have been given, and/or the set of contextually-specific access criteria.
- Consent: what permissions the user () has given permission to an application to do on its behalf. This is generally a requirement of delegated authorization. The user has to give permission to the Client to access the user’s data in a different system.
- Policy Enforcement: The act of enforcing the policies of the application or API, rejecting or allowing access based on a user’s authentication and/or authorization information.
- The first category is where access is either granted or denied to an application or an API in its entirety. Both the data required to enforce this and the enforcement process is typically defined in the context of the Authorization Server For example, by using app_metadataassociated with a user and a Rule defined in your Auth0 tenant.
- The second category is where access is either granted or denied to a specific subset of application or API functionality. The data required to enforce this is typically stored in the Authorization Server For example, by using app_metadataon a user in your Auth0 tenant with the enforcement process performed in the application or API itself. In this scenario, the data is typically communicated as one or more custom claims in anidoraccesstoken.
- The third category is where access is either granted or denied depending on what the principal (subject) can operate on within the context of an application or API. Both the data required to enforce this, and the enforcement process is typically defined in the context of the application or API. In this scenario, the data communicated as one or more custom claims in an idoraccesstoken may be consumed with or without data from an external source that is not Auth0.
- Are there scenarios where access to an entire application or API should be rejected?
- Will you be providing APIs that can be accessed by third-party applications?
- Will your APIs also be accessed by your own (first-party) applications?
- Will your application be calling a third-party API?
- Should your applications and/or APIs be enforcing access control based on user claims?
- What if I need to know which organization an or is associated with?
UnauthorizedError when, for example, a user attempts access to an application or an API at an incorrect time (as described in this example)—or if the user doesn’t have the right claim(s) contained in their app_metadata. For an application using OpenID Connect (OIDC), this would prevent the allocation of the ID Token used to authorize access. Similarly, for an API, allocation of any OAuth2 Access Token (used when calling the API), could be prevented as described in this example.
Best Practice
In the main, we have found that OIDC is the most commonly used industry-standard protocol used by Auth0 customers when it comes to authentication in their applications. We have also found that, even though OAuth2 was created as a delegation protocol, it is commonly used within first party applications when there is an API that does not have a shared session with the application.When deciding what data to include in your ID token and/or access token, consider token size, especially if you are passing the token in the URL. Even if you are not passing tokens in the URL, you will also need to consider the potential of exposing sensitive PII (Personally Identifiable Information). Token information is not encrypted, so although it isn’t generally a security issue for an ID token to be leaked, it can become a privacy issue depending on the data that is included in the token.
For multi-organization scenarios, it can often be important to know which organization an access token (or even an ID token) applies to. Taking care to follow the best practices can save you time and effort.
Application integration
In this scenario, your Auth0 tenant provides a token as an indicator of authorized access to an application. For applications utilizing OpenID Connect (OIDC), the industry-standard protocol we typically find most utilized when it comes to customer facing applications, this would be an ID Token expressed as a JWT.ID Token claims
Using Rule extensibility, Auth0 allows you to easily add custom claims to an ID Token based on, for example, a user’s metadata content. Your application can then verify the ID Token for the necessary claims, and either allow or prevent access to certain functionality as required. Note that though the process of adding custom claims via Rule is streamlined, the Rule engine is flexible and allows you to write custom code that may have negative effects. Therefore it’s important to follow our rules best practice guidance anytime you use this extensibility feature.Best Practice
When you are considering adding custom claims, we recommend that you store any access control data you may need to include within claims as part of the user’sapp_metadata. Firstly, this prevents you from needing to call an external API to fetch the data, which can negatively impact the performance and scalability of the login sequence. Secondly app_metadata cannot be modified by a user - so the user cannot directly circumvent any access control restrictions by modifying their own metadata. Also remember to check out our metadata best practices guidance too.ID Token scopes
OIDC Scopes are typically used by an application to obtain consent for authorized access to a user’s details during authentication. Each of the pre-defined scopes returns the set of standard claims where defined, and as described in the OIDC specification. The scopes an application requests depend on which user attributes the application needs. Once the requested scopes are authorized by the user, the claims are returned in the ID Token and are also made available via the /userinfo endpoint.API integration
In this scenario your Auth0 tenant can provide an OAuth2 Access Token, typically expressed as a JWT, which can be used by your API to restrict access to certain parties. In addition, Auth0 provides support for what is notionally described as both First-Party and Third-Party Applications. Acting as the authorization server, and with the consent of the user (the resource owner), your Auth0 tenant can be used to provide an Access Token—typically expressed as a JWT—to an application (client) so that it can access a protected resources hosted by a on behalf of the resource owner. The issued Access Token is typically passed as the Bearer token in the HTTP Authorization header sent to an API. Whether you have a single API, or perhaps a suite of logically related microservice APIs, you can leverage the Access Tokens that Auth0 provides in order to secure access to your service(s). Though relatively easy to set this up in the Auth0 Dashboard or through the Auth0 Management API, it’s important to review the different application scenarios and API layouts to determine the best architecture for your system.OAuth2 Access Tokens are primarily designed for use in securing public facing APIs; when expressed as a JWT, an Access Token is a self contained entity which can be verfied without the need to make any additional 3rd party API call. If your APIs do not fall into this category - i.e they are part of an application itself (as in only called by that application) or are sat behing your firewall - then protecting them with tokens may well be overkill, and your existing cookie based (et al) workflow may well suffice.
Though you can configure your applications to be first-party and subsequently configure your APIs to allow first-party clients to ignore consent, if you are using 
localhost then Auth0 cannot verify that the application is truly a first-party app so your users will be prompted for consent anyway. To work around this constraint, when testing on your local machine during development, create a fake local hostname and use that instead.Access Token claims
As is the case with ID Tokens, you can add custom claims to Access Tokens using Auth0 Rule extensibility. Once added, your API can then verify an Access Token for the necessary claims and either allow or prevent access to certain functionality as required.Best Practice
When you are considering adding custom claims, we recommend that you store any access control data you may need to include within claims as part of the user’sapp_metadata. Firstly, this prevents you from needing to call an external API to fetch the data, which can negatively impact performance and scalability. Secondly app_metadata cannot be modified by a user - so the user cannot directly circumvent any access control restrictions by modifying their own metadata. Also remember to check out our metadata best practices guidance too.Access Token scopes
OAuth2 Scopes are typically used as the mechanism by which an API can determine what actions can be performed on behalf of a user. Scopes can be added on a per API basis to define specific access permissions in the or through the Auth0 ). Scopes can also be manipulated via Auth0 extensibility (e.g. via a Rule, as in this example). The scopes an application requests for accessing an API should depend on what functionality the application needs the user to give permission for the application to use. Once the requested scopes are authorized, they will be returned in the Access Token which can be subsequently verified by said API. A good example of this is when you log in to an application that is using a social provider for login: the social provider API requires that the application specifies whether the user will want the application to post items on your behalf. This allows the user to accept or deny this request. This example demonstrates how the user is delegating permission to the application—which is different than the API restricting access based on a user’s role, and should be handled differently.Best Practice
Even though you have the ability to fully manipulate Access Token Scopes via Auth0 extensibility, as a security best practice you should only remove scopes which are not authorized and refrain from adding scopes that were not requested.Fine Grained Authorization (FGA)
Fine Grained Authorization allows you to grant individual users access to a specific resource or object based on:- A user’s role within an organization, such as editororadmin
- An attribute of the user or object, such as managerfor a user ormarketingfor an object
- A relationship between a user and an object, such as a user with view access to a parent folder also has view access to the child folder
Role Based Access Control (RBAC)
Auth0 has out-of-box support for Role Based Access Control (RBAC). RBAC refers to assigning permissions to users based on their role within an organization, and provides for simpler access control by offering a more manageable approach that is less prone to error. The core RBAC feature can be used in many multi-organization scenarios. See Organization Data in an Access Tokens for more information on how to ensure your setup can support your RBAC needs.Machine-to-Machine (M2M) Authorization
There are many scenarios that require an application without any user-interactive session to obtain an access token in order to call an API. In such scenarios you must authenticate the client instead of the user, and 2 provides the client credentials grant type to make this easy to achieve. Some common examples of where this is required include:- A cron job or other service that needs to communicate with your API (e.g. where a daily report needs to be generated and emailed it to an administrator).
- A separate API the supports privileged access (e.g. the API is not exposed to users directly, but instead to a backend only).
- In certain microservice architectures, where some API layers need to communicate to other API layers without a user involvement, or after a user token has expired.
- A privileged API that may need to be called before a user has authenticated (i.e. from a rule or custom DB script in your Auth0 tenant)
best practice
Traditionally, a special “service account” would have been created in order to cater for these scenarios: a user with a username and password that was configured for services which supported non-interactive use cases. That is no longer a recommended approach for many reasons, and the current best practice is to use OAuth 2.0 Client Credentials Grant in these situations.Organization Data in an Access Token
If you have a separate API from your application in your system that supports your multi-organization application, it is important to restrict operations to only the organization that the token was generated for. This requires that there is some sort of information in the access token to tell the API which organization the access token was issued for. This can be done in a couple of different ways depending on the answers to a couple of simple questions:- Will the End Users in this organization potentially have more than one organization, or is each End User isolated to a specific organization?
- Will you be allowing any Machine-to-Machine (M2M) access to your API?
- If you are allowing Machine-to-Machine (M2M) access to your API, Will you have any developers who need a single client ID and secret to access multiple organizations (but not all organizations)?
- Will you be allowing the creating of third-party apps that require consent?
- First, it allows you to pass the audience as a first-class parameter to Auth0 without having to create a custom parameter. The benefit of this is that Auth0 will help enforce the existence of the audience, and it will pass it to your rules. It will also ensure that an issued refresh token will only work for the specific audience it was originally issued to.
- It allows you to restrict client grants to only specific organizations out of the box. The alternative is to create a more complicated client credentials hook to attempt to retrieve the restrictions from somewhere else and also require a much more complex and potentially troublesome way to tell the client credentials call which organization to issue the access token for.
- This also allows you to use the core RBAC feature with Auth0 and ensure that the End Users who have access to more than one organization can have a potentially different role for each organization.