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:
parent
346b4d7aa1
commit
f5a84eb9bb
22
lib/index.js
22
lib/index.js
@ -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();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user