jose/lib/help/key_utils.js
2018-11-03 14:30:20 +01:00

26 lines
748 B
JavaScript

const keyto = require('@trust/keyto')
const { PrivateKeyObject, PublicKeyObject } = require('./key_objects')
const SUPPORTED = new Set(['EC', 'RSA'])
module.exports.pemToJwk = (keyObject) => {
if (!(keyObject instanceof PrivateKeyObject) && !(keyObject instanceof PublicKeyObject)) {
throw new TypeError('invalid keyObject type')
}
const type = keyObject.type === 'private' ? 'pkcs8' : 'spki'
const format = 'pem'
const pem = keyObject.export({ type, format })
return keyto.from(pem, 'pem').toJwk(keyObject.type)
}
module.exports.jwkToPem = (jwk) => {
if (!SUPPORTED.has(jwk.kty)) {
throw new TypeError('unsupported kty')
}
return keyto.from(jwk, 'jwk').toString('pem', jwk.d ? 'private_pkcs8' : 'public_pkcs8')
}