remove obsolete commented-out code
This commit is contained in:
parent
47fe12ea19
commit
0677ae46f8
74
BIP32.js
74
BIP32.js
@ -69,34 +69,16 @@ BIP32.prototype.init_from_bytes = function(bytes) {
|
|||||||
this.version == LITECOIN_TESTNET_PUBLIC );
|
this.version == LITECOIN_TESTNET_PUBLIC );
|
||||||
|
|
||||||
if (is_private && key_bytes[0] == 0) {
|
if (is_private && key_bytes[0] == 0) {
|
||||||
/*
|
|
||||||
this.eckey = new Bitcoin.ECKey(key_bytes.slice(1, 33));
|
|
||||||
this.eckey.setCompressed(true);
|
|
||||||
|
|
||||||
var ecparams = getSECCurveByName("secp256k1");
|
|
||||||
var pt = ecparams.getG().multiply(this.eckey.priv);
|
|
||||||
this.eckey.pub = pt;
|
|
||||||
this.eckey.pubKeyHash = Bitcoin.Util.sha256ripe160(this.eckey.pub.getEncoded(true));
|
|
||||||
this.has_private_key = true;
|
|
||||||
*/
|
|
||||||
this.eckey = new Key();
|
this.eckey = new Key();
|
||||||
this.eckey.private = key_bytes.slice(1, 33);
|
this.eckey.private = key_bytes.slice(1, 33);
|
||||||
this.eckey.compressed = true;
|
this.eckey.compressed = true;
|
||||||
this.eckey.regenerateSync();
|
this.eckey.regenerateSync();
|
||||||
this.pubKeyHash = coinUtil.sha256ripe160(this.eckey.public); //not compressed ... seems to conflict with below
|
this.pubKeyHash = coinUtil.sha256ripe160(this.eckey.public);
|
||||||
this.has_private_key = true;
|
this.has_private_key = true;
|
||||||
} else if (is_public && (key_bytes[0] == 0x02 || key_bytes[0] == 0x03)) {
|
} else if (is_public && (key_bytes[0] == 0x02 || key_bytes[0] == 0x03)) {
|
||||||
/*
|
|
||||||
this.eckey = new Bitcoin.ECKey();
|
|
||||||
this.eckey.pub = decompress_pubkey(key_bytes);
|
|
||||||
this.eckey.pubKeyHash = Bitcoin.Util.sha256ripe160(this.eckey.pub.getEncoded(true));
|
|
||||||
//TODO: why compute hash of uncompressed, then compress again?
|
|
||||||
this.eckey.setCompressed(true);
|
|
||||||
this.has_private_key = false;
|
|
||||||
*/
|
|
||||||
this.eckey = new Key();
|
this.eckey = new Key();
|
||||||
this.eckey.public = key_bytes; //assume compressed
|
this.eckey.public = key_bytes;
|
||||||
this.pubKeyHash = coinUtil.sha256ripe160(this.eckey.public); //not compressed ... seems to conflict with above
|
this.pubKeyHash = coinUtil.sha256ripe160(this.eckey.public);
|
||||||
this.has_private_key = false;
|
this.has_private_key = false;
|
||||||
} else {
|
} else {
|
||||||
throw new Error("Invalid key");
|
throw new Error("Invalid key");
|
||||||
@ -146,7 +128,6 @@ BIP32.prototype.build_extended_public_key = function() {
|
|||||||
this.extended_public_key = Buffer.concat([this.extended_public_key, new Buffer([v & 0xff])]);
|
this.extended_public_key = Buffer.concat([this.extended_public_key, new Buffer([v & 0xff])]);
|
||||||
|
|
||||||
// Depth
|
// Depth
|
||||||
|
|
||||||
this.extended_public_key = Buffer.concat([this.extended_public_key, new Buffer([this.depth])]);
|
this.extended_public_key = Buffer.concat([this.extended_public_key, new Buffer([this.depth])]);
|
||||||
|
|
||||||
// Parent fingerprint
|
// Parent fingerprint
|
||||||
@ -261,7 +242,6 @@ BIP32.prototype.derive_child = function(i) {
|
|||||||
ib = new Buffer(ib);
|
ib = new Buffer(ib);
|
||||||
|
|
||||||
var use_private = (i & 0x80000000) != 0;
|
var use_private = (i & 0x80000000) != 0;
|
||||||
//var ecparams = getSECCurveByName("secp256k1");
|
|
||||||
|
|
||||||
var is_private =
|
var is_private =
|
||||||
(this.version == BITCOIN_MAINNET_PRIVATE ||
|
(this.version == BITCOIN_MAINNET_PRIVATE ||
|
||||||
@ -284,12 +264,6 @@ BIP32.prototype.derive_child = function(i) {
|
|||||||
data = Buffer.concat([this.eckey.public, ib]);
|
data = Buffer.concat([this.eckey.public, ib]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
var j = new jsSHA(Crypto.util.bytesToHex(data), 'HEX');
|
|
||||||
var hash = j.getHMAC(Crypto.util.bytesToHex(this.chain_code), "HEX", "SHA-512", "HEX");
|
|
||||||
var il = new BigInteger(hash.slice(0, 64), 16);
|
|
||||||
var ir = Crypto.util.hexToBytes(hash.slice(64, 128));
|
|
||||||
*/
|
|
||||||
var hash = coinUtil.sha512hmac(data, this.chain_code);
|
var hash = coinUtil.sha512hmac(data, this.chain_code);
|
||||||
var il = bignum.fromBuffer(hash.slice(0, 32), {size: 32});
|
var il = bignum.fromBuffer(hash.slice(0, 32), {size: 32});
|
||||||
var ir = hash.slice(32, 64);
|
var ir = hash.slice(32, 64);
|
||||||
@ -307,21 +281,12 @@ BIP32.prototype.derive_child = function(i) {
|
|||||||
ret.has_private_key = true;
|
ret.has_private_key = true;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
/*
|
|
||||||
var data = this.eckey.public.getEncoded(true).concat(ib);
|
|
||||||
var data = Buffer.concat([this.eckey.public, new Buffer(ib]);
|
|
||||||
var j = new jsSHA(Crypto.util.bytesToHex(data), 'HEX');
|
|
||||||
var hash = j.getHMAC(Crypto.util.bytesToHex(this.chain_code), "HEX", "SHA-512", "HEX");
|
|
||||||
var il = new BigInteger(hash.slice(0, 64), 16);
|
|
||||||
var ir = Crypto.util.hexToBytes(hash.slice(64, 128));
|
|
||||||
*/
|
|
||||||
var data = Buffer.concat([this.eckey.public, ib]);
|
var data = Buffer.concat([this.eckey.public, ib]);
|
||||||
var hash = coinUtil.sha512hmac(data, this.chain_code);
|
var hash = coinUtil.sha512hmac(data, this.chain_code);
|
||||||
var il = bignum.fromBuffer(hash.slice(0, 32), {size: 32});
|
var il = bignum.fromBuffer(hash.slice(0, 32), {size: 32});
|
||||||
var ir = hash.slice(32, 64);
|
var ir = hash.slice(32, 64);
|
||||||
|
|
||||||
// Ki = (IL + kpar)*G = IL*G + Kpar
|
// Ki = (IL + kpar)*G = IL*G + Kpar
|
||||||
//var k = ecparams.getG().multiply(il).add(this.eckey.pub);
|
|
||||||
var pub = new bignum(this.eckey.public, {size: 32});
|
var pub = new bignum(this.eckey.public, {size: 32});
|
||||||
var k = secp256k1_G.mul(il).add(pub);
|
var k = secp256k1_G.mul(il).add(pub);
|
||||||
|
|
||||||
@ -367,37 +332,4 @@ function u16(f) {return uint(f,2);}
|
|||||||
function u32(f) {return uint(f,4);}
|
function u32(f) {return uint(f,4);}
|
||||||
function u64(f) {return uint(f,8);}
|
function u64(f) {return uint(f,8);}
|
||||||
|
|
||||||
/*
|
|
||||||
//This function is not actually necessary
|
|
||||||
|
|
||||||
function decompress_pubkey(key_bytes) {
|
|
||||||
//TODO: Fix this whole function
|
|
||||||
var y_bit = u8(key_bytes.slice(0, 1)) & 0x01;
|
|
||||||
var ecparams = getSECCurveByName("secp256k1");
|
|
||||||
|
|
||||||
// build X
|
|
||||||
var x = BigInteger.ZERO.clone();
|
|
||||||
x.fromString(Crypto.util.bytesToHex(key_bytes.slice(1, 33)), 16);
|
|
||||||
|
|
||||||
// get curve
|
|
||||||
var curve = ecparams.getCurve();
|
|
||||||
var a = curve.getA().toBigInteger();
|
|
||||||
var b = curve.getB().toBigInteger();
|
|
||||||
var p = curve.getQ();
|
|
||||||
|
|
||||||
// compute y^2 = x^3 + a*x + b
|
|
||||||
var tmp = x.multiply(x).multiply(x).add(a.multiply(x)).add(b).mod(p);
|
|
||||||
|
|
||||||
// compute modular square root of y (mod p)
|
|
||||||
var y = tmp.modSqrt(p);
|
|
||||||
|
|
||||||
// flip sign if we need to
|
|
||||||
if ((y[0] & 0x01) != y_bit) {
|
|
||||||
y = y.multiply(new BigInteger("-1")).mod(p);
|
|
||||||
}
|
|
||||||
|
|
||||||
return new ECPointFp(curve, curve.fromBigInteger(x), curve.fromBigInteger(y));
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
module.exports = require('soop')(BIP32);
|
module.exports = require('soop')(BIP32);
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user