mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-01 03:24:41 +01:00
8098a4cd21
we used this originally to suppress duplicate issuance of coin-move events; we're assuming that any plugin expects duplicate events though (and knows how to de-dupe them), so we no longer need this logic.
5.7 KiB
5.7 KiB
1 | #include <bitcoin/tx_parts.h> |
---|---|
2 | #include <common/coin_mvt.h> |
3 | #include <common/derive_basepoints.h> |
4 | #include <common/htlc_wire.h> |
5 | #include <common/wallet.h> |
6 | # Begin! Here's the onchain tx which spends funding tx, followed by all HTLCs. |
7 | msgtype,onchaind_init,5001 |
8 | msgdata,onchaind_init,shachain,shachain, |
9 | # This needs to be set explicitly since the same message also contains a |
10 | # transaction that we need to parse correctly. |
11 | msgdata,onchaind_init,chainparams,chainparams, |
12 | msgdata,onchaind_init,funding_amount_satoshi,amount_sat, |
13 | # Our current balance (of funding amount, not counting any pending htlcs) |
14 | msgdata,onchaind_init,our_msat,amount_msat, |
15 | # Remote per commit point for committed tx. |
16 | msgdata,onchaind_init,old_remote_per_commitment_point,pubkey, |
17 | # Remote per commit point for current tx (needed if we haven't got revoke_and_ack yet). |
18 | msgdata,onchaind_init,remote_per_commitment_point,pubkey, |
19 | msgdata,onchaind_init,local_to_self_delay,u32, |
20 | msgdata,onchaind_init,remote_to_self_delay,u32, |
21 | msgdata,onchaind_init,delayed_to_us_feerate,u32, |
22 | msgdata,onchaind_init,htlc_feerate,u32, |
23 | msgdata,onchaind_init,penalty_feerate,u32, |
24 | msgdata,onchaind_init,local_dust_limit_satoshi,amount_sat, |
25 | # Gives an easy way to tell if it's our unilateral close or theirs... |
26 | msgdata,onchaind_init,our_broadcast_txid,bitcoin_txid, |
27 | msgdata,onchaind_init,local_scriptpubkey_len,u16, |
28 | msgdata,onchaind_init,local_scriptpubkey,u8,local_scriptpubkey_len |
29 | msgdata,onchaind_init,remote_scriptpubkey_len,u16, |
30 | msgdata,onchaind_init,remote_scriptpubkey,u8,remote_scriptpubkey_len |
31 | msgdata,onchaind_init,ourwallet_pubkey,pubkey, |
32 | # We need these two for commit number obscurer |
33 | msgdata,onchaind_init,opener,enum side, |
34 | msgdata,onchaind_init,local_basepoints,basepoints, |
35 | msgdata,onchaind_init,remote_basepoints,basepoints, |
36 | msgdata,onchaind_init,tx_parts,tx_parts, |
37 | msgdata,onchaind_init,locktime,u32, |
38 | msgdata,onchaind_init,tx_blockheight,u32, |
39 | msgdata,onchaind_init,reasonable_depth,u32, |
40 | msgdata,onchaind_init,num_htlc_sigs,u16, |
41 | msgdata,onchaind_init,htlc_signature,bitcoin_signature,num_htlc_sigs |
42 | msgdata,onchaind_init,min_possible_feerate,u32, |
43 | msgdata,onchaind_init,max_possible_feerate,u32, |
44 | msgdata,onchaind_init,possible_remote_per_commit_point,?pubkey, |
45 | msgdata,onchaind_init,local_funding_pubkey,pubkey, |
46 | msgdata,onchaind_init,remote_funding_pubkey,pubkey, |
47 | msgdata,onchaind_init,local_static_remotekey_start,u64, |
48 | msgdata,onchaind_init,remote_static_remotekey_start,u64, |
49 | msgdata,onchaind_init,option_anchor_outputs,bool, |
50 | # We need this for BIP125 rule 4 |
51 | msgdata,onchaind_init,min_relay_feerate,u32, |
52 | # This says we're ready; give us htlcs and preimages. |
53 | msgtype,onchaind_init_reply,5101 |
54 | msgdata,onchaind_init_reply,commit_num,u64, |
55 | #include <onchaind/onchaind_wire.h> |
56 | msgtype,onchaind_htlcs,5002 |
57 | msgdata,onchaind_htlcs,num_htlcs,u32, |
58 | msgdata,onchaind_htlcs,htlc,htlc_stub,num_htlcs |
59 | # If it's not in the commitment tx, tell us (immediately or htlc_missing_depth) |
60 | msgdata,onchaind_htlcs,tell_if_missing,bool,num_htlcs |
61 | msgdata,onchaind_htlcs,tell_immediately,bool,num_htlcs |
62 | # onchaind->master: Send out a tx. |
63 | # If is_rbf is false then master should rebroadcast the tx. |
64 | # If is_rbf is true then onchaind is responsible for rebroadcasting |
65 | # it with a higher fee. |
66 | msgtype,onchaind_broadcast_tx,5003 |
67 | msgdata,onchaind_broadcast_tx,tx,bitcoin_tx, |
68 | msgdata,onchaind_broadcast_tx,type,enum wallet_tx_type, |
69 | msgdata,onchaind_broadcast_tx,is_rbf,bool, |
70 | # master->onchaind: Notifier that an output has been spent by input_num of tx. |
71 | msgtype,onchaind_spent,5004 |
72 | msgdata,onchaind_spent,tx,tx_parts, |
73 | msgdata,onchaind_spent,input_num,u32, |
74 | msgdata,onchaind_spent,blockheight,u32, |
75 | # master->onchaind: We will receive more than one of these, as depth changes. |
76 | msgtype,onchaind_depth,5005 |
77 | msgdata,onchaind_depth,txid,bitcoin_txid, |
78 | msgdata,onchaind_depth,depth,u32, |
79 | # onchaind->master: We don't want to watch this tx, or its outputs |
80 | msgtype,onchaind_unwatch_tx,5006 |
81 | msgdata,onchaind_unwatch_tx,txid,bitcoin_txid, |
82 | # master->onchaind: We know HTLC preimage |
83 | msgtype,onchaind_known_preimage,5007 |
84 | msgdata,onchaind_known_preimage,preimage,preimage, |
85 | # onchaind->master: We discovered HTLC preimage |
86 | msgtype,onchaind_extracted_preimage,5008 |
87 | msgdata,onchaind_extracted_preimage,preimage,preimage, |
88 | # onchaind->master: this HTLC was missing from commit tx. |
89 | msgtype,onchaind_missing_htlc_output,5009 |
90 | msgdata,onchaind_missing_htlc_output,htlc,htlc_stub, |
91 | # onchaind->master: this HTLC has timed out (after reasonable_depth) |
92 | msgtype,onchaind_htlc_timeout,5010 |
93 | msgdata,onchaind_htlc_timeout,htlc,htlc_stub, |
94 | # onchaind->master: this peer can be forgotten |
95 | msgtype,onchaind_all_irrevocably_resolved,5011 |
96 | # onchaind->master: hey, I identified an UTXO you'll want to track |
97 | msgtype,onchaind_add_utxo,5012 |
98 | msgdata,onchaind_add_utxo,prev_out,bitcoin_outpoint, |
99 | msgdata,onchaind_add_utxo,per_commit_point,?pubkey, |
100 | msgdata,onchaind_add_utxo,value,amount_sat, |
101 | msgdata,onchaind_add_utxo,blockheight,u32, |
102 | msgdata,onchaind_add_utxo,len,u16, |
103 | msgdata,onchaind_add_utxo,scriptpubkey,u8,len |
104 | msgdata,onchaind_add_utxo,csv_lock,u32, |
105 | # master -> onchaind: do you have a memleak? |
106 | msgtype,onchaind_dev_memleak,5033 |
107 | msgtype,onchaind_dev_memleak_reply,5133 |
108 | msgdata,onchaind_dev_memleak_reply,leak,bool, |
109 | # Tell the main daemon what we've been watching, mainly used for transactions |
110 | # that we tracked automatically but only onchaind knows how to classify their |
111 | # transactions. |
112 | msgtype,onchaind_annotate_txout,5035 |
113 | msgdata,onchaind_annotate_txout,outpoint,bitcoin_outpoint, |
114 | msgdata,onchaind_annotate_txout,type,enum wallet_tx_type, |
115 | msgtype,onchaind_annotate_txin,5036 |
116 | msgdata,onchaind_annotate_txin,txid,bitcoin_txid, |
117 | msgdata,onchaind_annotate_txin,innum,u32, |
118 | msgdata,onchaind_annotate_txin,type,enum wallet_tx_type, |
119 | msgtype,onchaind_notify_coin_mvt,5037 |
120 | msgdata,onchaind_notify_coin_mvt,mvt,chain_coin_mvt, |