mirror of
https://github.com/ElementsProject/lightning.git
synced 2024-11-19 09:54:16 +01:00
2e88249a7b
We need to set some variables as well, and the transition to FAILED is a bit special in that quite some modifiers will skip into FAILED.
286 lines
8.7 KiB
C
286 lines
8.7 KiB
C
#ifndef LIGHTNING_PLUGINS_LIBPLUGIN_PAY_H
|
|
#define LIGHTNING_PLUGINS_LIBPLUGIN_PAY_H
|
|
#include "config.h"
|
|
|
|
#include <common/bolt11.h>
|
|
#include <plugins/libplugin.h>
|
|
#include <wire/gen_onion_wire.h>
|
|
|
|
enum route_hop_style {
|
|
ROUTE_HOP_LEGACY = 1,
|
|
ROUTE_HOP_TLV = 2,
|
|
};
|
|
|
|
struct route_hop {
|
|
struct short_channel_id channel_id;
|
|
int direction;
|
|
struct node_id nodeid;
|
|
struct amount_msat amount;
|
|
u32 delay;
|
|
struct pubkey *blinding;
|
|
enum route_hop_style style;
|
|
};
|
|
|
|
struct legacy_payload {
|
|
struct short_channel_id scid;
|
|
struct amount_msat forward_amt;
|
|
u32 outgoing_cltv;
|
|
};
|
|
|
|
/* struct holding the information necessary to call createonion */
|
|
struct createonion_hop {
|
|
struct node_id pubkey;
|
|
|
|
enum route_hop_style style;
|
|
struct tlv_tlv_payload *tlv_payload;
|
|
struct legacy_payload *legacy_payload;
|
|
};
|
|
|
|
struct createonion_request {
|
|
struct createonion_hop *hops;
|
|
u8 *assocdata;
|
|
struct secret *session_key;
|
|
};
|
|
|
|
struct createonion_response {
|
|
u8 *onion;
|
|
struct secret *shared_secrets;
|
|
};
|
|
|
|
/* States returned by listsendpays, waitsendpay, etc. */
|
|
enum payment_result_state {
|
|
PAYMENT_PENDING,
|
|
PAYMENT_COMPLETE,
|
|
PAYMENT_FAILED,
|
|
};
|
|
|
|
/* A parsed version of the possible outcomes that a sendpay / payment may
|
|
* result in. It excludes the redundant fields such as payment_hash and partid
|
|
* which are already present in the `struct payment` itself. */
|
|
struct payment_result {
|
|
/* DB internal id */
|
|
u64 id;
|
|
u32 partid;
|
|
enum payment_result_state state;
|
|
struct amount_msat amount_sent;
|
|
struct preimage *payment_preimage;
|
|
u32 code;
|
|
const char* failcodename;
|
|
enum onion_type failcode;
|
|
const u8 *raw_message;
|
|
const char *message;
|
|
u32 *erring_index;
|
|
struct node_id *erring_node;
|
|
struct short_channel_id *erring_channel;
|
|
int *erring_direction;
|
|
};
|
|
|
|
/* Information about channels we inferred from a) looking at our channels, and
|
|
* b) from failures encountered during attempts to perform a payment. These
|
|
* are attached to the root payment, since that information is
|
|
* global. Attempts update the estimated channel capacities when starting, and
|
|
* get remove on failure. Success keeps the capacities, since the capacities
|
|
* changed due to the successful HTLCs. */
|
|
struct channel_hint {
|
|
struct short_channel_id_dir scid;
|
|
|
|
/* Upper bound on remove channels inferred from payment failures. */
|
|
struct amount_msat estimated_capacity;
|
|
|
|
/* Is the channel enabled? */
|
|
bool enabled;
|
|
};
|
|
|
|
/* Each payment goes through a number of steps that are always processed in
|
|
* the same order, and some modifiers are called with the payment, and the
|
|
* modifier's data before and after certain steps, allowing customization. The
|
|
* following enum represents the normal workflow of processing a payment, and
|
|
* is used by `payment_continue` to re-enter the state machine from a
|
|
* modifier. The values are powers of two in order to make aggregating of
|
|
* subtree states in the root easy.
|
|
*/
|
|
enum payment_step {
|
|
PAYMENT_STEP_INITIALIZED = 1,
|
|
|
|
/* We just called getroute and got a resulting route, allow modifiers
|
|
* to amend the route. */
|
|
PAYMENT_STEP_GOT_ROUTE = 2,
|
|
|
|
/* We just computed the onion payload, allow modifiers to amend,
|
|
* before constructing the onion packet. */
|
|
PAYMENT_STEP_ONION_PAYLOAD = 4,
|
|
|
|
/* The following states mean that the current payment failed, but a
|
|
* child payment is still running, and we can't say yet whether the
|
|
* overall payment will fail or succeed. */
|
|
PAYMENT_STEP_SPLIT = 8,
|
|
PAYMENT_STEP_RETRY = 16,
|
|
|
|
/* The payment state-machine has terminated, these are the final
|
|
* states that a payment can be in. */
|
|
PAYMENT_STEP_FAILED = 32,
|
|
PAYMENT_STEP_SUCCESS = 64,
|
|
};
|
|
|
|
/* Just a container to collect a subtree result so we can summarize all
|
|
* sub-payments and return a reasonable result to the caller of `pay` */
|
|
struct payment_tree_result {
|
|
/* OR of all the leafs in the subtree. */
|
|
enum payment_step leafstates;
|
|
|
|
/* OR of all the inner nodes and leaf nodes. */
|
|
enum payment_step treestates;
|
|
|
|
struct amount_msat sent;
|
|
|
|
/* Preimage if any of the attempts succeeded. */
|
|
struct preimage *preimage;
|
|
|
|
u32 attempts;
|
|
|
|
/* Pointer to the failure that caused the payment to fail. We just
|
|
* take the one with the highest failcode, since that happen to match
|
|
* the severity of the error. */
|
|
struct payment_result *failure;
|
|
};
|
|
|
|
struct payment {
|
|
/* The command that triggered this payment. Only set for the root
|
|
* payment. */
|
|
struct command *cmd;
|
|
struct plugin *plugin;
|
|
struct list_node list;
|
|
|
|
const char *json_buffer;
|
|
const jsmntok_t *json_toks;
|
|
|
|
/* The current phase we are in. */
|
|
enum payment_step step;
|
|
|
|
/* Real destination we want to route to */
|
|
struct node_id *destination;
|
|
|
|
/* Payment hash extracted from the invoice if any. */
|
|
struct sha256 *payment_hash;
|
|
|
|
/* Payment secret, from the invoice if any. */
|
|
struct secret *payment_secret;
|
|
|
|
u32 partid;
|
|
u32 next_partid;
|
|
|
|
/* Destination we should ask `getroute` for. This might differ from
|
|
* the above destination if we use rendez-vous routing of blinded
|
|
* paths to amend the route later in a mixin. */
|
|
struct node_id *getroute_destination;
|
|
u32 getroute_cltv;
|
|
|
|
struct createonion_request *createonion_request;
|
|
struct createonion_response *createonion_response;
|
|
|
|
/* Target amount to be delivered at the destination */
|
|
struct amount_msat amount;
|
|
|
|
/* tal_arr of route_hops we decoded from the `getroute` call. Exposed
|
|
* here so it can be amended by mixins. */
|
|
struct route_hop *route;
|
|
|
|
struct channel_status *peer_channels;
|
|
|
|
/* The blockheight at which the payment attempt was
|
|
* started. */
|
|
u32 start_block;
|
|
|
|
struct timeabs start_time, end_time;
|
|
struct timeabs deadline;
|
|
|
|
struct amount_msat extra_budget;
|
|
|
|
struct short_channel_id *exclusions;
|
|
|
|
/* Tree structure of payments and subpayments. */
|
|
struct payment *parent, **children;
|
|
|
|
/* Null-terminated array of modifiers to apply to the payment. NULL
|
|
* terminated mainly so we can build a stack of modifiers at
|
|
* compile-time instead of allocating a list for each payment
|
|
* specifically. */
|
|
struct payment_modifier **modifiers;
|
|
void **modifier_data;
|
|
int current_modifier;
|
|
|
|
struct bolt11 *invoice;
|
|
|
|
/* tal_arr of channel_hints we incrementally learn while performing
|
|
* payment attempts. */
|
|
struct channel_hint *channel_hints;
|
|
struct node_id *excluded_nodes;
|
|
|
|
struct payment_result *result;
|
|
|
|
/* Did something happen that will cause all future attempts to fail?
|
|
* This usually means that the final node reported that it can't be
|
|
* reached, or in MPP payments there are no more paths we can
|
|
* attempt. Modifiers need to leave failures alone once this is set to
|
|
* true. Set only on the root payment. */
|
|
bool abort;
|
|
|
|
/* Serialized bolt11 string, kept attachd to the root so we can filter
|
|
* by the invoice. */
|
|
const char *bolt11;
|
|
};
|
|
|
|
struct payment_modifier {
|
|
const char *name;
|
|
void *(*data_init)(struct payment *p);
|
|
void (*post_step_cb)(void *data, struct payment *p);
|
|
};
|
|
|
|
void *payment_mod_get_data(const struct payment *payment,
|
|
const struct payment_modifier *mod);
|
|
|
|
#define REGISTER_PAYMENT_MODIFIER(name, data_type, data_init_cb, step_cb) \
|
|
struct payment_modifier name##_pay_mod = { \
|
|
stringify(name), \
|
|
typesafe_cb_cast(void *(*)(struct payment *), \
|
|
data_type (*)(struct payment *), data_init_cb), \
|
|
typesafe_cb_cast(void (*)(void *, struct payment *), \
|
|
void (*)(data_type, struct payment *), step_cb), \
|
|
};
|
|
|
|
/* The UNUSED marker is used to shut some compilers up. */
|
|
#define REGISTER_PAYMENT_MODIFIER_HEADER(name, data_type) \
|
|
extern struct payment_modifier name##_pay_mod; \
|
|
UNUSED static inline data_type *payment_mod_##name##_get_data( \
|
|
const struct payment *p) \
|
|
{ \
|
|
return payment_mod_get_data(p, &name##_pay_mod); \
|
|
}
|
|
|
|
|
|
struct retry_mod_data {
|
|
int retries;
|
|
};
|
|
/* List of globally available payment modifiers. */
|
|
REGISTER_PAYMENT_MODIFIER_HEADER(retry, struct retry_mod_data);
|
|
|
|
/* For the root payment we can seed the channel_hints with the result from
|
|
* `listpeers`, hence avoid channels that we know have insufficient capacity
|
|
* or are disabled. We do this only for the root payment, to minimize the
|
|
* overhead. */
|
|
REGISTER_PAYMENT_MODIFIER_HEADER(local_channel_hints, void);
|
|
|
|
struct payment *payment_new(tal_t *ctx, struct command *cmd,
|
|
struct payment *parent,
|
|
struct payment_modifier **mods);
|
|
|
|
void payment_start(struct payment *p);
|
|
void payment_continue(struct payment *p);
|
|
|
|
/* Fails a partial payment and continues with the core flow. */
|
|
void payment_fail(struct payment *p);
|
|
struct payment *payment_root(struct payment *p);
|
|
struct payment_tree_result payment_collect_result(struct payment *p);
|
|
|
|
#endif /* LIGHTNING_PLUGINS_LIBPLUGIN_PAY_H */
|