2014-03-31 12:25:43 -07:00
var run = function ( ) {
2014-06-23 10:57:02 -07:00
bitcore = typeof ( bitcore ) === 'undefined' ? require ( '../bitcore' ) : bitcore ;
2014-03-31 12:25:43 -07:00
var networks = require ( '../networks' ) ;
var WalletKey = bitcore . WalletKey ;
var Script = bitcore . Script ;
var Builder = bitcore . TransactionBuilder ;
2014-06-23 10:57:02 -07:00
var opts = {
network : networks . testnet
} ;
2014-03-31 12:25:43 -07:00
console . log ( '## Network: ' + opts . network . name ) ;
var input = { } ;
input . addr = "n2hoFVbPrYQf7RJwiRy1tkbuPPqyhAEfbp" ;
input . priv = "cS62Ej4SobZnpFQYN1PEEBr2KWf5sgRYYnELtumcG6WVCfxno39V" ;
// Complete with the corresponding UTXO you want to use
2014-06-23 10:57:02 -07:00
var utxos = [ {
2014-03-31 20:07:45 -07:00
address : "n2hoFVbPrYQf7RJwiRy1tkbuPPqyhAEfbp" ,
2014-04-01 20:59:26 -07:00
txid : "e4bc22d8c519d3cf848d710619f8480be56176a4a6548dfbe865ab3886b578b5" ,
2014-03-31 20:07:45 -07:00
vout : 1 ,
ts : 1396290442 ,
2014-03-31 12:25:43 -07:00
scriptPubKey : "76a914e867aad8bd361f57c50adc37a0c018692b5b0c9a88ac" ,
2014-06-23 10:57:02 -07:00
amount : 0.3795 ,
2014-03-31 20:07:45 -07:00
confirmations : 7
2014-06-23 10:57:02 -07:00
} ] ;
2014-03-31 12:25:43 -07:00
2014-06-23 10:57:02 -07:00
var privs = [
2014-04-01 05:58:17 -07:00
"cMpKwGr5oxEacN95WFKNEq6tTcvi11regFwS3muHvGYVxMPJX8JA" ,
"cVf32m9MR4vxcPwKNJuPepUe8XrHD2z63eCk76d6njRGyCkXpkSM" ,
"cQ2sVRFX4jQYMLhWyzz6jTQ2xju51P36968ecXnPhRLKLH677eKR" ,
"cSw7x9ERcmeWCU3yVBT6Nz7b9JiZ5yjUB7JMhBUv9UM7rSaDpwX9" ,
"cRQBM8qM4ZXJGP1De4D5RtJm7Q6FNWQSMx7YExxzgn2ehjM3haxW" ,
2014-03-31 12:25:43 -07:00
] ;
var pubkeys = [ ]
privs . forEach ( function ( p ) {
var wk = new WalletKey ( opts ) ;
2014-06-23 10:57:02 -07:00
wk . fromObj ( {
priv : p
} ) ;
2014-03-31 12:25:43 -07:00
pubkeys . push ( bitcore . buffertools . toHex ( wk . privKey . public ) ) ;
} ) ;
2014-03-31 20:07:45 -07:00
// multisig p2sh
2014-06-23 10:57:02 -07:00
var opts = {
nreq : 3 ,
pubkeys : pubkeys
} ;
2014-03-31 12:25:43 -07:00
2014-03-31 20:07:45 -07:00
// p2scriphash p2sh
2014-04-09 10:13:48 -07:00
//var opts = [{address: an_address}];
2014-06-23 10:57:02 -07:00
2014-03-31 20:07:45 -07:00
var info = Builder . infoForP2sh ( opts , 'testnet' ) ;
var p2shScript = info . scriptBufHex ;
var p2shAddress = info . address ;
2014-04-01 05:58:17 -07:00
2014-06-23 10:57:02 -07:00
var outs = [ {
address : p2shAddress ,
amount : 0.05
} ] ;
2014-03-31 12:25:43 -07:00
var tx = new Builder ( opts )
. setUnspent ( utxos )
. setOutputs ( outs )
. sign ( [ input . priv ] )
. build ( ) ;
2014-04-01 20:59:26 -07:00
2014-06-23 10:57:02 -07:00
var txHex = tx . serialize ( ) . toString ( 'hex' ) ;
2014-04-01 05:58:17 -07:00
2014-04-01 20:59:26 -07:00
console . log ( '## p2sh address: ' + p2shAddress ) ; //TODO
console . log ( '\n1) SEND TO P2SH TX: ' , txHex ) ;
console . log ( '[this example originally generated TXID: c2e50d1c8c581d8c4408378b751633f7eb86687fc5f0502be7b467173f275ae7 on testnet]\n\n\thttp://test.bitcore.io/tx/c2e50d1c8c581d8c4408378b751633f7eb86687fc5f0502be7b467173f275ae7\n\n' ) ;
2014-03-31 12:25:43 -07:00
//save scriptPubKey
var scriptPubKey = tx . outs [ 0 ] . s . toString ( 'hex' ) ;
/ *
*
* REDDEEM TX
* /
2014-06-23 10:57:02 -07:00
var utxos2 = [ {
2014-03-31 20:07:45 -07:00
address : p2shAddress ,
2014-04-01 20:59:26 -07:00
txid : "c2e50d1c8c581d8c4408378b751633f7eb86687fc5f0502be7b467173f275ae7" ,
2014-03-31 12:25:43 -07:00
vout : 0 ,
2014-04-01 20:59:26 -07:00
ts : 1396375187 ,
scriptPubKey : scriptPubKey ,
2014-03-31 12:25:43 -07:00
amount : 0.05 ,
2014-04-01 20:59:26 -07:00
confirmations : 1
2014-06-23 10:57:02 -07:00
} ] ;
2014-03-31 12:25:43 -07:00
2014-06-23 10:57:02 -07:00
outs = [ {
address : input . addr ,
amount : 0.04
} ] ;
2014-03-31 20:07:45 -07:00
var hashMap = { } ;
2014-06-23 10:57:02 -07:00
hashMap [ p2shAddress ] = p2shScript ;
2014-03-31 20:07:45 -07:00
2014-03-31 12:25:43 -07:00
var b = new Builder ( opts )
. setUnspent ( utxos2 )
2014-03-31 20:07:45 -07:00
. setHashToScriptMap ( hashMap )
2014-03-31 12:25:43 -07:00
. setOutputs ( outs )
. sign ( privs ) ;
2014-06-23 10:57:02 -07:00
tx = b . build ( ) ;
2014-03-31 12:25:43 -07:00
2014-06-23 10:57:02 -07:00
console . log ( 'Builder:' ) ;
console . log ( '\tSignatures:' + tx . countInputMissingSignatures ( 0 ) ) ;
console . log ( '\t#isFullySigned:' + b . isFullySigned ( ) ) ;
2014-04-01 20:59:26 -07:00
2014-06-23 10:57:02 -07:00
console . log ( 'TX:' ) ;
console . log ( '\t #isComplete:' + tx . isComplete ( ) ) ;
2014-04-01 20:59:26 -07:00
2014-06-23 10:57:02 -07:00
var txHex = tx . serialize ( ) . toString ( 'hex' ) ;
2014-03-31 12:25:43 -07:00
console . log ( '2) REDEEM SCRIPT: ' , txHex ) ;
2014-04-01 20:59:26 -07:00
console . log ( '[this example originally generated TXID: 8284aa3b6f9c71c35ecb1d61d05ae78c8ca1f36940eaa615b50584dfc3d95cb7 on testnet]\n\n\thttp://test.bitcore.io/tx/8284aa3b6f9c71c35ecb1d61d05ae78c8ca1f36940eaa615b50584dfc3d95cb7\n\n' ) ;
2014-06-23 10:57:02 -07:00
/ *
2014-04-01 20:59:26 -07:00
// To send TX with RPC:
var RpcClient = bitcore . RpcClient ;
var config = {
protocol : 'http' ,
user : 'user' ,
pass : 'pass' ,
host : '127.0.0.1' ,
port : '18332' ,
} ;
var rpc = new RpcClient ( config ) ;
rpc . sendRawTransaction ( txHex , function ( err , ret ) {
console . log ( 'err' , err ) ; //TODO
console . log ( 'ret' , ret ) ; //TODO
process . exit ( - 1 ) ;
} ) ;
} ;
* /
2014-03-31 12:25:43 -07:00
} ;
2014-04-01 20:59:26 -07:00
2014-03-31 12:25:43 -07:00
// This is just for browser & mocha compatibility
if ( typeof module !== 'undefined' ) {
module . exports . run = run ;
if ( require . main === module ) {
run ( ) ;
}
} else {
run ( ) ;
}