UNPKG

@scefira/dfw-nodejs

Version:
87 lines 4.35 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { 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) : new P(function (resolve) { resolve(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 v4_1 = __importDefault(require("uuid/v4")); const dfw_user_model_1 = __importDefault(require("../model/dfw_user.model")); const dfw_session_model_1 = __importDefault(require("../model/dfw_session.model")); const Utils_1 = __importDefault(require("./Utils")); const dfw_credential_model_1 = __importDefault(require("../model/dfw_credential.model")); class SessionManager { static initialice() { // Nothing to do here } static touchAsync(dfw) { return __awaiter(this, void 0, void 0, function* () { dfw.session = { isLogged: false, model: {}, }; if (dfw.request.cookies == undefined || dfw.request.cookies == null || dfw.request.cookies.sid == undefined || dfw.request.cookies.stk == undefined) { dfw.session.model = yield this.regenerateSessionAsync(dfw); } else { dfw.session.sid = dfw.request.cookies.sid; dfw.session.stk = dfw.request.cookies.stk; var cSession = yield dfw_session_model_1.default.findOne({ where: { id: dfw.session.sid }, include: [{ model: dfw_user_model_1.default, include: [dfw_credential_model_1.default] }] }); // Current session if (cSession == null || cSession == undefined || cSession.token !== dfw.request.cookies.stk) { dfw.session.model = yield this.regenerateSessionAsync(dfw); } else { dfw.session.model = cSession; } } dfw.session.sid = dfw.session.model.id; dfw.session.stk = dfw.session.model.token; dfw.session.isLogged = dfw.session.model.idUser !== 0 && dfw.session.model.idUser !== null && dfw.session.model.idUser !== undefined; }); } static regenerateSessionAsync(dfw) { return __awaiter(this, void 0, void 0, function* () { var stk = v4_1.default(); var session = yield dfw_session_model_1.default.create({ token: stk, agent: dfw.request.headers['user-agent'], ip: dfw.request.ip, site: dfw.request.originalUrl }); dfw.response.cookie("sid", session.id); dfw.response.cookie("stk", stk); dfw.session = { sid: session.id, stk, isLogged: false, model: session }; return session; }); } static loginAsync(dfw, options) { return __awaiter(this, void 0, void 0, function* () { if (options.user == null || options.user == undefined || options.password == undefined || options.password == null) { // Seguridad, validación de campos de identificador vacio return false; } var user = yield dfw_user_model_1.default.getUser(options.user); if (user != null) { if (user.checkPassword(options.password)) { dfw.session.isLogged = true; dfw.session.model.user = user; dfw.session.model.idUser = user.id; dfw.session.model.save(); return true; } } yield Utils_1.default.sleepAsync(2000); return false; }); } } exports.default = SessionManager; //# sourceMappingURL=SessionManager.js.map