|
1 | | -/** |
2 | | - * update from cookie-sesion middleware |
3 | | - */ |
4 | | -(function() { |
5 | | - 'use strict'; |
6 | | - var Cookies = require('cookies'); |
7 | | - var onHeaders = require('on-headers'); |
8 | | - var debug = require('debug')('AV:cookieSession'); |
9 | | - |
10 | | - module.exports = function(AV) { |
11 | | - return function(opts) { |
12 | | - opts = opts || {}; |
13 | | - |
14 | | - // name - previously "opts.key" |
15 | | - var name = opts.name || opts.key || 'avos:sess'; |
16 | | - |
17 | | - // secrets |
18 | | - var keys = opts.keys; |
19 | | - if (!keys && opts.secret) { |
20 | | - keys = [opts.secret]; |
21 | | - } |
| 1 | +'use strict'; |
22 | 2 |
|
23 | | - // defaults |
24 | | - if (!opts.overwrite) { |
25 | | - opts.overwrite = true; |
26 | | - } |
27 | | - opts.httpOnly = true; |
28 | | - opts.signed = true; |
| 3 | +var Cookies = require('cookies'); |
| 4 | +var onHeaders = require('on-headers'); |
| 5 | +var debug = require('debug')('AV:cookieSession'); |
29 | 6 |
|
30 | | - if (!keys && opts.signed) { |
31 | | - throw new Error('.keys required for avos cookie sessions.'); |
32 | | - } |
| 7 | +module.exports = function(AV) { |
| 8 | + return function(opts) { |
| 9 | + opts = opts || {}; |
33 | 10 |
|
34 | | - debug('session options %j', opts); |
| 11 | + // name - previously "opts.key" |
| 12 | + var name = opts.name || opts.key || 'avos:sess'; |
35 | 13 |
|
36 | | - return function cookieSession(req, res, next) { |
37 | | - var cookies = req.sessionCookies = new Cookies(req, res, keys); |
38 | | - var responseUser; |
| 14 | + // secrets |
| 15 | + var keys = opts.keys; |
| 16 | + if (!keys && opts.secret) { |
| 17 | + keys = [opts.secret]; |
| 18 | + } |
39 | 19 |
|
40 | | - // 兼容 connect |
41 | | - if (!res.req) res.req = req; |
42 | | - if (!req.res) req.res = res; |
| 20 | + // defaults |
| 21 | + if (!opts.overwrite) { |
| 22 | + opts.overwrite = true; |
| 23 | + } |
| 24 | + opts.httpOnly = true; |
| 25 | + opts.signed = true; |
43 | 26 |
|
44 | | - // to pass to Session() |
45 | | - req.sessionOptions = opts; |
46 | | - req.sessionKey = name; |
| 27 | + if (!keys && opts.signed) { |
| 28 | + throw new Error('.keys required for avos cookie sessions.'); |
| 29 | + } |
47 | 30 |
|
48 | | - res.saveCurrentUser = function(user) { |
49 | | - responseUser = user; |
50 | | - }; |
| 31 | + debug('session options %j', opts); |
51 | 32 |
|
52 | | - res.clearCurrentUser = function() { |
53 | | - responseUser = null; |
54 | | - }; |
| 33 | + return function cookieSession(req, res, next) { |
| 34 | + var cookies = req.sessionCookies = new Cookies(req, res, keys); |
| 35 | + var responseUser; |
55 | 36 |
|
56 | | - onHeaders(res, function setHeaders() { |
57 | | - var session = null; |
| 37 | + // 兼容 connect |
| 38 | + if (!res.req) res.req = req; |
| 39 | + if (!req.res) req.res = res; |
58 | 40 |
|
59 | | - if (responseUser) { |
60 | | - session = { |
61 | | - _uid: responseUser.id, |
62 | | - _sessionToken: responseUser._sessionToken |
63 | | - }; |
| 41 | + // to pass to Session() |
| 42 | + req.sessionOptions = opts; |
| 43 | + req.sessionKey = name; |
64 | 44 |
|
65 | | - debug('session %j', session); |
66 | | - cookies.set(name, encode(session), opts); |
67 | | - } else if (responseUser === null) { |
68 | | - debug('clear session'); |
69 | | - cookies.set(name, '', opts); |
70 | | - } |
71 | | - }); |
| 45 | + res.saveCurrentUser = function(user) { |
| 46 | + responseUser = user; |
| 47 | + }; |
| 48 | + |
| 49 | + res.clearCurrentUser = function() { |
| 50 | + responseUser = null; |
| 51 | + }; |
72 | 52 |
|
73 | | - var session = {}; |
74 | | - var json = cookies.get(name, opts); |
75 | | - if (json) { |
76 | | - session = decode(json); |
| 53 | + onHeaders(res, function setHeaders() { |
| 54 | + var session = null; |
| 55 | + |
| 56 | + if (responseUser) { |
| 57 | + session = { |
| 58 | + _uid: responseUser.id, |
| 59 | + _sessionToken: responseUser._sessionToken |
| 60 | + }; |
| 61 | + |
| 62 | + debug('session %j', session); |
| 63 | + cookies.set(name, encode(session), opts); |
| 64 | + } else if (responseUser === null) { |
| 65 | + debug('clear session'); |
| 66 | + cookies.set(name, '', opts); |
77 | 67 | } |
78 | | - var uid = session._uid; |
79 | | - var sessionToken = session._sessionToken; |
80 | | - req.AV = req.AV || {}; |
81 | | - if (uid && sessionToken) { |
82 | | - AV.Cloud.logInByIdAndSessionToken(uid, sessionToken, opts.fetchUser, function(err, user) { |
83 | | - if(err) { |
84 | | - debug('sessionToken invalid, uid: %s', uid); |
85 | | - } else { |
86 | | - req.AV.user = user; |
87 | | - req.currentUser = user; |
88 | | - req.sessionToken = user.getSessionToken(); |
89 | | - } |
90 | | - return next(); |
91 | | - }); |
92 | | - } else { |
| 68 | + }); |
| 69 | + |
| 70 | + var session = {}; |
| 71 | + var json = cookies.get(name, opts); |
| 72 | + if (json) { |
| 73 | + session = decode(json); |
| 74 | + } |
| 75 | + var uid = session._uid; |
| 76 | + var sessionToken = session._sessionToken; |
| 77 | + req.AV = req.AV || {}; |
| 78 | + if (uid && sessionToken) { |
| 79 | + AV.Cloud.logInByIdAndSessionToken(uid, sessionToken, opts.fetchUser, function(err, user) { |
| 80 | + if(err) { |
| 81 | + debug('sessionToken invalid, uid: %s', uid); |
| 82 | + } else { |
| 83 | + req.AV.user = user; |
| 84 | + req.currentUser = user; |
| 85 | + req.sessionToken = user.getSessionToken(); |
| 86 | + } |
93 | 87 | return next(); |
94 | | - } |
95 | | - }; |
| 88 | + }); |
| 89 | + } else { |
| 90 | + return next(); |
| 91 | + } |
96 | 92 | }; |
97 | 93 | }; |
| 94 | +}; |
| 95 | + |
| 96 | +/** |
| 97 | + * Decode the base64 cookie value to an object. |
| 98 | + * |
| 99 | + * @param {String} string |
| 100 | + * @return {Object} |
| 101 | + * @private |
| 102 | + */ |
| 103 | + |
| 104 | +function decode(string) { |
| 105 | + var body = new Buffer(string, 'base64').toString('utf8'); |
| 106 | + return JSON.parse(body); |
| 107 | +} |
| 108 | + |
| 109 | +/** |
| 110 | + * Encode an object into a base64-encoded JSON string. |
| 111 | + * |
| 112 | + * @param {Object} body |
| 113 | + * @return {String} |
| 114 | + * @private |
| 115 | + */ |
98 | 116 |
|
99 | | - /** |
100 | | - * Decode the base64 cookie value to an object. |
101 | | - * |
102 | | - * @param {String} string |
103 | | - * @return {Object} |
104 | | - * @private |
105 | | - */ |
106 | | - |
107 | | - function decode(string) { |
108 | | - var body = new Buffer(string, 'base64').toString('utf8'); |
109 | | - return JSON.parse(body); |
110 | | - } |
111 | | - |
112 | | - /** |
113 | | - * Encode an object into a base64-encoded JSON string. |
114 | | - * |
115 | | - * @param {Object} body |
116 | | - * @return {String} |
117 | | - * @private |
118 | | - */ |
119 | | - |
120 | | - function encode(body) { |
121 | | - body = JSON.stringify(body); |
122 | | - return new Buffer(body).toString('base64'); |
123 | | - } |
124 | | -}).call(this); |
| 117 | +function encode(body) { |
| 118 | + body = JSON.stringify(body); |
| 119 | + return new Buffer(body).toString('base64'); |
| 120 | +} |
0 commit comments