mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-18 13:25:43 +01:00
3866d7605c
To do this we keep an order counter so we know how to retransmit. We could simply keep old packets, but this is a little clearer for now. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
61 lines
2.2 KiB
C
61 lines
2.2 KiB
C
#ifndef LIGHTNING_DAEMON_PACKETS_H
|
|
#define LIGHTNING_DAEMON_PACKETS_H
|
|
#include "config.h"
|
|
#include "lightning.pb-c.h"
|
|
|
|
struct peer;
|
|
struct htlc;
|
|
struct sha256;
|
|
struct bitcoin_signature;
|
|
struct commit_info;
|
|
|
|
/* Send various kinds of packets */
|
|
void queue_pkt_open(struct peer *peer, OpenChannel__AnchorOffer anchor);
|
|
void queue_pkt_anchor(struct peer *peer);
|
|
void queue_pkt_open_commit_sig(struct peer *peer);
|
|
void queue_pkt_open_complete(struct peer *peer);
|
|
void queue_pkt_htlc_add(struct peer *peer, struct htlc *htlc);
|
|
void queue_pkt_htlc_fulfill(struct peer *peer, struct htlc *htlc);
|
|
void queue_pkt_htlc_fail(struct peer *peer, struct htlc *htlc);
|
|
void queue_pkt_commit(struct peer *peer, const struct bitcoin_signature *sig);
|
|
void queue_pkt_revocation(struct peer *peer,
|
|
const struct sha256 *preimage,
|
|
const struct sha256 *next_hash);
|
|
void queue_pkt_close_shutdown(struct peer *peer);
|
|
void queue_pkt_close_signature(struct peer *peer);
|
|
|
|
Pkt *pkt_err(struct peer *peer, const char *msg, ...);
|
|
Pkt *pkt_reconnect(struct peer *peer, u64 ack);
|
|
void queue_pkt_err(struct peer *peer, Pkt *err);
|
|
Pkt *pkt_err_unexpected(struct peer *peer, const Pkt *pkt);
|
|
|
|
/* Process various packets: return an error packet on failure. */
|
|
Pkt *accept_pkt_open(struct peer *peer, const Pkt *pkt,
|
|
struct sha256 *revocation_hash,
|
|
struct sha256 *next_revocation_hash);
|
|
|
|
Pkt *accept_pkt_anchor(struct peer *peer, const Pkt *pkt);
|
|
|
|
Pkt *accept_pkt_open_commit_sig(struct peer *peer, const Pkt *pkt,
|
|
struct bitcoin_signature **sig);
|
|
|
|
Pkt *accept_pkt_open_complete(struct peer *peer, const Pkt *pkt);
|
|
|
|
Pkt *accept_pkt_htlc_add(struct peer *peer, const Pkt *pkt, struct htlc **h);
|
|
|
|
Pkt *accept_pkt_htlc_fail(struct peer *peer, const Pkt *pkt, struct htlc **h);
|
|
|
|
Pkt *accept_pkt_htlc_fulfill(struct peer *peer, const Pkt *pkt, struct htlc **h,
|
|
bool *was_already_fulfilled);
|
|
|
|
Pkt *accept_pkt_update_accept(struct peer *peer, const Pkt *pkt);
|
|
|
|
Pkt *accept_pkt_commit(struct peer *peer, const Pkt *pkt,
|
|
struct bitcoin_signature *sig);
|
|
|
|
Pkt *accept_pkt_revocation(struct peer *peer, const Pkt *pkt);
|
|
|
|
Pkt *accept_pkt_close_shutdown(struct peer *peer, const Pkt *pkt);
|
|
|
|
#endif /* LIGHTNING_DAEMON_PACKETS_H */
|