@churchapps/apihelper
Version:
Library of helper functions not specific to any one ChurchApps project or framework.
38 lines • 1.97 kB
JavaScript
;
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.CustomAuthProvider = void 0;
const inversify_1 = require("inversify");
const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
const _1 = require("./");
const __1 = require("..");
let CustomAuthProvider = class CustomAuthProvider {
// public async getUser(req: express.Request, res: express.Response, next: express.NextFunction): Promise<interfaces.Principal> {
async getUser(req, _res, _next) {
const authHeader = req.headers.authorization;
if (authHeader) {
const token = authHeader.split(" ")[1];
if (!token)
return null;
const decoded = jsonwebtoken_1.default.verify(token, __1.EnvironmentBase.jwtSecret);
const result = decoded ? new _1.Principal(typeof decoded === 'object' && decoded !== null ? decoded : {}) : null;
if (result)
result.details.jwt = token;
return result;
}
return null;
}
};
exports.CustomAuthProvider = CustomAuthProvider;
exports.CustomAuthProvider = CustomAuthProvider = __decorate([
(0, inversify_1.injectable)()
], CustomAuthProvider);
//# sourceMappingURL=CustomAuthProvider.js.map