X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fconf.h;h=13af26c07949b10b5e1e267a2d67938239c953a8;hp=de3d583c0d31f7b329fc576e1774628dbf376310;hb=30df5e95dbe585c6076d743d3771a42ad7c78590;hpb=d3ea434b3684093d6d160b8077c1f51a50ac7f61 diff --git a/src/conf.h b/src/conf.h index de3d583c..13af26c0 100644 --- a/src/conf.h +++ b/src/conf.h @@ -17,43 +17,60 @@ 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 2000/05/30 11:18:12 zarq Exp $ + $Id: conf.h,v 1.7 2000/10/18 20:12:08 zarq Exp $ */ #ifndef __TINC_CONF_H__ #define __TINC_CONF_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; } 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, + tincname = 1, + connectto, pingtimeout, + tapdevice, + tapsubnet, + privatekey, keyexpire, - vpnmask, - resolve_dns + resolve_dns, + interface, + interfaceip, + address, + port, + publickey, + subnet, + restricthosts, + restrictsubnets, + restrictaddress, + restrictport, + indirectdata, + tcponly, } which_t; typedef struct config_t { struct config_t *next; which_t which; - data_t data; + int argtype; + union data { + unsigned long val; + void *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 @@ -69,9 +86,16 @@ enum { extern config_t *config; extern int debug_lvl; extern int timeout; +extern int upstreamindex; +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 *, which_t type); +extern const config_t *get_next_config_val(config_t *, which_t type, int); +extern void clear_config(); +extern int read_server_config(void); #endif /* __TINC_CONF_H__ */