UNPKG

@churchapps/apihelper

Version:

Library of helper functions not specific to any one ChurchApps project or framework.

38 lines 1.97 kB
"use strict"; 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