2 conf.c -- configuration code
3 Copyright (C) 1998 Emphyrio,
4 Copyright (C) 1998,1999,2000 Ivo Timmermans <itimmermans@bigfoot.com>
5 2000 Guus Sliepen <guus@sliepen.warande.net>
6 2000 Cris van Pelt <tribbel@arise.dhs.org>
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 $Id: conf.c,v 1.9.4.13 2000/10/14 17:04:12 guus Exp $
37 #include "netutl.h" /* for strtoip */
38 #include <utils.h> /* for cp */
46 int timeout = 0; /* seconds before timeout */
47 char *confbase = NULL; /* directory in which all config files are */
49 /* Will be set if HUP signal is received. It will be processed when it is safe. */
53 These are all the possible configurable values
55 static internal_config_t hazahaza[] = {
56 /* Main configuration file keywords */
57 { "Name", tincname, TYPE_NAME },
58 { "ConnectTo", connectto, TYPE_NAME },
59 { "PingTimeout", pingtimeout, TYPE_INT },
60 { "TapDevice", tapdevice, TYPE_NAME },
61 { "PrivateKey", privatekey, TYPE_NAME },
62 { "KeyExpire", keyexpire, TYPE_INT },
63 { "Hostnames", resolve_dns, TYPE_BOOL },
64 { "Interface", interface, TYPE_NAME },
65 { "InterfaceIP", interfaceip, TYPE_IP },
66 /* Host configuration file keywords */
67 { "Address", address, TYPE_NAME },
68 { "Port", port, TYPE_INT },
69 { "PublicKey", publickey, TYPE_NAME },
70 { "Subnet", subnet, TYPE_NAME },
71 { "RestrictHosts", restricthosts, TYPE_BOOL },
72 { "RestrictSubnets", restrictsubnets, TYPE_BOOL },
73 { "RestrictAddress", restrictaddress, TYPE_BOOL },
74 { "RestrictPort", restrictport, TYPE_BOOL },
75 { "IndirectData", indirectdata, TYPE_BOOL },
76 { "TCPonly", tcponly, TYPE_BOOL },
81 Add given value to the list of configs cfg
84 add_config_val(config_t **cfg, int argtype, char *val)
89 p = (config_t*)xmalloc(sizeof(*p));
95 p->data.val = strtol(val, &q, 0);
100 p->data.ptr = xmalloc(strlen(val) + 1);
101 strcpy(p->data.ptr, val);
104 p->data.ip = strtoip(val);
107 if(!strcasecmp("yes", val))
108 p->data.val = stupid_true;
109 else if(!strcasecmp("no", val))
110 p->data.val = stupid_false;
115 p->argtype = argtype;
138 Parse a configuration file and put the results in the configuration tree
141 int read_config_file(config_t **base, const char *fname)
145 char line[MAXBUFSIZE]; /* There really should not be any line longer than this... */
150 if((fp = fopen (fname, "r")) == NULL)
157 if(fgets(line, MAXBUFSIZE, fp) == NULL)
165 if(!index(line, '\n'))
167 syslog(LOG_ERR, _("Line %d too long while reading config file %s"), lineno, fname);
171 if((p = strtok(line, "\t\n\r =")) == NULL)
172 continue; /* no tokens on this line */
175 continue; /* comment: ignore */
177 for(i = 0; hazahaza[i].name != NULL; i++)
178 if(!strcasecmp(hazahaza[i].name, p))
181 if(!hazahaza[i].name)
183 syslog(LOG_ERR, _("Invalid variable name on line %d while reading config file %s"),
188 if(((q = strtok(NULL, "\t\n\r =")) == NULL) || q[0] == '#')
190 fprintf(stderr, _("No value for variable on line %d while reading config file %s"),
195 cfg = add_config_val(base, hazahaza[i].argtype, q);
198 fprintf(stderr, _("Invalid value for variable on line %d while reading config file %s"),
203 cfg->which = hazahaza[i].which;
213 int read_server_config()
218 asprintf(fname, "%s/tinc.conf", confbase);
219 x = read_config_file(&config, fname);
226 Look up the value of the config option type
228 const config_t *get_config_val(config_t *p, which_t type)
231 for(p = config; p != NULL; p = p->next)
240 Support for multiple config lines.
241 Index is used to get a specific value, 0 being the first, 1 the second etc.
243 const config_t *get_next_config_val(config_t *p, which_t type, int index)
246 for(p = config; p != NULL; p = p->next)
256 Remove the complete configuration tree.
258 void clear_config(config_t **base)
262 for(p = *base; p != NULL; p = next)
265 if(p->data.ptr && (p->argtype == TYPE_NAME))