-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathindex.js
More file actions
78 lines (71 loc) · 2.32 KB
/
index.js
File metadata and controls
78 lines (71 loc) · 2.32 KB
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
66
67
68
69
70
71
72
73
74
75
76
77
78
'use strict';
const https = require('https');
const {promisify} = require('util');
const debug = require('debug')('cognito-toolkit');
const jwt = require('jsonwebtoken');
const jwkToPem = require('jwk-to-pem');
const verify = promisify(jwt.verify.bind(jwt));
let issuers = null,
pems = null;
const preparePems = async () => {
const jwks = await Promise.all(
issuers.map(
issuer =>
new Promise(resolve => {
let data = '';
const clientRequest = https.request(issuer + '/.well-known/jwks.json', response => {
if (response.statusCode >= 400) {
debug('Bad status code: ' + response.statusCode);
return resolve(null);
}
response.setEncoding('utf8');
response.on('data', chunk => (data += chunk));
response.on('end', () => resolve(data ? JSON.parse(data) : null));
});
clientRequest.on('error', error => {
debug('Cannot retrieve jwks from the user pool: ' + issuer);
resolve(null);
});
clientRequest.end();
})
)
);
pems = {};
jwks.forEach(jwk => jwk && jwk.keys.forEach(key => (pems[key.kid] = jwkToPem(key))));
};
const makeGetUser = options => {
if (!(options instanceof Array)) {
options = [options];
}
issuers = options.map(option => {
if (!option || !option.region) {
throw new Error('Region should be specified');
}
if (!option.userPoolId) {
throw new Error('User pool ID should be specified');
}
return `https://cognito-idp.${option.region}.amazonaws.com/${option.userPoolId}`;
});
return async token => {
!pems && (await preparePems());
const decodedToken = jwt.decode(token, {complete: true});
if (!decodedToken) {
debug('Invalid token: ' + token);
return null;
}
if (!issuers.some(issuer => decodedToken.payload.iss === issuer)) {
debug('Unexpected user pool: ' + decodedToken.payload.iss);
return null;
}
const pem = pems[decodedToken.header.kid];
if (!pem) {
debug('Unexpected kid: ' + decodedToken.header.kid);
return null;
}
return verify(token, pem, {issuer: decodedToken.payload.iss}).catch(error => {
debug('Cannot validate a token: ' + error.message);
return null;
});
};
};
module.exports = makeGetUser;