The Auth0 PHP SDK is a straightforward and rigorously-tested library for accessing Auth0's Authentication and Management API endpoints using modern PHP releases. Auth0 enables you to quickly integrate authentication and authorization into your applications so that you can focus on your core business. Learn more.
- Auth0 PHP SDK
- Requirements
- Usage
- Documentation
- Contributing
- Support + Feedback
- Vulnerability Reporting
- What is Auth0?
- License
- PHP 7.4 or 8.0
- Composer
- A PSR-17 HTTP factory library. (↗ Find libraries)
- A PSR-18 HTTP client library. (↗ Find libraries)
- A PSR-6 caching library is strongly recommended for performance reasons. (↗ Find libraries)
⚠️ PHP 7.3 is supported on the SDK 7.0 branch through December 2021. This README.md is relevant for the SDK 8.0 branch. Please review the README.md within the 7.0 branch for guidance on that version.
⚠️ This library follows the PHP release support schedule. We do not support PHP releases after they reach end-of-life. As Composer handles these deprecations safely, this is not considered a breaking change and we may drop version support with minor library releases. Please ensure you are always running the latest PHP version to keep your application up to date with PHP's security fixes, and continue to receive our latest library updates.
To get started, you'll need to create a free Auth0 account and register an Application.
The supported method of SDK installation is through Composer. From your terminal shell, cd
into your project directory and issue the following command:
$ composer require auth0/auth0-php:8.0.0-BETA3
You can find guidance on installing Composer here.
⚠️ Your application must include the Composer autoloader, as explained here, for the SDK to be usable within your application.
If you receive a warning regarding 'minimum-stability', you may need to update your composer.json
file to include the following options, and then retry the require
command above:
"minimum-stability": "beta",
"prefer-stable": true
Next, you will want ensure your application has PSR-17 and PSR-18 compatible libraries installed. These are used for network requests. As an example, let's say you wish to use Buzz and Nylom's PSR-7 implementation, which include PSR-18 and PSR-17 factories, respectively:
$ composer require kriswallsmith/buzz nyholm/psr7
The libraries specified above are simply examples. Any libraries that support the PSR-18 and PSR-17 standards will work.
↗ Guzzle 7 natively supports PSR-18.
↗ Guzzle 6 is compatible with an adaptor library.
↗ Symfony's HttpClient component natively supports PSR-18.
↗ Learn about other compatible libraries from PHP-HTTP.
↗ Search packagist for other PSR-17 HTTP factory libraries.
↗ Search packagist for other PSR-18 HTTP client libraries.
Begin by instantiating the SDK and passing the appropriate configuration options. Depending on your use case, you may need to configure more options during instantiation.
<?php
use Auth0\SDK\Auth0;
use Auth0\SDK\Configuration\SdkConfiguration;
use Auth0\SDK\Utility\HttpResponse;
$configuration = new SdkConfiguration(
// The values below are found in the Auth0 dashboard, under application settings:
domain: '{{YOUR_TENANT}}.auth0.com',
clientId: '{{YOUR_APPLICATION_CLIENT_ID}}'
);
$auth0 = new Auth0($configuration);
⚠️ You should never hard-code tokens or other sensitive configuration data in a real-world application. Consider using environment variables to store and pass these values to your application.
During configuration, you should pass instances of the PSR-18 and PSR-17 libraries your application is using:
<?php
use Auth0\SDK\Auth0;
use Auth0\SDK\Configuration\SdkConfiguration;
use Auth0\SDK\Utility\HttpResponse;
use Buzz\Client\MultiCurl;
use Nyholm\Psr7\Factory\Psr17Factory;
// PSR-17 HTTP Factory (creates http requests and responses)
$Psr17Library = new Psr17Factory();
// PSR-18 HTTP Client (delivers http requests created by the PSR-17 factory above)
$Psr18Library = new MultiCurl($Psr17Library);
// Configure the Sdk using these libraries
$configuration = new SdkConfiguration(
// 🧩 Other configuration options, such as those demonstrated above, here.
// An instance of your PSR-18 HTTP Client library:
httpClient: $Psr18Library,
// Instances of your PSR-17 HTTP Client library:
httpRequestFactory: $Psr17Library,
httpResponseFactory: $Psr17Library,
httpStreamFactory: $Psr17Library,
);
$auth0 = new Auth0($configuration);
As mentioned in the installation step, these are just examples: any PSR-18 or PSR-17 compatible libraries you choose to use in your application will be compatible here.
When configuring the SDK, you can instantiate SdkConfiguration
and pass options as named arguments in PHP 8 (strongly recommended) or as an array. The SDK Initialization step above uses named arguments. Another method of configuring the SDK is passing an array of key-values matching the argument names and values of the matching allowed types. For example:
<?php
use Auth0\SDK\Auth0;
use Auth0\SDK\Utility\HttpResponse;
$auth0 = new Auth0([
'domain' => '{{YOUR_TENANT}}.auth0.com',
'clientId' => '{{YOUR_APPLICATION_CLIENT_ID}}',
'clientSecret' => '{{YOUR_APPLICATION_CLIENT_SECRET}}',
]);
⚠️ You should never hard-code tokens or other sensitive configuration data in a real-world application. Consider using environment variables to store and pass these values to your application.
This method is discouraged because you lose out on type hinting but is helpful in PHP 7.4, where named arguments are not supported.
The following options are available for your configuration:
Option Name | Allowed Types | Required | Default | Description |
---|---|---|---|---|
strategy |
string |
webapp |
The type of application you are integrating the SDK for: api (for API-only uses, like authorizing endpoints), management (for uses where only the Management API endpoints will be used), or webapp (general use of all features) are allowed. The strategy determines what types of configuration options will be required at initialization. See the required column of this table to decide what configuration options you should be passing at initialization for your use case. |
|
domain |
string ,null |
api , webapp |
null |
Your Auth0 tenant domain, found in your Auth0 Application settings. |
customDomain |
string ,null |
null |
If you have configured Auth0 to use a custom domain, you should also configure it here. | |
clientId |
string ,null |
management , webapp |
null |
Client ID, found in the Auth0 Application settings. |
clientSecret |
string ,null |
webapp |
null |
Client Secret, found in the Auth0 Application settings. |
audience |
array<string> ,null |
api |
null |
One or more API identifiers, found in your Auth0 API settings. The SDK uses the first value for building links. If provided, at least one of these values must match the 'aud' claim to validate an ID Token successfully. When no audiene is specified, the clientId will be used to verify aud claims. |
redirectUri |
string ,null |
null |
Authentication callback URI, as defined in your Auth0 Application settings. | |
organization |
array<string> ,null |
null |
One or more Organization IDs, found in your Auth0 Organization settings. The SDK uses the first value for building links. If provided, at least one of these values must match the 'org_id' claim to validate an ID Token successfully. | |
usePkce |
bool |
true |
Use PKCE (Proof Key of Code Exchange) with Authorization Code Flow requests. | |
scope |
array<string> |
['openid', 'profile', 'email'] |
One or more scopes to request for Tokens. Learn more. | |
responseMode |
string |
query |
Where to extract request parameters from, either 'query' for GET or 'form_post' for POST requests. | |
responseType |
string |
code |
Use 'code' for server-side flows and 'token' for application side flow. | |
tokenAlgorithm |
string |
RS256 |
Algorithm to use for Token verification. Expects either 'RS256' or 'HS256'. | |
tokenJwksUri |
string ,null |
null |
URI to the JWKS when verifying RS256 tokens. | |
tokenMaxAge |
int ,null |
null |
The maximum window of time (in seconds) since the 'auth_time' to accept during Token validation. | |
tokenLeeway |
int ,null |
60 |
Leeway (in seconds) to allow during time calculations with Token validation. | |
tokenCache |
CacheItemPoolInterface ,null |
null |
A PSR-6 compatible cache adapter for storing JSON Web Key Sets (JWKS). | |
tokenCacheTtl |
int |
60 |
How long (in seconds) to keep a JWKS cached. | |
httpClient |
ClientInterface ,null |
null |
A PSR-18 compatible HTTP client to use for API requests. | |
httpMaxRetires |
int |
3 |
The number of times the SDK should retry an API request when you encounter rate-limits (429 status headers.) Maximum is 10. | |
httpRequestFactory |
RequestFactoryInterface ,null |
null |
A PSR-17 compatible request factory to generate HTTP requests. | |
httpResponseFactory |
ResponseFactoryInterface ,null |
null |
A PSR-17 compatible response factory to generate HTTP responses. | |
httpStreamFactory |
StreamFactoryInterface ,null |
null |
A PSR-17 compatible stream factory to create request body streams. | |
httpTelemetry |
bool |
true |
If true, API requests will include telemetry about the SDK and PHP runtime version to help us improve our services. | |
sessionStorage |
StoreInterface ,null |
null |
A StoreInterface-compatible class for storing Token state. null will cause the SDK to use PHP native sessions. |
|
cookieSecret |
string ,null |
null |
The secret used to derive an encryption key for the user identity in a session cookie and to sign the transient cookies used by the login callback. | |
cookieDomain |
string ,null |
null |
Defaults to value of HTTP_HOST server environment information. Cookie domain, for example 'www.example.com', for use with PHP sessions and SDK cookies. To make cookies visible on all subdomains then the domain must be prefixed with a dot like '.example.com'. | |
cookieExpires |
int |
0 |
How long, in seconds, before cookies expire. If set to 0 the cookie will expire at the end of the session (when the browser closes). | |
cookiePath |
string |
/ |
Specifies path on the domain where the cookies will work. Use a single slash ('/') for all paths on the domain. | |
cookieSecure |
bool |
false |
Specifies whether cookies should ONLY be sent over secure connections. | |
persistUser |
bool |
true |
If true, the user data will persist in session storage. | |
persistIdToken |
bool |
true |
If true, the Id Token will persist in session storage. | |
persistAccessToken |
bool |
true |
If true, the Access Token will persist in session storage. | |
persistRefreshToken |
bool |
true |
If true, the Refresh Token will persist in session storage. | |
transientStorage |
StoreInterface ,null |
null |
A StoreInterface-compatible class for storing ephemeral state data, such as a nonce. | |
queryUserInfo |
bool |
false |
If true, always query the /userinfo endpoint during an authorization code exchange. | |
managementToken |
string ,null |
null |
An Access Token to use for Management API calls. If there isn't one specified, the SDK will attempt to get one for you using your configured clientSecret . |
|
managementTokenCache |
CacheItemPoolInterface ,null |
null |
A PSR-6 compatible cache adapter for storing management access tokens. | |
eventListenerProvider |
ListenerProviderInterface ,null |
null |
A PSR-14 compatible event listener for hooking into SDK events. |
↗ Learn more about PSR-6 caches.
↗ Learn more about PSR-14 Event Dispatchers.
↗ Learn more about PSR-17 HTTP Factories, which are used to create PSR-7 HTTP messages.
↗ Learn more about the PSR-18 HTTP Client standard.
↗ Find PSR-6 cache libraries on Packagist.
↗ Find PSR-17 HTTP factory libraries on Packagist.
↗ Find PSR-18 HTTP client libraries on Packagist.
<?php
// 🧩 Include the configuration code from the 'SDK Initialization' step above here.
// Auth0::getCredentials() returns either null if no session is active, or an object.
$session = $auth0->getCredentials();
if ($session !== null) {
// The Id Token for the user as a string.
$idToken = $session->idToken;
// The Access Token for the user, as a string.
$accessToken = $session->accessToken;
// A Unix timestamp representing when the Access Token is expected to expire, as an int.
$accessTokenExpiration = $session->accessTokenExpiration;
// A bool; if time() is greater than the value of $accessTokenExpiration, this will be true.
$accessTokenExpired = $session->accessTokenExpired;
// A Refresh Token, if available, as a string.
$refreshToken = $session->refreshToken;
// Data about the user as an array.
$user = $session->user;
}
<?php
// 🧩 Include the configuration code from the 'SDK Initialization' step above here.
$session = $auth0->getCredentials();
// Is this end-user already signed in?
if ($session === null) {
// They are not. Redirect the end user to the login page.
header('Location: ' . $auth0->login());
exit;
}
When signing out an end-user from your application, it's important to use Auth0's /logout endpoint to sign them out properly:
<?php
// 🧩 Include the configuration code from the 'SDK Initialization' step above here.
$session = $auth0->getCredentials();
if ($session) {
// Clear the end-user's session, and redirect them to the Auth0 /logout endpoint.
header('Location: ' . $auth0->logout());
exit;
}
Your application must request the offline_access
scope to retrieve the Refresh Token necessary for this.
<?php
/*
🧩 Include the configuration code from the 'SDK Initialization' step above here.
⚠️ Add the 'offline_access' scope during configuration to retrieve Refresh Tokens.
*/
$session = $auth0->getCredentials();
// Is this end-user already signed in?
if ($session === null) {
// They are not. Redirect the end user to the login page.
header('Location: ' . $auth0->login());
exit;
}
// Is this end-user already signed in? If so, is their session expired?
if ($session->accessTokenExpired) {
try {
// Token has expired, attempt to renew it.
$auth0->renew();
} catch (StateException $e) {
// There was an error trying to renew the token. Clear the session.
$auth0->clear();
// Prompt to login again.
header('Location: ' . $auth0->login());
exit;
}
}
In instances where you need to manually decode an Id Token, such as a custom API service you've built, you can use the Auth0::decode()
method:
<?php
// 🧩 Include the configuration code from the 'SDK Initialization' step above here.
try {
$token = $auth0->decode('{{YOUR_ID_TOKEN}}');
} catch (\Auth0\SDK\Exception\InvalidTokenException $exception) {
die("Unable to decode Id Token; " . $exception->getMessage());
}
More advanced applications can access the SDK's full suite of authentication API functions using the Auth0\SDK\API\Authentication
class:
<?php
// 🧩 Include the configuration code from the 'SDK Initialization' step above here.
// Get a configured instance of the Auth0\SDK\API\Authentication class:
$authentication = $auth0->authentication();
// Start a passwordless login:
$auth0->emailPasswordlessStart(/* ...configuration */);
Alternatively, the SDK supports a fluent interface for more concise calls:
<?php
// 🧩 Include the configuration code from the 'SDK Initialization' step above here.
// Start a passwordless login:
$authentication = $auth0->authentication()->emailPasswordlessStart(/* ...configuration */);
This SDK offers an interface for Auth0's Management API, which, to access, requires an Access Token that is explicitly issued for your tenant's Management API by specifying the corresponding Audience.
<?php
use Auth0\SDK\Auth0;
use Auth0\SDK\Configuration\SdkConfiguration;
use Auth0\SDK\Utility\HttpResponse;
$configuration = new SdkConfiguration(
// 🧩 Include other required configuration options, such as outlined in the 'SDK Initialization' step above here.
// The process for retrieving an Access Token for Management API endpoints is described here:
// https://auth0.com/docs/libraries/auth0-php/using-the-management-api-with-auth0-php
managementToken: '{{YOUR_ACCESS_TOKEN}}'
);
$auth0 = new Auth0($configuration);
⚠️ You should never hard-code tokens or other sensitive configuration data in a real-world application. Consider using environment variables to store and pass these values to your application.
Once configured, use the Auth0::management()
method to get a configured instance of the Auth0\SDK\API\Management
class:
<?php
// 🧩 Include the configuration code from the above example here.
// Get a configured instance of the Auth0\SDK\API\Management class:
$management = $auth0->management();
// Request users from the /users Management API endpoint
$response = $management->users()->getAll();
// Was the API request successful?
if (HttpResponse::wasSuccessful($response)) {
// It was, decode the JSON into a PHP array:
$response = HttpResponse::decodeContent($response);
print_r($response);
}
Alternatively, the SDK supports a fluent interface for more concise calls:
<?php
// 🧩 Include the configuration code from the above example here.
// Request users from the /users Management API endpoint
$management = $auth0->management()->users()->getAll();
// Was the API request successful?
if (HttpResponse::wasSuccessful($response)) {
// It was, decode the JSON into a PHP array:
$response = HttpResponse::decodeContent($response);
print_r($response);
}
Organizations is a set of features that provide better support for developers who build and maintain SaaS and Business-to-Business (B2B) applications. Organizations are currently only available to customers on our Enterprise and Startup subscription plans.
Configure the SDK with your Organization ID:
<?php
use Auth0\SDK\Auth0;
use Auth0\SDK\Configuration\SdkConfiguration;
use Auth0\SDK\Utility\HttpResponse;
$configuration = new SdkConfiguration(
// 🧩 Include other required configuration options, such as outlined in the 'SDK Initialization' step above here.
// Found in your Auth0 dashboard, under your organization settings.
// Note that this must be configured as an array.
organization: [ '{{YOUR_ORGANIZATION_ID}}' ]
);
$auth0 = new Auth0($configuration);
⚠️ You should never hard-code tokens or other sensitive configuration data in a real-world application. Consider using environment variables to store and pass these values to your application.
With the SDK initialized using your Organization Id, you can use the Auth0::login()
method as you normally would. Methods throughout the SDK will use the Organization Id you configured in their API calls.
<?php
// 🧩 Include the configuration code from the 'Initializing the SDK with Organizations' step above here.
$session = $auth0->getCredentials();
// Is this end-user already signed in?
if ($session === null) {
// They are not. Redirect the end user to the login page.
header('Location: ' . $auth0->login());
exit;
}
Auth0 Organizations allow users to be invited using emailed links, which will direct a user back to your application. The user will be sent to your application URL based on your configured Application Login URI
, which you can change from your application's settings inside the Auth0 dashboard.
When the user arrives at your application using an invite link, three query parameters are available: invitation
, organization
, and organization_name.
These will always be delivered using a GET request.
A helper function is provided to handle extracting these query parameters and automatically redirecting to the Universal Login page:
<?php
// 🧩 Include the configuration code from the 'Initializing the SDK with Organizations' step above here.
$auth0->handleInvitation();
Suppose you prefer to have more control over this process. In that case, extract the relevant query parameters using getInvitationParameters()
, and then initiate the Universal Login redirect yourself:
<?php
// 🧩 Include the configuration code from the 'Initializing the SDK with Organizations' step above here.
// Returns an object containing the invitation query parameters, or null if they aren't present
if ($invite = $auth0->getInvitationParameters()) {
// Does the invite organization match one of your configured organizations?
if (in_array($invite->organization, $configuration->getOrganization()) === false) {
// It does not. Throw an error; for example:
throw new Exception("This invitation isn't intended for this service. Please have your administrator check the service configuration and request a new invitation.");
}
// Redirect to Universal Login using the emailed invitation code and Organization Id
header('Location: ' . $auth0->login(null, [
'invitation' => $invite->invitation,
'organization' => $invite->organization,
]));
}
After successful authentication via the Universal Login Page, the user will arrive back at your application using your configured redirect_uri
, their token will be validated, and they will have an authenticated session. Use Auth0::getCredentials()
to retrieve details about the authenticated user.
In the examples above, our application is operating with a single, configured Organization. By initializing the SDK with the organization
argument, we tell the internal token verifier to validate an org_id
claim's presence and match what was provided.
In some cases, your application may need to support validating tokens' org_id
claims for several different organizations. When initializing the SDK, the organization
argument accepts an array of organizations; during token validation, if ANY of those Organization Ids match, the token passes validation. When generating links or issuing API calls, the first Organization Id in that configuration array will be used. You can alter this value at any time by updating your instance of the SdkConfiguration
or passing custom parameters to methods that use Organization Ids.
⚠️ If you have a more complex application with custom token validation code, you must validate theorg_id
claim on tokens to ensure the value received is expected and known by your application. If the claim is not valid, your application should reject the token. See https://auth0.com/docs/organizations/using-tokens for more information.
- Documentation
- Quickstarts
We appreciate your feedback and contributions to the project! Before you get started, please review the following:
- Auth0's general contribution guidelines
- Auth0's code of conduct guidelines
- The Auth0 PHP SDK contribution guide
- The Auth0 Community is a valuable resource for asking questions and finding answers, staffed by the Auth0 team and a community of enthusiastic developers
- For code-level support (such as feature requests and bug reports), we encourage you to open issues here on our repo
- For customers on paid plans, our support center is available for opening tickets with our knowledgeable support specialists
Further details about our support solutions are available on our website.
Please do not report security vulnerabilities on the public GitHub issue tracker. The Responsible Disclosure Program details the procedure for disclosing security issues.
Auth0 helps you to:
- Add authentication with multiple authentication sources, either social like Google, Facebook, Microsoft, LinkedIn, GitHub, Twitter, Box, Salesforce (amongst others), or enterprise identity systems like Windows Azure AD, Google Apps, Active Directory, ADFS or any SAML Identity Provider.
- Add authentication through more traditional username/password databases.
- Add support for passwordless and multi-factor authentication.
- Add support for linking different user accounts with the same user.
- Analytics of how, when, and where users are logging in.
- Pull data from other sources and add it to the user profile through JavaScript rules.
The Auth0 PHP SDK is open source software licensed under the MIT license. See the LICENSE file for more info.