From 2ef6b45b66484b6a2292e3dcc47fab9a8858be02 Mon Sep 17 00:00:00 2001 From: pbca26 Date: Wed, 28 Mar 2018 23:25:52 +0300 Subject: [PATCH] address validation kmd multisig edge case --- routes/shepherd/electrum/keys.js | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/routes/shepherd/electrum/keys.js b/routes/shepherd/electrum/keys.js index 8edb339..fda562b 100644 --- a/routes/shepherd/electrum/keys.js +++ b/routes/shepherd/electrum/keys.js @@ -21,6 +21,7 @@ module.exports = (shepherd) => { shepherd.seedToWif = (seed, network, iguana) => { let bytes; + // legacy seed edge case if (process.argv.indexOf('spvold=true') > -1) { bytes = buggySha256(seed, { asBytes: true }); } else { @@ -142,7 +143,7 @@ module.exports = (shepherd) => { } else { return 'Unable to find matching coin version'; } - } catch(e) { + } catch (e) { return 'Invalid pub address'; } }; @@ -153,12 +154,13 @@ module.exports = (shepherd) => { try { const _b58check = shepherd.isZcash(network.toLowerCase()) ? bitcoinZcash.address.fromBase58Check(address) : bitcoin.address.fromBase58Check(address); - if (_b58check.version === _network.pubKeyHash) { + if (_b58check.version === _network.pubKeyHash || + (address[0] === 'b' && shepherd.getNetworkData(network.toLowerCase()).pubKeyHash === 60)) { // kmd multisig edge case return true; } else { return false; } - } catch(e) { + } catch (e) { return 'Invalid pub address'; } };