|
@ -1061,8 +1061,8 @@ static Pkt *handle_pkt_commit(struct peer *peer, const Pkt *pkt) |
|
|
true); |
|
|
true); |
|
|
if (errmsg) { |
|
|
if (errmsg) { |
|
|
log_broken(peer->log, "queue_pkt_revocation: %s", errmsg); |
|
|
log_broken(peer->log, "queue_pkt_revocation: %s", errmsg); |
|
|
/* FIXME: Return error. */ |
|
|
db_abort_transaction(peer); |
|
|
fatal("revocation_changes: %s", errmsg); |
|
|
return pkt_err(peer, "Database error"); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
peer_get_revocation_preimage(peer, peer->local.commit->commit_num - 1, |
|
|
peer_get_revocation_preimage(peer, peer->local.commit->commit_num - 1, |
|
@ -2226,17 +2226,14 @@ static void do_commit(struct peer *peer, struct command *jsoncmd) |
|
|
= tal_dup(peer, struct sha256, |
|
|
= tal_dup(peer, struct sha256, |
|
|
&peer->remote.commit->revocation_hash); |
|
|
&peer->remote.commit->revocation_hash); |
|
|
|
|
|
|
|
|
if (!db_start_transaction(peer)) { |
|
|
if (!db_start_transaction(peer)) |
|
|
/* FIXME: Return error. */ |
|
|
goto database_error; |
|
|
fatal("queue_pkt_commit: db fail"); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
errmsg = changestates(peer, changes, ARRAY_SIZE(changes), |
|
|
errmsg = changestates(peer, changes, ARRAY_SIZE(changes), |
|
|
feechanges, ARRAY_SIZE(feechanges), true); |
|
|
feechanges, ARRAY_SIZE(feechanges), true); |
|
|
if (errmsg) { |
|
|
if (errmsg) { |
|
|
log_broken(peer->log, "queue_pkt_commit: %s", errmsg); |
|
|
log_broken(peer->log, "queue_pkt_commit: %s", errmsg); |
|
|
/* FIXME: Return error. */ |
|
|
goto database_error; |
|
|
fatal("queue_pkt_commit: %s", errmsg); |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/* Create new commit info for this commit tx. */ |
|
|
/* Create new commit info for this commit tx. */ |
|
@ -2270,14 +2267,12 @@ static void do_commit(struct peer *peer, struct command *jsoncmd) |
|
|
tal_free(peer->remote.commit); |
|
|
tal_free(peer->remote.commit); |
|
|
peer->remote.commit = ci; |
|
|
peer->remote.commit = ci; |
|
|
peer->remote.commit->order = peer->order_counter++; |
|
|
peer->remote.commit->order = peer->order_counter++; |
|
|
if (!db_new_commit_info(peer, THEIRS, peer->their_prev_revocation_hash)){ |
|
|
if (!db_new_commit_info(peer, THEIRS, peer->their_prev_revocation_hash)) |
|
|
/* FIXME: Return error. */ |
|
|
goto database_error; |
|
|
fatal("queue_pkt_commit: database error"); |
|
|
|
|
|
} |
|
|
|
|
|
/* We don't need to remember their commit if we don't give sig. */ |
|
|
/* We don't need to remember their commit if we don't give sig. */ |
|
|
if (ci->sig && !peer_add_their_commit(peer, &ci->txid, ci->commit_num)) |
|
|
if (ci->sig && !peer_add_their_commit(peer, &ci->txid, ci->commit_num)) |
|
|
/* FIXME: Return error. */ |
|
|
goto database_error; |
|
|
fatal("queue_pkt_commit: database error"); |
|
|
|
|
|
|
|
|
|
|
|
if (peer->state == STATE_SHUTDOWN) { |
|
|
if (peer->state == STATE_SHUTDOWN) { |
|
|
set_peer_state(peer, STATE_SHUTDOWN_COMMITTING, __func__, true); |
|
|
set_peer_state(peer, STATE_SHUTDOWN_COMMITTING, __func__, true); |
|
@ -2286,9 +2281,15 @@ static void do_commit(struct peer *peer, struct command *jsoncmd) |
|
|
set_peer_state(peer, STATE_NORMAL_COMMITTING, __func__, true); |
|
|
set_peer_state(peer, STATE_NORMAL_COMMITTING, __func__, true); |
|
|
} |
|
|
} |
|
|
if (!db_commit_transaction(peer)) |
|
|
if (!db_commit_transaction(peer)) |
|
|
/* FIXME: Return error. */ |
|
|
goto database_error; |
|
|
fatal("queue_pkt_commit: database error"); |
|
|
|
|
|
queue_pkt_commit(peer, ci->sig); |
|
|
queue_pkt_commit(peer, ci->sig); |
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
|
|
|
database_error: |
|
|
|
|
|
db_abort_transaction(peer); |
|
|
|
|
|
set_peer_state(peer, STATE_ERR_BREAKDOWN, __func__, false); |
|
|
|
|
|
peer_breakdown(peer); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/* FIXME: don't spin on this timer if we're not connected! */ |
|
|
/* FIXME: don't spin on this timer if we're not connected! */ |
|
|