mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-18 13:25:43 +01:00
26a03acfd0
Simple routing topology, and ability to ask about the cheapest route. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
61 lines
1.6 KiB
C
61 lines
1.6 KiB
C
#ifndef LIGHTNING_DAEMON_ROUTING_H
|
|
#define LIGHTNING_DAEMON_ROUTING_H
|
|
#include "config.h"
|
|
#include "bitcoin/pubkey.h"
|
|
|
|
#define ROUTING_MAX_HOPS 20
|
|
|
|
struct node_connection {
|
|
struct node *src, *dst;
|
|
/* millisatoshi. */
|
|
u32 base_fee;
|
|
/* millionths */
|
|
s32 proportional_fee;
|
|
|
|
/* Delay for HTLC in blocks.*/
|
|
u32 delay;
|
|
/* Minimum allowable HTLC expiry in blocks. */
|
|
u32 min_blocks;
|
|
};
|
|
|
|
struct node {
|
|
struct pubkey id;
|
|
/* Routes connecting to us. */
|
|
struct node_connection *conns;
|
|
|
|
/* Temporary data for routefinding. */
|
|
struct {
|
|
/* Total to get to here from target. */
|
|
s64 total;
|
|
/* Where that came from. */
|
|
struct node_connection *prev;
|
|
} bfg[ROUTING_MAX_HOPS+1];
|
|
};
|
|
|
|
struct lightningd_state;
|
|
|
|
struct node *new_node(struct lightningd_state *dstate,
|
|
const struct pubkey *id);
|
|
|
|
struct node *get_node(struct lightningd_state *dstate,
|
|
const struct pubkey *id);
|
|
|
|
/* msatoshi must be possible (< 21 million BTC), ie < 2^60.
|
|
* If it returns more than msatoshis, it overflowed. */
|
|
s64 connection_fee(const struct node_connection *c, u64 msatoshi);
|
|
|
|
/* Updates existing connection, or creates new one as required. */
|
|
struct node_connection *add_connection(struct lightningd_state *dstate,
|
|
struct node *from, struct node *to,
|
|
u32 base_fee, s32 proportional_fee,
|
|
u32 delay, u32 min_blocks);
|
|
|
|
struct peer *find_route(struct lightningd_state *dstate,
|
|
const struct pubkey *to,
|
|
u64 msatoshi, s64 *fee,
|
|
struct node_connection ***route);
|
|
|
|
struct node_map *empty_node_map(struct lightningd_state *dstate);
|
|
|
|
#endif /* LIGHTNING_DAEMON_ROUTING_H */
|