unet-cli: bring up interface on ssh add
[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 } config;
42
43 struct {
44 union network_addr addr;
45 struct network_host *local_host;
46 unsigned int keepalive;
47 int port;
48 int pex_port;
49 bool local_host_changed;
50 } net_config;
51
52 void *net_data;
53 size_t net_data_len;
54 uint64_t net_data_version;
55 int num_net_queries;
56
57 struct uloop_timeout reload_timer;
58
59 int ifindex;
60 struct network_host *prev_local_host;
61 struct avl_tree hosts;
62 struct vlist_tree peers;
63
64 struct avl_tree groups;
65 struct vlist_tree services;
66
67 struct uloop_timeout connect_timer;
68
69 struct network_pex pex;
70 };
71
72 enum {
73 NETWORK_ATTR_NAME,
74 NETWORK_ATTR_TYPE,
75 NETWORK_ATTR_KEY,
76 NETWORK_ATTR_AUTH_KEY,
77 NETWORK_ATTR_FILE,
78 NETWORK_ATTR_DATA,
79 NETWORK_ATTR_INTERFACE,
80 NETWORK_ATTR_UPDATE_CMD,
81 NETWORK_ATTR_KEEPALIVE,
82 NETWORK_ATTR_DOMAIN,
83 NETWORK_ATTR_TUNNELS,
84 NETWORK_ATTR_AUTH_CONNECT,
85 __NETWORK_ATTR_MAX,
86 };
87
88 extern struct avl_tree networks;
89 extern const struct blobmsg_policy network_policy[__NETWORK_ATTR_MAX];
90
91 static inline const char *network_name(struct network *net)
92 {
93 return net->node.key;
94 }
95
96 void network_fill_host_addr(union network_addr *addr, uint8_t *key);
97 int network_save_dynamic(struct network *net);
98 void network_free_all(void);
99
100 int unetd_network_add(const char *name, struct blob_attr *config);
101 int unetd_network_remove(const char *name);
102
103 #endif