Skip to content

Commit

Permalink
[revert] Make generateId method async (#535)
Browse files Browse the repository at this point in the history
That is a breaking change, which mandates a major bump.
  • Loading branch information
darrachequesne committed Feb 27, 2018
1 parent be3833b commit c624751
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 60 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -261,7 +261,7 @@ to a single process.
- Overwrite this method to generate your custom socket id.
- **Parameters**
- `http.IncomingMessage`: a node request object
- `Function`: a callback method which contains an error (if there is) object and the generated id value
- **Returns** A socket id for connected client.

<hr><br>

Expand Down
84 changes: 40 additions & 44 deletions lib/server.js
Original file line number Diff line number Diff line change
Expand Up @@ -277,8 +277,8 @@ function sendErrorMessage (req, res, code) {
* @api public
*/

Server.prototype.generateId = function (req, callback) {
callback(null, base64id.generateId());
Server.prototype.generateId = function (req) {
return base64id.generateId();
};

/**
Expand All @@ -290,56 +290,52 @@ Server.prototype.generateId = function (req, callback) {
*/

Server.prototype.handshake = function (transportName, req) {
var self = this;
this.generateId(req, function (err, id) {
if (err) {
sendErrorMessage(req, req.res, Server.errors.BAD_REQUEST);
return;
}
debug('handshaking client "%s"', id);

try {
var transport = new transports[transportName](req);
if ('polling' === transportName) {
transport.maxHttpBufferSize = self.maxHttpBufferSize;
transport.httpCompression = self.httpCompression;
} else if ('websocket' === transportName) {
transport.perMessageDeflate = self.perMessageDeflate;
}
var id = this.generateId(req);

if (req._query && req._query.b64) {
transport.supportsBinary = false;
} else {
transport.supportsBinary = true;
}
} catch (e) {
sendErrorMessage(req, req.res, Server.errors.BAD_REQUEST);
return;
debug('handshaking client "%s"', id);

try {
var transport = new transports[transportName](req);
if ('polling' === transportName) {
transport.maxHttpBufferSize = this.maxHttpBufferSize;
transport.httpCompression = this.httpCompression;
} else if ('websocket' === transportName) {
transport.perMessageDeflate = this.perMessageDeflate;
}
var socket = new Socket(id, self, transport, req);

if (false !== self.cookie) {
transport.on('headers', function (headers) {
headers['Set-Cookie'] = cookieMod.serialize(self.cookie, id,
{
path: self.cookiePath,
httpOnly: self.cookiePath ? self.cookieHttpOnly : false
});
});

if (req._query && req._query.b64) {
transport.supportsBinary = false;
} else {
transport.supportsBinary = true;
}
} catch (e) {
sendErrorMessage(req, req.res, Server.errors.BAD_REQUEST);
return;
}
var socket = new Socket(id, this, transport, req);
var self = this;

transport.onRequest(req);
if (false !== this.cookie) {
transport.on('headers', function (headers) {
headers['Set-Cookie'] = cookieMod.serialize(self.cookie, id,
{
path: self.cookiePath,
httpOnly: self.cookiePath ? self.cookieHttpOnly : false
});
});
}

self.clients[id] = socket;
self.clientsCount++;
transport.onRequest(req);

socket.once('close', function () {
delete self.clients[id];
self.clientsCount--;
});
this.clients[id] = socket;
this.clientsCount++;

self.emit('connection', socket);
socket.once('close', function () {
delete self.clients[id];
self.clientsCount--;
});

this.emit('connection', socket);
};

/**
Expand Down
17 changes: 2 additions & 15 deletions test/server.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
'use strict';
/* eslint-disable standard/no-callback-literal */

/**
Expand Down Expand Up @@ -248,8 +247,8 @@ describe('server', function () {

var customId = 'CustomId' + Date.now();

engine.generateId = function (req, callback) {
callback(null, customId);
engine.generateId = function (req) {
return customId;
};

var socket = new eioc.Socket('ws://localhost:%d'.s(port));
Expand All @@ -263,18 +262,6 @@ describe('server', function () {
});
});

it('should disallow connection when custom id cannot be generated', function (done) {
let engine = listen({ allowUpgrades: false }, port => {
engine.generateId = (req, callback) => {
callback(new Error('no ID found'));
};

let socket = new eioc.Socket('ws://localhost:%d'.s(port));
socket.on('open', () => done(new Error('should not be able to connect')));
socket.on('error', () => done());
});
});

it('should exchange handshake data', function (done) {
listen({ allowUpgrades: false }, function (port) {
var socket = new eioc.Socket('ws://localhost:%d'.s(port));
Expand Down

0 comments on commit c624751

Please sign in to comment.