UNPKG

@qelos/auth

Version:

Express Passport authentication service

133 lines (132 loc) 5.74 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const tokens_1 = require("../services/tokens"); const users_1 = require("../services/users"); const config_1 = require("../../config"); const cache_manager_1 = require("../services/cache-manager"); const req_host_1 = require("../services/req-host"); const logger_1 = __importDefault(require("../services/logger")); function oAuthVerify(req, res, next) { // get the last part from an authorization header string like "bearer token-value" const tokenHeader = req.headers.authorization || req.headers.Authorization; const token = tokenHeader.split(' ')[1]; const tenant = (req.headers.tenant = req.headers.tenant || '0'); return (0, tokens_1.verifyToken)(token, tenant) .then((payload) => setUserPayload(payload, req, next)) .catch(() => { if (token && tenant) { res.status(401).json({ message: 'authorization token is not valid.' }).end(); return; } next(); }); } function cookieVerify(req, res, next) { var _a; return __awaiter(this, void 0, void 0, function* () { // get the last part from an authorization header string like "bearer token-value" const tenant = (req.headers.tenant = req.headers.tenant || '0'); const token = (0, users_1.getCookieTokenValue)(req); if (!tenant && config_1.showLogs) { logger_1.default.log('CookieVerify requires a tenant', { url: req.url, tenanthost: req.headers.tenanthost, }); } try { const payload = yield (0, tokens_1.verifyToken)(token, tenant); const created = Number((_a = payload.tokenIdentifier) === null || _a === void 0 ? void 0 : _a.split(':')[0]); if ((Date.now() - created < config_1.cookieTokenVerificationTime) || (yield isCookieProcessed(payload.tokenIdentifier))) { setUserPayload(payload, req, next); return; } const newCookieIdentifier = (0, tokens_1.getUniqueId)(); let user; try { user = yield (0, users_1.getUserIfTokenExists)(payload.tenant, payload.sub, payload.tokenIdentifier); } catch (e) { if (yield isCookieProcessed(payload.tokenIdentifier)) { setUserPayload(payload, req, next); return; } else { throw e; } } setCookieAsProcessed(payload.tokenIdentifier).catch(logger_1.default.log); try { yield (0, users_1.updateToken)(user, 'cookie', payload, newCookieIdentifier); const { token: newToken, payload: newPayload } = (0, tokens_1.getSignedToken)(user, payload.workspace, newCookieIdentifier, String(config_1.cookieTokenExpiration / 1000)); (0, tokens_1.setCookie)(res, (0, users_1.getCookieTokenName)(req.headers.tenant), newToken, null, (0, req_host_1.getRequestHost)(req)); setUserPayload(newPayload, req, next); } catch (e) { if (yield isCookieProcessed(payload.tokenIdentifier)) { setUserPayload(payload, req, next); return; } else { throw e; } } } catch (e) { logger_1.default.log('failed to handle cookie verification', e); next(); } }); } function setCookieAsProcessed(tokenIdentifier) { return __awaiter(this, void 0, void 0, function* () { yield cache_manager_1.cacheManager.setItem(tokenIdentifier, 'tokenIdentifier', { ttl: config_1.processedCookieExpiration }); }); } function isCookieProcessed(tokenIdentifier) { return __awaiter(this, void 0, void 0, function* () { try { const res = yield cache_manager_1.cacheManager.getItem(tokenIdentifier); return !!res; } catch (err) { logger_1.default.log('failed to check isCookieProcessed', err); return false; } }); } function setUserPayload(payload, req, next) { req.userPayload = payload; req.userPayload.isPrivileged = payload.roles.some((role) => { return config_1.privilegedRoles.includes(role); }); req.activeWorkspace = payload.workspace; next(); } /** * The Auth Checker middleware function. */ exports.default = (function verifyUser(req, res, next) { const cookie = (0, users_1.getCookieTokenValue)(req); const token = req.headers.authorization || req.headers.Authorization; if (cookie) { return cookieVerify(req, res, next).catch(next); } else if (token) { return oAuthVerify(req, res, next).catch(next); } else { next(); } });