mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-18 13:25:43 +01:00
62e1e2467c
This allows us to ensure a packet is read by the other end, but we don't read anything else from them or write anything to them. Using '+' is similar, but because it closes the connection, the peer might notice before receiving the packet (such as if it does a write). Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
39 lines
1.2 KiB
C
39 lines
1.2 KiB
C
#ifndef LIGHTNING_COMMON_DEV_DISCONNECT_H
|
|
#define LIGHTNING_COMMON_DEV_DISCONNECT_H
|
|
#include "config.h"
|
|
#include <stdbool.h>
|
|
|
|
#if DEVELOPER
|
|
enum dev_disconnect {
|
|
/* Do nothing. */
|
|
DEV_DISCONNECT_NORMAL = '=',
|
|
/* Close connection before sending packet (and fail write). */
|
|
DEV_DISCONNECT_BEFORE = '-',
|
|
/* Close connection after sending packet. */
|
|
DEV_DISCONNECT_AFTER = '+',
|
|
/* Close connection after dropping packet. */
|
|
DEV_DISCONNECT_DROPPKT = '@',
|
|
/* Swallow all writes from now on, and do no more reads. */
|
|
DEV_DISCONNECT_BLACKHOLE = '0',
|
|
/* Don't use connection after sending packet, but don't close. */
|
|
DEV_DISCONNECT_DISABLE_AFTER = 'x',
|
|
};
|
|
|
|
/* Force a close fd before or after a certain packet type */
|
|
enum dev_disconnect dev_disconnect(int pkt_type);
|
|
|
|
/* Make next write on fd fail as if they'd disconnected. */
|
|
void dev_sabotage_fd(int fd, bool close_fd);
|
|
|
|
/* No more data to arrive, what's written is swallowed. */
|
|
void dev_blackhole_fd(int fd);
|
|
|
|
/* For debug code to set in daemon. */
|
|
void dev_disconnect_init(int fd);
|
|
|
|
/* Hack for channeld to do DEV_DISCONNECT_SUPPRESS_COMMIT. */
|
|
extern bool dev_suppress_commit;
|
|
#endif /* DEVELOPER */
|
|
|
|
#endif /* LIGHTNING_COMMON_DEV_DISCONNECT_H */
|