@qelos/auth
Version:
Express Passport authentication service
40 lines (39 loc) • 1.96 kB
JavaScript
;
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 req_host_1 = require("../services/req-host");
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;
const cookieToken = (0, users_1.getCookieTokenValue)(req);
let token, authType;
if (cookieToken) {
token = cookieToken;
authType = "cookie";
setCookie(res, (0, users_1.getCookieTokenName)(tenant), "", -1, (0, req_host_1.getRequestHost)(req));
}
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;