ln-service 53.7.3 → 53.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/README.md +129 -0
- package/index.js +4 -0
- package/package.json +6 -4
- package/test/integration/test_get_pending_payments.js +87 -0
- package/test/integration/test_send_to_chain_address.js +4 -0
- package/test/walletrpc-integration/test_get_master_public_keys.js +79 -0
- package/test/walletrpc-integration/test_partially_sign_psbt.js +5 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# Versions
|
|
2
2
|
|
|
3
|
+
## 53.9.1
|
|
4
|
+
|
|
5
|
+
- `getPendingPayments`: Add method to get payments in flight
|
|
6
|
+
|
|
7
|
+
## 53.8.1
|
|
8
|
+
|
|
9
|
+
- `fundPsbt`: Fix bip32 key derivation error
|
|
10
|
+
|
|
11
|
+
## 53.8.0
|
|
12
|
+
|
|
13
|
+
- `getMasterPublicKeys`: Add method to get bip32 master public keys
|
|
14
|
+
|
|
3
15
|
## 53.7.3
|
|
4
16
|
|
|
5
17
|
- `payViaRoutes`, `subscribeToPayViaRoutes`: Add support for relay messages
|
package/README.md
CHANGED
|
@@ -157,6 +157,7 @@ for `unlocker` methods.
|
|
|
157
157
|
- [getInvoice](#getinvoice) - Get a previously created invoice
|
|
158
158
|
- [getInvoices](#getinvoices) - Get all previously created invoices
|
|
159
159
|
- [getLockedUtxos](#getlockedutxos) - Get all previously locked UTXOs
|
|
160
|
+
- [getMasterPublicKeys](#getmasterpublickeys) - Get a list of master pub keys
|
|
160
161
|
- [getMethods](#getmethods) - Get available methods and associated permissions
|
|
161
162
|
- [getNetworkCentrality](#getnetworkcentrality) - Get centrality score for nodes
|
|
162
163
|
- [getNetworkGraph](#getnetworkgraph) - Get the channels and nodes of the graph
|
|
@@ -169,6 +170,7 @@ for `unlocker` methods.
|
|
|
169
170
|
- [getPeers](#getpeers) - Get all connected peers
|
|
170
171
|
- [getPendingChainBalance](#getpendingchainbalance) - Get pending chain balance
|
|
171
172
|
- [getPendingChannels](#getpendingchannels) - Get channels in pending states
|
|
173
|
+
- [getPendingPayments](#getpendingpayments) - Get in-flight outgoing payments
|
|
172
174
|
- [getPublicKey](#getpublickey) - Get a public key out of the seed
|
|
173
175
|
- [getRouteConfidence](#getrouteconfidence) - Get confidence in a route
|
|
174
176
|
- [getRouteThroughHops](#getroutethroughhops) - Get a route through nodes
|
|
@@ -2102,6 +2104,41 @@ const {getLockedUtxos} = require('ln-service');
|
|
|
2102
2104
|
const numLockedUtxos = (await getLockedUtxos({lnd})).utxos.length;
|
|
2103
2105
|
```
|
|
2104
2106
|
|
|
2107
|
+
### getMasterPublicKeys
|
|
2108
|
+
|
|
2109
|
+
Get the currently tracked master public keys
|
|
2110
|
+
|
|
2111
|
+
Requires LND compiled with `walletrpc` build tag
|
|
2112
|
+
|
|
2113
|
+
Requires `onchain:read` permission
|
|
2114
|
+
|
|
2115
|
+
This method is not supported in LND 0.13.3 and below
|
|
2116
|
+
|
|
2117
|
+
{
|
|
2118
|
+
lnd: <Authenticated API LND Object>
|
|
2119
|
+
}
|
|
2120
|
+
|
|
2121
|
+
@returns via cbk or Promise
|
|
2122
|
+
{
|
|
2123
|
+
keys: [{
|
|
2124
|
+
derivation_path: <Key Derivation Path String>
|
|
2125
|
+
extended_public_key: <Base58 Encoded Master Public Key String>
|
|
2126
|
+
external_key_count: <Used External Keys Count Number>
|
|
2127
|
+
internal_key_count: <Used Internal Keys Count Number>
|
|
2128
|
+
is_watch_only: <Node has Master Private Key Bool>
|
|
2129
|
+
named: <Account Name String>
|
|
2130
|
+
}]
|
|
2131
|
+
}
|
|
2132
|
+
|
|
2133
|
+
```node
|
|
2134
|
+
const {getMasterPublicKeys} = require('ln-service');
|
|
2135
|
+
|
|
2136
|
+
const {keys} = await getMasterPublicKeys({lnd});
|
|
2137
|
+
|
|
2138
|
+
// Find the master public key that derives pay to witness public key hash keys
|
|
2139
|
+
const masterAddressesKey = keys.find(n => n.derivation_path === `m/84'/0'/0'`);
|
|
2140
|
+
```
|
|
2141
|
+
|
|
2105
2142
|
### getMethods
|
|
2106
2143
|
|
|
2107
2144
|
Get the list of all methods and their associated requisite permissions
|
|
@@ -2626,6 +2663,98 @@ const {getPendingChannels} = require('ln-service');
|
|
|
2626
2663
|
const pendingChannels = (await getPendingChannels({lnd})).pending_channels;
|
|
2627
2664
|
```
|
|
2628
2665
|
|
|
2666
|
+
### getPendingPayments
|
|
2667
|
+
|
|
2668
|
+
Get pending payments made through channels.
|
|
2669
|
+
|
|
2670
|
+
Requires `offchain:read` permission
|
|
2671
|
+
|
|
2672
|
+
{
|
|
2673
|
+
[limit]: <Page Result Limit Number>
|
|
2674
|
+
lnd: <Authenticated LND API Object>
|
|
2675
|
+
[token]: <Opaque Paging Token String>
|
|
2676
|
+
}
|
|
2677
|
+
|
|
2678
|
+
@returns via cbk or Promise
|
|
2679
|
+
{
|
|
2680
|
+
payments: [{
|
|
2681
|
+
attempts: [{
|
|
2682
|
+
[failure]: {
|
|
2683
|
+
code: <Error Type Code Number>
|
|
2684
|
+
[details]: {
|
|
2685
|
+
[channel]: <Standard Format Channel Id String>
|
|
2686
|
+
[height]: <Error Associated Block Height Number>
|
|
2687
|
+
[index]: <Failed Hop Index Number>
|
|
2688
|
+
[mtokens]: <Error Millitokens String>
|
|
2689
|
+
[policy]: {
|
|
2690
|
+
base_fee_mtokens: <Base Fee Millitokens String>
|
|
2691
|
+
cltv_delta: <Locktime Delta Number>
|
|
2692
|
+
fee_rate: <Fees Charged in Millitokens Per Million Number>
|
|
2693
|
+
[is_disabled]: <Channel is Disabled Bool>
|
|
2694
|
+
max_htlc_mtokens: <Maximum HLTC Millitokens Value String>
|
|
2695
|
+
min_htlc_mtokens: <Minimum HTLC Millitokens Value String>
|
|
2696
|
+
updated_at: <Updated At ISO 8601 Date String>
|
|
2697
|
+
}
|
|
2698
|
+
[timeout_height]: <Error CLTV Timeout Height Number>
|
|
2699
|
+
[update]: {
|
|
2700
|
+
chain: <Chain Id Hex String>
|
|
2701
|
+
channel_flags: <Channel Flags Number>
|
|
2702
|
+
extra_opaque_data: <Extra Opaque Data Hex String>
|
|
2703
|
+
message_flags: <Message Flags Number>
|
|
2704
|
+
signature: <Channel Update Signature Hex String>
|
|
2705
|
+
}
|
|
2706
|
+
}
|
|
2707
|
+
message: <Error Message String>
|
|
2708
|
+
}
|
|
2709
|
+
[index]: <Payment Add Index Number>
|
|
2710
|
+
[confirmed_at]: <Payment Confirmed At ISO 8601 Date String>
|
|
2711
|
+
is_confirmed: <Payment Attempt Succeeded Bool>
|
|
2712
|
+
is_failed: <Payment Attempt Failed Bool>
|
|
2713
|
+
is_pending: <Payment Attempt is Waiting For Resolution Bool>
|
|
2714
|
+
route: {
|
|
2715
|
+
fee: <Route Fee Tokens Number>
|
|
2716
|
+
fee_mtokens: <Route Fee Millitokens String>
|
|
2717
|
+
hops: [{
|
|
2718
|
+
channel: <Standard Format Channel Id String>
|
|
2719
|
+
channel_capacity: <Channel Capacity Tokens Number>
|
|
2720
|
+
fee: <Fee Number>
|
|
2721
|
+
fee_mtokens: <Fee Millitokens String>
|
|
2722
|
+
forward: <Forward Tokens Number>
|
|
2723
|
+
forward_mtokens: <Forward Millitokens String>
|
|
2724
|
+
[public_key]: <Forward Edge Public Key Hex String>
|
|
2725
|
+
[timeout]: <Timeout Block Height Number>
|
|
2726
|
+
}]
|
|
2727
|
+
mtokens: <Total Fee-Inclusive Millitokens String>
|
|
2728
|
+
[payment]: <Payment Identifier Hex String>
|
|
2729
|
+
timeout: <Timeout Block Height Number>
|
|
2730
|
+
tokens: <Total Fee-Inclusive Tokens Number>
|
|
2731
|
+
[total_mtokens]: <Total Millitokens String>
|
|
2732
|
+
}
|
|
2733
|
+
}]
|
|
2734
|
+
created_at: <Payment at ISO-8601 Date String>
|
|
2735
|
+
[destination]: <Destination Node Public Key Hex String>
|
|
2736
|
+
id: <Payment Preimage Hash String>
|
|
2737
|
+
[index]: <Payment Add Index Number>
|
|
2738
|
+
is_confirmed: <Payment is Confirmed Bool>
|
|
2739
|
+
is_outgoing: <Transaction Is Outgoing Bool>
|
|
2740
|
+
mtokens: <Millitokens Attempted to Pay to Destination String>
|
|
2741
|
+
[request]: <BOLT 11 Payment Request String>
|
|
2742
|
+
safe_tokens: <Payment Tokens Attempted to Pay Rounded Up Number>
|
|
2743
|
+
tokens: <Rounded Down Tokens Attempted to Pay to Destination Number>
|
|
2744
|
+
}]
|
|
2745
|
+
[next]: <Next Opaque Paging Token String>
|
|
2746
|
+
}
|
|
2747
|
+
|
|
2748
|
+
```node
|
|
2749
|
+
const {getPendingPayments} = require('ln-service')
|
|
2750
|
+
|
|
2751
|
+
const {next, payments} = await getPendingPayments({lnd});
|
|
2752
|
+
|
|
2753
|
+
if (!next) {
|
|
2754
|
+
const inFlightPaymentsCount = payments.length;
|
|
2755
|
+
}
|
|
2756
|
+
```
|
|
2757
|
+
|
|
2629
2758
|
### getPublicKey
|
|
2630
2759
|
|
|
2631
2760
|
Get a public key in the seed
|
package/index.js
CHANGED
|
@@ -49,6 +49,7 @@ const {getIdentity} = require('lightning');
|
|
|
49
49
|
const {getInvoice} = require('lightning');
|
|
50
50
|
const {getInvoices} = require('lightning');
|
|
51
51
|
const {getLockedUtxos} = require('lightning');
|
|
52
|
+
const {getMasterPublicKeys} = require('lightning');
|
|
52
53
|
const {getMethods} = require('lightning');
|
|
53
54
|
const {getNetworkCentrality} = require('lightning');
|
|
54
55
|
const {getNetworkGraph} = require('lightning');
|
|
@@ -60,6 +61,7 @@ const {getPayments} = require('lightning');
|
|
|
60
61
|
const {getPeers} = require('lightning');
|
|
61
62
|
const {getPendingChainBalance} = require('lightning');
|
|
62
63
|
const {getPendingChannels} = require('lightning');
|
|
64
|
+
const {getPendingPayments} = require('lightning');
|
|
63
65
|
const {getPublicKey} = require('lightning');
|
|
64
66
|
const {getRouteConfidence} = require('lightning');
|
|
65
67
|
const {getRouteThroughHops} = require('lightning');
|
|
@@ -189,6 +191,7 @@ module.exports = {
|
|
|
189
191
|
getInvoice,
|
|
190
192
|
getInvoices,
|
|
191
193
|
getLockedUtxos,
|
|
194
|
+
getMasterPublicKeys,
|
|
192
195
|
getMethods,
|
|
193
196
|
getNetworkCentrality,
|
|
194
197
|
getNetworkGraph,
|
|
@@ -200,6 +203,7 @@ module.exports = {
|
|
|
200
203
|
getPeers,
|
|
201
204
|
getPendingChainBalance,
|
|
202
205
|
getPendingChannels,
|
|
206
|
+
getPendingPayments,
|
|
203
207
|
getPublicKey,
|
|
204
208
|
getRouteConfidence,
|
|
205
209
|
getRouteThroughHops,
|
package/package.json
CHANGED
|
@@ -10,11 +10,11 @@
|
|
|
10
10
|
"bolt07": "1.8.0",
|
|
11
11
|
"cors": "2.8.5",
|
|
12
12
|
"express": "4.17.2",
|
|
13
|
-
"invoices": "2.0.
|
|
14
|
-
"lightning": "5.
|
|
13
|
+
"invoices": "2.0.4",
|
|
14
|
+
"lightning": "5.8.1",
|
|
15
15
|
"macaroon": "3.0.4",
|
|
16
16
|
"morgan": "1.10.0",
|
|
17
|
-
"ws": "8.
|
|
17
|
+
"ws": "8.5.0"
|
|
18
18
|
},
|
|
19
19
|
"description": "Interaction helper for your Lightning Network daemon",
|
|
20
20
|
"devDependencies": {
|
|
@@ -22,9 +22,11 @@
|
|
|
22
22
|
"@alexbosworth/node-fetch": "2.6.2",
|
|
23
23
|
"async": "3.2.3",
|
|
24
24
|
"asyncjs-util": "1.2.8",
|
|
25
|
+
"bip32": "3.0.1",
|
|
25
26
|
"bip66": "1.1.5",
|
|
26
27
|
"bitcoinjs-lib": "6.0.1",
|
|
27
28
|
"bn.js": "5.2.0",
|
|
29
|
+
"bs58check": "2.1.2",
|
|
28
30
|
"ecpair": "2.0.1",
|
|
29
31
|
"ln-docker-daemons": "2.2.4",
|
|
30
32
|
"portfinder": "1.0.28",
|
|
@@ -66,5 +68,5 @@
|
|
|
66
68
|
"integration-test-0.12.0": "DOCKER_LND_VERSION=v0.12.0-beta npm run test",
|
|
67
69
|
"test": "echo $DOCKER_LND_VERSION && tap -j 2 --branches=1 --functions=1 --lines=1 --statements=1 -t 200 test/autopilotrpc-integration/*.js test/chainrpc-integration/*.js test/integration/*.js test/invoicesrpc-integration/*.js test/routerrpc-integration/*.js test/signerrpc-integration/*.js test/tower_clientrpc-integration/*.js test/tower_serverrpc-integration/*.js test/walletrpc-integration/*.js"
|
|
68
70
|
},
|
|
69
|
-
"version": "53.
|
|
71
|
+
"version": "53.9.1"
|
|
70
72
|
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
const {once} = require('events');
|
|
2
|
+
|
|
3
|
+
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
4
|
+
const {test} = require('@alexbosworth/tap');
|
|
5
|
+
|
|
6
|
+
const {addPeer} = require('./../../');
|
|
7
|
+
const {createCluster} = require('./../macros');
|
|
8
|
+
const {createInvoice} = require('./../../');
|
|
9
|
+
const {deleteForwardingReputations} = require('./../../');
|
|
10
|
+
const {getHeight} = require('./../../');
|
|
11
|
+
const {getInvoice} = require('./../../');
|
|
12
|
+
const {getPayment} = require('./../../');
|
|
13
|
+
const {getPendingPayments} = require('./../../');
|
|
14
|
+
const {payViaPaymentRequest} = require('./../../');
|
|
15
|
+
const {subscribeToForwardRequests} = require('./../../');
|
|
16
|
+
const {subscribeToPayViaRequest} = require('./../../');
|
|
17
|
+
const {setupChannel} = require('./../macros');
|
|
18
|
+
const {waitForRoute} = require('./../macros');
|
|
19
|
+
|
|
20
|
+
const size = 3;
|
|
21
|
+
const tokens = 100;
|
|
22
|
+
|
|
23
|
+
// Getting pending payments should list out payments in flight
|
|
24
|
+
test(`Get pending payments`, async ({end, equal, rejects, strictSame}) => {
|
|
25
|
+
const {kill, nodes} = await spawnLightningCluster({size});
|
|
26
|
+
|
|
27
|
+
const [{generate, lnd}, target, remote] = nodes;
|
|
28
|
+
|
|
29
|
+
const channel = await setupChannel({generate, lnd, to: target});
|
|
30
|
+
|
|
31
|
+
await remote.generate({count: 100});
|
|
32
|
+
|
|
33
|
+
const remoteChan = await setupChannel({
|
|
34
|
+
lnd: target.lnd,
|
|
35
|
+
generate: target.generate,
|
|
36
|
+
to: remote,
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
await addPeer({lnd, public_key: remote.id, socket: remote.socket});
|
|
40
|
+
|
|
41
|
+
const {routes} = await waitForRoute({lnd, tokens, destination: remote.id});
|
|
42
|
+
|
|
43
|
+
let height;
|
|
44
|
+
const [route] = routes;
|
|
45
|
+
|
|
46
|
+
{
|
|
47
|
+
const invoice = await createInvoice({tokens, lnd: remote.lnd});
|
|
48
|
+
|
|
49
|
+
const sub = subscribeToForwardRequests({lnd: target.lnd});
|
|
50
|
+
|
|
51
|
+
sub.once('forward_request', async forward => {
|
|
52
|
+
const {pending} = await getPayment({lnd, id: invoice.id});
|
|
53
|
+
|
|
54
|
+
const {next, payments} = await getPendingPayments({lnd});
|
|
55
|
+
|
|
56
|
+
strictSame(next, undefined, 'No more pages');
|
|
57
|
+
strictSame(payments.length, 1, 'A single pending payment');
|
|
58
|
+
|
|
59
|
+
const [payment] = payments;
|
|
60
|
+
|
|
61
|
+
strictSame(payment.destination, remote.id, 'Paying to remote');
|
|
62
|
+
strictSame(payment.index, 1, 'First payment');
|
|
63
|
+
strictSame(payment.request, invoice.request, 'Paying invoice request');
|
|
64
|
+
strictSame(payment.confirmed_at, undefined, 'Not a confirmed payment');
|
|
65
|
+
strictSame(!!payment.created_at, true, 'Has created date');
|
|
66
|
+
strictSame(payment.fee, undefined, 'No fee yet');
|
|
67
|
+
strictSame(payment.fee_mtokens, undefined, 'No fee mtokens');
|
|
68
|
+
strictSame(payment.hops.length, 1, 'Going through hops');
|
|
69
|
+
strictSame(payment.id, invoice.id, 'Paying to the same hash');
|
|
70
|
+
strictSame(payment.is_confirmed, false, 'Payment is pending');
|
|
71
|
+
strictSame(payment.is_outgoing, true, 'Outgoing payment type');
|
|
72
|
+
strictSame(payment.mtokens, invoice.mtokens, 'Paying invoiced mtokens');
|
|
73
|
+
strictSame(payment.safe_fee, undefined, 'No fee paid yet');
|
|
74
|
+
strictSame(payment.safe_tokens, invoice.tokens, 'Paying safe tokens');
|
|
75
|
+
strictSame(payment.secret, undefined, 'Preimage not yet known');
|
|
76
|
+
strictSame(payment.tokens, invoice.tokens, 'Paying invoiced tokens');
|
|
77
|
+
|
|
78
|
+
return forward.accept();
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
await payViaPaymentRequest({lnd, request: invoice.request});
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
await kill({});
|
|
85
|
+
|
|
86
|
+
return end();
|
|
87
|
+
});
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
const bip32 = require('bip32');
|
|
2
|
+
const bs58check = require('bs58check');
|
|
3
|
+
const ecc = require('tiny-secp256k1')
|
|
4
|
+
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
5
|
+
const {test} = require('@alexbosworth/tap');
|
|
6
|
+
|
|
7
|
+
const {createChainAddress} = require('./../../');
|
|
8
|
+
const {getMasterPublicKeys} = require('./../../');
|
|
9
|
+
|
|
10
|
+
const asHex = n => n.toString('hex');
|
|
11
|
+
const BIP32Factory = bip32.default;
|
|
12
|
+
const chainCodeFromMasterPublicKey = n => n.slice(13, 45);
|
|
13
|
+
const firstKeyPath = 'm/0/0';
|
|
14
|
+
const identityKeyName = 'act:6';
|
|
15
|
+
const p2wpkhPath = `m/84'/0'/0'`;
|
|
16
|
+
const publicKeyFromMasterPublicKey = n => n.slice(45, 78);
|
|
17
|
+
|
|
18
|
+
// Getting master public keys should return a list of master public keys
|
|
19
|
+
test(`Get master public keys`, async ({end, equal, strictSame}) => {
|
|
20
|
+
const [{id, kill, lnd}] = (await spawnLightningCluster({})).nodes;
|
|
21
|
+
|
|
22
|
+
const {fromPublicKey} = await BIP32Factory(ecc);
|
|
23
|
+
|
|
24
|
+
// This method is not supported on LND 0.13.3 and below
|
|
25
|
+
try {
|
|
26
|
+
const {keys} = await getMasterPublicKeys({lnd});
|
|
27
|
+
|
|
28
|
+
const [,, key] = keys;
|
|
29
|
+
|
|
30
|
+
// Check if extended keys are available
|
|
31
|
+
if (!key) {
|
|
32
|
+
await kill({});
|
|
33
|
+
|
|
34
|
+
return end();
|
|
35
|
+
}
|
|
36
|
+
} catch (err) {
|
|
37
|
+
strictSame(err, [501, 'GetMasterPublicKeysMethodNotSupported'], 'Got err');
|
|
38
|
+
|
|
39
|
+
await kill({});
|
|
40
|
+
|
|
41
|
+
return end();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
try {
|
|
45
|
+
// Make a new address
|
|
46
|
+
const {address} = await createChainAddress({lnd});
|
|
47
|
+
|
|
48
|
+
// Get the list of accounts
|
|
49
|
+
const {keys} = await getMasterPublicKeys({lnd});
|
|
50
|
+
|
|
51
|
+
const masterP2wpkhKey = keys.find(n => n.derivation_path === p2wpkhPath);
|
|
52
|
+
|
|
53
|
+
// The address creation is reflected in the accounts metadata
|
|
54
|
+
equal(masterP2wpkhKey.external_key_count, [address].length, 'Key is used');
|
|
55
|
+
|
|
56
|
+
// Find the identity key master public key
|
|
57
|
+
const masterIdentityKey = keys.find(n => n.named === identityKeyName);
|
|
58
|
+
|
|
59
|
+
// Convert the key from base58 into its raw form
|
|
60
|
+
const rawKey = bs58check.decode(masterIdentityKey.extended_public_key);
|
|
61
|
+
|
|
62
|
+
const chainCode = chainCodeFromMasterPublicKey(rawKey);
|
|
63
|
+
const publicKey = publicKeyFromMasterPublicKey(rawKey);
|
|
64
|
+
|
|
65
|
+
// Make a bip32 object to derive from
|
|
66
|
+
const masterKey = fromPublicKey(publicKey, chainCode);
|
|
67
|
+
|
|
68
|
+
// Pull out the first key from the identity master public key
|
|
69
|
+
const identityKey = masterKey.derivePath(firstKeyPath);
|
|
70
|
+
|
|
71
|
+
equal(asHex(identityKey.publicKey), id, 'Got identity master public key');
|
|
72
|
+
} catch (err) {
|
|
73
|
+
equal(err, null, 'Expected no error');
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
await kill({});
|
|
77
|
+
|
|
78
|
+
return end();
|
|
79
|
+
});
|
|
@@ -158,6 +158,11 @@ test(`Partially sign PSBT`, async ({end, equal, strictSame}) => {
|
|
|
158
158
|
|
|
159
159
|
const bip32Derivations = flatten(allDerivations);
|
|
160
160
|
|
|
161
|
+
// Exit early when derivations are not supported
|
|
162
|
+
if (!!bip32Derivations.filter(n => !n).length) {
|
|
163
|
+
await partiallySignPsbt({lnd: control.lnd, psbt: base.psbt});
|
|
164
|
+
}
|
|
165
|
+
|
|
161
166
|
// Update the PSBT so that it has the consolidated details
|
|
162
167
|
const updated = updatePsbt({
|
|
163
168
|
ecp,
|