mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-03 20:44:54 +01:00
a0c2686ebd
The payment should be stored in a "timely" manner, i.e. within 10ms.
86 lines
2.8 KiB
C
86 lines
2.8 KiB
C
#ifndef LIGHTNING_LIGHTNINGD_PAY_H
|
|
#define LIGHTNING_LIGHTNINGD_PAY_H
|
|
#include "config.h"
|
|
#include <bitcoin/preimage.h>
|
|
#include <bitcoin/pubkey.h>
|
|
#include <bitcoin/short_channel_id.h>
|
|
#include <wire/gen_onion_wire.h>
|
|
|
|
struct htlc_out;
|
|
struct lightningd;
|
|
struct route_hop;
|
|
struct sha256;
|
|
|
|
/* Routing failure object */
|
|
struct routing_failure {
|
|
unsigned int erring_index;
|
|
enum onion_type failcode;
|
|
struct pubkey erring_node;
|
|
struct short_channel_id erring_channel;
|
|
u8 *channel_update;
|
|
};
|
|
|
|
/* Result of send_payment */
|
|
struct sendpay_result {
|
|
/* Did the payment succeed? */
|
|
bool succeeded;
|
|
/* Preimage. Only loaded if payment succeeded. */
|
|
struct preimage preimage;
|
|
/* Error code, one of the PAY_* macro in jsonrpc_errors.h.
|
|
* Only loaded if payment failed. */
|
|
int errorcode;
|
|
/* Unparseable onion reply. Only loaded if payment failed,
|
|
* and errorcode == PAY_UNPARSEABLE_ONION. */
|
|
const u8* onionreply;
|
|
/* Routing failure object. Only loaded if payment failed,
|
|
* and errorcode == PAY_DESTINATION_PERM_FAIL or
|
|
* errorcode == PAY_TRY_OTHER_ROUTE */
|
|
struct routing_failure* routing_failure;
|
|
/* Error message. Only loaded if payment failed. */
|
|
const char *details;
|
|
};
|
|
|
|
/* Initiate a payment. Return true if the callback will be
|
|
* scheduled for later, or false if the callback has already
|
|
* been called. If the given context is freed before the
|
|
* callback is called, then the callback will no longer be
|
|
* called.
|
|
*
|
|
* This will call the callback "soon" in 10ms or less.
|
|
*
|
|
* Typically the callback will be called with a failed
|
|
* sendpay_result indicating an error code of PAY_IN_PROGRESS.
|
|
* It will only call the callback with successful sendpay_result
|
|
* if the payment has already completed with the same amount
|
|
* and destination before. */
|
|
bool send_payment(const tal_t *ctx,
|
|
struct lightningd* ld,
|
|
const struct sha256 *rhash,
|
|
const struct route_hop *route,
|
|
void (*cb)(const struct sendpay_result *, void*),
|
|
void *cbarg);
|
|
/* Wait for a previous send_payment to complete in definite
|
|
* success or failure. If the given context is freed before
|
|
* the callback is called, then the callback will no longer
|
|
* be called.
|
|
*
|
|
* Return true if the payment is still pending on return, or
|
|
* false if the callback was already invoked before this
|
|
* function returned. */
|
|
bool wait_payment(const tal_t *ctx,
|
|
struct lightningd* ld,
|
|
const struct sha256 *payment_hash,
|
|
void (*cb)(const struct sendpay_result *, void *cbarg),
|
|
void *cbarg);
|
|
|
|
void payment_succeeded(struct lightningd *ld, struct htlc_out *hout,
|
|
const struct preimage *rval);
|
|
|
|
void payment_failed(struct lightningd *ld, const struct htlc_out *hout,
|
|
const char *localfail);
|
|
|
|
/* Inform payment system to save the payment. */
|
|
void payment_store(struct lightningd *ld, const struct sha256 *payment_hash);
|
|
|
|
#endif /* LIGHTNING_LIGHTNINGD_PAY_H */
|