From 8bd40d1a14ac3854d57af86a6e59b6be5dc26de1 Mon Sep 17 00:00:00 2001 From: Filip Skokan Date: Wed, 14 Dec 2022 11:04:15 +0100 Subject: [PATCH] crypto: fix CryptoKey prototype WPT PR-URL: https://github.com/nodejs/node/pull/45857 Reviewed-By: Antoine du Hamel Reviewed-By: James M Snell --- lib/internal/crypto/keys.js | 65 ++++++++++++++++--------------- test/wpt/status/WebCryptoAPI.json | 1 - 2 files changed, 33 insertions(+), 33 deletions(-) diff --git a/lib/internal/crypto/keys.js b/lib/internal/crypto/keys.js index 5e4ab819af5b3d..968116d6bf2ea7 100644 --- a/lib/internal/crypto/keys.js +++ b/lib/internal/crypto/keys.js @@ -56,7 +56,7 @@ const { } = require('internal/util/types'); const { - JSTransferable, + makeTransferable, kClone, kDeserialize, } = require('internal/worker/js_transferable'); @@ -630,14 +630,12 @@ function isKeyObject(obj) { } // Our implementation of CryptoKey is a simple wrapper around a KeyObject -// that adapts it to the standard interface. This implementation also -// extends the JSTransferable class, allowing the CryptoKey to be cloned -// to Workers. +// that adapts it to the standard interface. // TODO(@jasnell): Embedder environments like electron may have issues // here similar to other things like URL. A chromium provided CryptoKey // will not be recognized as a Node.js CryptoKey, and vice versa. It // would be fantastic if we could find a way of making those interop. -class CryptoKey extends JSTransferable { +class CryptoKey { constructor() { throw new ERR_ILLEGAL_CONSTRUCTOR(); } @@ -682,30 +680,6 @@ class CryptoKey extends JSTransferable { throw new ERR_INVALID_THIS('CryptoKey'); return ArrayFrom(this[kKeyUsages]); } - - [kClone]() { - const keyObject = this[kKeyObject]; - const algorithm = this.algorithm; - const extractable = this.extractable; - const usages = this.usages; - - return { - data: { - keyObject, - algorithm, - usages, - extractable, - }, - deserializeInfo: 'internal/crypto/keys:InternalCryptoKey' - }; - } - - [kDeserialize]({ keyObject, algorithm, usages, extractable }) { - this[kKeyObject] = keyObject; - this[kAlgorithm] = algorithm; - this[kKeyUsages] = usages; - this[kExtractable] = extractable; - } } ObjectDefineProperties(CryptoKey.prototype, { @@ -718,13 +692,14 @@ ObjectDefineProperties(CryptoKey.prototype, { // All internal code must use new InternalCryptoKey to create // CryptoKey instances. The CryptoKey class is exposed to end // user code but is not permitted to be constructed directly. -class InternalCryptoKey extends JSTransferable { +// Using makeTransferable also allows the CryptoKey to be +// cloned to Workers. +class InternalCryptoKey { constructor( keyObject, algorithm, keyUsages, extractable) { - super(); // Using symbol properties here currently instead of private // properties because (for now) the performance penalty of // private fields is still too high. @@ -732,9 +707,35 @@ class InternalCryptoKey extends JSTransferable { this[kAlgorithm] = algorithm; this[kExtractable] = extractable; this[kKeyUsages] = keyUsages; + + // eslint-disable-next-line no-constructor-return + return makeTransferable(this); } -} + [kClone]() { + const keyObject = this[kKeyObject]; + const algorithm = this.algorithm; + const extractable = this.extractable; + const usages = this.usages; + + return { + data: { + keyObject, + algorithm, + usages, + extractable, + }, + deserializeInfo: 'internal/crypto/keys:InternalCryptoKey' + }; + } + + [kDeserialize]({ keyObject, algorithm, usages, extractable }) { + this[kKeyObject] = keyObject; + this[kAlgorithm] = algorithm; + this[kKeyUsages] = usages; + this[kExtractable] = extractable; + } +} InternalCryptoKey.prototype.constructor = CryptoKey; ObjectSetPrototypeOf(InternalCryptoKey.prototype, CryptoKey.prototype); diff --git a/test/wpt/status/WebCryptoAPI.json b/test/wpt/status/WebCryptoAPI.json index 961d8b515d702f..0eee00e0705e34 100644 --- a/test/wpt/status/WebCryptoAPI.json +++ b/test/wpt/status/WebCryptoAPI.json @@ -23,7 +23,6 @@ "expected": [ "Crypto interface: existence and properties of interface object", "CryptoKey interface: existence and properties of interface object", - "CryptoKey interface: existence and properties of interface prototype object", "Window interface: attribute crypto" ] }