X-Git-Url: https://www.tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fconf.h;h=3a040c7b74cdb9b5502210e764b59d6e13ecc059;hp=9ab0add63884ee8f6efe5b72007f365ae249b9be;hb=84531fb6e621959e06519fdbb7f2a8f7578f66bd;hpb=698191fd2f512f3618e2d60592fcd57cd750b965 diff --git a/src/conf.h b/src/conf.h index 9ab0add6..3a040c7b 100644 --- a/src/conf.h +++ b/src/conf.h @@ -1,7 +1,7 @@ /* conf.h -- header for conf.c - Copyright (C) 1998,1999,2000 Ivo Timmermans - 2000 Guus Sliepen + Copyright (C) 1998-2005 Ivo Timmermans + 2000-2012 Guus Sliepen This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,88 +13,55 @@ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - - $Id: conf.h,v 1.6.4.16 2000/11/04 22:57:30 guus Exp $ + You should have received a copy of the GNU General Public License along + with this program; if not, write to the Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #ifndef __TINC_CONF_H__ #define __TINC_CONF_H__ -#include "net.h" - -#define MAXTIMEOUT 900 /* Maximum timeout value for retries. Should this be a configuration option? */ - -typedef struct ip_mask_t { - ipv4_t address; - ipv4_t mask; -} ip_mask_t; - -typedef enum which_t { - config_name = 1, - config_connectto, - config_pingtimeout, - config_tapdevice, - config_privatekey, - config_keyexpire, - config_hostnames, - config_interface, - config_interfaceip, - config_address, - config_port, - config_publickey, - config_subnet, - config_restricthosts, - config_restrictsubnets, - config_restrictaddress, - config_restrictport, - config_indirectdata, - config_tcponly, -} which_t; +#include "avl_tree.h" +#include "list.h" typedef struct config_t { - struct config_t *next; - which_t which; - int argtype; - union data { - unsigned long val; - void *ptr; - ip_mask_t *ip; - struct config_t *next; /* For nested configs! */ - } data; + char *variable; + char *value; + char *file; + int line; } config_t; -typedef struct internal_config_t { - char *name; - enum which_t which; - int argtype; -} internal_config_t; +#include "subnet.h" -enum { - stupid_false = 1, - stupid_true -}; +extern avl_tree_t *config_tree; -enum { - TYPE_NAME = 1, - TYPE_INT, - TYPE_IP, - TYPE_BOOL -}; - -extern config_t *config; -extern int debug_lvl; -extern int timeout; -extern int sighup; +extern int pinginterval; +extern int pingtimeout; +extern int maxtimeout; +extern bool bypass_security; extern char *confbase; extern char *netname; - -extern config_t *add_config_val(config_t **, int, char *); -extern int read_config_file(config_t **, const char *); -extern const config_t *get_config_val(config_t *, which_t type); -extern void clear_config(); -extern int read_server_config(void); - -#endif /* __TINC_CONF_H__ */ +extern list_t *cmdline_conf; + +extern void init_configuration(avl_tree_t **); +extern void exit_configuration(avl_tree_t **); +extern config_t *new_config(void) __attribute__ ((__malloc__)); +extern void free_config(config_t *); +extern void config_add(avl_tree_t *, config_t *); +extern config_t *lookup_config(const avl_tree_t *, char *); +extern config_t *lookup_config_next(const avl_tree_t *, const config_t *); +extern bool get_config_bool(const config_t *, bool *); +extern bool get_config_int(const config_t *, int *); +extern bool get_config_string(const config_t *, char **); +extern bool get_config_address(const config_t *, struct addrinfo **); +extern bool get_config_subnet(const config_t *, struct subnet_t **); + +extern config_t *parse_config_line(char *, const char *, int); +extern bool read_config_file(avl_tree_t *, const char *); +extern void read_config_options(avl_tree_t *, const char *); +extern bool read_server_config(void); +extern bool read_connection_config(struct connection_t *); +extern FILE *ask_and_open(const char *, const char *); +extern bool is_safe_path(const char *); + +#endif /* __TINC_CONF_H__ */