Add an "additionnal" option (Function(decoded, onSuccess, onError)). When the token is parser and validated the callback is triggered and allow addition of extra logic (e.g. validate the user status against database).

Improve returned errors.
This commit is contained in:
dbrugne 2015-05-07 11:49:00 +02:00
parent 346b4d7aa1
commit f5a84eb9bb

View File

@ -21,13 +21,26 @@ function noQsMethod(options) {
socket.on('authenticate', function (data) { socket.on('authenticate', function (data) {
clearTimeout(auth_timeout); clearTimeout(auth_timeout);
jwt.verify(data.token, options.secret, options, function(err, decoded) { jwt.verify(data.token, options.secret, options, function(err, decoded) {
// error handler
var onError = function(err, code) {
if (err) { if (err) {
socket.emit('unauthorized', err, function() { code = code || 'unknown';
var error = new UnauthorizedError(code, {
message: (Object.prototype.toString.call(err) === '[object Object]' && err.message) ? err.message : err
});
socket.emit('unauthorized', error, function() {
socket.disconnect('unauthorized'); socket.disconnect('unauthorized');
}); });
return; // stop logic, socket will be close on next tick return; // stop logic, socket will be close on next tick
} }
};
if (err) {
return onError(err, 'invalid_token');
}
// success handler
var onSuccess = function(){
socket.decoded_token = decoded; socket.decoded_token = decoded;
socket.emit('authenticated'); socket.emit('authenticated');
if (server.$emit) { if (server.$emit) {
@ -35,6 +48,13 @@ function noQsMethod(options) {
} else { } else {
server.server.sockets.emit('authenticated', socket); server.server.sockets.emit('authenticated', socket);
} }
};
if(options.additional && typeof options.additional === 'function') {
options.additional(decoded, onSuccess, onError);
} else {
onSuccess();
}
}); });
}); });