schangxiang@126.com
2025-09-09 3d8966ba2c81e7e0365c8b123e861d18ee4f94f5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
'use strict';
 
/**
 * Session model.
 */
 
class Session {
  /**
   * Session constructor
   * @param {Context} ctx
   * @param {Object} obj
   * @api private
   */
 
  constructor(sessionContext, obj) {
    this._sessCtx = sessionContext;
    this._ctx = sessionContext.ctx;
    if (!obj) {
      this.isNew = true;
    } else {
      for (const k in obj) {
        // restore maxAge from store
        if (k === '_maxAge') this._ctx.sessionOptions.maxAge = obj._maxAge;
        else if (k === '_session') this._ctx.sessionOptions.maxAge = 'session';
        else this[k] = obj[k];
      }
    }
  }
 
  /**
   * JSON representation of the session.
   *
   * @return {Object}
   * @api public
   */
 
  toJSON() {
    const obj = {};
 
    Object.keys(this).forEach(key => {
      if (key === 'isNew') return;
      if (key[0] === '_') return;
      obj[key] = this[key];
    });
 
    return obj;
  }
 
  /**
   *
   * alias to `toJSON`
   * @api public
   */
 
  inspect() {
    return this.toJSON();
  }
 
  /**
   * Return how many values there are in the session object.
   * Used to see if it's "populated".
   *
   * @return {Number}
   * @api public
   */
 
  get length() {
    return Object.keys(this.toJSON()).length;
  }
 
  /**
   * populated flag, which is just a boolean alias of .length.
   *
   * @return {Boolean}
   * @api public
   */
 
  get populated() {
    return !!this.length;
  }
 
  /**
   * get session maxAge
   *
   * @return {Number}
   * @api public
   */
 
  get maxAge() {
    return this._ctx.sessionOptions.maxAge;
  }
 
  /**
   * set session maxAge
   *
   * @param {Number}
   * @api public
   */
 
  set maxAge(val) {
    this._ctx.sessionOptions.maxAge = val;
    // maxAge changed, must save to cookie and store
    this._requireSave = true;
  }
 
  /**
   * save this session no matter whether it is populated
   *
   * @api public
   */
 
  save() {
    this._requireSave = true;
  }
 
  /**
   * commit this session's headers if autoCommit is set to false
   *
   * @api public
   */
 
  async manuallyCommit() {
    await this._sessCtx.commit();
  }
 
}
 
module.exports = Session;