|
@ -196,21 +196,27 @@ Script.prototype.isPublicKeyHashIn = function() { |
|
|
this.chunks[0].buf.length >= 0x47 && |
|
|
this.chunks[0].buf.length >= 0x47 && |
|
|
this.chunks[0].buf.length <= 0x49 && |
|
|
this.chunks[0].buf.length <= 0x49 && |
|
|
this.chunks[1].buf && |
|
|
this.chunks[1].buf && |
|
|
|
|
|
PublicKey.isValid(this.chunks[1].buf)); |
|
|
|
|
|
/* |
|
|
( |
|
|
( |
|
|
// compressed public key
|
|
|
// compressed public key
|
|
|
(this.chunks[1].buf[0] === 0x03 && this.chunks[1].buf.length === 0x21) || |
|
|
( |
|
|
|
|
|
(this.chunks[1].buf[0] === 0x02 || this.chunks[1].buf[0] === 0x03) && |
|
|
|
|
|
this.chunks[1].buf.length === 0x21) || |
|
|
// uncompressed public key
|
|
|
// uncompressed public key
|
|
|
(this.chunks[1].buf[0] === 0x04 && this.chunks[1].buf.length === 0x41)) |
|
|
(this.chunks[1].buf[0] === 0x04 && this.chunks[1].buf.length === 0x41)) |
|
|
); |
|
|
); |
|
|
|
|
|
*/ |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
/** |
|
|
/** |
|
|
* @returns true if this is a public key output script |
|
|
* @returns true if this is a public key output script |
|
|
*/ |
|
|
*/ |
|
|
Script.prototype.isPublicKeyOut = function() { |
|
|
Script.prototype.isPublicKeyOut = function() { |
|
|
|
|
|
console.log(this.toString()); |
|
|
return this.chunks.length === 2 && |
|
|
return this.chunks.length === 2 && |
|
|
Buffer.isBuffer(this.chunks[0].buf) && |
|
|
Buffer.isBuffer(this.chunks[0].buf) && |
|
|
this.chunks[0].buf.length === 0x41 && |
|
|
PublicKey.isValid(this.chunks[0].buf) && |
|
|
this.chunks[1] === Opcode('OP_CHECKSIG').toNumber(); |
|
|
this.chunks[1] === Opcode('OP_CHECKSIG').toNumber(); |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
@ -404,13 +410,15 @@ Script.prototype._addOpcode = function(opcode, prepend) { |
|
|
Script.prototype._addBuffer = function(buf, prepend) { |
|
|
Script.prototype._addBuffer = function(buf, prepend) { |
|
|
var opcodenum; |
|
|
var opcodenum; |
|
|
var len = buf.length; |
|
|
var len = buf.length; |
|
|
if (buf.length > 0 && buf.length < Opcode.map.OP_PUSHDATA1) { |
|
|
if (len === 0) { |
|
|
opcodenum = buf.length; |
|
|
return; |
|
|
} else if (buf.length < Math.pow(2, 8)) { |
|
|
} else if (len > 0 && len < Opcode.map.OP_PUSHDATA1) { |
|
|
|
|
|
opcodenum = len; |
|
|
|
|
|
} else if (len < Math.pow(2, 8)) { |
|
|
opcodenum = Opcode.map.OP_PUSHDATA1; |
|
|
opcodenum = Opcode.map.OP_PUSHDATA1; |
|
|
} else if (buf.length < Math.pow(2, 16)) { |
|
|
} else if (len < Math.pow(2, 16)) { |
|
|
opcodenum = Opcode.map.OP_PUSHDATA2; |
|
|
opcodenum = Opcode.map.OP_PUSHDATA2; |
|
|
} else if (buf.length < Math.pow(2, 32)) { |
|
|
} else if (len < Math.pow(2, 32)) { |
|
|
opcodenum = Opcode.map.OP_PUSHDATA4; |
|
|
opcodenum = Opcode.map.OP_PUSHDATA4; |
|
|
} else { |
|
|
} else { |
|
|
throw new Error('You can\'t push that much data'); |
|
|
throw new Error('You can\'t push that much data'); |
|
@ -433,7 +441,7 @@ Script.prototype._addBuffer = function(buf, prepend) { |
|
|
Script.buildMultisigOut = function(pubkeys, m) { |
|
|
Script.buildMultisigOut = function(pubkeys, m) { |
|
|
var s = new Script(); |
|
|
var s = new Script(); |
|
|
s.add(Opcode.smallInt(m)); |
|
|
s.add(Opcode.smallInt(m)); |
|
|
for (var i = 0; i<pubkeys.length; i++) { |
|
|
for (var i = 0; i < pubkeys.length; i++) { |
|
|
var pubkey = pubkeys[i]; |
|
|
var pubkey = pubkeys[i]; |
|
|
s.add(pubkey.toBuffer()); |
|
|
s.add(pubkey.toBuffer()); |
|
|
} |
|
|
} |
|
@ -464,16 +472,23 @@ Script.buildPublicKeyHashOut = function(to) { |
|
|
* public key |
|
|
* public key |
|
|
*/ |
|
|
*/ |
|
|
Script.buildPublicKeyOut = function(pubkey) { |
|
|
Script.buildPublicKeyOut = function(pubkey) { |
|
|
console.log(pubkey); |
|
|
var s = new Script(); |
|
|
return new Script(); |
|
|
s.add(pubkey.toBuffer()) |
|
|
|
|
|
.add(Opcode('OP_CHECKSIG')); |
|
|
|
|
|
return s; |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
/** |
|
|
/** |
|
|
* @returns a new OP_RETURN script with data |
|
|
* @returns a new OP_RETURN script with data |
|
|
*/ |
|
|
*/ |
|
|
Script.buildDataOut = function(data) { |
|
|
Script.buildDataOut = function(data) { |
|
|
console.log(data); |
|
|
if (typeof data === 'string') { |
|
|
return new Script(); |
|
|
data = new Buffer(data); |
|
|
|
|
|
} |
|
|
|
|
|
var s = new Script(); |
|
|
|
|
|
s.add(Opcode('OP_RETURN')) |
|
|
|
|
|
.add(data); |
|
|
|
|
|
return s; |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
/** |
|
|
/** |
|
|