From f43c2f9aa320ba96b2e88be348c9f90122a65cd8 Mon Sep 17 00:00:00 2001 From: Braydon Fuller Date: Sat, 13 Dec 2014 13:11:03 -0500 Subject: [PATCH 1/4] Fixed bug, toObject should use other object's toObject --- lib/block.js | 2 +- lib/transaction/transaction.js | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/lib/block.js b/lib/block.js index 43e90c8..6ffa2c1 100644 --- a/lib/block.js +++ b/lib/block.js @@ -149,7 +149,7 @@ Block.fromRawBlock = function fromRawBlock(data) { Block.prototype.toObject = function toObject() { var txs = []; this.txs.forEach(function(tx) { - txs.push(tx.toJSON()); + txs.push(tx.toObject()); }); return { magicnum: this.magicnum, diff --git a/lib/transaction/transaction.js b/lib/transaction/transaction.js index 654efe7..e6bbe50 100644 --- a/lib/transaction/transaction.js +++ b/lib/transaction/transaction.js @@ -144,11 +144,11 @@ Transaction.prototype.fromJSON = function(json) { Transaction.prototype.toObject = function toObject() { var inputs = []; this.inputs.forEach(function(input) { - inputs.push(input.toJSON()); + inputs.push(input.toObject()); }); var outputs = []; this.outputs.forEach(function(output) { - outputs.push(output.toJSON()); + outputs.push(output.toObject()); }); return { version: this.version, From b544b0594d4a08418704a5c3f840162a795480b7 Mon Sep 17 00:00:00 2001 From: Braydon Fuller Date: Sat, 13 Dec 2014 14:10:03 -0500 Subject: [PATCH 2/4] Added test to check that Transaction fromJSON could initialize from toJSON, and fixed a bug. --- lib/transaction/input/input.js | 4 ++-- lib/transaction/output.js | 7 ++----- test/transaction.js | 19 +++++++++++++++++++ 3 files changed, 23 insertions(+), 7 deletions(-) diff --git a/lib/transaction/input/input.js b/lib/transaction/input/input.js index 3a4f5b1..e01fb12 100644 --- a/lib/transaction/input/input.js +++ b/lib/transaction/input/input.js @@ -42,7 +42,7 @@ Input.prototype._fromObject = function(params) { Input.prototype.toObject = function toObject() { return { - prevTxId: this.prevTxId, + prevTxId: this.prevTxId.toString('hex'), outputIndex: this.outputIndex, sequenceNumber: this.sequenceNumber, script: this._scriptBuffer.toString('hex') @@ -59,7 +59,7 @@ Input.fromJSON = function(json) { } return new Input({ prevTxId: json.prevTxId || json.txidbuf, - outputIndex: json.outputIndex || json.txoutnum, + outputIndex: _.isUndefined(json.outputIndex) ? json.txoutnum : json.outputIndex, sequenceNumber: json.sequenceNumber || json.seqnum, scriptBuffer: new Script(json.script, 'hex') }); diff --git a/lib/transaction/output.js b/lib/transaction/output.js index 759aeac..2fdd26f 100644 --- a/lib/transaction/output.js +++ b/lib/transaction/output.js @@ -32,15 +32,12 @@ Object.defineProperty(Output.prototype, 'satoshis', { configurable: false, writeable: true, get: function() { - if (this._satoshis.lt(1e52)) { - return this._satoshis.toNumber(); - } - return this._satoshis; + return this._satoshis.toNumber(); }, set: function(num) { if (num instanceof BN) { this._satoshis = num; - } else if (_.isNumber(num)) { + } else { this._satoshis = BN().fromNumber(num); } } diff --git a/test/transaction.js b/test/transaction.js index 9af3b56..4ef0c84 100644 --- a/test/transaction.js +++ b/test/transaction.js @@ -31,6 +31,11 @@ describe('Transaction', function() { transaction.serialize().should.equal(tx_1_hex); }); + it('should input/output json', function() { + var transaction = JSON.parse(Transaction().fromJSON(tx_1_json).toJSON()); + transaction.should.deep.equal(JSON.parse(tx_1_json)); + }); + it('should create a sample transaction from an utxo', function() { var transaction = new Transaction() .from(utxo_1a) @@ -57,6 +62,20 @@ var tx_1_hex = '01000000015884e5db9de218238671572340b207ee85b628074e7e467096c267 var tx_1_id = '779a3e5b3c2c452c85333d8521f804c1a52800e60f4b7c3bbe36f4bab350b72c'; var tx_2_hex = ''; +var tx_1_json = JSON.stringify({ + version:1, + inputs:[{ + prevTxId:"a477af6b2667c29670467e4e0728b685ee07b240235771862318e29ddbe58458", + outputIndex:0, + sequenceNumber:4294967295, + script:"473044022013fa3089327b50263029265572ae1b022a91d10ac80eb4f32f291c914533670b02200d8a5ed5f62634a7e1a0dc9188a3cc460a986267ae4d58faf50c79105431327501210223078d2942df62c45621d209fab84ea9a7a23346201b7727b9b45a29c4e76f5e"}], + outputs:[{ + satoshis:1010000, + script:"76a9147821c0a3768aa9d1a37e16cf76002aef5373f1a888ac" + }], + nLockTime:0 +}); + var utxo_1a_address = 'mszYqVnqKoQx4jcTdJXxwKAissE3Jbrrc1'; var utxo_2a_address = 'mrU9pEmAx26HcbKVrABvgL7AwA5fjNFoDc'; From ad4bc9324fed7c03a27ccb24fe7b88dfada2c5f3 Mon Sep 17 00:00:00 2001 From: Braydon Fuller Date: Sat, 13 Dec 2014 14:35:25 -0500 Subject: [PATCH 3/4] Transaction: Use Script toString for transaction JSON output --- lib/transaction/input/input.js | 2 +- lib/transaction/output.js | 4 ++-- test/transaction.js | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/lib/transaction/input/input.js b/lib/transaction/input/input.js index e01fb12..fd85364 100644 --- a/lib/transaction/input/input.js +++ b/lib/transaction/input/input.js @@ -45,7 +45,7 @@ Input.prototype.toObject = function toObject() { prevTxId: this.prevTxId.toString('hex'), outputIndex: this.outputIndex, sequenceNumber: this.sequenceNumber, - script: this._scriptBuffer.toString('hex') + script: this._script.toString() }; }; diff --git a/lib/transaction/output.js b/lib/transaction/output.js index 2fdd26f..95406b3 100644 --- a/lib/transaction/output.js +++ b/lib/transaction/output.js @@ -38,7 +38,7 @@ Object.defineProperty(Output.prototype, 'satoshis', { if (num instanceof BN) { this._satoshis = num; } else { - this._satoshis = BN().fromNumber(num); + this._satoshis = BN(num, 'hex'); } } }); @@ -54,7 +54,7 @@ Output.prototype._fromObject = function(param) { Output.prototype.toObject = function toObject() { return { satoshis: this.satoshis, - script: this._scriptBuffer.toString('hex') + script: this._script.toString() }; }; diff --git a/test/transaction.js b/test/transaction.js index 4ef0c84..b01c734 100644 --- a/test/transaction.js +++ b/test/transaction.js @@ -68,10 +68,10 @@ var tx_1_json = JSON.stringify({ prevTxId:"a477af6b2667c29670467e4e0728b685ee07b240235771862318e29ddbe58458", outputIndex:0, sequenceNumber:4294967295, - script:"473044022013fa3089327b50263029265572ae1b022a91d10ac80eb4f32f291c914533670b02200d8a5ed5f62634a7e1a0dc9188a3cc460a986267ae4d58faf50c79105431327501210223078d2942df62c45621d209fab84ea9a7a23346201b7727b9b45a29c4e76f5e"}], + script:'71 0x3044022013fa3089327b50263029265572ae1b022a91d10ac80eb4f32f291c914533670b02200d8a5ed5f62634a7e1a0dc9188a3cc460a986267ae4d58faf50c79105431327501 33 0x0223078d2942df62c45621d209fab84ea9a7a23346201b7727b9b45a29c4e76f5e'}], outputs:[{ satoshis:1010000, - script:"76a9147821c0a3768aa9d1a37e16cf76002aef5373f1a888ac" + script:'OP_DUP OP_HASH160 20 0x7821c0a3768aa9d1a37e16cf76002aef5373f1a8 OP_EQUALVERIFY OP_CHECKSIG' }], nLockTime:0 }); From 6f6d56866161935b7b2182d2351881ff098eee81 Mon Sep 17 00:00:00 2001 From: Braydon Fuller Date: Sat, 13 Dec 2014 15:10:51 -0500 Subject: [PATCH 4/4] Transaction: toNumber/fromNumber to set satoshis --- lib/transaction/output.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/transaction/output.js b/lib/transaction/output.js index 95406b3..c7a988d 100644 --- a/lib/transaction/output.js +++ b/lib/transaction/output.js @@ -38,7 +38,7 @@ Object.defineProperty(Output.prototype, 'satoshis', { if (num instanceof BN) { this._satoshis = num; } else { - this._satoshis = BN(num, 'hex'); + this._satoshis = BN().fromNumber(num); } } });