X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fconf.h;h=de93f72eb55e8a6896d8e7d8092178665aa398e7;hp=673573b3d62f6fc34450af2fe7fac4b44a24b145;hb=a54ec980e047d13ecff7f1f337aa2665072febfd;hpb=d0ba34ccae02d07051bc3f7012a6c116cfb3b653 diff --git a/src/conf.h b/src/conf.h index 673573b3..de93f72e 100644 --- a/src/conf.h +++ b/src/conf.h @@ -1,6 +1,7 @@ /* conf.h -- header for conf.c - Copyright (C) 1998,99 Ivo Timmermans + Copyright (C) 1998-2001 Ivo Timmermans + 2000,2001 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 @@ -15,41 +16,66 @@ 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.26 2001/09/01 12:46:49 guus Exp $ */ #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 { - unsigned long ip; - unsigned long mask; + ipv4_t address; + ipv4_t mask; } ip_mask_t; -typedef union data_t { - unsigned long val; - void *ptr; - ip_mask_t *ip; -} data_t; - typedef enum which_t { - passphrasesdir = 1, - upstreamip, - upstreamport, - listenport, - myvpnip, - tapdevice, - allowconnect, - pingtimeout, - keyexpire, - proxymode + config_dummy = 0, + config_name = 1, + config_connectto, + config_pingtimeout, + config_tapdevice, + config_privatekey, + config_privatekeyfile, + config_keyexpire, + config_hostnames, + config_interface, + config_interfaceip, + config_address, + config_port, + config_publickey, + config_publickeyfile, + config_subnet, + config_restricthosts, + config_restrictsubnets, + config_restrictaddress, + config_restrictport, + config_indirectdata, + config_tcponly, + config_mode, } which_t; typedef struct config_t { struct config_t *next; which_t which; - data_t data; + int argtype; + union data { + long val; + char *ptr; + ip_mask_t *ip; + struct config_t *next; /* For nested configs! */ + } data; } config_t; +typedef struct internal_config_t { + char *name; + enum which_t which; + int argtype; +} internal_config_t; + enum { stupid_false = 1, stupid_true @@ -65,9 +91,16 @@ enum { extern config_t *config; extern int debug_lvl; extern int timeout; +extern int sighup; +extern char *confbase; +extern char *netname; extern config_t *add_config_val(config_t **, int, char *); -extern int read_config_file(const char *); -extern const config_t *get_config_val(which_t type); +extern int read_config_file(config_t **, const char *); +extern const config_t *get_config_val(config_t const *, which_t type); +extern void clear_config(); +extern int read_server_config(void); +extern FILE *ask_and_safe_open(const char*, const char*, const char *); +extern int is_safe_path(const char *); #endif /* __TINC_CONF_H__ */