mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-07 14:29:33 +01:00
314622028f
Turns out that if we have the init message contain both the chainparams as well as a transaction that needs to be parsed we need to set the parser to elements mode before we reach the transaction...
4.6 KiB
4.6 KiB
1 | #include <common/derive_basepoints.h> |
---|---|
2 | #include <common/htlc_wire.h> |
3 | #include <common/wallet.h> |
4 | # Begin! Here's the onchain tx which spends funding tx, followed by all HTLCs. |
5 | msgtype,onchain_init,5001 |
6 | msgdata,onchain_init,shachain,shachain, |
7 | # This needs to be set explicitly since the same message also contains a |
8 | # transaction that we need to parse correctly. |
9 | msgdata,onchain_init,is_elements,bool, |
10 | msgdata,onchain_init,chain_hash,bitcoin_blkid, |
11 | msgdata,onchain_init,funding_amount_satoshi,amount_sat, |
12 | # Remote per commit point for committed tx. |
13 | msgdata,onchain_init,old_remote_per_commitment_point,pubkey, |
14 | # Remote per commit point for current tx (needed if we haven't got revoke_and_ack yet). |
15 | msgdata,onchain_init,remote_per_commitment_point,pubkey, |
16 | msgdata,onchain_init,local_to_self_delay,u32, |
17 | msgdata,onchain_init,remote_to_self_delay,u32, |
18 | msgdata,onchain_init,feerate_per_kw,u32, |
19 | msgdata,onchain_init,local_dust_limit_satoshi,amount_sat, |
20 | # Gives an easy way to tell if it's our unilateral close or theirs... |
21 | msgdata,onchain_init,our_broadcast_txid,bitcoin_txid, |
22 | msgdata,onchain_init,local_scriptpubkey_len,u16, |
23 | msgdata,onchain_init,local_scriptpubkey,u8,local_scriptpubkey_len |
24 | msgdata,onchain_init,remote_scriptpubkey_len,u16, |
25 | msgdata,onchain_init,remote_scriptpubkey,u8,remote_scriptpubkey_len |
26 | msgdata,onchain_init,ourwallet_pubkey,pubkey, |
27 | # We need these two for commit number obscurer |
28 | msgdata,onchain_init,funder,enum side, |
29 | msgdata,onchain_init,local_basepoints,basepoints, |
30 | msgdata,onchain_init,remote_basepoints,basepoints, |
31 | msgdata,onchain_init,tx,bitcoin_tx, |
32 | msgdata,onchain_init,tx_blockheight,u32, |
33 | msgdata,onchain_init,reasonable_depth,u32, |
34 | msgdata,onchain_init,num_htlc_sigs,u16, |
35 | msgdata,onchain_init,htlc_signature,secp256k1_ecdsa_signature,num_htlc_sigs |
36 | msgdata,onchain_init,num_htlcs,u64, |
37 | msgdata,onchain_init,min_possible_feerate,u32, |
38 | msgdata,onchain_init,max_possible_feerate,u32, |
39 | msgdata,onchain_init,possible_remote_per_commit_point,?pubkey, |
40 | msgdata,onchain_init,option_static_remotekey,bool, |
41 | #include <onchaind/onchain_wire.h> |
42 | # This is all the HTLCs: one per message |
43 | msgtype,onchain_htlc,5002 |
44 | msgdata,onchain_htlc,htlc,htlc_stub, |
45 | # If it's not in the commitment tx, tell us (immediately or htlc_missing_depth) |
46 | msgdata,onchain_htlc,tell_if_missing,bool, |
47 | msgdata,onchain_htlc,tell_immediately,bool, |
48 | # This says we're ready; give us preimages. |
49 | msgtype,onchain_init_reply,5101 |
50 | # onchaind->master: Send out a tx. |
51 | msgtype,onchain_broadcast_tx,5003 |
52 | msgdata,onchain_broadcast_tx,tx,bitcoin_tx, |
53 | msgdata,onchain_broadcast_tx,type,enum wallet_tx_type, |
54 | # master->onchaind: Notifier that an output has been spent by input_num of tx. |
55 | msgtype,onchain_spent,5004 |
56 | msgdata,onchain_spent,tx,bitcoin_tx, |
57 | msgdata,onchain_spent,input_num,u32, |
58 | msgdata,onchain_spent,blockheight,u32, |
59 | # master->onchaind: We will receive more than one of these, as depth changes. |
60 | msgtype,onchain_depth,5005 |
61 | msgdata,onchain_depth,txid,bitcoin_txid, |
62 | msgdata,onchain_depth,depth,u32, |
63 | # onchaind->master: We don't want to watch this tx, or its outputs |
64 | msgtype,onchain_unwatch_tx,5006 |
65 | msgdata,onchain_unwatch_tx,txid,bitcoin_txid, |
66 | # master->onchaind: We know HTLC preimage |
67 | msgtype,onchain_known_preimage,5007 |
68 | msgdata,onchain_known_preimage,preimage,preimage, |
69 | # onchaind->master: We discovered HTLC preimage |
70 | msgtype,onchain_extracted_preimage,5008 |
71 | msgdata,onchain_extracted_preimage,preimage,preimage, |
72 | # onchaind->master: this HTLC was missing from commit tx. |
73 | msgtype,onchain_missing_htlc_output,5009 |
74 | msgdata,onchain_missing_htlc_output,htlc,htlc_stub, |
75 | # onchaind->master: this HTLC has timed out (after reasonable_depth) |
76 | msgtype,onchain_htlc_timeout,5010 |
77 | msgdata,onchain_htlc_timeout,htlc,htlc_stub, |
78 | # onchaind->master: this peer can be forgotten |
79 | msgtype,onchain_all_irrevocably_resolved,5011 |
80 | # onchaind->master: hey, I identified an UTXO you'll want to track |
81 | msgtype,onchain_add_utxo,5012 |
82 | msgdata,onchain_add_utxo,prev_out_tx,bitcoin_txid, |
83 | msgdata,onchain_add_utxo,prev_out_index,u32, |
84 | msgdata,onchain_add_utxo,per_commit_point,?pubkey, |
85 | msgdata,onchain_add_utxo,value,amount_sat, |
86 | msgdata,onchain_add_utxo,blockheight,u32, |
87 | msgdata,onchain_add_utxo,len,u16, |
88 | msgdata,onchain_add_utxo,scriptpubkey,u8,len |
89 | # master -> onchaind: do you have a memleak? |
90 | msgtype,onchain_dev_memleak,5033 |
91 | msgtype,onchain_dev_memleak_reply,5133 |
92 | msgdata,onchain_dev_memleak_reply,leak,bool, |
93 | # Tell the main daemon what we've been watching, mainly used for transactions |
94 | # that we tracked automatically but only onchaind knows how to classify their |
95 | # transactions. |
96 | msgtype,onchain_transaction_annotate,5034 |
97 | msgdata,onchain_transaction_annotate,txid,bitcoin_txid, |
98 | msgdata,onchain_transaction_annotate,type,enum wallet_tx_type, |