-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathbcoin-p2pkh.js
91 lines (69 loc) · 2.12 KB
/
bcoin-p2pkh.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
'use strict';
const bledger = require('../lib/bledger');
const {LedgerBcoin, LedgerTXInput} = bledger;
const {Device} = bledger.USB;
const MTX = require('bcoin/lib/primitives/mtx');
const Amount = require('bcoin/lib/btc/amount');
const KeyRing = require('bcoin/lib/primitives/keyring');
const Logger = require('blgr');
const fundUtil = require('../test/util/fund');
(async () => {
const logger = new Logger({
console: true,
level: 'info'
});
await logger.open();
const device = await Device.requestDevice();
device.set({
timeout: 20000,
logger
});
await device.open();
/**
* We receive 2 transactions per path
* combine all of them and send to one address,
* with little change left
*/
const ledgerBcoin = new LedgerBcoin({ device, logger });
const account = 'm/44/0\'/0\'';
const accinfo = [
{ path: `${account}/0/0` },
{ path: `${account}/1/0` },
{ path: `${account}/1/1` }
];
// we need address to send tx to ourselves.
for (const info of accinfo) {
const hd = await ledgerBcoin.getPublicKey(info.path);
const ring = KeyRing.fromPublic(hd.publicKey);
info.address = ring.getAddress('base58');
// fund with 2 transactions
const {coins, txs} = await fundUtil.fundAddress(info.address, 2);
info.coins = coins;
info.txs = txs;
}
const coins = accinfo.reduce((coins, info) => coins.concat(info.coins), []);
const spendAmount = coins.length - 1;
const mtx = new MTX();
mtx.addOutput({
address: '3Bi9H1hzCHWJoFEjc4xzVzEMywi35dyvsV',
value: Amount.fromBTC(spendAmount).toValue()
});
await mtx.fund(coins, { changeAddress: accinfo[0].address });
let ledgerInputs = [];
for (const info of accinfo) {
ledgerInputs = ledgerInputs.concat(info.txs.map((tx, i) => {
return new LedgerTXInput({
tx: tx,
index: info.coins[i].index,
path: info.path
});
}));
}
await ledgerBcoin.signTransaction(mtx, ledgerInputs);
console.log(mtx.toRaw().toString('hex'));
console.log(`Valid Transaction: ${mtx.verify()}.`);
await device.close();
})().catch((e) => {
console.error(e);
process.exit(1);
});