lightningd: rename htlc_in field from failcode to badonion.

That's all it's used for now.

And remove unreferenced failoutchannel.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
Rusty Russell 2020-02-21 15:40:44 +10:30
parent 447730e70f
commit c9e73dc4e0
4 changed files with 31 additions and 33 deletions

View File

@ -100,9 +100,9 @@ struct htlc_in *htlc_in_check(const struct htlc_in *hin, const char *abortstr)
htlc_state_name(hin->hstate)); htlc_state_name(hin->hstate));
else if (hin->failonion && hin->preimage) else if (hin->failonion && hin->preimage)
return corrupt(abortstr, "Both failonion and succeeded"); return corrupt(abortstr, "Both failonion and succeeded");
else if (hin->failcode != 0 && hin->preimage) else if (hin->badonion != 0 && hin->preimage)
return corrupt(abortstr, "Both failcode and succeeded"); return corrupt(abortstr, "Both badonion and succeeded");
else if (hin->failonion && (hin->failcode & BADONION)) else if (hin->failonion && hin->badonion)
return corrupt(abortstr, "Both failed and malformed"); return corrupt(abortstr, "Both failed and malformed");
/* Can't have a resolution while still being added. */ /* Can't have a resolution while still being added. */
@ -112,11 +112,11 @@ struct htlc_in *htlc_in_check(const struct htlc_in *hin, const char *abortstr)
return corrupt(abortstr, "Still adding, has preimage"); return corrupt(abortstr, "Still adding, has preimage");
if (hin->failonion) if (hin->failonion)
return corrupt(abortstr, "Still adding, has failmsg"); return corrupt(abortstr, "Still adding, has failmsg");
if (hin->failcode) if (hin->badonion)
return corrupt(abortstr, "Still adding, has failcode"); return corrupt(abortstr, "Still adding, has badonion");
} else if (hin->hstate >= SENT_REMOVE_HTLC } else if (hin->hstate >= SENT_REMOVE_HTLC
&& hin->hstate <= SENT_REMOVE_ACK_REVOCATION) { && hin->hstate <= SENT_REMOVE_ACK_REVOCATION) {
if (!hin->preimage && !hin->failonion && !hin->failcode) if (!hin->preimage && !hin->failonion && !hin->badonion)
return corrupt(abortstr, "Removing, no resolution"); return corrupt(abortstr, "Removing, no resolution");
} else } else
return corrupt(abortstr, "Bad state %s", return corrupt(abortstr, "Bad state %s",
@ -148,7 +148,7 @@ struct htlc_in *new_htlc_in(const tal_t *ctx,
sizeof(hin->onion_routing_packet)); sizeof(hin->onion_routing_packet));
hin->hstate = RCVD_ADD_COMMIT; hin->hstate = RCVD_ADD_COMMIT;
hin->failcode = 0; hin->badonion = 0;
hin->failonion = NULL; hin->failonion = NULL;
hin->preimage = NULL; hin->preimage = NULL;
@ -186,9 +186,9 @@ struct htlc_out *htlc_out_check(const struct htlc_out *hout,
/* If output is resolved, input must be resolved same /* If output is resolved, input must be resolved same
* way (or not resolved yet). */ * way (or not resolved yet). */
if (hout->failonion) { if (hout->failonion) {
if (hout->in->failcode) if (hout->in->badonion)
return corrupt(abortstr, return corrupt(abortstr,
"Output failmsg, input failcode"); "Output failmsg, input badonion");
if (hout->in->preimage) if (hout->in->preimage)
return corrupt(abortstr, return corrupt(abortstr,
"Output failmsg, input preimage"); "Output failmsg, input preimage");
@ -203,9 +203,9 @@ struct htlc_out *htlc_out_check(const struct htlc_out *hout,
if (hout->in->failonion) if (hout->in->failonion)
return corrupt(abortstr, return corrupt(abortstr,
"Output preimage, input failonion"); "Output preimage, input failonion");
if (hout->in->failcode) if (hout->in->badonion)
return corrupt(abortstr, return corrupt(abortstr,
"Output preimage, input failcode"); "Output preimage, input badonion");
} else { } else {
if (hout->in->preimage) if (hout->in->preimage)
return corrupt(abortstr, return corrupt(abortstr,
@ -213,9 +213,9 @@ struct htlc_out *htlc_out_check(const struct htlc_out *hout,
if (hout->in->failonion) if (hout->in->failonion)
return corrupt(abortstr, return corrupt(abortstr,
"Output unresovled, input failmsg"); "Output unresovled, input failmsg");
if (hout->in->failcode) if (hout->in->badonion)
return corrupt(abortstr, return corrupt(abortstr,
"Output unresolved, input failcode"); "Output unresolved, input badonion");
} }
} }

View File

@ -36,16 +36,12 @@ struct htlc_in {
/* Shared secret for us to send any failure message (NULL if malformed) */ /* Shared secret for us to send any failure message (NULL if malformed) */
struct secret *shared_secret; struct secret *shared_secret;
/* FIXME: Use failed_htlc here */ /* If we couldn't decode the onion, this contains the error code.. */
/* If a local error, this is non-zero. */ enum onion_type badonion;
enum onion_type failcode;
/* For a remote error. */ /* Otherwise, this contains the failure message to send. */
const struct onionreply *failonion; const struct onionreply *failonion;
/* If failcode & UPDATE, this is the channel which failed. */
struct short_channel_id failoutchannel;
/* If they fulfilled, here's the preimage. */ /* If they fulfilled, here's the preimage. */
struct preimage *preimage; struct preimage *preimage;

View File

@ -76,7 +76,7 @@ static bool htlc_in_update_state(struct channel *channel,
wallet_htlc_update(channel->peer->ld->wallet, wallet_htlc_update(channel->peer->ld->wallet,
hin->dbid, newstate, hin->preimage, hin->dbid, newstate, hin->preimage,
hin->failcode, hin->failonion, NULL); hin->badonion, hin->failonion, NULL);
hin->hstate = newstate; hin->hstate = newstate;
return true; return true;
@ -161,7 +161,7 @@ static void local_fail_in_htlc_badonion(struct htlc_in *hin,
assert(!hin->preimage); assert(!hin->preimage);
assert(badonion & BADONION); assert(badonion & BADONION);
hin->failcode = badonion; hin->badonion = badonion;
/* We update state now to signal it's in progress, for persistence. */ /* We update state now to signal it's in progress, for persistence. */
htlc_in_update_state(hin->key.channel, hin, SENT_REMOVE_HTLC); htlc_in_update_state(hin->key.channel, hin, SENT_REMOVE_HTLC);
htlc_in_check(hin, __func__); htlc_in_check(hin, __func__);
@ -714,7 +714,7 @@ static void channel_resolve_reply(struct subd *gossip, const u8 *msg,
wallet_forwarded_payment_add(gr->hin->key.channel->peer->ld->wallet, wallet_forwarded_payment_add(gr->hin->key.channel->peer->ld->wallet,
gr->hin, &gr->next_channel, NULL, gr->hin, &gr->next_channel, NULL,
FORWARD_LOCAL_FAILED, FORWARD_LOCAL_FAILED,
gr->hin->failcode); WIRE_UNKNOWN_NEXT_PEER);
tal_free(gr); tal_free(gr);
return; return;
} }
@ -1293,12 +1293,12 @@ void onchain_failed_our_htlc(const struct channel *channel,
static void remove_htlc_in(struct channel *channel, struct htlc_in *hin) static void remove_htlc_in(struct channel *channel, struct htlc_in *hin)
{ {
htlc_in_check(hin, __func__); htlc_in_check(hin, __func__);
assert(hin->failonion || hin->preimage || hin->failcode); assert(hin->failonion || hin->preimage || hin->badonion);
log_debug(channel->log, "Removing in HTLC %"PRIu64" state %s %s", log_debug(channel->log, "Removing in HTLC %"PRIu64" state %s %s",
hin->key.id, htlc_state_name(hin->hstate), hin->key.id, htlc_state_name(hin->hstate),
hin->preimage ? "FULFILLED" hin->preimage ? "FULFILLED"
: hin->failcode ? onion_type_name(hin->failcode) : hin->badonion ? onion_type_name(hin->badonion)
: "REMOTEFAIL"); : "REMOTEFAIL");
/* If we fulfilled their HTLC, credit us. */ /* If we fulfilled their HTLC, credit us. */
@ -2019,8 +2019,8 @@ void peer_htlcs(const tal_t *ctx,
hin->cltv_expiry, hin->onion_routing_packet, hin->cltv_expiry, hin->onion_routing_packet,
hin->hstate); hin->hstate);
if (hin->failcode) if (hin->badonion)
add_fail_badonion(hin, hin->failcode, failed_in); add_fail_badonion(hin, hin->badonion, failed_in);
if (hin->failonion) if (hin->failonion)
add_fail(hin, hin->failonion, failed_in); add_fail(hin, hin->failonion, failed_in);
if (hin->preimage) if (hin->preimage)

View File

@ -1828,7 +1828,7 @@ static bool wallet_stmt2htlc_in(struct channel *channel,
in->failonion = NULL; in->failonion = NULL;
else else
in->failonion = db_column_onionreply(in, stmt, 8); in->failonion = db_column_onionreply(in, stmt, 8);
in->failcode = db_column_int(stmt, 9); in->badonion = db_column_int(stmt, 9);
if (db_column_is_null(stmt, 11)) { if (db_column_is_null(stmt, 11)) {
in->shared_secret = NULL; in->shared_secret = NULL;
} else { } else {
@ -1853,12 +1853,12 @@ static bool wallet_stmt2htlc_in(struct channel *channel,
#ifdef COMPAT_V080 #ifdef COMPAT_V080
/* This field is now reserved for badonion codes: the rest should /* This field is now reserved for badonion codes: the rest should
* use the failonion field. */ * use the failonion field. */
if (in->failcode && !(in->failcode & BADONION)) { if (in->badonion && !(in->badonion & BADONION)) {
log_broken(channel->log, log_broken(channel->log,
"Replacing incoming HTLC %"PRIu64" error " "Replacing incoming HTLC %"PRIu64" error "
"%s with WIRE_TEMPORARY_NODE_FAILURE", "%s with WIRE_TEMPORARY_NODE_FAILURE",
in->key.id, onion_type_name(in->failcode)); in->key.id, onion_type_name(in->badonion));
in->failcode = 0; in->badonion = 0;
in->failonion = create_onionreply(in, in->failonion = create_onionreply(in,
in->shared_secret, in->shared_secret,
towire_temporary_node_failure(tmpctx)); towire_temporary_node_failure(tmpctx));
@ -1947,10 +1947,12 @@ static void fixup_hin(struct wallet *wallet, struct htlc_in *hin)
return; return;
/* Failed ones (only happens after db fixed!) OK. */ /* Failed ones (only happens after db fixed!) OK. */
if (hin->failcode || hin->failonion) if (hin->badonion || hin->failonion)
return; return;
hin->failcode = WIRE_TEMPORARY_NODE_FAILURE; hin->failonion = create_onionreply(hin,
hin->shared_secret,
towire_temporary_node_failure(tmpctx));
log_broken(wallet->log, "HTLC #%"PRIu64" (%s) " log_broken(wallet->log, "HTLC #%"PRIu64" (%s) "
" for amount %s" " for amount %s"