2017-01-10 06:08:33 +01:00
|
|
|
# These are fatal.
|
|
|
|
gossipstatus_init_failed,0x8000
|
|
|
|
gossipstatus_bad_new_peer_request,0x8001
|
|
|
|
gossipstatus_bad_release_request,0x8002
|
|
|
|
gossipstatus_bad_request,0x8003
|
|
|
|
gossipstatus_fdpass_failed,0x8004
|
|
|
|
|
|
|
|
# Peers can give a bad message, we close their fd, but no harm done.
|
2017-03-10 11:50:43 +01:00
|
|
|
gossipstatus_peer_bad_msg,1000
|
2017-01-10 06:08:33 +01:00
|
|
|
gossipstatus_peer_bad_msg,0,unique_id,8
|
|
|
|
gossipstatus_peer_bad_msg,8,len,2
|
2017-03-16 05:05:25 +01:00
|
|
|
gossipstatus_peer_bad_msg,10,err,len*u8
|
2017-01-10 06:08:33 +01:00
|
|
|
|
2017-03-19 21:32:40 +01:00
|
|
|
# Misc problems like opening control fd.
|
|
|
|
gossipstatus_peer_failed,1001
|
|
|
|
gossipstatus_peer_failed,0,unique_id,8
|
|
|
|
gossipstatus_peer_failed,8,len,2
|
|
|
|
gossipstatus_peer_failed,10,err,len*u8
|
|
|
|
|
2017-03-10 11:50:43 +01:00
|
|
|
#include <lightningd/cryptomsg.h>
|
|
|
|
|
2017-04-24 14:31:26 +02:00
|
|
|
# Initialize the gossip daemon
|
|
|
|
gossipctl_init,0
|
|
|
|
gossipctl_init,0,broadcast_interval,4
|
|
|
|
|
2017-03-10 11:50:43 +01:00
|
|
|
# These take an fd, but have no response
|
|
|
|
# (if it is to move onto a channel, we get a status msg).
|
|
|
|
gossipctl_new_peer,1
|
|
|
|
gossipctl_new_peer,0,unique_id,8
|
2017-03-16 05:05:25 +01:00
|
|
|
gossipctl_new_peer,8,crypto_state,struct crypto_state
|
2017-03-10 11:50:43 +01:00
|
|
|
|
|
|
|
# Tell it to release a peer which has initialized.
|
|
|
|
gossipctl_release_peer,2
|
|
|
|
gossipctl_release_peer,0,unique_id,8
|
|
|
|
|
2017-03-19 21:32:40 +01:00
|
|
|
# This releases the peer and returns the cryptostate (followed two fds: peer and gossip)
|
2017-03-10 11:50:43 +01:00
|
|
|
gossipctl_release_peer_reply,102
|
|
|
|
gossipctl_release_peer_reply,0,unique_id,8
|
2017-03-16 05:05:25 +01:00
|
|
|
gossipctl_release_peer_reply,8,crypto_state,struct crypto_state
|
2017-03-10 11:50:43 +01:00
|
|
|
|
2017-01-10 06:08:33 +01:00
|
|
|
# This is where we save a peer's features.
|
|
|
|
#gossipstatus_peer_features,1
|
|
|
|
#gossipstatus_peer_features,0,unique_id,8
|
|
|
|
#gossipstatus_peer_features,8,gflen,2
|
|
|
|
#gossipstatus_peer_features,10,globalfeatures,gflen
|
|
|
|
#gossipstatus_peer_features,10+gflen,lflen,2
|
|
|
|
#gossipstatus_peer_features,12+gflen,localfeatures,lflen
|
|
|
|
|
2017-03-19 21:32:40 +01:00
|
|
|
# Peer can send non-gossip packet (usually an open_channel) (followed two fds: peer and gossip)
|
2017-03-10 11:50:43 +01:00
|
|
|
gossipstatus_peer_nongossip,4
|
2017-01-10 06:08:33 +01:00
|
|
|
gossipstatus_peer_nongossip,0,unique_id,8
|
2017-03-16 05:05:25 +01:00
|
|
|
gossipstatus_peer_nongossip,10,crypto_state,struct crypto_state
|
2017-01-10 06:08:33 +01:00
|
|
|
gossipstatus_peer_nongossip,154,len,2
|
2017-03-16 05:05:25 +01:00
|
|
|
gossipstatus_peer_nongossip,156,msg,len*u8
|
2017-03-12 13:39:23 +01:00
|
|
|
|
|
|
|
# Pass JSON-RPC getnodes call through
|
|
|
|
gossip_getnodes_request,5
|
|
|
|
|
2017-03-16 05:05:26 +01:00
|
|
|
#include <lightningd/gossip_msg.h>
|
2017-03-12 13:39:23 +01:00
|
|
|
gossip_getnodes_reply,105
|
2017-03-16 05:05:26 +01:00
|
|
|
gossip_getnodes_reply,0,num_nodes,u16
|
|
|
|
gossip_getnodes_reply,2,nodes,num_nodes*struct gossip_getnodes_entry
|
2017-03-15 11:36:52 +01:00
|
|
|
|
|
|
|
# Pass JSON-RPC getroute call through
|
|
|
|
gossip_getroute_request,6
|
|
|
|
gossip_getroute_request,0,source,struct pubkey
|
|
|
|
gossip_getroute_request,33,destination,struct pubkey
|
|
|
|
gossip_getroute_request,66,msatoshi,u32
|
|
|
|
gossip_getroute_request,70,riskfactor,u16
|
|
|
|
|
|
|
|
gossip_getroute_reply,106
|
|
|
|
gossip_getroute_reply,0,num_hops,u16
|
|
|
|
gossip_getroute_reply,2,hops,num_hops*struct route_hop
|
2017-03-22 13:30:09 +01:00
|
|
|
|
|
|
|
gossip_getchannels_request,7
|
|
|
|
|
|
|
|
gossip_getchannels_reply,107
|
|
|
|
gossip_getchannels_reply,0,num_channels,u16
|
|
|
|
gossip_getchannels_reply,2,nodes,num_channels*struct gossip_getchannels_entry
|
2017-04-12 20:20:48 +02:00
|
|
|
|
|
|
|
# Ping/pong test.
|
|
|
|
gossip_ping,8
|
|
|
|
gossip_ping,0,unique_id,u64
|
|
|
|
gossip_ping,0,num_pong_bytes,u16
|
|
|
|
gossip_ping,0,len,u16
|
|
|
|
|
|
|
|
gossip_ping_reply,108
|
|
|
|
gossip_ping_reply,0,totlen,u16
|
|
|
|
|
2017-04-30 23:49:15 +02:00
|
|
|
# Given a short_channel_id, return the endpoints
|
|
|
|
gossip_resolve_channel_request,9
|
|
|
|
gossip_resolve_channel_request,0,channel_id,struct short_channel_id
|
|
|
|
|
|
|
|
gossip_resolve_channel_reply,109
|
2017-05-05 08:41:44 +02:00
|
|
|
gossip_resolve_channel_reply,0,num_keys,u16
|
|
|
|
gossip_resolve_channel_reply,0,keys,num_keys*struct pubkey
|
2017-05-07 01:59:48 +02:00
|
|
|
|
|
|
|
# The main daemon forward some gossip message to gossipd, allows injecting
|
|
|
|
# arbitrary gossip messages.
|
|
|
|
gossip_forwarded_msg,10
|
|
|
|
gossip_forwarded_msg,0,msglen,2
|
|
|
|
gossip_forwarded_msg,2,msg,msglen
|