jose/lib/jwa/eddsa.js
Filip Skokan 23b874cc20 feat: add JWK key_ops support, fix .algorithms() op returns
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
2019-04-23 14:30:51 +02:00

22 lines
660 B
JavaScript

const { strict: assert } = require('assert')
const { sign: signOneShot, verify: verifyOneShot } = require('crypto')
const { KEYOBJECT } = require('../help/consts')
const sign = ({ [KEYOBJECT]: keyObject }, payload) => {
return signOneShot(undefined, payload, keyObject)
}
const verify = ({ [KEYOBJECT]: keyObject }, payload, signature) => {
return verifyOneShot(undefined, payload, keyObject, signature)
}
const ALG = 'EdDSA'
module.exports = (JWA) => {
assert(!JWA.sign.has(ALG), `sign alg ${ALG} already registered`)
assert(!JWA.verify.has(ALG), `verify alg ${ALG} already registered`)
JWA.sign.set(ALG, sign)
JWA.verify.set(ALG, verify)
}