core-lightning/connectd/connect_wire.csv
Vasil Dimov 55173a56b7 Use dedicated type for error codes
Before this patch we used `int` for error codes. The problem with
`int` is that we try to pass it to/from wire and the size of `int` is
not defined by the standard. So a sender with 4-byte `int` would write
4 bytes to the wire and a receiver with 2-byte `int` (for example) would
read just 2 bytes from the wire.

To resolve this:

* Introduce an error code type with a known size:
  `typedef s32 errcode_t`.

* Change all error code macros to constants of type `errcode_t`.
  Constants also play better with gdb - it would visualize the name of
  the constant instead of the numeric value.

* Change all functions that take error codes to take the new type
  `errcode_t` instead of `int`.

* Introduce towire / fromwire functions to send / receive the newly added
  type `errcode_t` and use it instead of `towire_int()`.

In addition:

* Remove the now unneeded `towire_int()`.

* Replace a hardcoded error code `-2` with a new constant
  `INVOICE_EXPIRED_DURING_WAIT` (903).

Changelog-Changed: The waitinvoice command would now return error code 903 to designate that the invoice expired during wait, instead of the previous -2
2020-01-31 06:02:47 +00:00

2.6 KiB

1#include <common/cryptomsg.h>
2#include <common/per_peer_state.h>
3#include <common/wireaddr.h>
4#include <lightningd/gossip_msg.h>
5msgtype,connectctl_init,2000
6msgdata,connectctl_init,chainparams,chainparams,
7msgdata,connectctl_init,id,node_id,
8msgdata,connectctl_init,num_wireaddrs,u16,
9msgdata,connectctl_init,wireaddrs,wireaddr_internal,num_wireaddrs
10msgdata,connectctl_init,listen_announce,enum addr_listen_announce,num_wireaddrs
11msgdata,connectctl_init,tor_proxyaddr,?wireaddr,
12msgdata,connectctl_init,use_tor_proxy_always,bool,
13msgdata,connectctl_init,dev_allow_localhost,bool,
14msgdata,connectctl_init,use_dns,bool,
15msgdata,connectctl_init,tor_password,wirestring,
16msgdata,connectctl_init,use_v3_autotor,bool,
17# Connectd->master, here are the addresses I bound, can announce.
18msgtype,connectctl_init_reply,2100
19msgdata,connectctl_init_reply,num_bindings,u16,
20msgdata,connectctl_init_reply,bindings,wireaddr_internal,num_bindings
21msgdata,connectctl_init_reply,num_announcable,u16,
22msgdata,connectctl_init_reply,announcable,wireaddr,num_announcable
23# Activate the connect daemon, so others can connect.
24msgtype,connectctl_activate,2025
25# Do we listen?
26msgdata,connectctl_activate,listen,bool,
27# Connectd->master, I am ready.
28msgtype,connectctl_activate_reply,2125
29# connectd->master: disconnect this peer please (due to reconnect).
30msgtype,connect_reconnected,2112
31msgdata,connect_reconnected,id,node_id,
32# Master -> connectd: connect to a peer.
33msgtype,connectctl_connect_to_peer,2001
34msgdata,connectctl_connect_to_peer,id,node_id,
35msgdata,connectctl_connect_to_peer,seconds_waited,u32,
36msgdata,connectctl_connect_to_peer,addrhint,?wireaddr_internal,
37# Connectd->master: connect failed.
38msgtype,connectctl_connect_failed,2020
39msgdata,connectctl_connect_failed,id,node_id,
40msgdata,connectctl_connect_failed,failcode,errcode_t,
41msgdata,connectctl_connect_failed,failreason,wirestring,
42msgdata,connectctl_connect_failed,seconds_to_delay,u32,
43msgdata,connectctl_connect_failed,addrhint,?wireaddr_internal,
44# Connectd -> master: we got a peer. Three fds: peer, gossip and gossip_store
45msgtype,connect_peer_connected,2002
46msgdata,connect_peer_connected,id,node_id,
47msgdata,connect_peer_connected,addr,wireaddr_internal,
48msgdata,connect_peer_connected,pps,per_peer_state,
49msgdata,connect_peer_connected,flen,u16,
50msgdata,connect_peer_connected,features,u8,flen
51# master -> connectd: peer has disconnected.
52msgtype,connectctl_peer_disconnected,2015
53msgdata,connectctl_peer_disconnected,id,node_id,
54# master -> connectd: do you have a memleak?
55msgtype,connect_dev_memleak,2033
56msgtype,connect_dev_memleak_reply,2133
57msgdata,connect_dev_memleak_reply,leak,bool,