data:image/s3,"s3://crabby-images/9fc86/9fc86ba8110569c612246361e9694bf1614d94ab" alt="Build Status"
Note: use at your own risk, this project is on early stages. The api is changing a lot.
Express.js middleware for OpenID Relying Party (aka OAuth 2.0 Client).
The purpose of this middleware is to give a tool to our customers to easily add authentication to their applications, the goals for this project are:
- Secure by default:
- The middleware implements the best practices to work with OpenID Connect providers.
- All routes after the middleware require authentication by default.
- Simple setup: Pain-free configuration by using OpenID Connect metadata and the best defaults.
- Standard: The library is standard enough to work with many OpenID Connect providers.
Install
npm i express-openid-connect --save
Requirements
Before installing the routes,
Usage
Using the auth middleware:
const { auth } = require('express-openid-connect');
app.use(auth())
app.use('/', (req, res) => {
res.send(`hello ${req.openid.user.name}`);
});
- Every route after the
auth()
requires authentication. - If a user try to access a resource without being authenticated, the application will trigger the authentication process. After completion the user is redirected back to the resource.
- The application also gets a
GET /login
and GET /logout
route for easy linking.
This application needs the following environment variables to work:
ISSUER_BASE_URL
: The url of the issuer.CLIENT_ID
: The client id of the application.BASE_URL
: The url of your application. For development environments you can omit this.
For more examples check the EXAMPLES document.
The auth()
middleware can be customized, please check the API document.
License
This project is licensed under the MIT license. See the LICENSE file for more info.