mirror of
https://github.com/louislam/uptime-kuma.git
synced 2024-12-20 21:24:44 -05:00
8a92054c2b
* Added JSDoc to eslint rules Signed-off-by: Matthew Nickson <mnickson@sidingsmedia.com> * Fixed JSDoc eslint errors Signed-off-by: Matthew Nickson <mnickson@sidingsmedia.com> * Update the check-linters workflow to Node.js 20 --------- Signed-off-by: Matthew Nickson <mnickson@sidingsmedia.com> Co-authored-by: Louis Lam <louislam@users.noreply.github.com>
45 lines
1.1 KiB
JavaScript
45 lines
1.1 KiB
JavaScript
const passwordHashOld = require("password-hash");
|
|
const bcrypt = require("bcryptjs");
|
|
const saltRounds = 10;
|
|
|
|
/**
|
|
* Hash a password
|
|
* @param {string} password Password to hash
|
|
* @returns {string} Hash
|
|
*/
|
|
exports.generate = function (password) {
|
|
return bcrypt.hashSync(password, saltRounds);
|
|
};
|
|
|
|
/**
|
|
* Verify a password against a hash
|
|
* @param {string} password Password to verify
|
|
* @param {string} hash Hash to verify against
|
|
* @returns {boolean} Does the password match the hash?
|
|
*/
|
|
exports.verify = function (password, hash) {
|
|
if (isSHA1(hash)) {
|
|
return passwordHashOld.verify(password, hash);
|
|
}
|
|
|
|
return bcrypt.compareSync(password, hash);
|
|
};
|
|
|
|
/**
|
|
* Is the hash a SHA1 hash
|
|
* @param {string} hash Hash to check
|
|
* @returns {boolean} Is SHA1 hash?
|
|
*/
|
|
function isSHA1(hash) {
|
|
return (typeof hash === "string" && hash.startsWith("sha1"));
|
|
}
|
|
|
|
/**
|
|
* Does the hash need to be rehashed?
|
|
* @param {string} hash Hash to check
|
|
* @returns {boolean} Needs to be rehashed?
|
|
*/
|
|
exports.needRehash = function (hash) {
|
|
return isSHA1(hash);
|
|
};
|