Browse Source

dual-open: use tx_roles, not side, as switch

It's easier to reason about
travis-experimental
niftynei 4 years ago
committed by Rusty Russell
parent
commit
46641951fa
  1. 14
      lightningd/dual_open_control.c

14
lightningd/dual_open_control.c

@ -351,8 +351,8 @@ static bool psbt_side_contribs_changed(struct wally_psbt *orig,
return false; return false;
} }
/* Adds serials to our inputs + outputs that don't have one yet */ /* Adds serials to inputs + outputs that don't have one yet */
static void psbt_add_serials(struct wally_psbt *psbt, enum side opener) static void psbt_add_serials(struct wally_psbt *psbt, enum tx_role role)
{ {
u16 serial_id; u16 serial_id;
const u64 serial_space = 100000; const u64 serial_space = 100000;
@ -361,7 +361,7 @@ static void psbt_add_serials(struct wally_psbt *psbt, enum side opener)
if (psbt_get_serial_id(&psbt->inputs[i].unknowns, &serial_id)) if (psbt_get_serial_id(&psbt->inputs[i].unknowns, &serial_id))
continue; continue;
while ((serial_id = pseudorand(serial_space)) % 2 != opener || while ((serial_id = pseudorand(serial_space)) % 2 != role ||
psbt_find_serial_input(psbt, serial_id) != -1) { psbt_find_serial_input(psbt, serial_id) != -1) {
/* keep going; */ /* keep going; */
} }
@ -372,7 +372,7 @@ static void psbt_add_serials(struct wally_psbt *psbt, enum side opener)
if (psbt_get_serial_id(&psbt->outputs[i].unknowns, &serial_id)) if (psbt_get_serial_id(&psbt->outputs[i].unknowns, &serial_id))
continue; continue;
while ((serial_id = pseudorand(serial_space)) % 2 != opener || while ((serial_id = pseudorand(serial_space)) % 2 != role ||
psbt_find_serial_output(psbt, serial_id) != -1) { psbt_find_serial_output(psbt, serial_id) != -1) {
/* keep going; */ /* keep going; */
} }
@ -410,7 +410,7 @@ openchannel2_hook_deserialize(struct openchannel2_payload *payload,
/* Add a serial_id to everything that doesn't have one yet */ /* Add a serial_id to everything that doesn't have one yet */
if (payload->psbt) if (payload->psbt)
psbt_add_serials(payload->psbt, REMOTE); psbt_add_serials(payload->psbt, TX_ACCEPTER);
if (payload->psbt && !psbt_has_required_fields(payload->psbt)) if (payload->psbt && !psbt_has_required_fields(payload->psbt))
fatal("Plugin supplied PSBT that's missing required fields. %s", fatal("Plugin supplied PSBT that's missing required fields. %s",
@ -1113,7 +1113,7 @@ static struct command_result *json_open_channel_update(struct command *cmd,
return command_fail(cmd, LIGHTNINGD, "Channel funding in progress"); return command_fail(cmd, LIGHTNINGD, "Channel funding in progress");
/* Add serials to PSBT */ /* Add serials to PSBT */
psbt_add_serials(psbt, LOCAL); psbt_add_serials(psbt, TX_INITIATOR);
if (!psbt_has_required_fields(psbt)) if (!psbt_has_required_fields(psbt))
return command_fail(cmd, FUNDING_PSBT_INVALID, return command_fail(cmd, FUNDING_PSBT_INVALID,
"PSBT is missing required fields %s", "PSBT is missing required fields %s",
@ -1251,7 +1251,7 @@ static struct command_result *json_open_channel_init(struct command *cmd,
} }
/* Add serials to any input that's missing them */ /* Add serials to any input that's missing them */
psbt_add_serials(psbt, LOCAL); psbt_add_serials(psbt, TX_INITIATOR);
if (!psbt_has_required_fields(psbt)) if (!psbt_has_required_fields(psbt))
return command_fail(cmd, FUNDING_PSBT_INVALID, return command_fail(cmd, FUNDING_PSBT_INVALID,
"PSBT is missing required fields %s", "PSBT is missing required fields %s",

Loading…
Cancel
Save