????JFIF??x?x????'
Server IP : 79.136.114.73 / Your IP : 18.216.105.175 Web Server : Apache/2.4.7 (Ubuntu) PHP/5.5.9-1ubuntu4.29 OpenSSL/1.0.1f System : Linux b8009 3.13.0-170-generic #220-Ubuntu SMP Thu May 9 12:40:49 UTC 2019 x86_64 User : www-data ( 33) PHP Version : 5.5.9-1ubuntu4.29 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority, MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /usr/lib/nodejs/connect/middleware/session/ |
Upload File : |
/*! * Connect - session - Session * Copyright(c) 2010 Sencha Inc. * Copyright(c) 2011 TJ Holowaychuk * MIT Licensed */ /** * Module dependencies. */ var utils = require('../../utils') , Cookie = require('./cookie'); /** * Create a new `Session` with the given request and `data`. * * @param {IncomingRequest} req * @param {Object} data * @api private */ var Session = module.exports = function Session(req, data) { Object.defineProperty(this, 'req', { value: req }); Object.defineProperty(this, 'id', { value: req.sessionID }); if ('object' == typeof data) { utils.merge(this, data); } else { this.lastAccess = Date.now(); } }; /** * Update `.lastAccess` timestamp, * and reset `.cookie.maxAge` to prevent * the cookie from expiring when the * session is still active. * * @return {Session} for chaining * @api public */ Session.prototype.touch = function(){ return this .resetLastAccess() .resetMaxAge(); }; /** * Update `.lastAccess` timestamp. * * @return {Session} for chaining * @api public */ Session.prototype.resetLastAccess = function(){ this.lastAccess = Date.now(); return this; }; /** * Reset `.maxAge` to `.originalMaxAge`. * * @return {Session} for chaining * @api public */ Session.prototype.resetMaxAge = function(){ this.cookie.maxAge = this.cookie.originalMaxAge; return this; }; /** * Save the session data with optional callback `fn(err)`. * * @param {Function} fn * @return {Session} for chaining * @api public */ Session.prototype.save = function(fn){ this.req.sessionStore.set(this.id, this, fn || function(){}); return this; }; /** * Re-loads the session data _without_ altering * the maxAge or lastAccess properties. Invokes the * callback `fn(err)`, after which time if no exception * has occurred the `req.session` property will be * a new `Session` object, although representing the * same session. * * @param {Function} fn * @return {Session} for chaining * @api public */ Session.prototype.reload = function(fn){ var req = this.req , store = this.req.sessionStore; store.get(this.id, function(err, sess){ if (err) return fn(err); if (!sess) return fn(new Error('failed to load session')); store.createSession(req, sess); fn(); }); return this; }; /** * Destroy `this` session. * * @param {Function} fn * @return {Session} for chaining * @api public */ Session.prototype.destroy = function(fn){ delete this.req.session; this.req.sessionStore.destroy(this.id, fn); return this; }; /** * Regenerate this request's session. * * @param {Function} fn * @return {Session} for chaining * @api public */ Session.prototype.regenerate = function(fn){ this.req.sessionStore.regenerate(this.req, fn); return this; };