2021-10-23 04:35:13 -04:00
|
|
|
const basicAuth = require("express-basic-auth");
|
2021-07-27 13:47:13 -04:00
|
|
|
const passwordHash = require("./password-hash");
|
|
|
|
const { R } = require("redbean-node");
|
2021-08-02 12:08:46 -04:00
|
|
|
const { setting } = require("./util-server");
|
|
|
|
const { debug } = require("../src/util");
|
2021-10-23 04:35:13 -04:00
|
|
|
const { loginRateLimiter } = require("./rate-limiter");
|
2021-07-27 12:52:31 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param username : string
|
|
|
|
* @param password : string
|
|
|
|
* @returns {Promise<Bean|null>}
|
|
|
|
*/
|
|
|
|
exports.login = async function (username, password) {
|
2022-03-29 05:38:48 -04:00
|
|
|
if (typeof username !== "string" || typeof password !== "string") {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2021-07-27 12:52:31 -04:00
|
|
|
let user = await R.findOne("user", " username = ? AND active = 1 ", [
|
2021-07-27 13:47:13 -04:00
|
|
|
username,
|
2021-10-23 04:35:13 -04:00
|
|
|
]);
|
2021-07-27 12:52:31 -04:00
|
|
|
|
|
|
|
if (user && passwordHash.verify(password, user.password)) {
|
|
|
|
// Upgrade the hash to bcrypt
|
|
|
|
if (passwordHash.needRehash(user.password)) {
|
|
|
|
await R.exec("UPDATE `user` SET password = ? WHERE id = ? ", [
|
|
|
|
passwordHash.generate(password),
|
2021-07-27 13:47:13 -04:00
|
|
|
user.id,
|
2021-07-27 12:52:31 -04:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
return user;
|
|
|
|
}
|
2021-07-27 13:47:13 -04:00
|
|
|
|
|
|
|
return null;
|
2021-10-23 04:35:13 -04:00
|
|
|
};
|
2021-07-27 12:52:31 -04:00
|
|
|
|
2021-11-10 00:24:31 -05:00
|
|
|
/**
|
|
|
|
* A function that checks if a user is logged in.
|
|
|
|
* @param {string} username The username of the user to check for.
|
|
|
|
* @param {function} callback The callback to call when done, with an error and result parameter.
|
|
|
|
*
|
|
|
|
* Generated by Trelent
|
|
|
|
*/
|
2021-07-27 12:52:31 -04:00
|
|
|
function myAuthorizer(username, password, callback) {
|
2022-03-24 06:02:34 -04:00
|
|
|
// Login Rate Limit
|
|
|
|
loginRateLimiter.pass(null, 0).then((pass) => {
|
|
|
|
if (pass) {
|
|
|
|
exports.login(username, password).then((user) => {
|
|
|
|
callback(null, user != null);
|
2021-10-23 04:35:13 -04:00
|
|
|
|
2022-03-24 06:02:34 -04:00
|
|
|
if (user == null) {
|
|
|
|
loginRateLimiter.removeTokens(1);
|
2021-10-23 04:35:13 -04:00
|
|
|
}
|
|
|
|
});
|
2022-03-24 06:02:34 -04:00
|
|
|
} else {
|
|
|
|
callback(null, false);
|
2021-10-23 04:35:13 -04:00
|
|
|
}
|
|
|
|
});
|
2021-07-27 12:52:31 -04:00
|
|
|
}
|
|
|
|
|
2022-03-24 06:02:34 -04:00
|
|
|
exports.basicAuth = async function (req, res, next) {
|
|
|
|
const middleware = basicAuth({
|
|
|
|
authorizer: myAuthorizer,
|
|
|
|
authorizeAsync: true,
|
|
|
|
challenge: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const disabledAuth = await setting("disableAuth");
|
|
|
|
|
|
|
|
if (!disabledAuth) {
|
|
|
|
middleware(req, res, next);
|
|
|
|
} else {
|
|
|
|
next();
|
|
|
|
}
|
|
|
|
};
|