1 /* SPDX-License-Identifier: LGPL-2.1+ */
3 * Copyright (C) 2015-2020 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved.
10 #include <netinet/in.h>
11 #include <sys/socket.h>
16 typedef uint8_t wg_key
[32];
17 typedef char wg_key_b64_string
[((sizeof(wg_key
) + 2) / 3) * 4 + 1];
19 /* Cross platform __kernel_timespec */
25 typedef struct wg_allowedip
{
32 struct wg_allowedip
*next_allowedip
;
36 WGPEER_REMOVE_ME
= 1U << 0,
37 WGPEER_REPLACE_ALLOWEDIPS
= 1U << 1,
38 WGPEER_HAS_PUBLIC_KEY
= 1U << 2,
39 WGPEER_HAS_PRESHARED_KEY
= 1U << 3,
40 WGPEER_HAS_PERSISTENT_KEEPALIVE_INTERVAL
= 1U << 4
43 typedef union wg_endpoint
{
45 struct sockaddr_in addr4
;
46 struct sockaddr_in6 addr6
;
49 typedef struct wg_peer
{
50 enum wg_peer_flags flags
;
57 struct timespec64 last_handshake_time
;
58 uint64_t rx_bytes
, tx_bytes
;
59 uint16_t persistent_keepalive_interval
;
61 struct wg_allowedip
*first_allowedip
, *last_allowedip
;
62 struct wg_peer
*next_peer
;
65 enum wg_device_flags
{
66 WGDEVICE_REPLACE_PEERS
= 1U << 0,
67 WGDEVICE_HAS_PRIVATE_KEY
= 1U << 1,
68 WGDEVICE_HAS_PUBLIC_KEY
= 1U << 2,
69 WGDEVICE_HAS_LISTEN_PORT
= 1U << 3,
70 WGDEVICE_HAS_FWMARK
= 1U << 4
73 typedef struct wg_device
{
77 enum wg_device_flags flags
;
85 struct wg_peer
*first_peer
, *last_peer
;
88 #define wg_for_each_device_name(__names, __name, __len) for ((__name) = (__names), (__len) = 0; ((__len) = strlen(__name)); (__name) += (__len) + 1)
89 #define wg_for_each_peer(__dev, __peer) for ((__peer) = (__dev)->first_peer; (__peer); (__peer) = (__peer)->next_peer)
90 #define wg_for_each_allowedip(__peer, __allowedip) for ((__allowedip) = (__peer)->first_allowedip; (__allowedip); (__allowedip) = (__allowedip)->next_allowedip)
92 int wg_set_device(wg_device
*dev
);
93 int wg_get_device(wg_device
**dev
, const char *device_name
);
94 int wg_add_device(const char *device_name
);
95 int wg_del_device(const char *device_name
);
96 void wg_free_device(wg_device
*dev
);
97 char *wg_list_device_names(void); /* first\0second\0third\0forth\0last\0\0 */
98 void wg_key_to_base64(wg_key_b64_string base64
, const wg_key key
);
99 int wg_key_from_base64(wg_key key
, const wg_key_b64_string base64
);
100 bool wg_key_is_zero(const wg_key key
);
101 void wg_generate_public_key(wg_key public_key
, const wg_key private_key
);
102 void wg_generate_private_key(wg_key private_key
);
103 void wg_generate_preshared_key(wg_key preshared_key
);