Auth0
This guide serves as a configuration lab that provides the ID.me customers with the steps to configure ID.me on the Auth0 platform. This guide will provide an overview of:
- How to obtain an Auth0 tenant
- How to configure ID.me as an Social Login within Auth0
- Specific nuances within the Auth0 Platform
Step 1: Create an Auth0 Developer Account
Navigate to Auth0 and Sign Up
data:image/s3,"s3://crabby-images/100ec/100ec305d7f26616228998c8d2ca69813425388e" alt=""
Enter your Email and Password
Select and enter Company name
Click Next and wait for your tenant to be created
Step 2: Configure your ID.me Identity Social Login
Navigate to Authentication -> Social
data:image/s3,"s3://crabby-images/69a1c/69a1cca455f2fdf66fcf0d356f2552cbaef3dc8b" alt=""
Select Creation Connection
data:image/s3,"s3://crabby-images/c5f72/c5f72806807b5d9a85e3e80a56b4a51056542090" alt=""
Enter ID.me in the Search
Select ID.me (Identity) and select Continue
data:image/s3,"s3://crabby-images/57d67/57d67baa545ba0906c7162f8e14ecb4e6008aab5" alt=""
Enter your own ID.me Client ID & Client Secret
data:image/s3,"s3://crabby-images/abb00/abb00d676af364a51aa26e4a856373dc65738df4" alt=""
Select OpenID & the Identity Policy you want to test with
Select Create
We will assign this Policy to an Auth0 Application at a later step
Step 3: Configure your ID.me Community Social Login
Navigate to Authentication -> Social
data:image/s3,"s3://crabby-images/69a1c/69a1cca455f2fdf66fcf0d356f2552cbaef3dc8b" alt=""
Select Creation Connection
data:image/s3,"s3://crabby-images/c5f72/c5f72806807b5d9a85e3e80a56b4a51056542090" alt=""
Enter ID.me in the Search
Select ID.me (Community) and select Continue
data:image/s3,"s3://crabby-images/57d67/57d67baa545ba0906c7162f8e14ecb4e6008aab5" alt=""
Enter your own ID.me Production Client ID & Client Secret
data:image/s3,"s3://crabby-images/abb00/abb00d676af364a51aa26e4a856373dc65738df4" alt=""
Select OpenID & the Identity Policy you want to test with
data:image/s3,"s3://crabby-images/9742c/9742c2e00c58aeb7e4aaff37b881ecedd618d5d3" alt=""
Select Create
We will assign this Policy to an Auth0 Application at a later step
Step 4: Configure an Auth0 Application
Navigate to Applications -> Applications
data:image/s3,"s3://crabby-images/679de/679de1e914b9d7050ce6bfd8a5bbc5be23b983e3" alt=""
Select Create Application
data:image/s3,"s3://crabby-images/84d93/84d930b811a1ca9b2725a73e2923547bfc8b1a1f" alt=""
Select Regular Web applications
Click Create
data:image/s3,"s3://crabby-images/a19a1/a19a103f8d9374fbd59e6546f44f8925a895c6b1" alt=""
Select Next.js
data:image/s3,"s3://crabby-images/189d5/189d52377adab475f088cdf6f01d303bd632e5d6" alt=""
Select Download Sample
Take note of the steps here, we will need to configure our ID.me accounts with the Redirect URI provided in this step. We will also need to insall Node.JS LTS using the steps provided.
data:image/s3,"s3://crabby-images/438b3/438b3867a1123ac6daf5a918388242ca3dd28175" alt=""
Select Download
data:image/s3,"s3://crabby-images/50463/504634848247202cba02f9467cfc05693f388cbf" alt=""
Navigate to the Settings tab
data:image/s3,"s3://crabby-images/eb8ba/eb8ba609c2a89ac9d155b11f1707eceedde3aa26" alt=""
Enter the Callback URL
Under Allowed Callback URLs, enter the Callback URL that was displayed in the previous step
data:image/s3,"s3://crabby-images/9d26b/9d26b5cc6e13a2e000be10bb7ca62e30548a8a02" alt=""
Add http://localhost:3000/ under Allowed Logout URLs
Under Allowed Callback URLs, enter the Callback URL that was displayed in the previous step
data:image/s3,"s3://crabby-images/173f5/173f56b35e847d6b0cf94560dbe5c16c6bcff4f2" alt=""
Select Save Changes
Extract the downloaded nextjs-01-login directory
data:image/s3,"s3://crabby-images/c0ece/c0ece321a3ac68974e512da35d7bca9c2c898f32" alt=""
Open nextjs-01-login directory in your favorite IDE
data:image/s3,"s3://crabby-images/59f43/59f43279707884b86112d894447c4d06289371fc" alt=""
Within the nextjs-01-login directory, select sample-01 directory
data:image/s3,"s3://crabby-images/a0c7d/a0c7d06fd58f8128c9915e9681f598240a69a678" alt=""
Open your Terminal
Ensure Node.js is installed: https://nodejs.org/en/download
Navigate to sample-01 directory and install dependencies
In Terminal, run npm install
data:image/s3,"s3://crabby-images/a0c7d/a0c7d06fd58f8128c9915e9681f598240a69a678" alt=""
Successful install dependencies
data:image/s3,"s3://crabby-images/6f703/6f7036c8fc65d4bf91eaeeb919c1244c95a8953c" alt=""
Start your application
In Terminal, run npm start
data:image/s3,"s3://crabby-images/19b5d/19b5dc6f65126d4bfa7d13b1209529f3bd22bd76" alt=""
Run your application locally
In Terminal, run npm run dev
data:image/s3,"s3://crabby-images/373ab/373abd741da5331af808559798829488cac51aef" alt=""
Open a browser tab and navigate to: http://localhost:3000
Select Log In
You should see the Auth0 Email / Password page appear
data:image/s3,"s3://crabby-images/cbc82/cbc82f540cdb4d1dd1b3d511b3d834e6b587816e" alt=""
Auth0 Email / Password page should appear
data:image/s3,"s3://crabby-images/7232b/7232b4ef8c2310e97c1a466ccc5ee5721cd3dc64" alt=""
On the Auth0 Developer Portal, navigate to Authentication -> Social
We now have to assign the Social Login to the application
Select your ID.me Identity Social Login
data:image/s3,"s3://crabby-images/19fe4/19fe4cc80acc190f49fe7c5207f5e2ca45511a87" alt=""
Navigate to Applications
data:image/s3,"s3://crabby-images/2c611/2c611bd6dec3e99b15fef5cddcb68ded1284f5fd" alt=""
Turn on the Social Login for your new Application
data:image/s3,"s3://crabby-images/2d546/2d54635556305d38aa2a3e342fb822138af9c186" alt=""
Repeat the same steps for the Community Verification Social Login
Step 5: Test Auth0 <> ID.me Social Login
Navigate back to the Auth0 Login Page
Refresh the Page, you should see the ID.me Social Login options
data:image/s3,"s3://crabby-images/8b065/8b0652ded4f6751c4108a05ac88d61a90c73d813" alt=""
Click Continue with ID.me (Community)
If you received a Redirect URI error, make sure to add the Redirect URI to admin!
Sign into your ID.me account
Select Accept to authorize app
data:image/s3,"s3://crabby-images/4eadd/4eadd7eaf55d9ecae32022cd61f267e9b39359d9" alt=""
You should be redirected to localhost and logged in
data:image/s3,"s3://crabby-images/fdc2b/fdc2b5dd848247f0fddeea50974426d702ace514" alt=""
On the Auth0 Developer Portal, navigate to User Management -> Users
data:image/s3,"s3://crabby-images/42aa7/42aa7ab0ee259c2744b056c96ac39664612825fe" alt=""
Select your new user
Scroll down and notice the ID.me mapped attributes tied to the account such as group, uuid, etc.
data:image/s3,"s3://crabby-images/bd499/bd49927757c3f5e4ca7661f8dc07d6f6ae393e24" alt=""
Useful Links
Authentication & Identity Verification
Enables organizations to easily define pre-configured identity verification policies to verify users’ identities at the exact level of trust required to access a requested service. No more, no less. ID.me’s solution orchestrates multiple verification methods at each level of trust to ensure that all of your users are able to easily and securely prove their identity online.
Community Verification
Offers a comprehensive and easy-to-deploy progressive community verification solution to fit your business needs and risk tolerance. Through this integration, you can successfully verify a user's eligibility for the following groups: Military, Students, Teachers, First Responders, Health Care Providers, Company Employees, Government Employees, Alumni, and more; to offer gated access or discounts to your customers.
Post Login Action
The post-login integration is for both identity proofing and community verification. This can be configured within your existing Auth0 flows to trigger verification appropriate to your use cases.