Project to test integration between Auth0 and NestJS framework, also having a frontend to test roles and permissions.
- Auth0 register and login
- Auth0 RBAC
- Notes C.R.U.D
- Admin support
To run this project, you will need to add the following environment variables to your .env file
Name |
Description |
AUTH0_DOMAIN |
Go to manage.auth0.com > Applications > APIs > Select your previously created API > Quick Start > Select Node.js tab. Should look something like this: |
|
data:image/s3,"s3://crabby-images/6f345/6f34540960c9a374b9433dd949c458fd38734828" alt="Auth0 Domain" |
AUTH0_AUDIENCE |
Go to manage.auth0.com > Applications > APIs > Select your previously created API > Settings. Should look something like this: |
|
data:image/s3,"s3://crabby-images/a5de2/a5de2d1d22aa003845f559a3a130ad6433029f38" alt="Auth0 Audience" |
REACT_APP_AUTH0_DOMAIN |
Same as AUTH0_DOMAIN |
REACT_APP_AUTH0_AUDIENCE |
Same as AUTH0_AUDIENCE |
REACT_APP_AUTH0_CLIENT_ID |
Go to manage.auth0.com > Applications > Applications > Select your previously created SPA application > Settings. Should look something like this: |
|
data:image/s3,"s3://crabby-images/54a5d/54a5d059ad35c528f23c00d21137625b5a525e71" alt="Auth0 React Audience" |
-
I start from the premise that you have already created an Auth0 account, an API and also a SPA application (from Auth0 dashboard).
-
Add some roles and permissions to your Auth0 API:
Roles |
Permissions |
data:image/s3,"s3://crabby-images/58fb9/58fb94814be29e60effc2fd1a6cf3168b088fea4" alt="Auth0 Roles" |
data:image/s3,"s3://crabby-images/9db28/9db28d54364495d9605631cdeafa957a2f241bfa" alt="Auth0 Permissions" |
-
Install:
-
Clone the project:
git clone https://github.com/AloisCRR/nestjs-auth0-integration.git
-
Go to the project directory:
cd nestjs-auth0-integration
-
Install dependencies:
-
Start NestJS and React dev servers by running:
Headers |
Type |
Description |
Authentication |
Bearer token |
Required. Access token given by Auth0 |
Body |
Type |
Description |
title |
string |
Required. Note title |
note |
string |
Required. Note content |
Response |
Type |
Description |
Note |
Note |
Created note |
Headers |
Type |
Description |
Authentication |
Bearer token |
Required. Access token given by Auth0 |
Response |
Type |
Description |
Notes |
Note[] |
Private notes of some user |
Parameter |
Type |
Description |
id |
string |
Required. Note ID |
Headers |
Type |
Description |
Authentication |
Bearer token |
Required. Access token given by Auth0 |
Response |
Type |
Description |
Note |
Note |
Updated note |
Parameter |
Type |
Description |
id |
string |
Required. Note ID |
Headers |
Type |
Description |
Authentication |
Bearer token |
Required. Access token given by Auth0 |
Response |
Type |
Description |
Note |
Note |
Note of user by it's ID |
Parameter |
Type |
Description |
id |
string |
Required. Note ID |
Headers |
Type |
Description |
Authentication |
Bearer token |
Required. Access token given by Auth0 |
data:image/s3,"s3://crabby-images/ebd0d/ebd0dcc60e7b5d11061726b3280d6a3b52fb4aa3" alt="Admin view"
Name |
Description |
Auth0 |
Flexible, drop-in solution to add authentication and authorization services to your applications. |
React |
Frontend |
NestJS |
Progressive Node.js framework for building efficient, reliable and scalable server-side applications |
-
To add new packages run:
npm run add -- [app|api] somepackage