Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cerbos/express-auth0-cerbos
An example application of integrating Cerbos with an Express server using Auth0 for authentication.
https://github.com/cerbos/express-auth0-cerbos
auth0 authentication authorization cerbos express nodejs passport
Last synced: about 2 months ago
JSON representation
An example application of integrating Cerbos with an Express server using Auth0 for authentication.
- Host: GitHub
- URL: https://github.com/cerbos/express-auth0-cerbos
- Owner: cerbos
- Created: 2021-09-23T13:28:42.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-09-16T04:29:42.000Z (4 months ago)
- Last Synced: 2024-09-17T05:43:53.216Z (4 months ago)
- Topics: auth0, authentication, authorization, cerbos, express, nodejs, passport
- Language: JavaScript
- Homepage: https://demo-auth0.cerbos.cloud
- Size: 197 KB
- Stars: 3
- Watchers: 2
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# express-auth0-cerbos
An example application of integrating [Cerbos](https://cerbos.dev) with an [Express](https://expressjs.com/) server using [Auth0](https://auth0.com/) for authentication.
## Dependencies
- Node.js
- Docker for running the [Cerbos Policy Decision Point (PDP)](https://docs.cerbos.dev/cerbos/0.6.0/installation/container.html)
- An Auth0 account if you want to use your own## Getting Started
1. Start up the Cerbos PDP instance docker container. This will be called by the express app to check authorization.
```bash
cd cerbos
./start.sh
```2. Install node dependencies
```bash
npm install
```3. Start the express server
```bash
node index.js
```## Auth0 Rule to add roles to token
By default any roles set up in the Auth0 console are not passed through in the authentication token. To enable this, add the following rule to the Auth Pipeline in your Auth0 account.
```js
function (user, context, callback) {
const namespace = 'https://cerbos.cloud';
const assignedRoles = (context.authorization || {}).roles;let idTokenClaims = context.idToken || {};
let accessTokenClaims = context.accessToken || {};idTokenClaims[`${namespace}/roles`] = assignedRoles;
accessTokenClaims[`${namespace}/roles`] = assignedRoles;context.idToken = idTokenClaims;
context.accessToken = accessTokenClaims;callback(null, user, context);
}
```## Policies
This example has a simple CRUD policy in place for a resource kind of `contact` - like a CRM system would have. The policy file can be found in the `cerbos/policies` folder [here](https://github.com/cerbos/express-auth0-cerbos/blob/main/cerbos/policies/contact.yaml).
Should you wish to experiment with this policy, you can try it in the Cerbos Playground.
The policy expects one of two roles to be set on the principal - `admin` and `user`. These roles are authorized as follows:
| Action | User | Admin |
| ------ | -------- | ----- |
| list | Y | Y |
| read | Y | Y |
| create | Y | Y |
| update | If owner | Y |
| delete | If owner | Y |