mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-10 07:37:05 +01:00
d236e724a9
We need the old remote per_commitment_point so we can validate the per_commitment_secret when we get it. We unify this housekeeping in the master daemon using update_per_commit_point(). This patch also saves whether remote funding is locked, and disallows doing that twice (channeld should ignore it). Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
5.9 KiB
5.9 KiB
1 | # Shouldn't happen |
---|---|
2 | channel_bad_command,0x8000 |
3 | # Also shouldn't happen |
4 | channel_hsm_failed,0x8001 |
5 | channel_crypto_failed,0x8002 |
6 | channel_internal_error,0x8003 |
7 | channel_gossip_bad_message,0x8004 |
8 | # These are due to peer. |
9 | channel_peer_write_failed,0x8010 |
10 | channel_peer_read_failed,0x8011 |
11 | channel_peer_bad_message,0x8012 |
12 | # Received and sent funding_locked |
13 | channel_normal_operation,1001 |
14 | #include <lightningd/cryptomsg.h> |
15 | #include <lightningd/channel_config.h> |
16 | # Begin! (passes gossipd-client fd) |
17 | channel_init,1 |
18 | channel_init,,funding_txid,struct sha256_double |
19 | channel_init,,funding_txout,2 |
20 | channel_init,,funding_satoshi,8 |
21 | channel_init,,our_config,struct channel_config |
22 | channel_init,,their_config,struct channel_config |
23 | channel_init,,first_commit_sig,secp256k1_ecdsa_signature |
24 | channel_init,,crypto_state,struct crypto_state |
25 | channel_init,,remote_fundingkey,33 |
26 | channel_init,,revocation_basepoint,33 |
27 | channel_init,,payment_basepoint,33 |
28 | channel_init,,delayed_payment_basepoint,33 |
29 | channel_init,,remote_per_commit,33 |
30 | channel_init,,old_remote_per_commit,33 |
31 | channel_init,,am_funder,bool |
32 | channel_init,,fee_base,4 |
33 | channel_init,,fee_proportional,4 |
34 | channel_init,,local_msatoshi,8 |
35 | channel_init,,seed,struct privkey |
36 | channel_init,,local_node_id,struct pubkey |
37 | channel_init,,remote_node_id,struct pubkey |
38 | channel_init,,commit_msec,4 |
39 | channel_init,,cltv_delta,u16 |
40 | channel_init,,last_was_revoke,bool |
41 | channel_init,,num_last_sent_commit,u16 |
42 | channel_init,,last_sent_commit,num_last_sent_commit*struct changed_htlc |
43 | channel_init,,commits_sent,u64 |
44 | channel_init,,commits_received,u64 |
45 | channel_init,,revocations_received,u64 |
46 | channel_init,,next_htlc_id,u64 |
47 | channel_init,,num_htlcs,u16 |
48 | channel_init,,htlcs,num_htlcs*struct added_htlc |
49 | channel_init,,htlc_states,num_htlcs*enum htlc_state |
50 | channel_init,,num_fulfilled,u16 |
51 | channel_init,,fulfilled,num_fulfilled*struct fulfilled_htlc |
52 | channel_init,,fulfilled_sides,num_fulfilled*enum side |
53 | channel_init,,num_failed,u16 |
54 | channel_init,,failed,num_failed*struct failed_htlc |
55 | channel_init,,failed_sides,num_failed*enum side |
56 | channel_init,,local_funding_locked,bool |
57 | channel_init,,remote_funding_locked,bool |
58 | channel_init,,funding_short_id,struct short_channel_id |
59 | channel_init,,reestablish,bool |
60 | channel_init,,init_peer_pkt_len,u16 |
61 | channel_init,,init_peer_pkt,init_peer_pkt_len*u8 |
62 | # Tx is deep enough, go! |
63 | channel_funding_locked,2 |
64 | channel_funding_locked,,short_channel_id,struct short_channel_id |
65 | # Tell the channel that we may announce the channel's existence |
66 | channel_funding_announce_depth,3 |
67 | # Tell channel to offer this htlc |
68 | channel_offer_htlc,4 |
69 | channel_offer_htlc,,amount_msat,8 |
70 | channel_offer_htlc,,cltv_expiry,4 |
71 | channel_offer_htlc,,payment_hash,32 |
72 | channel_offer_htlc,,onion_routing_packet,1366*u8 |
73 | # Reply; synchronous since IDs have to increment. |
74 | channel_offer_htlc_reply,104 |
75 | channel_offer_htlc_reply,,id,8 |
76 | # Zero failure code means success. |
77 | channel_offer_htlc_reply,,failure_code,2 |
78 | channel_offer_htlc_reply,,failurestrlen,2 |
79 | channel_offer_htlc_reply,,failurestr,failurestrlen*u8 |
80 | # Main daemon found out the preimage for an htlc |
81 | #include <bitcoin/preimage.h> |
82 | channel_fulfill_htlc,5 |
83 | channel_fulfill_htlc,,id,8 |
84 | channel_fulfill_htlc,,payment_preimage,struct preimage |
85 | # Main daemon says HTLC failed |
86 | channel_fail_htlc,6 |
87 | channel_fail_htlc,,id,8 |
88 | # If malformed is non-zero, it's a BADONION code |
89 | channel_fail_htlc,,malformed,u16 |
90 | # Otherwise, error_pkt contains failreason. |
91 | channel_fail_htlc,,len,2 |
92 | channel_fail_htlc,,error_pkt,len*u8 |
93 | # Ping/pong test. |
94 | channel_ping,11 |
95 | channel_ping,,num_pong_bytes,u16 |
96 | channel_ping,,len,u16 |
97 | channel_ping_reply,111 |
98 | channel_ping_reply,,totlen,u16 |
99 | # Channeld tells the master that the channel has been announced |
100 | channel_announced,12 |
101 | # When we receive funding_locked. |
102 | channel_got_funding_locked,19 |
103 | channel_got_funding_locked,,next_per_commit_point,struct pubkey |
104 | # When we send a commitment_signed message, tell master. |
105 | channel_sending_commitsig,20 |
106 | channel_sending_commitsig,,commitnum,u64 |
107 | # SENT_ADD_COMMIT, SENT_REMOVE_ACK_COMMIT, SENT_ADD_ACK_COMMIT, SENT_REMOVE_COMMIT |
108 | channel_sending_commitsig,,num_changed,u16 |
109 | channel_sending_commitsig,,changed,num_changed*struct changed_htlc |
110 | channel_sending_commitsig,,commit_sig,secp256k1_ecdsa_signature |
111 | channel_sending_commitsig,,num_htlc_sigs,u16 |
112 | channel_sending_commitsig,,htlc_sigs,num_htlc_sigs*secp256k1_ecdsa_signature |
113 | # Wait for reply, to make sure it's on disk before we send commit. |
114 | channel_sending_commitsig_reply,120 |
115 | # When we have a commitment_signed message, tell master to remember. |
116 | channel_got_commitsig,21 |
117 | channel_got_commitsig,,commitnum,u64 |
118 | channel_got_commitsig,,signature,secp256k1_ecdsa_signature |
119 | channel_got_commitsig,,num_htlcs,u16 |
120 | channel_got_commitsig,,htlc_signature,num_htlcs*secp256k1_ecdsa_signature |
121 | # RCVD_ADD_COMMIT: we're now committed to their new offered HTLCs. |
122 | channel_got_commitsig,,num_added,u16 |
123 | channel_got_commitsig,,added,num_added*struct added_htlc |
124 | channel_got_commitsig,,shared_secret,num_added*struct secret |
125 | # RCVD_REMOVE_COMMIT: we're now no longer committed to these HTLCs. |
126 | channel_got_commitsig,,num_fulfilled,u16 |
127 | channel_got_commitsig,,fulfilled,num_fulfilled*struct fulfilled_htlc |
128 | channel_got_commitsig,,num_failed,u16 |
129 | channel_got_commitsig,,failed,num_failed*struct failed_htlc |
130 | # RCVD_ADD_ACK_COMMIT, RCVD_REMOVE_ACK_COMMIT |
131 | channel_got_commitsig,,num_changed,u16 |
132 | channel_got_commitsig,,changed,num_changed*struct changed_htlc |
133 | # Wait for reply, to make sure it's on disk before we send revocation. |
134 | channel_got_commitsig_reply,121 |
135 | #include <lightningd/htlc_wire.h> |
136 | channel_got_revoke,22 |
137 | channel_got_revoke,,revokenum,u64 |
138 | channel_got_revoke,,per_commitment_secret,struct sha256 |
139 | channel_got_revoke,,next_per_commit_point,struct pubkey |
140 | # RCVD_ADD_ACK_REVOCATION, RCVD_REMOVE_ACK_REVOCATION, RCVD_ADD_REVOCATION, RCVD_REMOVE_REVOCATION |
141 | channel_got_revoke,,num_changed,u16 |
142 | channel_got_revoke,,changed,num_changed*struct changed_htlc |
143 | # Wait for reply, to make sure it's on disk before we continue |
144 | # (eg. if we sent another commitment_signed, that would implicitly ack). |
145 | channel_got_revoke_reply,122 |