projects
/
tinc
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
- It's 2001, all copyright notices are updated.
[tinc]
/
src
/
conf.h
diff --git
a/src/conf.h
b/src/conf.h
index
de3d583
..
dce3802
100644
(file)
--- a/
src/conf.h
+++ b/
src/conf.h
@@
-1,7
+1,7
@@
/*
conf.h -- header for conf.c
/*
conf.h -- header for conf.c
- Copyright (C) 1998
,1999,2000
Ivo Timmermans <itimmermans@bigfoot.com>
-
2000
Guus Sliepen <guus@sliepen.warande.net>
+ Copyright (C) 1998
-2001
Ivo Timmermans <itimmermans@bigfoot.com>
+
2000,2001
Guus Sliepen <guus@sliepen.warande.net>
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
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
@@
-17,43
+17,64
@@
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
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.6
.4.21 2001/01/07 17:08:56 guus
Exp $
*/
#ifndef __TINC_CONF_H__
#define __TINC_CONF_H__
*/
#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 {
typedef struct ip_mask_t {
-
unsigned long ip
;
-
unsigned long
mask;
+
ipv4_t address
;
+
ipv4_t
mask;
} ip_mask_t;
} ip_mask_t;
-typedef union data_t {
- unsigned long val;
- void *ptr;
- ip_mask_t *ip;
-} data_t;
-
typedef enum which_t {
typedef enum which_t {
- passphrasesdir = 1,
- upstreamip,
- upstreamport,
- listenport,
- myvpnip,
- tapdevice,
- allowconnect,
- pingtimeout,
- keyexpire,
- vpnmask,
- resolve_dns
+ 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,
} which_t;
typedef struct config_t {
struct config_t *next;
which_t which;
} which_t;
typedef struct config_t {
struct config_t *next;
which_t which;
- data_t data;
+ int argtype;
+ union data {
+ unsigned long val;
+ char *ptr;
+ ip_mask_t *ip;
+ struct config_t *next; /* For nested configs! */
+ } data;
} config_t;
} config_t;
+typedef struct internal_config_t {
+ char *name;
+ enum which_t which;
+ int argtype;
+} internal_config_t;
+
enum {
stupid_false = 1,
stupid_true
enum {
stupid_false = 1,
stupid_true
@@
-69,9
+90,15
@@
enum {
extern config_t *config;
extern int debug_lvl;
extern int timeout;
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 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 void clear_config();
+extern int read_server_config(void);
+extern FILE *ask_and_safe_open(const char*, const char*);
#endif /* __TINC_CONF_H__ */
#endif /* __TINC_CONF_H__ */