Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gwenaelp/express-user-management
A ready-to-use library for authentication and user management with express.
https://github.com/gwenaelp/express-user-management
account-management auth authentication express jwt jwt-authentication jwt-token mongodb
Last synced: 2 months ago
JSON representation
A ready-to-use library for authentication and user management with express.
- Host: GitHub
- URL: https://github.com/gwenaelp/express-user-management
- Owner: gwenaelp
- Created: 2019-04-17T05:48:46.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-11-11T14:46:20.000Z (about 1 year ago)
- Last Synced: 2023-11-11T15:34:44.001Z (about 1 year ago)
- Topics: account-management, auth, authentication, express, jwt, jwt-authentication, jwt-token, mongodb
- Language: JavaScript
- Size: 173 KB
- Stars: 7
- Watchers: 2
- Forks: 5
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
README
# express-user-management
A ready-to-use library for authentication and user management with express.
Uses mongo, passport, and jwt by default.
# What does it do?
express-user-management will automatically create API endpoints for :
- user registration
- user account activation
- user login
- password forgotten
- password change with a token for the previous route
- password change when logged in
- account deletionIt handles everything you need to handle in those routes. You can set various options to adapt it to your project.
It uses nodemailer to send mails, and you can link it easily to your mail service.
# Installation
```npm i express-user-management```
# Usage
```
const userManagement = require('express-user-management');
userManagement.init(expressApp, options);
```
# OptionsHere are the available options with their default values :
```javascript
const options = {
/* Adapter to use under the hood. */
adapter: 'passport-mongo',
/* Table in the database where users are stored */
usersTable: 'users',
/* How API key is handled */
apiKey: {
/* Table where to look at API keys */
table: 'projects',
/* Key in the document that stores the API key */
documentKey: 'apiKey.apiKey',
},
/* URL of the database */
mongoUrl: '',
/* Password reset URL. Used in mail templates below */
passwordResetAdress: 'http://localhost:30000/resetPassword',
/* Account activation URL. Used in mail templates below */
accountActivationAdress: 'http://localhost:30000/activate',
nodeMailerConfig: undefined,
/* Whether or not you need to handle account activation on your project */
activationRequired: true,
/* Mail templates. See dedicated section in the readme for more info */
mails: {
activation: {
subject: 'Activate your account!',
sender: '[email protected]',
body: `Almost done!
Please click this link to activate your account!{{accountActivationAdress}}/activate/{{user.activation.code.apiKey}}`,
},
passwordReset: {
subject: 'Password reset link',
sender: '[email protected]',
body: `You are receiving this because you (or someone else) have requested the reset of the password for your account.
Please click on the following link, or paste this into your browser to complete the process:
{{passwordResetAdress}}{{token}}
If you did not request this, please ignore this email and your password will remain unchanged.`,
},
}
```# Mailing
node-mailer is used to handle mailing. Simply put in the options the config object you would give to node-mailer directly.
If no configuration object is provided, mails are not being sent but the output is logged.
# Hooks
This feature is not implement yet!
In order to allow you to execute some arbitrary code when the endpoints are called, some hooks can be provided to the options.