From 580eced1fdab336f8dad6288364387d08b6757a5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tobias=20Nie=C3=9Fen?= Date: Sat, 30 Mar 2019 11:01:45 +0100 Subject: [PATCH 1/2] crypto: remove legacy native handles --- doc/api/deprecations.md | 9 ++++++--- lib/internal/crypto/cipher.js | 6 ------ lib/internal/crypto/diffiehellman.js | 6 ------ lib/internal/crypto/hash.js | 5 ----- lib/internal/crypto/sig.js | 5 ----- lib/internal/crypto/util.js | 13 ------------- 6 files changed, 6 insertions(+), 38 deletions(-) diff --git a/doc/api/deprecations.md b/doc/api/deprecations.md index 9820b8039c0792..6617838ae107a9 100644 --- a/doc/api/deprecations.md +++ b/doc/api/deprecations.md @@ -2237,18 +2237,21 @@ use the [WHATWG URL API][] instead. ### DEP0117: Native crypto handles -Type: Runtime +Type: End-of-Life Previous versions of Node.js exposed handles to internal native objects through the `_handle` property of the `Cipher`, `Decipher`, `DiffieHellman`, `DiffieHellmanGroup`, `ECDH`, `Hash`, `Hmac`, `Sign`, and `Verify` classes. -Using the `_handle` property to access the native object is deprecated because -improper use of the native object can lead to crashing the application. +The `_handle` property has been removed because improper use of the native +object can lead to crashing the application. ### DEP0118: dns.lookup() support for a falsy hostname diff --git a/lib/internal/crypto/cipher.js b/lib/internal/crypto/cipher.js index dd6fe2d6d7139a..28bd1e57a62a67 100644 --- a/lib/internal/crypto/cipher.js +++ b/lib/internal/crypto/cipher.js @@ -20,7 +20,6 @@ const { const { getDefaultEncoding, kHandle, - legacyNativeHandle, toBuf } = require('internal/crypto/util'); @@ -219,8 +218,6 @@ Cipher.prototype.setAAD = function setAAD(aadbuf, options) { return this; }; -legacyNativeHandle(Cipher); - function Cipheriv(cipher, key, iv, options) { if (!(this instanceof Cipheriv)) return new Cipheriv(cipher, key, iv, options); @@ -245,7 +242,6 @@ function addCipherPrototypeFunctions(constructor) { Object.setPrototypeOf(Cipheriv.prototype, LazyTransform.prototype); Object.setPrototypeOf(Cipheriv, LazyTransform); addCipherPrototypeFunctions(Cipheriv); -legacyNativeHandle(Cipheriv); function Decipher(cipher, password, options) { if (!(this instanceof Decipher)) @@ -257,7 +253,6 @@ function Decipher(cipher, password, options) { Object.setPrototypeOf(Decipher.prototype, LazyTransform.prototype); Object.setPrototypeOf(Decipher, LazyTransform); addCipherPrototypeFunctions(Decipher); -legacyNativeHandle(Decipher); function Decipheriv(cipher, key, iv, options) { @@ -270,7 +265,6 @@ function Decipheriv(cipher, key, iv, options) { Object.setPrototypeOf(Decipheriv.prototype, LazyTransform.prototype); Object.setPrototypeOf(Decipheriv, LazyTransform); addCipherPrototypeFunctions(Decipheriv); -legacyNativeHandle(Decipheriv); module.exports = { Cipher, diff --git a/lib/internal/crypto/diffiehellman.js b/lib/internal/crypto/diffiehellman.js index 3bfc531455ca1c..7ec2ce6e4124f0 100644 --- a/lib/internal/crypto/diffiehellman.js +++ b/lib/internal/crypto/diffiehellman.js @@ -11,7 +11,6 @@ const { isArrayBufferView } = require('internal/util/types'); const { getDefaultEncoding, kHandle, - legacyNativeHandle, toBuf } = require('internal/crypto/util'); const { @@ -165,9 +164,6 @@ DiffieHellman.prototype.setPrivateKey = function setPrivateKey(key, encoding) { return this; }; -legacyNativeHandle(DiffieHellman); -legacyNativeHandle(DiffieHellmanGroup); - function ECDH(curve) { if (!(this instanceof ECDH)) @@ -195,8 +191,6 @@ ECDH.prototype.getPublicKey = function getPublicKey(encoding, format) { return encode(key, encoding); }; -legacyNativeHandle(ECDH); - ECDH.convertKey = function convertKey(key, curve, inEnc, outEnc, format) { if (typeof key !== 'string' && !isArrayBufferView(key)) { throw new ERR_INVALID_ARG_TYPE( diff --git a/lib/internal/crypto/hash.js b/lib/internal/crypto/hash.js index 5e67efe6c5c257..89ab29d845e749 100644 --- a/lib/internal/crypto/hash.js +++ b/lib/internal/crypto/hash.js @@ -8,7 +8,6 @@ const { const { getDefaultEncoding, kHandle, - legacyNativeHandle, toBuf } = require('internal/crypto/util'); @@ -89,8 +88,6 @@ Hash.prototype.digest = function digest(outputEncoding) { return ret; }; -legacyNativeHandle(Hash); - function Hmac(hmac, key, options) { if (!(this instanceof Hmac)) @@ -130,8 +127,6 @@ Hmac.prototype.digest = function digest(outputEncoding) { Hmac.prototype._flush = Hash.prototype._flush; Hmac.prototype._transform = Hash.prototype._transform; -legacyNativeHandle(Hmac); - module.exports = { Hash, Hmac diff --git a/lib/internal/crypto/sig.js b/lib/internal/crypto/sig.js index 9eacfec8c0b74a..fa844e96966117 100644 --- a/lib/internal/crypto/sig.js +++ b/lib/internal/crypto/sig.js @@ -19,7 +19,6 @@ const { const { getDefaultEncoding, kHandle, - legacyNativeHandle, toBuf, validateArrayBufferView, } = require('internal/crypto/util'); @@ -56,8 +55,6 @@ Sign.prototype.update = function update(data, encoding) { return this; }; -legacyNativeHandle(Sign); - function getPadding(options) { return getIntOption('padding', RSA_PKCS1_PADDING, options); } @@ -166,8 +163,6 @@ Verify.prototype.verify = function verify(options, signature, sigEncoding) { rsaPadding, pssSaltLength); }; -legacyNativeHandle(Verify); - function verifyOneShot(algorithm, data, key, signature) { if (algorithm != null) validateString(algorithm, 'algorithm'); diff --git a/lib/internal/crypto/util.js b/lib/internal/crypto/util.js index c8a1f9e927ec6b..c6832f8e2e34bc 100644 --- a/lib/internal/crypto/util.js +++ b/lib/internal/crypto/util.js @@ -30,18 +30,6 @@ const { const kHandle = Symbol('kHandle'); -function legacyNativeHandle(clazz) { - Object.defineProperty(clazz.prototype, '_handle', { - get: deprecate(function() { return this[kHandle]; }, - `${clazz.name}._handle is deprecated. Use the public API ` + - 'instead.', 'DEP0117'), - set: deprecate(function(h) { this[kHandle] = h; }, - `${clazz.name}._handle is deprecated. Use the public API ` + - 'instead.', 'DEP0117'), - enumerable: false - }); -} - var defaultEncoding = 'buffer'; function setDefaultEncoding(val) { @@ -116,7 +104,6 @@ module.exports = { getDefaultEncoding, getHashes, kHandle, - legacyNativeHandle, setDefaultEncoding, setEngine, timingSafeEqual, From 8330d7bbbcacedbbab80ba561c27b267da2a5d09 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tobias=20Nie=C3=9Fen?= Date: Sun, 31 Mar 2019 17:14:54 +0200 Subject: [PATCH 2/2] fixup! crypto: remove legacy native handles --- lib/internal/crypto/util.js | 1 - 1 file changed, 1 deletion(-) diff --git a/lib/internal/crypto/util.js b/lib/internal/crypto/util.js index c6832f8e2e34bc..ddef1a163ceec2 100644 --- a/lib/internal/crypto/util.js +++ b/lib/internal/crypto/util.js @@ -21,7 +21,6 @@ const { validateString } = require('internal/validators'); const { Buffer } = require('buffer'); const { cachedResult, - deprecate, filterDuplicateStrings } = require('internal/util'); const {