network: add support for configuring extra peers via a separate json file
[project/unetd.git] / network.h
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3 * Copyright (C) 2022 Felix Fietkau <nbd@nbd.name>
4 */
5 #ifndef __UNETD_NETWORK_H
6 #define __UNETD_NETWORK_H
7
8 #include <netinet/in.h>
9 #include <libubox/uloop.h>
10 #include "curve25519.h"
11
12 enum network_type {
13 NETWORK_TYPE_FILE,
14 NETWORK_TYPE_INLINE,
15 NETWORK_TYPE_DYNAMIC,
16 };
17
18 struct wg_ops;
19 struct network_group;
20 struct network_host;
21
22 struct network {
23 struct avl_node node;
24
25 struct wg wg;
26
27 struct {
28 struct blob_attr *data;
29 enum network_type type;
30 int keepalive;
31 uint8_t key[CURVE25519_KEY_SIZE];
32 uint8_t pubkey[CURVE25519_KEY_SIZE];
33 uint8_t auth_key[CURVE25519_KEY_SIZE];
34 const char *file;
35 const char *interface;
36 const char *update_cmd;
37 const char *domain;
38 struct blob_attr *tunnels;
39 struct blob_attr *net_data;
40 struct blob_attr *auth_connect;
41 struct blob_attr *peer_data;
42 } config;
43
44 struct {
45 union network_addr addr;
46 struct network_host *local_host;
47 unsigned int keepalive;
48 int port;
49 int pex_port;
50 bool local_host_changed;
51 } net_config;
52
53 void *net_data;
54 size_t net_data_len;
55 uint64_t net_data_version;
56 int num_net_queries;
57
58 struct uloop_timeout reload_timer;
59
60 int ifindex;
61 struct network_host *prev_local_host;
62
63 struct list_head dynamic_peers;
64 struct avl_tree hosts;
65 struct vlist_tree peers;
66
67 struct avl_tree groups;
68 struct vlist_tree services;
69
70 struct uloop_timeout connect_timer;
71
72 struct network_pex pex;
73 };
74
75 enum {
76 NETWORK_ATTR_NAME,
77 NETWORK_ATTR_TYPE,
78 NETWORK_ATTR_KEY,
79 NETWORK_ATTR_AUTH_KEY,
80 NETWORK_ATTR_FILE,
81 NETWORK_ATTR_DATA,
82 NETWORK_ATTR_INTERFACE,
83 NETWORK_ATTR_UPDATE_CMD,
84 NETWORK_ATTR_KEEPALIVE,
85 NETWORK_ATTR_DOMAIN,
86 NETWORK_ATTR_TUNNELS,
87 NETWORK_ATTR_AUTH_CONNECT,
88 NETWORK_ATTR_PEER_DATA,
89 __NETWORK_ATTR_MAX,
90 };
91
92 extern struct avl_tree networks;
93 extern const struct blobmsg_policy network_policy[__NETWORK_ATTR_MAX];
94
95 static inline const char *network_name(struct network *net)
96 {
97 return net->node.key;
98 }
99
100 void network_fill_host_addr(union network_addr *addr, uint8_t *key);
101 int network_save_dynamic(struct network *net);
102 void network_free_all(void);
103
104 int unetd_network_add(const char *name, struct blob_attr *config);
105 int unetd_network_remove(const char *name);
106
107 #endif