requires empty username/password if set disableAuth for basic auth

This commit is contained in:
LouisLam 2021-08-03 00:08:46 +08:00
parent 6f868c9ec3
commit 44c8ca9da8
2 changed files with 17 additions and 3 deletions

View file

@ -1,6 +1,8 @@
const basicAuth = require("express-basic-auth") const basicAuth = require("express-basic-auth")
const passwordHash = require("./password-hash"); const passwordHash = require("./password-hash");
const { R } = require("redbean-node"); const { R } = require("redbean-node");
const { setting } = require("./util-server");
const { debug } = require("../src/util");
/** /**
* *
@ -28,9 +30,18 @@ exports.login = async function (username, password) {
} }
function myAuthorizer(username, password, callback) { function myAuthorizer(username, password, callback) {
exports.login(username, password).then((user) => {
callback(null, user != null) setting("disableAuth").then((result) => {
if (result) {
callback(null, true)
} else {
exports.login(username, password).then((user) => {
callback(null, user != null)
})
}
}) })
} }
exports.basicAuth = basicAuth({ exports.basicAuth = basicAuth({

View file

@ -1,6 +1,7 @@
const tcpp = require("tcp-ping"); const tcpp = require("tcp-ping");
const Ping = require("./ping-lite"); const Ping = require("./ping-lite");
const { R } = require("redbean-node"); const { R } = require("redbean-node");
const { debug } = require("../src/util");
exports.tcping = function (hostname, port) { exports.tcping = function (hostname, port) {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
@ -45,7 +46,9 @@ exports.setting = async function (key) {
]); ]);
try { try {
return JSON.parse(value); const v = JSON.parse(value);
debug(`Get Setting: ${key}: ${v}`)
return v;
} catch (e) { } catch (e) {
return value; return value;
} }