'use strict'; /* * Stores session data in the database * Source; https://github.com/edy-b/SciFlowWriter/blob/develop/available_plugins/ep_sciflowwriter/db/DirtyStore.js * This is not used for authors that are created via the API at current * * RPB: this module was not migrated to Promises, because it is only used via * express-session, which can't actually use promises anyway. */ const DB = require('./DB'); const Store = require('express-session').Store; const log4js = require('log4js'); const logger = log4js.getLogger('SessionStore'); module.exports = class SessionStore extends Store { get(sid, fn) { logger.debug(`GET ${sid}`); DB.db.get(`sessionstorage:${sid}`, (err, s) => { if (err != null) return fn(err); if (!s) return fn(null); if (typeof s.cookie.expires === 'string') s.cookie.expires = new Date(s.cookie.expires); if (s.cookie.expires && new Date() >= s.cookie.expires) return this.destroy(sid, fn); fn(null, s); }); } set(sid, sess, fn) { logger.debug(`SET ${sid}`); DB.db.set(`sessionstorage:${sid}`, sess, fn); } destroy(sid, fn) { logger.debug(`DESTROY ${sid}`); DB.db.remove(`sessionstorage:${sid}`, fn); } };