2025-10-01 19:55:38 +02:00

44 lines
1.7 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var Errors_1 = require("../../../Errors");
var HTTPBasicAuthentication = /** @class */ (function () {
function HTTPBasicAuthentication(userManager, realm) {
if (realm === void 0) { realm = 'realm'; }
this.userManager = userManager;
this.realm = realm;
}
HTTPBasicAuthentication.prototype.askForAuthentication = function (ctx) {
return {
'WWW-Authenticate': 'Basic realm="' + this.realm + '"'
};
};
HTTPBasicAuthentication.prototype.getUser = function (ctx, callback) {
var _this = this;
var onError = function (error) {
_this.userManager.getDefaultUser(function (defaultUser) {
callback(error, defaultUser);
});
};
var authHeader = ctx.headers.find('Authorization');
if (!authHeader) {
onError(Errors_1.Errors.MissingAuthorisationHeader);
return;
}
if (!/^Basic \s*[a-zA-Z0-9]+=*\s*$/.test(authHeader)) {
onError(Errors_1.Errors.WrongHeaderFormat);
return;
}
var value = Buffer.from(/^Basic \s*([a-zA-Z0-9]+=*)\s*$/.exec(authHeader)[1], 'base64').toString().split(':', 2);
var username = value[0];
var password = value[1];
this.userManager.getUserByNamePassword(username, password, function (e, user) {
if (e)
onError(Errors_1.Errors.BadAuthentication);
else
callback(null, user);
});
};
return HTTPBasicAuthentication;
}());
exports.HTTPBasicAuthentication = HTTPBasicAuthentication;