mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-06 05:49:30 +01:00
5591c0b5d8
Keeping the uintmap ordering all the broadcastable messages is expensive: 130MB for the million-channels project. But now we delete obsolete entries from the store, we can have the per-peer daemons simply read that sequentially and stream the gossip itself. This is the most primitive version, where all gossip is streamed; successive patches will bring back proper handling of timestamp filtering and initial_routing_sync. We add a gossip_state field to track what's happening with our gossip streaming: it's initialized in gossipd, and currently always set, but once we handle timestamps the per-peer daemon may do it when the first filter is sent. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
68 lines
2.3 KiB
Plaintext
68 lines
2.3 KiB
Plaintext
#include <common/cryptomsg.h>
|
|
#include <common/per_peer_state.h>
|
|
#include <common/wireaddr.h>
|
|
#include <lightningd/gossip_msg.h>
|
|
|
|
connectctl_init,2000
|
|
connectctl_init,,id,struct node_id
|
|
connectctl_init,,num_wireaddrs,u16
|
|
connectctl_init,,wireaddrs,num_wireaddrs*struct wireaddr_internal
|
|
connectctl_init,,listen_announce,num_wireaddrs*enum addr_listen_announce
|
|
connectctl_init,,tor_proxyaddr,?struct wireaddr
|
|
connectctl_init,,use_tor_proxy_always,bool
|
|
connectctl_init,,dev_allow_localhost,bool
|
|
connectctl_init,,use_dns,bool
|
|
connectctl_init,,tor_password,wirestring
|
|
|
|
# Connectd->master, here are the addresses I bound, can announce.
|
|
connectctl_init_reply,2100
|
|
connectctl_init_reply,,num_bindings,u16
|
|
connectctl_init_reply,,bindings,num_bindings*struct wireaddr_internal
|
|
connectctl_init_reply,,num_announcable,u16
|
|
connectctl_init_reply,,announcable,num_announcable*struct wireaddr
|
|
|
|
# Activate the connect daemon, so others can connect.
|
|
connectctl_activate,2025
|
|
# Do we listen?
|
|
connectctl_activate,,listen,bool
|
|
|
|
# Connectd->master, I am ready.
|
|
connectctl_activate_reply,2125
|
|
|
|
# connectd->master: disconnect this peer please (due to reconnect).
|
|
connect_reconnected,2112
|
|
connect_reconnected,,id,struct node_id
|
|
|
|
# Master -> connectd: connect to a peer.
|
|
connectctl_connect_to_peer,2001
|
|
connectctl_connect_to_peer,,id,struct node_id
|
|
connectctl_connect_to_peer,,seconds_waited,u32
|
|
connectctl_connect_to_peer,,addrhint,?struct wireaddr_internal
|
|
|
|
# Connectd->master: connect failed.
|
|
connectctl_connect_failed,2020
|
|
connectctl_connect_failed,,id,struct node_id
|
|
connectctl_connect_failed,,failreason,wirestring
|
|
connectctl_connect_failed,,seconds_to_delay,u32
|
|
connectctl_connect_failed,,addrhint,?struct wireaddr_internal
|
|
|
|
# Connectd -> master: we got a peer. Three fds: peer, gossip and gossip_store
|
|
connect_peer_connected,2002
|
|
connect_peer_connected,,id,struct node_id
|
|
connect_peer_connected,,addr,struct wireaddr_internal
|
|
connect_peer_connected,,pps,struct per_peer_state
|
|
connect_peer_connected,,gflen,u16
|
|
connect_peer_connected,,globalfeatures,gflen*u8
|
|
connect_peer_connected,,lflen,u16
|
|
connect_peer_connected,,localfeatures,lflen*u8
|
|
|
|
# master -> connectd: peer has disconnected.
|
|
connectctl_peer_disconnected,2015
|
|
connectctl_peer_disconnected,,id,struct node_id
|
|
|
|
# master -> connectd: do you have a memleak?
|
|
connect_dev_memleak,2033
|
|
|
|
connect_dev_memleak_reply,2133
|
|
connect_dev_memleak_reply,,leak,bool
|