From 9ee22af4bad63ca35a00cff69c2b65a3963f1221 Mon Sep 17 00:00:00 2001 From: Alex Beregszaszi Date: Thu, 20 Dec 2018 21:04:15 +0000 Subject: [PATCH] Refactor decipherBuffer --- src/index.js | 12 ++++++------ src/thirdparty.js | 6 +++--- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/src/index.js b/src/index.js index cfcf126..dfc3442 100644 --- a/src/index.js +++ b/src/index.js @@ -12,8 +12,8 @@ function assert (val, msg) { } } -function decipherBuffer (decipher, data) { - return Buffer.concat([ decipher.update(data), decipher.final() ]) +function runCipherBuffer (cipher, data) { + return Buffer.concat([ cipher.update(data), cipher.final() ]) } var Wallet = function (priv, pub) { @@ -140,7 +140,7 @@ Wallet.prototype.toV3 = function (password, opts) { throw new Error('Unsupported cipher') } - var ciphertext = Buffer.concat([ cipher.update(this.privKey), cipher.final() ]) + var ciphertext = runCipherBuffer(cipher, this.privKey) var mac = ethUtil.keccak256(Buffer.concat([ derivedKey.slice(16, 32), Buffer.from(ciphertext, 'hex') ])) @@ -237,7 +237,7 @@ Wallet.fromV1 = function (input, password) { } var decipher = crypto.createDecipheriv('aes-128-cbc', ethUtil.keccak256(derivedKey.slice(0, 16)).slice(0, 16), Buffer.from(json.Crypto.IV, 'hex')) - var seed = decipherBuffer(decipher, ciphertext) + var seed = runCipherBuffer(decipher, ciphertext) return new Wallet(seed) } @@ -277,7 +277,7 @@ Wallet.fromV3 = function (input, password, nonStrict) { } var decipher = crypto.createDecipheriv(json.crypto.cipher, derivedKey.slice(0, 16), Buffer.from(json.crypto.cipherparams.iv, 'hex')) - var seed = decipherBuffer(decipher, ciphertext) + var seed = runCipherBuffer(decipher, ciphertext) return new Wallet(seed) } @@ -299,7 +299,7 @@ Wallet.fromEthSale = function (input, password) { // NOTE: crypto (derived from openssl) when used with aes-*-cbc will handle PKCS#7 padding internally // see also http://stackoverflow.com/a/31614770/4964819 var decipher = crypto.createDecipheriv('aes-128-cbc', derivedKey, encseed.slice(0, 16)) - var seed = decipherBuffer(decipher, encseed.slice(16)) + var seed = runCipherBuffer(decipher, encseed.slice(16)) var wallet = new Wallet(ethUtil.keccak256(seed)) if (wallet.getAddress().toString('hex') !== json.ethaddr) { diff --git a/src/thirdparty.js b/src/thirdparty.js index 2d9bed7..41a9d85 100644 --- a/src/thirdparty.js +++ b/src/thirdparty.js @@ -12,8 +12,8 @@ function assert (val, msg) { } } -function decipherBuffer (decipher, data) { - return Buffer.concat([ decipher.update(data), decipher.final() ]) +function runCipherBuffer (cipher, data) { + return Buffer.concat([ cipher.update(data), cipher.final() ]) } var Thirdparty = {} @@ -118,7 +118,7 @@ Thirdparty.fromEtherWallet = function (input, password) { var evp = evp_kdf(Buffer.from(password), cipher.salt, { keysize: 32, ivsize: 16 }) var decipher = crypto.createDecipheriv('aes-256-cbc', evp.key, evp.iv) - privKey = decipherBuffer(decipher, Buffer.from(cipher.ciphertext)) + privKey = runCipherBuffer(decipher, Buffer.from(cipher.ciphertext)) // NOTE: yes, they've run it through UTF8 privKey = Buffer.from(utf8.decode(privKey.toString()), 'hex')