added HA resync option to (re-)integrate nodes to a cluster
[strongswan.git] / src / charon / plugins / ha_sync / ha_sync_socket.h
1 /*
2 * Copyright (C) 2008 Martin Willi
3 * Hochschule fuer Technik Rapperswil
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
12 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
13 * for more details.
14 *
15 * $Id$
16 */
17
18 /**
19 * @defgroup ha_sync_socket ha_sync_socket
20 * @{ @ingroup ha_sync
21 */
22
23 #ifndef HA_SYNC_SOCKET_H_
24 #define HA_SYNC_SOCKET_H_
25
26 #include "ha_sync_message.h"
27
28 /**
29 * UDP port we use for communication
30 */
31 #define HA_SYNC_PORT 4510
32
33 typedef struct ha_sync_socket_t ha_sync_socket_t;
34
35 /**
36 * Socket to send/received SA synchronization data
37 */
38 struct ha_sync_socket_t {
39
40 /**
41 * Push synchronization information to the responsible node.
42 *
43 * @param message message to send
44 */
45 void (*push)(ha_sync_socket_t *this, ha_sync_message_t *message);
46
47 /**
48 * Pull synchronization information from a peer we are responsible.
49 *
50 * @return received message
51 */
52 ha_sync_message_t *(*pull)(ha_sync_socket_t *this);
53
54 /**
55 * Destroy a ha_sync_socket_t.
56 */
57 void (*destroy)(ha_sync_socket_t *this);
58 };
59
60 /**
61 * Create a ha_sync_socket instance.
62 */
63 ha_sync_socket_t *ha_sync_socket_create();
64
65 #endif /* HA_SYNC_SOCKET_ @}*/