@scefira/dfw-nodejs
Version:
87 lines • 4.35 kB
JavaScript
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
;