Browse Source

handle_pkt_commit: don't abort on database error.

Simply mark an error with this peer.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
ppa-0.6.1
Rusty Russell 8 years ago
parent
commit
89235e0904
  1. 33
      daemon/peer.c

33
daemon/peer.c

@ -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! */

Loading…
Cancel
Save