link
This commit is contained in:
80
node_modules/jwks-rsa/src/utils.js
generated
vendored
Normal file
80
node_modules/jwks-rsa/src/utils.js
generated
vendored
Normal file
@@ -0,0 +1,80 @@
|
||||
const jose = require('jose');
|
||||
const JwksError = require('./errors/JwksError');
|
||||
|
||||
function resolveAlg(jwk) {
|
||||
if (jwk.alg) {
|
||||
return jwk.alg;
|
||||
}
|
||||
|
||||
if (jwk.kty === 'RSA') {
|
||||
return 'RS256';
|
||||
}
|
||||
|
||||
if (jwk.kty === 'EC') {
|
||||
switch (jwk.crv) {
|
||||
case 'P-256':
|
||||
return 'ES256';
|
||||
case 'secp256k1':
|
||||
return 'ES256K';
|
||||
case 'P-384':
|
||||
return 'ES384';
|
||||
case 'P-521':
|
||||
return 'ES512';
|
||||
}
|
||||
}
|
||||
|
||||
if (jwk.kty === 'OKP') {
|
||||
switch (jwk.crv) {
|
||||
case 'Ed25519':
|
||||
case 'Ed448':
|
||||
return 'EdDSA';
|
||||
}
|
||||
}
|
||||
|
||||
throw new JwksError('Unsupported JWK');
|
||||
}
|
||||
|
||||
async function retrieveSigningKeys(jwks) {
|
||||
const results = [];
|
||||
|
||||
jwks = jwks
|
||||
.filter(({ use }) => use === 'sig' || use === undefined)
|
||||
.filter(({ kty }) => kty === 'RSA' || kty === 'EC' || kty === 'OKP');
|
||||
|
||||
for (const jwk of jwks) {
|
||||
try {
|
||||
const key = await jose.importJWK({ ...jwk, ext: true }, resolveAlg(jwk));
|
||||
if (key.type !== 'public') {
|
||||
continue;
|
||||
}
|
||||
let getSpki;
|
||||
switch (key[Symbol.toStringTag]) {
|
||||
case 'CryptoKey': {
|
||||
const spki = await jose.exportSPKI(key);
|
||||
getSpki = () => spki;
|
||||
break;
|
||||
}
|
||||
case 'KeyObject':
|
||||
// Assume legacy Node.js version without the Symbol.toStringTag backported
|
||||
// Fall through
|
||||
default:
|
||||
getSpki = () => key.export({ format: 'pem', type: 'spki' });
|
||||
}
|
||||
results.push({
|
||||
get publicKey() { return getSpki(); },
|
||||
get rsaPublicKey() { return getSpki(); },
|
||||
getPublicKey() { return getSpki(); },
|
||||
...(typeof jwk.kid === 'string' && jwk.kid ? { kid: jwk.kid } : undefined),
|
||||
...(typeof jwk.alg === 'string' && jwk.alg ? { alg: jwk.alg } : undefined)
|
||||
});
|
||||
} catch (err) {
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
return results;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
retrieveSigningKeys
|
||||
};
|
||||
Reference in New Issue
Block a user