forked from anvilresearch/connect
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrevoke.js
65 lines (51 loc) · 1.35 KB
/
revoke.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/**
* Module dependencies
*/
var request = require('superagent')
, providers = require('../providers')
, User = require('../models/User')
, InvalidRequestError = require('../errors/InvalidRequestError')
;
/**
* Revoke
*/
function revoke (req, res, next) {
var provider = providers[req.params.provider]
, endpoint = provider && provider.endpoints && provider.endpoints.revoke
;
if (!provider) {
return next(new InvalidRequestError('Unknown provider'));
}
if (!endpoint) {
return next(new InvalidRequestError('Undefined revoke endpoint'));
}
User.get(req.claims.sub, function (err, user) {
if (err) {
return next(err);
}
if (!user) {
return next(new InvalidRequestError('Unknown user'));
}
if (!user.providers[req.params.provider]) {
return next(new InvalidRequestError('No provider for this user'));
}
var auth = user.providers[req.params.provider].auth
, url = endpoint.url
, method = endpoint.method.toLowerCase()
, param = endpoint.auth && endpoint.auth.param
, token = auth && auth.access_token
;
request[method](url)
.query(param + '=' + token)
.end(function (err, response) {
res.json({
err: err,
response: response
});
});
});
}
/**
* Exports
*/
module.exports = revoke;