Browse Source

lightningd: Don't accept 0sat for closing fee step

We must give up something on each negotiation step. Can't take 0 satoshi
as an argument.

Changelog-None
travis-debug
Vasil Dimov 5 years ago
committed by neil saitug
parent
commit
d2165ff4d8
  1. 12
      lightningd/peer_control.c

12
lightningd/peer_control.c

@ -1370,9 +1370,15 @@ static struct command_result *json_close(struct command *cmd,
} else { } else {
channel->closing_fee_negotiation_step = channel->closing_fee_negotiation_step =
strtoull(fee_negotiation_step_str, &end, 10); strtoull(fee_negotiation_step_str, &end, 10);
if (*end == '%') {
if (channel->closing_fee_negotiation_step < 1 || if (channel->closing_fee_negotiation_step == 0)
channel->closing_fee_negotiation_step > 100) return command_fail(
cmd, JSONRPC2_INVALID_PARAMS,
"Wrong value given for fee_negotiation_step: "
"\"%s\", must be positive",
fee_negotiation_step_str);
else if (*end == '%') {
if (channel->closing_fee_negotiation_step > 100)
return command_fail( return command_fail(
cmd, JSONRPC2_INVALID_PARAMS, cmd, JSONRPC2_INVALID_PARAMS,
"Wrong value given for " "Wrong value given for "

Loading…
Cancel
Save