1234567891011121314151617181920212223242526272829303132333435 |
- "use strict";
- Object.defineProperty(exports, "__esModule", { value: true });
- exports.generalDecrypt = void 0;
- const decrypt_js_1 = require("../flattened/decrypt.js");
- const errors_js_1 = require("../../util/errors.js");
- const is_object_js_1 = require("../../lib/is_object.js");
- async function generalDecrypt(jwe, key, options) {
- if (!(0, is_object_js_1.default)(jwe)) {
- throw new errors_js_1.JWEInvalid('General JWE must be an object');
- }
- if (!Array.isArray(jwe.recipients) || !jwe.recipients.every(is_object_js_1.default)) {
- throw new errors_js_1.JWEInvalid('JWE Recipients missing or incorrect type');
- }
- if (!jwe.recipients.length) {
- throw new errors_js_1.JWEInvalid('JWE Recipients has no members');
- }
- for (const recipient of jwe.recipients) {
- try {
- return await (0, decrypt_js_1.flattenedDecrypt)({
- aad: jwe.aad,
- ciphertext: jwe.ciphertext,
- encrypted_key: recipient.encrypted_key,
- header: recipient.header,
- iv: jwe.iv,
- protected: jwe.protected,
- tag: jwe.tag,
- unprotected: jwe.unprotected,
- }, key, options);
- }
- catch {
- }
- }
- throw new errors_js_1.JWEDecryptionFailed();
- }
- exports.generalDecrypt = generalDecrypt;
|