Browse Source

payalgo: Report route, and result of trying route.

ppa-0.6.1
ZmnSCPxj 7 years ago
committed by Christian Decker
parent
commit
73cda2f2ae
  1. 30
      lightningd/payalgo.c

30
lightningd/payalgo.c

@ -4,11 +4,13 @@
#include <ccan/tal/str/str.h> #include <ccan/tal/str/str.h>
#include <ccan/time/time.h> #include <ccan/time/time.h>
#include <common/bolt11.h> #include <common/bolt11.h>
#include <common/type_to_string.h>
#include <gossipd/gen_gossip_wire.h> #include <gossipd/gen_gossip_wire.h>
#include <gossipd/routing.h> #include <gossipd/routing.h>
#include <lightningd/jsonrpc.h> #include <lightningd/jsonrpc.h>
#include <lightningd/jsonrpc_errors.h> #include <lightningd/jsonrpc_errors.h>
#include <lightningd/lightningd.h> #include <lightningd/lightningd.h>
#include <lightningd/log.h>
#include <lightningd/subd.h> #include <lightningd/subd.h>
#include <sodium/randombytes.h> #include <sodium/randombytes.h>
@ -131,6 +133,7 @@ static void json_pay_sendpay_resolve(const struct sendpay_result *r,
/* If we succeed, hurray */ /* If we succeed, hurray */
if (r->succeeded) { if (r->succeeded) {
log_info(pay->cmd->ld->log, "pay(%p): Success", pay);
json_pay_success(pay->cmd, &r->preimage, json_pay_success(pay->cmd, &r->preimage,
pay->getroute_tries, pay->sendpay_tries); pay->getroute_tries, pay->sendpay_tries);
return; return;
@ -140,13 +143,39 @@ static void json_pay_sendpay_resolve(const struct sendpay_result *r,
* below. If it is not, fail now. */ * below. If it is not, fail now. */
if (r->errorcode != PAY_UNPARSEABLE_ONION && if (r->errorcode != PAY_UNPARSEABLE_ONION &&
r->errorcode != PAY_TRY_OTHER_ROUTE) { r->errorcode != PAY_TRY_OTHER_ROUTE) {
log_info(pay->cmd->ld->log, "pay(%p): Failed, reporting to caller", pay);
json_pay_failure(pay, r); json_pay_failure(pay, r);
return; return;
} }
log_info(pay->cmd->ld->log, "pay(%p): Try another route", pay);
json_pay_try(pay); json_pay_try(pay);
} }
/* Generates a string describing the route. Route should be a
* tal_arr */
static char const *stringify_route(const tal_t *ctx, struct route_hop *route)
{
size_t i;
char *rv = tal_strdup(ctx, "us");
for (i = 0; i < tal_count(route); ++i)
tal_append_fmt(&rv, " -> %s (%"PRIu32"msat, %"PRIu32"blk) -> %s",
type_to_string(ctx, struct short_channel_id, &route[i].channel_id),
route[i].amount, route[i].delay,
type_to_string(ctx, struct pubkey, &route[i].nodeid));
return rv;
}
static void log_route(struct pay *pay, struct route_hop *route)
{
const tal_t *tmpctx = tal_tmpctx(pay->try_parent);
log_info(pay->cmd->ld->log, "pay(%p): sendpay via route: %s",
pay, stringify_route(tmpctx, route));
tal_free(tmpctx);
}
static void json_pay_getroute_reply(struct subd *gossip UNUSED, static void json_pay_getroute_reply(struct subd *gossip UNUSED,
const u8 *reply, const int *fds UNUSED, const u8 *reply, const int *fds UNUSED,
struct pay *pay) struct pay *pay)
@ -215,6 +244,7 @@ static void json_pay_getroute_reply(struct subd *gossip UNUSED,
++pay->sendpay_tries; ++pay->sendpay_tries;
log_route(pay, route);
send_payment(pay->try_parent, send_payment(pay->try_parent,
pay->cmd->ld, &pay->payment_hash, route, pay->cmd->ld, &pay->payment_hash, route,
&json_pay_sendpay_resolve, pay); &json_pay_sendpay_resolve, pay);

Loading…
Cancel
Save