UNPKG

@greenpress/auth

Version:

Express Passport authentication service

38 lines (37 loc) 1.83 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()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.logout = void 0; const users_1 = require("../services/users"); const { setCookie } = require("../services/tokens"); function removeToken(tenant, userId, authType, token) { (0, users_1.deleteToken)(tenant, userId, authType, token, authType === "oauth").catch(Promise.resolve); } function logout(req, res) { var _a, _b; return __awaiter(this, void 0, void 0, function* () { const tenant = (req.headers.tenant = req.headers.tenant || "0"); const userId = req.userPayload.sub; let token, authType; if (req.cookies.token || req.signedCookies.token) { token = req.cookies.token || req.signedCookies.token; authType = "cookie"; setCookie(res, "", -1); } else { token = (_b = (_a = req.headers.authorization) === null || _a === void 0 ? void 0 : _a.split(" ")[1]) !== null && _b !== void 0 ? _b : ""; authType = "oauth"; } removeToken(tenant, userId, authType, token); res.status(200).end(); }); } exports.logout = logout;