mirror of
https://github.com/danbulant/jose
synced 2026-05-25 04:51:47 +00:00
BREAKING CHANGE: key.algorithms(op) un+wrapKey was split into correct wrapKey/unwrapKey/deriveKey returns BREAKING CHANGE: keystore.all and keystore.get `operation` option was removed, `key_ops: string[]` supersedes it
25 lines
881 B
JavaScript
25 lines
881 B
JavaScript
const { strict: assert } = require('assert')
|
|
const { sign: signOneShot, verify: verifyOneShot } = require('crypto')
|
|
|
|
const { KEYOBJECT } = require('../help/consts')
|
|
const resolveNodeAlg = require('../help/node_alg')
|
|
|
|
const sign = (nodeAlg, { [KEYOBJECT]: keyObject }, payload) => {
|
|
return signOneShot(nodeAlg, payload, keyObject)
|
|
}
|
|
|
|
const verify = (nodeAlg, { [KEYOBJECT]: keyObject }, payload, signature) => {
|
|
return verifyOneShot(nodeAlg, payload, keyObject, signature)
|
|
}
|
|
|
|
module.exports = (JWA) => {
|
|
['RS256', 'RS384', 'RS512'].forEach((jwaAlg) => {
|
|
const nodeAlg = resolveNodeAlg(jwaAlg)
|
|
|
|
assert(!JWA.sign.has(jwaAlg), `sign alg ${jwaAlg} already registered`)
|
|
assert(!JWA.verify.has(jwaAlg), `verify alg ${jwaAlg} already registered`)
|
|
|
|
JWA.sign.set(jwaAlg, sign.bind(undefined, nodeAlg))
|
|
JWA.verify.set(jwaAlg, verify.bind(undefined, nodeAlg))
|
|
})
|
|
}
|