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?

questionAnswers(1)

yourAnswerToTheQuestion