|
@ -1,6 +1,7 @@ |
|
|
var assert = require('assert') |
|
|
var assert = require('assert') |
|
|
var bufferutils = require('./bufferutils') |
|
|
var bufferutils = require('./bufferutils') |
|
|
var crypto = require('./crypto') |
|
|
var crypto = require('./crypto') |
|
|
|
|
|
var enforceType = require('./types') |
|
|
var opcodes = require('./opcodes') |
|
|
var opcodes = require('./opcodes') |
|
|
var scripts = require('./scripts') |
|
|
var scripts = require('./scripts') |
|
|
|
|
|
|
|
@ -8,12 +9,6 @@ var Address = require('./address') |
|
|
var ECSignature = require('./ecsignature') |
|
|
var ECSignature = require('./ecsignature') |
|
|
var Script = require('./script') |
|
|
var Script = require('./script') |
|
|
|
|
|
|
|
|
Transaction.DEFAULT_SEQUENCE = 0xffffffff |
|
|
|
|
|
Transaction.SIGHASH_ALL = 0x01 |
|
|
|
|
|
Transaction.SIGHASH_NONE = 0x02 |
|
|
|
|
|
Transaction.SIGHASH_SINGLE = 0x03 |
|
|
|
|
|
Transaction.SIGHASH_ANYONECANPAY = 0x80 |
|
|
|
|
|
|
|
|
|
|
|
function Transaction() { |
|
|
function Transaction() { |
|
|
this.version = 1 |
|
|
this.version = 1 |
|
|
this.locktime = 0 |
|
|
this.locktime = 0 |
|
@ -21,6 +16,12 @@ function Transaction() { |
|
|
this.outs = [] |
|
|
this.outs = [] |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Transaction.DEFAULT_SEQUENCE = 0xffffffff |
|
|
|
|
|
Transaction.SIGHASH_ALL = 0x01 |
|
|
|
|
|
Transaction.SIGHASH_NONE = 0x02 |
|
|
|
|
|
Transaction.SIGHASH_SINGLE = 0x03 |
|
|
|
|
|
Transaction.SIGHASH_ANYONECANPAY = 0x80 |
|
|
|
|
|
|
|
|
/** |
|
|
/** |
|
|
* Create a new txin. |
|
|
* Create a new txin. |
|
|
* |
|
|
* |
|
@ -31,26 +32,23 @@ function Transaction() { |
|
|
* |
|
|
* |
|
|
* Note that this method does not sign the created input. |
|
|
* Note that this method does not sign the created input. |
|
|
*/ |
|
|
*/ |
|
|
Transaction.prototype.addInput = function(tx, index, sequence) { |
|
|
Transaction.prototype.addInput = function(hash, index, sequence) { |
|
|
if (sequence == undefined) sequence = Transaction.DEFAULT_SEQUENCE |
|
|
if (sequence === undefined) sequence = Transaction.DEFAULT_SEQUENCE |
|
|
|
|
|
|
|
|
var hash |
|
|
if (typeof hash === 'string') { |
|
|
|
|
|
|
|
|
if (typeof tx === 'string') { |
|
|
|
|
|
// TxId hex is big-endian, we need little-endian
|
|
|
// TxId hex is big-endian, we need little-endian
|
|
|
hash = bufferutils.reverse(new Buffer(tx, 'hex')) |
|
|
hash = bufferutils.reverse(new Buffer(hash, 'hex')) |
|
|
|
|
|
|
|
|
} else if (tx instanceof Transaction) { |
|
|
} else if (hash instanceof Transaction) { |
|
|
hash = tx.getHash() |
|
|
hash = hash.getHash() |
|
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
hash = tx |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
assert(Buffer.isBuffer(hash), 'Expected Transaction, txId or txHash, got ' + tx) |
|
|
enforceType('Buffer', hash) |
|
|
|
|
|
enforceType('Number', index) |
|
|
|
|
|
enforceType('Number', sequence) |
|
|
|
|
|
|
|
|
assert.equal(hash.length, 32, 'Expected hash length of 32, got ' + hash.length) |
|
|
assert.equal(hash.length, 32, 'Expected hash length of 32, got ' + hash.length) |
|
|
assert(isFinite(index), 'Expected number index, got ' + index) |
|
|
|
|
|
assert(isFinite(sequence), 'Expected number sequence, got ' + sequence) |
|
|
|
|
|
|
|
|
|
|
|
// Add the input and return the input's index
|
|
|
// Add the input and return the input's index
|
|
|
return (this.ins.push({ |
|
|
return (this.ins.push({ |
|
@ -81,8 +79,8 @@ Transaction.prototype.addOutput = function(scriptPubKey, value) { |
|
|
scriptPubKey = scriptPubKey.toOutputScript() |
|
|
scriptPubKey = scriptPubKey.toOutputScript() |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
assert(scriptPubKey instanceof Script, 'Expected Address or Script, got ' + scriptPubKey) |
|
|
enforceType(Script, scriptPubKey) |
|
|
assert(isFinite(value), 'Expected number value, got ' + value) |
|
|
enforceType('Number', value) |
|
|
|
|
|
|
|
|
// Add the output and return the output's index
|
|
|
// Add the output and return the output's index
|
|
|
return (this.outs.push({ |
|
|
return (this.outs.push({ |
|
@ -172,9 +170,12 @@ Transaction.prototype.hashForSignature = function(inIndex, prevOutScript, hashTy |
|
|
prevOutScript = tmp |
|
|
prevOutScript = tmp |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
enforceType('Number', inIndex) |
|
|
|
|
|
enforceType(Script, prevOutScript) |
|
|
|
|
|
enforceType('Number', hashType) |
|
|
|
|
|
|
|
|
assert(inIndex >= 0, 'Invalid vin index') |
|
|
assert(inIndex >= 0, 'Invalid vin index') |
|
|
assert(inIndex < this.ins.length, 'Invalid vin index') |
|
|
assert(inIndex < this.ins.length, 'Invalid vin index') |
|
|
assert(prevOutScript instanceof Script, 'Invalid Script object') |
|
|
|
|
|
|
|
|
|
|
|
var txTmp = this.clone() |
|
|
var txTmp = this.clone() |
|
|
var hashScript = prevOutScript.without(opcodes.OP_CODESEPARATOR) |
|
|
var hashScript = prevOutScript.without(opcodes.OP_CODESEPARATOR) |
|
|