Browse Source

Add optional from id parameter to getroute call.

ppa-0.6.1
root 7 years ago
committed by Christian Decker
parent
commit
8b0ed27c43
  1. 18
      lightningd/gossip_control.c

18
lightningd/gossip_control.c

@ -296,7 +296,9 @@ static void json_getroute_reply(struct subd *gossip, const u8 *reply, const int
static void json_getroute(struct command *cmd, const char *buffer, const jsmntok_t *params) static void json_getroute(struct command *cmd, const char *buffer, const jsmntok_t *params)
{ {
struct pubkey id; struct pubkey id;
jsmntok_t *idtok, *msatoshitok, *riskfactortok, *cltvtok; struct pubkey from_id;
struct pubkey *from_id_to_use;
jsmntok_t *idtok, *msatoshitok, *riskfactortok, *cltvtok, *fromidtok;
u64 msatoshi; u64 msatoshi;
unsigned cltv = 9; unsigned cltv = 9;
double riskfactor; double riskfactor;
@ -307,6 +309,7 @@ static void json_getroute(struct command *cmd, const char *buffer, const jsmntok
"msatoshi", &msatoshitok, "msatoshi", &msatoshitok,
"riskfactor", &riskfactortok, "riskfactor", &riskfactortok,
"?cltv", &cltvtok, "?cltv", &cltvtok,
"?fromid", &fromidtok,
NULL)) { NULL)) {
return; return;
} }
@ -334,7 +337,18 @@ static void json_getroute(struct command *cmd, const char *buffer, const jsmntok
buffer + riskfactortok->start); buffer + riskfactortok->start);
return; return;
} }
u8 *req = towire_gossip_getroute_request(cmd, &ld->id, &id, msatoshi, riskfactor*1000, cltv);
if (fromidtok) {
if (!json_tok_pubkey(buffer, fromidtok, &from_id)) {
command_fail(cmd, "Invalid from id");
return;
}
from_id_to_use = &from_id;
} else {
from_id_to_use = &ld->id;
}
u8 *req = towire_gossip_getroute_request(cmd, from_id_to_use, &id, msatoshi, riskfactor*1000, cltv);
subd_req(ld->gossip, ld->gossip, req, -1, 0, json_getroute_reply, cmd); subd_req(ld->gossip, ld->gossip, req, -1, 0, json_getroute_reply, cmd);
command_still_pending(cmd); command_still_pending(cmd);
} }

Loading…
Cancel
Save