network: add support for configuring extra peers via a separate json file
[project/unetd.git] / network.h
index 81fe892a1ee49cac5260fc963d28a1d80e81634d..38bb8e26f4c05c5af75d147f294d117b31883baf 100644 (file)
--- a/network.h
+++ b/network.h
@@ -1,4 +1,4 @@
-// SPDX-License-Identifier: GPL-2.0+
+// SPDX-License-Identifier: GPL-2.0-or-later
 /*
  * Copyright (C) 2022 Felix Fietkau <nbd@nbd.name>
  */
@@ -37,6 +37,8 @@ struct network {
                const char *domain;
                struct blob_attr *tunnels;
                struct blob_attr *net_data;
+               struct blob_attr *auth_connect;
+               struct blob_attr *peer_data;
        } config;
 
        struct {
@@ -50,9 +52,15 @@ struct network {
 
        void *net_data;
        size_t net_data_len;
+       uint64_t net_data_version;
+       int num_net_queries;
+
+       struct uloop_timeout reload_timer;
 
        int ifindex;
        struct network_host *prev_local_host;
+
+       struct list_head dynamic_peers;
        struct avl_tree hosts;
        struct vlist_tree peers;
 
@@ -76,6 +84,8 @@ enum {
        NETWORK_ATTR_KEEPALIVE,
        NETWORK_ATTR_DOMAIN,
        NETWORK_ATTR_TUNNELS,
+       NETWORK_ATTR_AUTH_CONNECT,
+       NETWORK_ATTR_PEER_DATA,
        __NETWORK_ATTR_MAX,
 };
 
@@ -88,6 +98,7 @@ static inline const char *network_name(struct network *net)
 }
 
 void network_fill_host_addr(union network_addr *addr, uint8_t *key);
+int network_save_dynamic(struct network *net);
 void network_free_all(void);
 
 int unetd_network_add(const char *name, struct blob_attr *config);