Passken.js is an open source password management library for Node.js to create, encrypt and compare passwords safely.
- Only 1 dependency to check inputs variables
- Very lightweight
- Thoroughly tested
- Works in Node.js
- Can be used as CommonJS or EcmaScrypt module
- Written in Typescript
- Node.js: 16
This is the oldest targeted versions. The library should not work properly on older versions of Node.js because it uses node:crypto in order to not depend on external dependencies.
$ npm i @dwtechs/passken
Example of use with Express.js in Typescript using ES6 module format
import { compare, create } from "@dwtechs/passken";
/**
* This function checks if a user-provided password matches a stored hashed password in a database.
* It takes a request object req and a response object res as input, and uses a pass service to compare the password.
* If the password is correct, it calls the next() function to proceed with the request.
* If the password is incorrect or missing, it calls next() with an error status and message.
*/
function compare(req, res, next) {
const pwd = req.body.pwd; // from request
const hash = req.user.hash; //from db
if (compare(pwd, hash))
return next();
return next({ status: 401, msg: "Wrong password" });
}
/**
* Generates random passwords for a user and encrypts it.
*/
function createPassword(req, res, next) {
const user = req.body.user;
const pwd = create();
const encryptedPwd = pk.encrypt(pwd);
next();
}
export {
compare,
create,
};
Example of use with Express.js in Javascript using CommonJS format
const pk = require("@dwtechs/passken");
/**
* This function checks if a user-provided password matches a stored hashed password in a database.
* It takes a request object req and a response object res as input, and uses a pass service to compare the password.
* If the password is correct, it calls the next() function to proceed with the request.
* If the password is incorrect or missing, it calls next() with an error status and message.
*/
function compare(req, res, next) {
const pwd = req.body.pwd; // from request
const hash = req.user.hash; //from db
if (pk.compare(pwd, hash))
return next();
return next({ status: 401, msg: "Wrong password" });
}
/**
* Generates random passwords for a user and encrypts it.
*/
function create(req, res, next) {
const user = req.body.user;
const pwd = pk.create();
const encryptedPwd = pk.encrypt(pwd);
next();
}
module.exports = {
compare,
create,
};
type Options = {
len: number,
num: boolean,
ucase: boolean,
lcase: boolean,
sym: boolean,
strict: boolean,
exclSimilarChars: boolean,
};
// Default values
let saltRnds = 12
let digest = "sha256";
let keyLen = 64;
getSaltRounds(): number {}
setSaltRounds(rnds: number): number {} // between 12 and 100
getKeyLen(): number {}
setKeyLen(r: number): number {} // between 2 and 256
getDigest(): string {}
setDigest(d: string): string {} // the list of available digests can be given by getDigests()
getDigests(): string[] {}
encrypt(pwd: string, secret: string): string | false {}
compare(pwd: string, hash: string, secret: string): boolean {}
create(opts: Partial<Options> = defOpts): string {}
Any of these can be passed into the options object for each function.
Name | Description | Default value |
---|---|---|
len | Integer, length of password. | 12 |
num* | Boolean, put numbers in password. | true |
sym* | Boolean, put symbols in password. | true |
lcase* | Boolean, put lowercase in password | true |
ucase* | Boolean, use uppercase letters in password. | true |
exclSimilarChars | Boolean, exclude similar chars, like 'i' and 'l'. | true |
strict | Boolean, password must include at least one character from each pool. | true |
*At least one should be true.
Passken.js is still in development and we would be glad to get all the help you can provide. To contribute please read contributor.md for detailed installation guide.
Purpose | Choice | Motivation |
---|---|---|
repository | Github | hosting for software development version control using Git |
package manager | npm | default node.js package manager |
language | TypeScript | static type checking along with the latest ECMAScript features |
module bundler | Rollup.js | advanced module bundler for ES6 modules |
unit testing | Jest | delightful testing with a focus on simplicity |