From 94fd82dc819a0cbe22210c7227e19785b0f60fb5 Mon Sep 17 00:00:00 2001 From: Christian Decker Date: Fri, 28 Oct 2016 16:36:20 +0200 Subject: [PATCH 1/2] irc: Announce the real expiry time So far we've been announcing the locktime instead of the min_expiry the node requires, this results in routes having wrong expiries. --- daemon/irc_announce.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/daemon/irc_announce.c b/daemon/irc_announce.c index c2ae6ad53..6bd182c1d 100644 --- a/daemon/irc_announce.c +++ b/daemon/irc_announce.c @@ -44,7 +44,7 @@ static bool announce_channel(const tal_t *ctx, struct ircstate *state, struct pe loc->index, state->dstate->config.fee_base, state->dstate->config.fee_per_satoshi, - p->remote.locktime.locktime + state->dstate->config.min_htlc_expiry ); sign_privmsg(state, msg); irc_send_msg(state, msg); From f9a4af62e3b0e3b6d07cbf1729ad41ef4945a56e Mon Sep 17 00:00:00 2001 From: Christian Decker Date: Fri, 28 Oct 2016 16:40:27 +0200 Subject: [PATCH 2/2] irc: Added alias handling for node announcements Aliases seem to be popular among users wanting to show off their node, so let's add them :-) --- daemon/irc_announce.c | 12 +++++++++--- daemon/routing.c | 1 + daemon/routing.h | 3 +++ 3 files changed, 13 insertions(+), 3 deletions(-) diff --git a/daemon/irc_announce.c b/daemon/irc_announce.c index 6bd182c1d..cc7e07293 100644 --- a/daemon/irc_announce.c +++ b/daemon/irc_announce.c @@ -177,7 +177,6 @@ static void handle_node_announcement( struct pubkey *pk = talz(msg, struct pubkey); char *hostname = tal_strdup(msg, splits[2]); int port = atoi(splits[3]); - if (!pubkey_from_hexstr(istate->dstate->secpctx, splits[1], strlen(splits[1]), pk) || port < 1) return; @@ -185,9 +184,16 @@ static void handle_node_announcement( log_debug(istate->log, "Ignoring node announcement from %s, signature check failed.", splits[1]); return; + } else if(splits[4] != NULL && strlen(splits[4]) > 64) { + log_debug(istate->log, "Ignoring node announcement from %s, alias too long", + splits[1]); } - add_node(istate->dstate, pk, hostname, port); + struct node *node = add_node(istate->dstate, pk, hostname, port); + if (splits[4] != NULL){ + tal_free(node->alias); + node->alias = tal_hexdata(node, splits[5], strlen(splits[4])); + } } /* @@ -210,7 +216,7 @@ static void handle_irc_privmsg(struct ircstate *istate, const struct privmsg *ms if (splitcount == 10 && streq(type, "CHAN")) handle_channel_announcement(istate, msg, splits + 1); - else if (splitcount == 5 && streq(type, "NODE")) + else if (splitcount >= 5 && streq(type, "NODE")) handle_node_announcement(istate, msg, splits + 1); } diff --git a/daemon/routing.c b/daemon/routing.c index 6c1c60730..0b42f9039 100644 --- a/daemon/routing.c +++ b/daemon/routing.c @@ -65,6 +65,7 @@ struct node *new_node(struct lightningd_state *dstate, n->in = tal_arr(n, struct node_connection *, 0); n->out = tal_arr(n, struct node_connection *, 0); n->port = 0; + n->alias = NULL; node_map_add(dstate->nodes, n); tal_add_destructor(n, destroy_node); diff --git a/daemon/routing.h b/daemon/routing.h index 5430c47ba..9523296e6 100644 --- a/daemon/routing.h +++ b/daemon/routing.h @@ -37,6 +37,9 @@ struct node { /* Where that came from. */ struct node_connection *prev; } bfg[ROUTING_MAX_HOPS+1]; + + /* UTF-8 encoded alias as tal_arr, not zero terminated */ + u8 *alias; }; struct lightningd_state;