-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path11_pay_to_multisig.js
101 lines (82 loc) · 3.12 KB
/
11_pay_to_multisig.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
var explorers = require('bitcore-explorers'); delete global._bitcore;
var bitcore = require('bitcore-lib');
var Insight = explorers.Insight;
// Indirizzo sorgente - deterministico - brain wallet
var walletNumero = 1;
var value = new Buffer('casa cane gatto leone tigre' + '__' + walletNumero);
var hash = bitcore.crypto.Hash.sha256(value);
var bn = bitcore.crypto.BN.fromBuffer(hash);
var source = {};
source.privateKey = new bitcore.PrivateKey(bn);
source.publicKey = source.privateKey.toAddress('testnet');
console.log('Indirizzo sorgente ', source.publicKey);
console.log('');
// Indirizzi destinazione multisig
// https://github.com/bitpay/bitcore-lib/blob/master/docs/examples.md#import-an-address-via-wif
// https://www.bitaddress.org/ // ?testnet=true
var wif_private_keys = require('./WIF_private_keys.js');
var address_pippo = new bitcore.PrivateKey.fromWIF(wif_private_keys.pippo);
var address_peppino = new bitcore.PrivateKey.fromWIF(wif_private_keys.peppino);
var address_cappuccio = new bitcore.PrivateKey.fromWIF(wif_private_keys.cappuccio);
var dest_pubkeys = [
new bitcore.PublicKey(address_pippo) ,
new bitcore.PublicKey(address_peppino),
new bitcore.PublicKey(address_cappuccio),
];
dest_pubkeys.sort();
// script multi sig
var threshold = 2;
var dest_address = new bitcore.Address(dest_pubkeys, threshold, bitcore.Networks.testnet);
console.log('Indirizzi destinazione ');
console.log(dest_pubkeys[0]);
console.log(dest_pubkeys[1]);
console.log(dest_pubkeys[2]);
console.log('');
//var script = new bitcore.Script.buildMultisigOut(dest_pubkeys, threshold);
// console.log('Script Multisig ');
// console.log(script.toString(), '\n');
console.log(dest_address);
// Ora andiamo a trovare un output di transazione non speso
var insight = new Insight('testnet');
insight.getUnspentUtxos(source.publicKey, function(err, utxos){
if(err){
console.log(err);
}else{
// console.log('ecco un\'output di transazione non speso: ', utxos);
var tx = bitcore.Transaction();
tx.from(utxos);
// tx.addOutput(
// new bitcore.Transaction.Output({
// script: script,
// satoshis: 200000
// })
// );
tx.to(dest_address, 500000);
// daro' 50000 satoshi al miner che inserira' nel blocco
// la mia transazione :)
tx.fee(50000);
// il resto mettilo sempre nel mio wallet sorgente :)
tx.change(source.publicKey);
// segno questa transazione con la mia chiave privata
// si sono io che voglio inviare questi satoshi :)
tx.sign(source.privateKey);
// console.log('questa e\' la transazione', tx.toObject());
tx.serialize();
var scriptIn = bitcore.Script(tx.toObject().inputs[0].script);
console.log('input scripting: ', scriptIn);
var scriptOut = bitcore.Script(tx.toObject().outputs[0].script);
console.log('\noutput scripting 0 : ', scriptOut);
var scriptOut = bitcore.Script(tx.toObject().outputs[1].script);
console.log('output scripting 1 : ', scriptOut);
// invio al network la transazione
insight.broadcast(tx.toString(), function(err, returnedTxId){
if(err){
console.log(err);
}else{
console.log(
'transazione inviata, ecco l\'Id Transazione: ',
returnedTxId);
}
});
}
});