core-lightning/gossipd/gossip_wire.csv
Rusty Russell 5591c0b5d8 gossipd: don't send gossip stream, let per-peer daemons read it themselves.
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>
2019-06-04 01:29:39 +00:00

5.4 KiB

1#include <common/cryptomsg.h>
2#include <common/wireaddr.h>
3#include <wire/gen_onion_wire.h>
4# Initialize the gossip daemon.
5gossipctl_init,3000
6gossipctl_init,,chain_hash,struct bitcoin_blkid
7gossipctl_init,,id,struct node_id
8gossipctl_init,,gflen,u16
9gossipctl_init,,globalfeatures,gflen*u8
10gossipctl_init,,rgb,3*u8
11gossipctl_init,,alias,32*u8
12gossipctl_init,,update_channel_interval,u32
13gossipctl_init,,num_announcable,u16
14gossipctl_init,,announcable,num_announcable*struct wireaddr
15gossipctl_init,,dev_gossip_time,?u32
16# Pass JSON-RPC getnodes call through
17gossip_getnodes_request,3005
18gossip_getnodes_request,,id,?struct node_id
19#include <lightningd/gossip_msg.h>
20gossip_getnodes_reply,3105
21gossip_getnodes_reply,,num_nodes,u32
22gossip_getnodes_reply,,nodes,num_nodes*struct gossip_getnodes_entry
23# Pass JSON-RPC getroute call through
24gossip_getroute_request,3006
25gossip_getroute_request,,source,struct node_id
26gossip_getroute_request,,destination,struct node_id
27gossip_getroute_request,,msatoshi,struct amount_msat
28# We don't pass doubles, so pass riskfactor * 1000000.
29gossip_getroute_request,,riskfactor_by_million,u64
30gossip_getroute_request,,final_cltv,u32
31gossip_getroute_request,,fuzz,double
32gossip_getroute_request,,num_excluded,u16
33gossip_getroute_request,,excluded,num_excluded*struct short_channel_id_dir
34gossip_getroute_request,,max_hops,u32
35gossip_getroute_reply,3106
36gossip_getroute_reply,,num_hops,u16
37gossip_getroute_reply,,hops,num_hops*struct route_hop
38gossip_getchannels_request,3007
39gossip_getchannels_request,,short_channel_id,?struct short_channel_id
40gossip_getchannels_request,,source,?struct node_id
41gossip_getchannels_request,,prev,?struct short_channel_id
42gossip_getchannels_reply,3107
43gossip_getchannels_reply,,complete,bool
44gossip_getchannels_reply,,num_channels,u32
45gossip_getchannels_reply,,nodes,num_channels*struct gossip_getchannels_entry
46# Ping/pong test. Waits for a reply if it expects one.
47gossip_ping,3008
48gossip_ping,,id,struct node_id
49gossip_ping,,num_pong_bytes,u16
50gossip_ping,,len,u16
51gossip_ping_reply,3108
52gossip_ping_reply,,id,struct node_id
53# False if id in gossip_ping was unknown.
54gossip_ping_reply,,sent,bool
55# 0 == no pong expected
56gossip_ping_reply,,totlen,u16
57# Test of query_short_channel_ids. Master->gossipd
58gossip_query_scids,3031
59gossip_query_scids,,id,struct node_id
60gossip_query_scids,,num_ids,u16
61gossip_query_scids,,ids,num_ids*struct short_channel_id
62# Gossipd -> master
63gossip_scids_reply,3131
64gossip_scids_reply,,ok,bool
65gossip_scids_reply,,complete,bool
66# Test gossip timestamp filtering.
67gossip_send_timestamp_filter,3028
68gossip_send_timestamp_filter,,id,struct node_id
69gossip_send_timestamp_filter,,first_timestamp,u32
70gossip_send_timestamp_filter,,timestamp_range,u32
71# Test of query_channel_range. Master->gossipd
72gossip_query_channel_range,3029
73gossip_query_channel_range,,id,struct node_id
74gossip_query_channel_range,,first_blocknum,u32
75gossip_query_channel_range,,number_of_blocks,u32
76# Gossipd -> master
77gossip_query_channel_range_reply,3129
78gossip_query_channel_range_reply,,final_first_block,u32
79gossip_query_channel_range_reply,,final_num_blocks,u32
80gossip_query_channel_range_reply,,final_complete,bool
81gossip_query_channel_range_reply,,num,u16
82gossip_query_channel_range_reply,,scids,num*struct short_channel_id
83# Set artificial maximum reply_channel_range size. Master->gossipd
84gossip_dev_set_max_scids_encode_size,3030
85gossip_dev_set_max_scids_encode_size,,max,u32
86# Given a short_channel_id, return the other endpoint (or none if DNE)
87gossip_get_channel_peer,3009
88gossip_get_channel_peer,,channel_id,struct short_channel_id
89gossip_get_channel_peer_reply,3109
90gossip_get_channel_peer_reply,,peer_id,?struct node_id
91# gossipd->master: we're closing this channel.
92gossip_local_channel_close,3027
93gossip_local_channel_close,,short_channel_id,struct short_channel_id
94# Gossipd->master get this tx output please.
95gossip_get_txout,3018
96gossip_get_txout,,short_channel_id,struct short_channel_id
97# master->gossipd here is the output, or empty if none.
98gossip_get_txout_reply,3118
99gossip_get_txout_reply,,short_channel_id,struct short_channel_id
100gossip_get_txout_reply,,satoshis,struct amount_sat
101gossip_get_txout_reply,,len,u16
102gossip_get_txout_reply,,outscript,len*u8
103# master->gossipd an htlc failed with this onion error.
104gossip_payment_failure,3021
105gossip_payment_failure,,erring_node,struct node_id
106gossip_payment_failure,,erring_channel,struct short_channel_id
107gossip_payment_failure,,erring_channel_direction,u8
108gossip_payment_failure,,len,u16
109gossip_payment_failure,,error,len*u8
110# master -> gossipd: a potential funding outpoint was spent, please forget the eventual channel
111gossip_outpoint_spent,3024
112gossip_outpoint_spent,,short_channel_id,struct short_channel_id
113# master -> gossipd: stop gossip timers.
114gossip_dev_suppress,3032
115# master -> gossipd: do you have a memleak?
116gossip_dev_memleak,3033
117gossip_dev_memleak_reply,3133
118gossip_dev_memleak_reply,,leak,bool
119# master -> gossipd: please rewrite the gossip_store
120gossip_dev_compact_store,3034
121# gossipd -> master: ok
122gossip_dev_compact_store_reply,3134
123gossip_dev_compact_store_reply,,success,bool
124#include <common/bolt11.h>
125# master -> gossipd: get route_info for our incoming channels
126gossip_get_incoming_channels,3025
127gossip_get_incoming_channels,,private_too,?bool
128# gossipd -> master: here they are.
129gossip_get_incoming_channels_reply,3125
130gossip_get_incoming_channels_reply,,num,u16
131gossip_get_incoming_channels_reply,,route_info,num*struct route_info