ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/gvpe/src/conf.h
(Generate patch)

Comparing gvpe/src/conf.h (file contents):
Revision 1.37 by pcg, Sat Jul 18 05:59:16 2009 UTC vs.
Revision 1.44 by root, Wed Jul 17 16:40:57 2013 UTC

37#include <openssl/rsa.h> 37#include <openssl/rsa.h>
38 38
39#include "slog.h" 39#include "slog.h"
40#include "global.h" 40#include "global.h"
41 41
42#define DEFAULT_REKEY 3600 42#define DEFAULT_REKEY 3607 // interval between rekeys
43#define DEFAULT_RESEED 3613 // interval between rng reseeds
43#define DEFAULT_KEEPALIVE 60 // one keepalive/minute (it's just 8 bytes...) 44#define DEFAULT_KEEPALIVE 60 // one keepalive/minute (it's just 8 bytes...)
44#define DEFAULT_UDPPORT 655 // same as tinc, conflicts would be rare 45#define DEFAULT_UDPPORT 655 // same as tinc, conflicts would be rare
45#define DEFAULT_MTU 1500 // let's ether-net 46#define DEFAULT_MTU 1500 // let's ether-net
46#define DEFAULT_MAX_RETRY 3600 // retry at least this often 47#define DEFAULT_MAX_RETRY 3600 // retry at least this often
47#define DEFAULT_MAX_TTL 60 // packets expire after this many seconds 48#define DEFAULT_MAX_TTL 60 // packets expire after this many seconds
48#define DEFAULT_MAX_QUEUE 512 // never queue more than this many packets 49#define DEFAULT_MAX_QUEUE 512 // never queue more than this many packets
49 50
50#define DEFAULT_DNS_TIMEOUT_FACTOR 8.F // initial retry timeout multiple 51#define DEFAULT_DNS_TIMEOUT_FACTOR 8.F // initial retry timeout multiple
51#define DEFAULT_DNS_SEND_INTERVAL .01F // minimum send interval 52#define DEFAULT_DNS_SEND_INTERVAL .01F // minimum send interval
52#define DEFAULT_DNS_OVERLAP_FACTOR .5F // RTT * LATENCY_FACTOR == sending rate 53#define DEFAULT_DNS_OVERLAP_FACTOR .5F // RTT * LATENCY_FACTOR == sending rate
53#define DEFAULT_DNS_MAX_OUTSTANDING 100 // max. number of outstanding requests 54#define DEFAULT_DNS_MAX_OUTSTANDING 100 // max. number of outstanding requests
57 PROT_UDPv4 = 0x01, // udp over ipv4 58 PROT_UDPv4 = 0x01, // udp over ipv4
58 PROT_IPv4 = 0x02, // generic ip protocol 59 PROT_IPv4 = 0x02, // generic ip protocol
59 PROT_TCPv4 = 0x04, // tcp over ipv4 (server) 60 PROT_TCPv4 = 0x04, // tcp over ipv4 (server)
60 PROT_ICMPv4 = 0x08, // icmp over ipv4 61 PROT_ICMPv4 = 0x08, // icmp over ipv4
61 PROT_DNSv4 = 0x10, // dns tunnel ipv4 (server) 62 PROT_DNSv4 = 0x10, // dns tunnel ipv4 (server)
63 PROT_ALL = 0x1f
62}; 64};
63 65
64#define PROT_RELIABLE (PROT_TCPv4 | PROT_DNSv4) 66#define PROT_RELIABLE (PROT_TCPv4 | PROT_DNSv4)
65#define PROT_SLOW PROT_DNSv4 67#define PROT_SLOW PROT_DNSv4
66 68
121{ 123{
122 typedef vector<conf_node *> node_vector; 124 typedef vector<conf_node *> node_vector;
123 node_vector nodes; 125 node_vector nodes;
124 conf_node default_node; 126 conf_node default_node;
125 conf_node *thisnode; 127 conf_node *thisnode;
128 char *seed_dev; // the randomd evice to use for seeding
129 double reseed; // the interval between additional seeds
126 int mtu; // the mtu used for outgoing tunnel packets 130 int mtu; // the mtu used for outgoing tunnel packets
127 int nfmark; // the SO_MARK // netfilter mark // fwmark 131 int nfmark; // the SO_MARK // netfilter mark // fwmark
128 double rekey; // rekey interval 132 double rekey; // rekey interval
129 double keepalive; // keepalive probes interval 133 double keepalive; // keepalive probes interval
130 char *ifname; // the interface name (tap0 ...) 134 char *ifname; // the interface name (tap0 ...)
131 bool ifpersist; // should the interface be persistent 135 bool ifpersist; // should the interface be persistent
132 char *prikeyfile; 136 char *prikeyfile;
133 RSA *rsa_key; // our private rsa key 137 RSA *rsa_key; // our private rsa key
134 loglevel llevel; 138 loglevel llevel;
135 u8 ip_proto; // the ip protocol to use 139 u8 ip_proto; // the ip protocol to use
140 uid_t change_uid; // the uid of the user to switch to, or 0
141 gid_t change_gid; // the gid of the user to switch to, or 0
142 char *change_root;// the path to chroot to, "/" == anonymous
136#if ENABLE_ICMP 143#if ENABLE_ICMP
137 u8 icmp_type; // the icmp type for the icmp-protocol 144 u8 icmp_type; // the icmp type for the icmp-protocol
138#endif 145#endif
139 146
140 char *script_if_up; 147 char *script_if_up;
149 u16 proxy_port; // the proxy port, e.g. 3128 156 u16 proxy_port; // the proxy port, e.g. 3128
150#endif 157#endif
151 158
152#if ENABLE_DNS 159#if ENABLE_DNS
153 char *dns_forw_host; 160 char *dns_forw_host;
161 bool dns_case_preserving;
154 u16 dns_forw_port; 162 u16 dns_forw_port;
155 float dns_timeout_factor; 163 float dns_timeout_factor;
156 float dns_send_interval; 164 float dns_send_interval;
157 float dns_overlap_factor; 165 float dns_overlap_factor;
158 int dns_max_outstanding; 166 int dns_max_outstanding;
160 168
161 void init (); 169 void init ();
162 void cleanup (); 170 void cleanup ();
163 void clear (); 171 void clear ();
164 172
173 conf_node *find_node (const char *name);
174
165 // create a filename from string, replacing %s by the nodename 175 // create a filename from string, replacing %s by the nodename
166 // and using relative paths under confbase. 176 // and using relative paths under confbase.
167 char *config_filename (const char *name, const char *dflt); 177 char *config_filename (const char *name, const char *dflt = 0);
168 178
169 void print (); 179 void print ();
170 180
171 configuration (); 181 configuration ();
172 ~configuration (); 182 ~configuration ();
182 int argc; 192 int argc;
183 char **argv; 193 char **argv;
184 194
185 configuration_parser (configuration &conf, bool need_keys, int argc, char **argv); 195 configuration_parser (configuration &conf, bool need_keys, int argc, char **argv);
186 196
197 void parse_file (const char *fname);
187 const char *parse_line (char *line); 198 const char *parse_line (char *line);
188 void parse_argv (); 199 void parse_argv ();
189}; 200};
190 201
191extern struct configuration conf; 202extern struct configuration conf;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines