This tutorial will help you call your own API using the Hybrid Flow. If you want to learn how the flow works and why you should use it, see Hybrid Flow.
- Authentication API: If you prefer to build your own solution, keep reading to learn how to call our API directly.
Prerequisites
Before beginning this tutorial:- 
Register your Application with Auth0.
- Select the appropriate Application Type.
- Add an Allowed Callback URL of {https://yourApp/callback}.
- Make sure your Application’s Grant Types include Implicit and Authorization Code. To learn how, read Update Grant Types.
- If you want your Application to be able to use Refresh Tokens, make sure the Application’s Grant Types include Refresh Token. To learn how, read Update Grant Types. To learn more about Refresh Tokens, read Refresh Tokens.
 
- 
Register your API with Auth0
- If you want your API to receive Refresh Tokens to allow it to obtain new tokens when the previous ones expire, enable Allow Offline Access.
 
Steps
- Authorize user: Request the user’s authorization and redirect back to your app with an authorization code.
- Request tokens: Exchange your authorization code for tokens.
- Call API: Use the retrieved Access Token to call your API.
- Refresh tokens: Use a Refresh Token to request new tokens when the existing ones expire.
Authorize user
This step may include one or more of the following processes:- Authenticating the user
- Redirecting the user to an to handle authentication
- Checking for active (SSO) sessions
- Obtaining user consent for the requested permission level, unless consent has been previously given.
Example authorization URL
Parameters
Note that for authorizing a user when calling a custom API, you:- must include an parameter
- can include additional scopes supported by the target API
| Parameter Name | Description | 
|---|---|
| response_type | Denotes the kind of credential that Auth0 will return (code or token). For this flow, the value must include code, but may also includeid_token,token, orid_token token. Specifically,id_tokenreturns an ID Token, andtokenreturns an Access Token. | 
| response_mode | Specifies the method with which response parameters should be returned. For security purposes, the value should be form_post. In this mode, response parameters will be encoded as HTML form values that are transmitted via the HTTP POST method and encoded in the body using theapplication/x-www-form-urlencodedformat. | 
| client_id | Your application’s Client ID. You can find this value in your Application Settings. | 
| redirect_uri | The URL to which Auth0 will redirect the browser after authorization has been granted by the user. The Authorization Code will be available in the codeURL parameter. You must specify this URL as a valid callback URL in your Application Settings.Warning: Per the OAuth 2.0 Specification, Auth0 removes everything after the hash and does not honor any fragments. | 
| scope | Specifies the scopes for which you want to request authorization, which dictate which claims (or user attributes) you want returned. These must be separated by a space. You can request any of the standard OpenID Connect (OIDC) scopes about users, such as profileoremail, custom claims conforming to a namespaced format, or any scopes supported by the target API (e.g.,read:contacts). Includeoffline_accessto get a  (make sure that the Allow Offline Access field is enabled in the Application Settings). | 
| audience | The unique identifier of the API your application wants to access. Use the Identifier value on the Settings tab for the API you created as part of the prerequisites for this tutorial. | 
| state | (recommended) An opaque arbitrary alphanumeric string your app adds to the initial request that Auth0 includes when redirecting back to your application. To see how to use this value to prevent cross-site request forgery (CSRF) attacks, see Mitigate CSRF Attacks With State Parameters. | 
| nonce | A cryptographically random string that your app adds to the initial request and Auth0 includes inside the ID Token, used to prevent token replay attacks. | 
| organization | (optional) ID of the organization to use when authenticating a user. When not provided, if your application is configured to Display Organization Prompt, the user will be able to enter the organization name when authenticating. | 
| invitation | (optional) Ticket ID of the organization invitation. When inviting a member to an Organization, your application should handle invitation acceptance by forwarding the invitationandorganizationkey-value pairs when the user accepts the invitation. | 
Response
If all goes well, you’ll receive anHTTP 302 response. The requested credentials are encoded in the body:
response_type.
| Response Type | Components | 
|---|---|
| code   | Authorization code | 
| id_token  | ID Token | 
| token  | Access Token (plus expires_inandtoken_typevalues) | 
| id_token token | ID Token, Access Token (plus expires_inandtoken_typevalues) | 
The Access Token that you receive in this transaction is only the first Access Token that you will receive. We do not recommend that it be used to call APIs.
Validate your tokens before saving them. To learn how, read Validate ID Tokens and Validate Access Tokens.
c_hash, which contains a hash of the code. This claim is mandatory when an ID token is issued at the same time as a code, and you should validate it:
- Using the hash algorithm specified in the algclaim in the ID Token header, hash the octets of the ASCII representation of thecode.
- Base64url-encode the left-most half of the hash.
- Check that the result matches the c_hashvalue.
Request tokens
Now that you have an Authorization Code, you must exchange it for tokens. Using the extracted Authorization Code (code) from the previous step, you will need to POST to the token URL.
The  you receive in this step is the one you should use to call your API. Make sure you keep it separate from the Access Token you received in the previous step of this tutorial.
Example POST to token URL
Parameters
| Parameter Name | Description | 
|---|---|
| grant_type | Set this to authorization_code. | 
| code | The authorization_coderetrieved in the previous step of this tutorial. | 
| client_id | Your application’s Client ID. You can find this value in your Application Settings. | 
| client_secret | Your application’s Client Secret. You can find this value in your Application Settings. To learn more about available application authentication methods, read Application Credentials. | 
| redirect_uri | The valid callback URL set in your Application settings. This must exactly match the redirect_uripassed to the authorization URL in the previous step of this tutorial. Note that this must be URL encoded. | 
Response
If all goes well, you’ll receive anHTTP 200 response with a payload containing access_token, refresh_token, id_token, and token_type values:
Validate your tokens before saving them. To learn how, read Validate ID Tokens and Validate Access Tokens.
refresh_token will only be present in the response if you included the offline_access scope and enabled Allow Offline Access for your API in the Dashboard.
Refresh tokens must be stored securely since they allow a user to remain authenticated essentially forever.
Call API
To call your API from a regular web application (or similar cases in which the application credentials can be safely stored), the application must pass the retrieved Access Token as a Bearer token in the Authorization header of your HTTP request.Refresh tokens
You have already received a refresh token if you’ve been following this tutorial and completed the following:- configured your API to allow offline access
- included the offline_accessscope when you initiated the authentication request through the authorize endpoint.
POST request to the /oauth/token endpoint in the Authentication API, using grant_type=refresh_token.
Example POST to token URL
Parameters
| Parameter Name | Description | 
|---|---|
| grant_type | Set this to refresh_token. | 
| client_id | Your application’s Client ID. You can find this value in your Application Settings. | 
| refresh_token | The refresh token to use. | 
| scope | (optional) A space-delimited list of requested scope permissions. If not sent, the original scopes will be used; otherwise you can request a reduced set of scopes. Note that this must be URL encoded. | 
Response
If all goes well, you’ll receive anHTTP 200 response with a payload containing a new access_token, its lifetime in seconds (expires_in), granted scope values, and token_type. If the scope of the initial token included openid, then the response will also include a new id_token:
Validate your tokens before saving them. To learn how, read Validate ID Tokens and Validate Access Tokens.
Sample use cases
Customize tokens
You can use rules to change the returned scopes of Access Tokens and/or add claims to Access and ID Tokens. (To learn more about rules, read Auth0 Rules.) To do so, add the following rule, which will run after the user authenticates:Auth0 returns profile information in a structured claim format as defined by the OpenID Connect (OIDC) specification. This means that custom claims added to ID tokens or access tokens must conform to guidelines and restrictions to avoid possible collisions.