socket.io parse connect (> = 2.4.1) podpisany plik cookie sesji
Z najnowszą wersją connect (stan na 2012-07-26) znalazłem następujący sposób na uzyskanie identyfikatora sesji z socket.io, który będzie działał ze sklepem connect-redis.
var express = require('express')
, routes = require('./routes')
, fs = require('fs')
, http = require('http')
, io = require('socket.io')
, redis = require('connect-redis')
, connect = require('express/node_modules/connect')
, parseSignedCookie = connect.utils.parseSignedCookie
, cookie = require('express/node_modules/cookie');
var secret = '...';
var rStore = new(require('connect-redis')(express));
//...
var server = http.createServer(app);
var sio = io.listen(server);
sio.set('authorization', function(data, accept) {
if(data.headers.cookie) {
data.cookie = cookie.parse(data.headers.cookie);
data.sessionID = parseSignedCookie(data.cookie['connect.sid'], secret);
} else {
return accept('No cookie transmitted', false);
}
accept(null, true);
});
data.sessionID
może być później użyty, np
sio.sockets.on('connection', function(socket) {
console.log('New socket connection with ID: ' + socket.handshake.sessionID);
rStore.get(socket.handshake.sessionID, function(err, session) {
//...
});
});
Konieczność importowania tak wielu z express (connect, użyteczność connect i modułu cookie) wydaje się nadmiernie okrężnym sposobem uzyskania funkcji potrzebnych do przeanalizowania podpisanych plików cookie. Czy ktoś znalazł inny sposób?