/* Routing helpers for use with dijkstra */ #ifndef LIGHTNING_COMMON_ROUTE_H #define LIGHTNING_COMMON_ROUTE_H #include "config.h" #include #include #include struct dijkstra; struct gossmap; struct gossmap_chan; struct gossmap_node; enum route_hop_style { ROUTE_HOP_LEGACY = 1, ROUTE_HOP_TLV = 2, }; /** * struct route_hop: a hop in a route. * * @scid: the short_channel_id. * @direction: 0 (dest node_id < src node_id), 1 (dest node_id > src). * @node_id: the node_id of the destination of this hop. * @amount: amount to send through this hop. * @delay: total cltv delay at this hop. * @blinding: blinding key for this hop (if any) * @enctlv: encrypted TLV for this hop (if any) * @style: onion encoding style for this hop. */ struct route_hop { struct short_channel_id scid; int direction; struct node_id node_id; struct amount_msat amount; u32 delay; struct pubkey *blinding; u8 *enctlv; enum route_hop_style style; }; /* Can c carry amount in dir? */ bool route_can_carry(const struct gossmap *map, const struct gossmap_chan *c, int dir, struct amount_msat amount, void *arg); /* Same, but ignore disabled flags on channel */ bool route_can_carry_even_disabled(const struct gossmap *map, const struct gossmap_chan *c, int dir, struct amount_msat amount, void *unused); /* Shortest path, with lower amount tiebreak */ u64 route_score_shorter(u32 distance, struct amount_msat cost, struct amount_msat risk, int dir UNUSED, const struct gossmap_chan *c UNUSED); /* Cheapest path, with shorter path tiebreak */ u64 route_score_cheaper(u32 distance, struct amount_msat cost, struct amount_msat risk, int dir UNUSED, const struct gossmap_chan *c UNUSED); /* Extract route tal_arr from completed dijkstra: NULL if none. */ struct route_hop *route_from_dijkstra(const tal_t *ctx, const struct gossmap *map, const struct dijkstra *dij, const struct gossmap_node *src, struct amount_msat final_amount, u32 final_cltv); #endif /* LIGHTNING_COMMON_ROUTE_H */