26047b161b575da4fe03dfdea7c5620edcfe506f
[olsrd.git] / src / cfgparser / cfgfile_gen.c
1 /*
2  * The olsr.org Optimized Link-State Routing daemon(olsrd)
3  * Copyright (c) 2005, Andreas T√łnnesen(andreto@olsr.org)
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without 
7  * modification, are permitted provided that the following conditions 
8  * are met:
9  *
10  * * Redistributions of source code must retain the above copyright 
11  *   notice, this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above copyright 
13  *   notice, this list of conditions and the following disclaimer in 
14  *   the documentation and/or other materials provided with the 
15  *   distribution.
16  * * Neither the name of olsr.org, olsrd nor the names of its 
17  *   contributors may be used to endorse or promote products derived 
18  *   from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
23  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 
24  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 
25  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
26  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 
27  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 
28  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 
30  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
31  * POSSIBILITY OF SUCH DAMAGE.
32  *
33  * Visit http://www.olsr.org for more information.
34  *
35  * If you find this software useful feel free to make a donation
36  * to the project. For more information see the website or contact
37  * the copyright holders.
38  *
39  */
40
41 #include "olsrd_conf.h"
42 #include "../ipcalc.h"
43 #include "../net_olsr.h"
44
45 #include <stdio.h>
46 #include <string.h>
47 #include <errno.h>
48 #include <sys/types.h>
49 #include <netinet/in.h>
50 #include <arpa/inet.h>
51
52
53 int
54 olsrd_write_cnf(struct olsrd_config *cnf, const char *fname)
55 {
56   struct ip_prefix_list   *h  = cnf->hna_entries;
57   struct olsr_if           *in = cnf->interfaces;
58   struct plugin_entry      *pe = cnf->plugins;
59   struct plugin_param      *pp;
60   struct ip_prefix_list    *ie = cnf->ipc_nets;
61   struct olsr_lq_mult      *mult;
62
63   char ipv6_buf[100];             /* buffer for IPv6 inet_htop */
64
65   FILE *fd;
66
67   fd = fopen(fname, "w");
68
69   if(fd == NULL)
70     {
71       fprintf(stderr, "Could not open file %s for writing\n%s\n", fname, strerror(errno));
72       return -1;
73     }
74
75   printf("Writing config to file \"%s\".... ", fname);
76
77   fprintf(fd, "#\n# Configuration file for s%s\n# automatically generated by olsrd-cnf parser v. %s\n#\n\n", olsrd_version, PARSER_VERSION);
78
79   /* Debug level */
80   fprintf(fd, "# Debug level(0-9)\n# If set to 0 the daemon runs in the background\n\nDebugLevel\t%d\n\n", cnf->debug_level);
81
82   /* IP version */
83   fprintf(fd, "# IP version to use (4 or 6)\n\nIpVersion\t%d\n\n", cnf->ip_version == AF_INET ? 4 : 6);
84
85   /* FIB Metric */
86   fprintf(fd, "# FIBMetric (\"%s\", \"%s\", or \"%s\")\n\nFIBMetric\t\"%s\"\n\n", CFG_FIBM_FLAT, CFG_FIBM_CORRECT, CFG_FIBM_APPROX,
87     FIBM_FLAT == cnf->fib_metric ? CFG_FIBM_FLAT : FIBM_CORRECT == cnf->fib_metric ? CFG_FIBM_CORRECT : CFG_FIBM_APPROX);
88
89   /* HNA IPv4/IPv6 */
90   fprintf(fd, "# HNA IPv%d routes\n# syntax: netaddr/prefix\n\nHna%d {\n", cnf->ip_version == AF_INET ? 4 : 6, cnf->ip_version == AF_INET ? 4 : 6);
91   while(h) {
92     struct ipaddr_str strbuf;
93     fprintf(fd, "    %s/%d\n", olsr_ip_to_string(&strbuf, &h->net.prefix), h->net.prefix_len);
94     h = h->next;
95   }
96   fprintf(fd, "}\n\n");
97
98   /* No interfaces */
99   fprintf(fd, "# Should olsrd keep on running even if there are\n# no interfaces available? This is a good idea\n# for a PCMCIA/USB hotswap environment.\n# \"yes\" OR \"no\"\n\nAllowNoInt\t");
100   if(cnf->allow_no_interfaces)
101     fprintf(fd, "yes\n\n");
102   else
103     fprintf(fd, "no\n\n");
104
105   /* TOS */
106   fprintf(fd, "# TOS(type of service) to use. Default is 16\n\n");
107   fprintf(fd, "TosValue\t%d\n\n", cnf->tos);
108
109   /* RtTable */
110   fprintf(fd, "# Policy Routing Table to use. Default is 254\n\n");
111   fprintf(fd, "RtTable\t\t%d\n\n", cnf->rttable);
112
113   /* Willingness */
114   fprintf(fd, "# The fixed willingness to use(0-7)\n# If not set willingness will be calculated\n# dynammically based on battery/power status\n\n");
115   if(cnf->willingness_auto)
116     fprintf(fd, "#Willingness\t4\n\n");
117   else
118     fprintf(fd, "Willingness\t%d\n\n", cnf->willingness);
119
120   /* IPC */
121   fprintf(fd, "# Allow processes like the GUI front-end\n# to connect to the daemon.\n\n");
122   fprintf(fd, "IpcConnect {\n");
123   fprintf(fd, "    MaxConnections\t%d\n", cnf->ipc_connections);
124
125   while(ie)
126     {
127       struct ipaddr_str strbuf;
128       if (ie->net.prefix_len == olsr_cnf->maxplen) {
129           fprintf(fd, "    Host\t\t%s\n", olsr_ip_to_string(&strbuf, &ie->net.prefix));
130       } else {
131           fprintf(fd, "    Net\t\t\t%s/%d\n", olsr_ip_to_string(&strbuf, &ie->net.prefix), ie->net.prefix_len);
132       }
133       ie = ie->next;
134     }
135
136   fprintf(fd, "}\n\n");
137
138   /* Hysteresis */
139   fprintf(fd, "# Hysteresis adds more robustness to the\n# link sensing.\n# Used by default. 'yes' or 'no'\n\n");
140
141   if(cnf->use_hysteresis)
142     {
143       fprintf(fd, "UseHysteresis\tyes\n\n");
144       fprintf(fd, "# Hysteresis parameters\n# Do not alter these unless you know \n# what you are doing!\n# Set to auto by default. Allowed\n# values are floating point values\n# in the interval 0,1\n# THR_LOW must always be lower than\n# THR_HIGH!!\n\n");
145       fprintf(fd, "HystScaling\t%0.2f\n", cnf->hysteresis_param.scaling);
146       fprintf(fd, "HystThrHigh\t%0.2f\n", cnf->hysteresis_param.thr_high);
147       fprintf(fd, "HystThrLow\t%0.2f\n\n", cnf->hysteresis_param.thr_low);
148     }
149   else
150     {
151       fprintf(fd, "UseHysteresis\tno\n\n");
152       fprintf(fd, "# Hysteresis parameters\n# Do not alter these unless you know \n# what you are doing!\n# Set to auto by default. Allowed\n# values are floating point values\n# in the interval 0,1\n# THR_LOW must always be lower than\n# THR_HIGH!!\n\n");
153       fprintf(fd, "#HystScaling\t%0.2f\n", cnf->hysteresis_param.scaling);
154       fprintf(fd, "#HystThrHigh\t%0.2f\n", cnf->hysteresis_param.thr_high);
155       fprintf(fd, "#HystThrLow\t%0.2f\n\n", cnf->hysteresis_param.thr_low);
156     }
157
158   /* Pollrate */
159   fprintf(fd, "# Polling rate in seconds(float).\n# Auto uses default value 0.05 sec\n\n");
160   fprintf(fd, "Pollrate\t%0.2f\n", cnf->pollrate);
161
162   /* NIC Changes Pollrate */
163   fprintf(fd, "# Interval to poll network interfaces for configuration\n# changes. Defaults to 2.5 seconds\n");
164   fprintf(fd, "NicChgsPollInt\t%0.2f\n", cnf->nic_chgs_pollrate);
165
166   /* TC redundancy */
167   fprintf(fd, "# TC redundancy\n# Specifies how much neighbor info should\n# be sent in TC messages\n# Possible values are:\n# 0 - only send MPR selectors\n# 1 - send MPR selectors and MPRs\n# 2 - send all neighbors\n#\n# defaults to 0\n\n");
168   fprintf(fd, "TcRedundancy\t%d\n\n", cnf->tc_redundancy);
169
170   /* MPR coverage */
171   fprintf(fd, "# MPR coverage\n# Specifies how many MPRs a node should\n# try select to reach every 2 hop neighbor\n# Can be set to any integer >0\n# defaults to 1\n\n");
172
173   fprintf(fd, "MprCoverage\t%d\n\n", cnf->mpr_coverage);
174
175   fprintf(fd, "# Link quality level\n# 0 = do not use link quality\n# 1 = use link quality for MPR selection\n# 2 = use link quality for MPR selection and routing\n\n");
176   fprintf(fd, "LinkQualityLevel\t%d\n\n", cnf->lq_level);
177
178   fprintf(fd, "# Fish Eye algorithm\n# 0 = do not use fish eye\n# 1 = use fish eye\n\n");
179   fprintf(fd, "LinkQualityFishEye\t%d\n\n", cnf->lq_fish);
180
181   fprintf(fd, "# Link quality window size\n\n");
182   fprintf(fd, "LinkQualityWinSize\t%d\n\n", cnf->lq_wsize);
183
184   fprintf(fd, "# NAT threshold\n\n");
185   fprintf(fd, "NatThreshold\t%f\n\n", cnf->lq_nat_thresh);
186
187   fprintf(fd, "# Clear screen when printing debug output?\n\n");
188   fprintf(fd, "ClearScreen\t%s\n\n", cnf->clear_screen ? "yes" : "no");
189
190   /* Plugins */
191   fprintf(fd, "# Olsrd plugins to load\n# This must be the absolute path to the file\n# or the loader will use the following scheme:\n# - Try the paths in the LD_LIBRARY_PATH \n#   environment variable.\n# - The list of libraries cached in /etc/ld.so.cache\n# - /lib, followed by /usr/lib\n\n");
192   if(pe)
193     {
194       while(pe)
195         {
196           fprintf(fd, "LoadPlugin \"%s\" {\n", pe->name);
197           pp = pe->params;
198           while(pp)
199             {
200               fprintf(fd, "    PlParam \"%s\"\t\"%s\"\n", pp->key, pp->value);
201               pp = pp->next;
202             }
203           fprintf(fd, "}\n");
204           pe = pe->next;
205         }
206     }
207   fprintf(fd, "\n");
208
209   
210   
211
212   /* Interfaces */
213   fprintf(fd, "# Interfaces\n# Multiple interfaces with the same configuration\n# can shar the same config block. Just list the\n# interfaces(e.g. Interface \"eth0\" \"eth2\"\n\n");
214   /* Interfaces */
215   if(in)
216     {
217       while(in)
218         {
219           fprintf(fd, "Interface \"%s\" {\n", in->name);
220           fprintf(fd, "\n");
221       
222           fprintf(fd, "    # IPv4 broadcast address to use. The\n    # one usefull example would be 255.255.255.255\n    # If not defined the broadcastaddress\n    # every card is configured with is used\n\n");
223
224
225           if(in->cnf->ipv4_broadcast.v4.s_addr)
226             {
227               fprintf(fd, "    Ip4Broadcast\t%s\n\n", inet_ntoa(in->cnf->ipv4_broadcast.v4));
228             }
229           else
230             {
231               fprintf(fd, "    #Ip4Broadcast\t255.255.255.255\n\n");
232             }
233           
234           
235           fprintf(fd, "    # IPv6 address scope to use.\n    # Must be 'site-local' or 'global'\n\n");
236           if(in->cnf->ipv6_addrtype)
237             fprintf(fd, "    Ip6AddrType \tsite-local\n\n");
238           else
239             fprintf(fd, "    Ip6AddrType \tglobal\n\n");
240           
241           fprintf(fd, "    # IPv6 multicast address to use when\n    # using site-local addresses.\n    # If not defined, ff05::15 is used\n");
242           fprintf(fd, "    Ip6MulticastSite\t%s\n\n", inet_ntop(AF_INET6, &in->cnf->ipv6_multi_site.v6, ipv6_buf, sizeof(ipv6_buf)));
243           fprintf(fd, "    # IPv6 multicast address to use when\n    # using global addresses\n    # If not defined, ff0e::1 is used\n");
244           fprintf(fd, "    Ip6MulticastGlobal\t%s\n\n", inet_ntop(AF_INET6, &in->cnf->ipv6_multi_glbl.v6, ipv6_buf, sizeof(ipv6_buf)));
245           
246           
247           fprintf(fd, "    # Olsrd can autodetect changes in\n    # interface configurations. Enabled by default\n    # turn off to save CPU.\n    AutoDetectChanges: %s\n", in->cnf->autodetect_chg ? "yes" : "no");
248
249           fprintf(fd, "    # Emission and validity intervals.\n    # If not defined, RFC proposed values will\n    # in most cases be used.\n\n");
250           
251           
252           if(in->cnf->hello_params.emission_interval != HELLO_INTERVAL)
253             fprintf(fd, "    HelloInterval\t%0.2f\n", in->cnf->hello_params.emission_interval);
254           else
255             fprintf(fd, "    #HelloInterval\t%0.2f\n", in->cnf->hello_params.emission_interval);
256           if(in->cnf->hello_params.validity_time != NEIGHB_HOLD_TIME)
257             fprintf(fd, "    HelloValidityTime\t%0.2f\n", in->cnf->hello_params.validity_time);
258           else
259             fprintf(fd, "    #HelloValidityTime\t%0.2f\n", in->cnf->hello_params.validity_time);
260           if(in->cnf->tc_params.emission_interval != TC_INTERVAL)
261             fprintf(fd, "    TcInterval\t\t%0.2f\n", in->cnf->tc_params.emission_interval);
262           else
263             fprintf(fd, "    #TcInterval\t\t%0.2f\n", in->cnf->tc_params.emission_interval);
264           if(in->cnf->tc_params.validity_time != TOP_HOLD_TIME)
265             fprintf(fd, "    TcValidityTime\t%0.2f\n", in->cnf->tc_params.validity_time);
266           else
267             fprintf(fd, "    #TcValidityTime\t%0.2f\n", in->cnf->tc_params.validity_time);
268           if(in->cnf->mid_params.emission_interval != MID_INTERVAL)
269             fprintf(fd, "    MidInterval\t\t%0.2f\n", in->cnf->mid_params.emission_interval);
270           else
271             fprintf(fd, "    #MidInterval\t%0.2f\n", in->cnf->mid_params.emission_interval);
272           if(in->cnf->mid_params.validity_time != MID_HOLD_TIME)
273             fprintf(fd, "    MidValidityTime\t%0.2f\n", in->cnf->mid_params.validity_time);
274           else
275             fprintf(fd, "    #MidValidityTime\t%0.2f\n", in->cnf->mid_params.validity_time);
276           if(in->cnf->hna_params.emission_interval != HNA_INTERVAL)
277             fprintf(fd, "    HnaInterval\t\t%0.2f\n", in->cnf->hna_params.emission_interval);
278           else
279             fprintf(fd, "    #HnaInterval\t%0.2f\n", in->cnf->hna_params.emission_interval);
280           if(in->cnf->hna_params.validity_time != HNA_HOLD_TIME)
281             fprintf(fd, "    HnaValidityTime\t%0.2f\n", in->cnf->hna_params.validity_time);       
282           else
283             fprintf(fd, "    #HnaValidityTime\t%0.2f\n", in->cnf->hna_params.validity_time);      
284           
285           mult = in->cnf->lq_mult;
286
287           if (mult == NULL)
288             {
289               fprintf(fd, "    #LinkQualityMult\tdefault 1.0\n");
290             }
291           else
292             {
293               while (mult != NULL)
294                 {
295                   fprintf(fd, "    LinkQualityMult\t%s %0.2f\n", inet_ntop(cnf->ip_version, &mult->addr, ipv6_buf, sizeof(ipv6_buf)), mult->val);
296                   mult = mult->next;
297                 }
298             }
299
300          fprintf(fd, "    # When multiple links exist between hosts\n");
301          fprintf(fd, "    # the weight of interface is used to determine\n");
302          fprintf(fd, "    # the link to use. Normally the weight is\n");
303          fprintf(fd, "    # automatically calculated by olsrd based\n");
304          fprintf(fd, "    # on the characteristics of the interface,\n");
305          fprintf(fd, "    # but here you can specify a fixed value.\n");
306          fprintf(fd, "    # Olsrd will choose links with the lowest value.\n");
307          fprintf(fd, "    # Note:\n");
308          fprintf(fd, "    # Interface weight is used only when LinkQualityLevel is 0.\n");
309          fprintf(fd, "    # For any other value of LinkQualityLevel, the interface ETX\n");
310          fprintf(fd, "    # value is used instead.\n\n");
311           if(in->cnf->weight.fixed)
312             {
313               fprintf(fd, "    Weight\t %d\n\n", in->cnf->weight.value);
314             }
315           else
316             {
317               fprintf(fd, "    #Weight\t 0\n\n");
318             }
319
320           
321           fprintf(fd, "}\n\n");
322           in = in->next;
323         }
324
325     }
326
327
328   fprintf(fd, "\n# END AUTOGENERATED CONFIG\n");
329
330   fclose(fd);
331   printf("DONE\n");
332
333   return 1;
334 }
335
336 #define MAX_LINESIZE 250
337
338 #define WRITE_TO_BUF(fmt, args...)                                      \
339     do {                                                                \
340         if((bufsize - size) < MAX_LINESIZE) {                           \
341             return -1;                                                  \
342         }                                                               \
343         size += snprintf(&buf[size], MAX_LINESIZE, fmt, ##args);        \
344     } while (0)
345
346 int
347 olsrd_write_cnf_buf(struct olsrd_config *cnf, char *buf, olsr_u32_t bufsize)
348 {
349   struct ip_prefix_list   *h  = cnf->hna_entries;
350   struct olsr_if           *in = cnf->interfaces;
351   struct plugin_entry      *pe = cnf->plugins;
352   struct plugin_param      *pp;
353   struct ip_prefix_list    *ie = cnf->ipc_nets;
354   struct olsr_lq_mult      *mult;
355
356   int size = 0;
357
358   char ipv6_buf[100];             /* buffer for IPv6 inet_htop */
359
360 #if 0
361   printf("\n\n\n\nolsrd_write_cnf_buf bufsize  %d\n\n\n\n\n", bufsize);
362 #endif
363   if (buf == NULL || bufsize < MAX_LINESIZE) {
364       return -1;
365   }
366
367   WRITE_TO_BUF("#\n# Configuration file for olsr.org olsrd\n# automatically generated by olsrd-cnf %s\n#\n\n\n", PARSER_VERSION);
368
369   /* Debug level */
370   WRITE_TO_BUF("# Debug level(0-9)\n# If set to 0 the daemon runs in the background\n\nDebugLevel\t%d\n\n", cnf->debug_level);
371
372   /* IP version */
373   WRITE_TO_BUF("# IP version to use (4 or 6)\n\nIpVersion\t%d\n\n", cnf->ip_version == AF_INET ? 4 : 6);
374
375   /* FIB Metric */
376   WRITE_TO_BUF("# FIBMetric (\"%s\", \"%s\", or \"%s\")\n\nFIBMetric\t\"%s\"\n\n", CFG_FIBM_FLAT, CFG_FIBM_CORRECT, CFG_FIBM_APPROX,
377     FIBM_FLAT == cnf->fib_metric ? CFG_FIBM_FLAT : FIBM_CORRECT == cnf->fib_metric ? CFG_FIBM_CORRECT : CFG_FIBM_APPROX);
378
379   /* HNA IPv4/IPv6 */
380   WRITE_TO_BUF("# HNA IPv%1$d routes\n# syntax: netaddr netmask\n\nHna%1$d {\n", cnf->ip_version == AF_INET ? 4 : 6);
381   while(h) {
382     struct ipaddr_str strbuf;
383     WRITE_TO_BUF("    %s/%d\n", olsr_ip_to_string(&strbuf, &h->net.prefix), h->net.prefix_len);
384     h = h->next;
385   }
386   WRITE_TO_BUF("}\n\n");
387
388   /* No interfaces */
389   WRITE_TO_BUF("# Should olsrd keep on running even if there are\n# no interfaces available? This is a good idea\n# for a PCMCIA/USB hotswap environment.\n# \"yes\" OR \"no\"\n\nAllowNoInt\t");
390   if(cnf->allow_no_interfaces)
391     WRITE_TO_BUF("yes\n\n");
392   else
393     WRITE_TO_BUF("no\n\n");
394
395   /* TOS */
396   WRITE_TO_BUF("# TOS(type of service) to use. Default is 16\n\n");
397   WRITE_TO_BUF("TosValue\t%d\n\n", cnf->tos);
398
399   /* RtTable */
400   WRITE_TO_BUF("# Policy Routing Tableto use. Default is 254\n\n");
401   WRITE_TO_BUF("RtTable\t\t%d\n\n", cnf->rttable);
402
403   /* Willingness */
404   WRITE_TO_BUF("# The fixed willingness to use(0-7)\n# If not set willingness will be calculated\n# dynammically based on battery/power status\n\n");
405   if(cnf->willingness_auto)
406     WRITE_TO_BUF("#Willingness\t4\n\n");
407   else
408     WRITE_TO_BUF("Willingness\t%d\n\n", cnf->willingness);
409
410   /* IPC */
411   WRITE_TO_BUF("# Allow processes like the GUI front-end\n# to connect to the daemon.\n\n");
412   WRITE_TO_BUF("IpcConnect {\n");
413   WRITE_TO_BUF("    MaxConnections\t%d\n", cnf->ipc_connections);
414   while(ie)
415     {
416       struct ipaddr_str strbuf;
417       if (ie->net.prefix_len == olsr_cnf->maxplen) {
418           WRITE_TO_BUF("    Host\t\t%s\n", olsr_ip_to_string(&strbuf, &ie->net.prefix));
419       } else {
420           WRITE_TO_BUF("    Net\t\t\t%s/%d\n", olsr_ip_to_string(&strbuf, &ie->net.prefix), ie->net.prefix_len);
421       }
422       ie = ie->next;
423     }
424
425   WRITE_TO_BUF("}\n\n");
426
427
428
429   /* Hysteresis */
430   WRITE_TO_BUF("# Hysteresis adds more robustness to the\n# link sensing.\n# Used by default. 'yes' or 'no'\n\n");
431
432   if(cnf->use_hysteresis)
433     {
434       WRITE_TO_BUF("UseHysteresis\tyes\n\n");
435       WRITE_TO_BUF("# Hysteresis parameters\n# Do not alter these unless you know \n# what you are doing!\n# Set to auto by default. Allowed\n# values are floating point values\n# in the interval 0,1\n# THR_LOW must always be lower than\n# THR_HIGH!!\n\n");
436       WRITE_TO_BUF("HystScaling\t%0.2f\n", cnf->hysteresis_param.scaling);
437       WRITE_TO_BUF("HystThrHigh\t%0.2f\n", cnf->hysteresis_param.thr_high);
438       WRITE_TO_BUF("HystThrLow\t%0.2f\n\n", cnf->hysteresis_param.thr_low);
439     }
440   else
441     {
442       WRITE_TO_BUF("UseHysteresis\tno\n\n");
443       WRITE_TO_BUF("# Hysteresis parameters\n# Do not alter these unless you know \n# what you are doing!\n# Set to auto by default. Allowed\n# values are floating point values\n# in the interval 0,1\n# THR_LOW must always be lower than\n# THR_HIGH!!\n\n");
444       WRITE_TO_BUF("#HystScaling\t%0.2f\n", cnf->hysteresis_param.scaling);
445       WRITE_TO_BUF("#HystThrHigh\t%0.2f\n", cnf->hysteresis_param.thr_high);
446       WRITE_TO_BUF("#HystThrLow\t%0.2f\n\n", cnf->hysteresis_param.thr_low);
447     }
448
449   /* Pollrate */
450   WRITE_TO_BUF("# Polling rate in seconds(float).\n# Auto uses default value 0.05 sec\n\n");
451   WRITE_TO_BUF("Pollrate\t%0.2f\n", cnf->pollrate);
452
453   /* TC redundancy */
454   WRITE_TO_BUF("# TC redundancy\n# Specifies how much neighbor info should\n# be sent in TC messages\n# Possible values are:\n# 0 - only send MPR selectors\n# 1 - send MPR selectors and MPRs\n# 2 - send all neighbors\n#\n# defaults to 0\n\n");
455   WRITE_TO_BUF("TcRedundancy\t%d\n\n", cnf->tc_redundancy);
456
457   /* MPR coverage */
458   WRITE_TO_BUF("# MPR coverage\n# Specifies how many MPRs a node should\n# try select to reach every 2 hop neighbor\n# Can be set to any integer >0\n# defaults to 1\n\n");
459
460   WRITE_TO_BUF("MprCoverage\t%d\n\n", cnf->mpr_coverage);
461
462   WRITE_TO_BUF("# Link quality level\n# 0 = do not use link quality\n# 1 = use link quality for MPR selection\n# 2 = use link quality for MPR selection and routing\n\n");
463   WRITE_TO_BUF("LinkQualityLevel\t%d\n\n", cnf->lq_level);
464
465   WRITE_TO_BUF("# Link quality window size\n\n");
466   WRITE_TO_BUF("LinkQualityWinSize\t%d\n\n", cnf->lq_wsize);
467
468   WRITE_TO_BUF("# NAT threshold\n\n");
469   WRITE_TO_BUF("NatThreshold\t%f\n\n", cnf->lq_nat_thresh);
470
471   WRITE_TO_BUF("# Clear screen when printing debug output?\n\n");
472   WRITE_TO_BUF("ClearScreen\t%s\n\n", cnf->clear_screen ? "yes" : "no");
473
474   /* Plugins */
475   WRITE_TO_BUF("# Olsrd plugins to load\n# This must be the absolute path to the file\n# or the loader will use the following scheme:\n");
476   WRITE_TO_BUF("# - Try the paths in the LD_LIBRARY_PATH \n#   environment variable.\n# - The list of libraries cached in /etc/ld.so.cache\n# - /lib, followed by /usr/lib\n\n");
477   if(pe)
478     {
479       while(pe)
480         {
481           WRITE_TO_BUF("LoadPlugin \"%s\" {\n", pe->name);
482           pp = pe->params;
483           while(pp)
484             {
485               WRITE_TO_BUF("    PlParam \"%s\"\t\"%s\"\n", pp->key, pp->value);
486               pp = pp->next;
487             }
488           WRITE_TO_BUF("}\n");
489           pe = pe->next;
490         }
491     }
492   WRITE_TO_BUF("\n");
493
494   
495   
496
497   /* Interfaces */
498   WRITE_TO_BUF("# Interfaces\n# Multiple interfaces with the same configuration\n");
499   WRITE_TO_BUF("# can shar the same config block. Just list the\n# interfaces(e.g. Interface \"eth0\" \"eth2\"\n\n");
500   /* Interfaces */
501   if(in)
502     {
503       olsr_bool first = OLSR_TRUE;
504       while(in)
505         {
506           WRITE_TO_BUF("Interface \"%s\" {\n", in->name);
507
508           if(first)
509              WRITE_TO_BUF("    # IPv4 broadcast address to use. The\n    # one usefull example would be 255.255.255.255\n    # If not defined the broadcastaddress\n    # every card is configured with is used\n\n");
510
511
512           if(in->cnf->ipv4_broadcast.v4.s_addr)
513             {
514               WRITE_TO_BUF("    Ip4Broadcast\t%s\n", inet_ntoa(in->cnf->ipv4_broadcast.v4));
515             }
516           else
517             {
518               if(first)
519                 WRITE_TO_BUF("    #Ip4Broadcast\t255.255.255.255\n");
520             }
521           
522           if(first) WRITE_TO_BUF("\n");
523
524           if(first)
525               WRITE_TO_BUF("    # IPv6 address scope to use.\n    # Must be 'site-local' or 'global'\n\n");
526           if(in->cnf->ipv6_addrtype)
527             WRITE_TO_BUF("    Ip6AddrType \tsite-local\n");
528           else
529             WRITE_TO_BUF("    Ip6AddrType \tglobal\n");
530
531           if(first) WRITE_TO_BUF("\n");
532
533           if(first)
534             WRITE_TO_BUF("    # IPv6 multicast address to use when\n    # using site-local addresses.\n    # If not defined, ff05::15 is used\n");
535           WRITE_TO_BUF("    Ip6MulticastSite\t%s\n", inet_ntop(AF_INET6, &in->cnf->ipv6_multi_site.v6, ipv6_buf, sizeof(ipv6_buf)));
536           if(first) WRITE_TO_BUF("\n");
537           if(first)
538             WRITE_TO_BUF("    # IPv6 multicast address to use when\n    # using global addresses\n    # If not defined, ff0e::1 is used\n");
539           WRITE_TO_BUF("    Ip6MulticastGlobal\t%s\n", inet_ntop(AF_INET6, &in->cnf->ipv6_multi_glbl.v6, ipv6_buf, sizeof(ipv6_buf)));
540           if(first) WRITE_TO_BUF("\n");
541           
542           
543           if(first)
544             WRITE_TO_BUF("    # Emission and validity intervals.\n    # If not defined, RFC proposed values will\n    # in most cases be used.\n\n");
545           
546           
547           if(in->cnf->hello_params.emission_interval != HELLO_INTERVAL)
548             WRITE_TO_BUF("    HelloInterval\t%0.2f\n", in->cnf->hello_params.emission_interval);
549           else if(first)
550             WRITE_TO_BUF("    #HelloInterval\t%0.2f\n", in->cnf->hello_params.emission_interval);
551           if(in->cnf->hello_params.validity_time != NEIGHB_HOLD_TIME)
552             WRITE_TO_BUF("    HelloValidityTime\t%0.2f\n", in->cnf->hello_params.validity_time);
553           else if(first)
554             WRITE_TO_BUF("    #HelloValidityTime\t%0.2f\n", in->cnf->hello_params.validity_time);
555           if(in->cnf->tc_params.emission_interval != TC_INTERVAL)
556             WRITE_TO_BUF("    TcInterval\t\t%0.2f\n", in->cnf->tc_params.emission_interval);
557           else if(first)
558             WRITE_TO_BUF("    #TcInterval\t\t%0.2f\n", in->cnf->tc_params.emission_interval);
559           if(in->cnf->tc_params.validity_time != TOP_HOLD_TIME)
560             WRITE_TO_BUF("    TcValidityTime\t%0.2f\n", in->cnf->tc_params.validity_time);
561           else if(first)
562             WRITE_TO_BUF("    #TcValidityTime\t%0.2f\n", in->cnf->tc_params.validity_time);
563           if(in->cnf->mid_params.emission_interval != MID_INTERVAL)
564             WRITE_TO_BUF("    MidInterval\t\t%0.2f\n", in->cnf->mid_params.emission_interval);
565           else if(first)
566             WRITE_TO_BUF("    #MidInterval\t%0.2f\n", in->cnf->mid_params.emission_interval);
567           if(in->cnf->mid_params.validity_time != MID_HOLD_TIME)
568             WRITE_TO_BUF("    MidValidityTime\t%0.2f\n", in->cnf->mid_params.validity_time);
569           else if(first)
570             WRITE_TO_BUF("    #MidValidityTime\t%0.2f\n", in->cnf->mid_params.validity_time);
571           if(in->cnf->hna_params.emission_interval != HNA_INTERVAL)
572             WRITE_TO_BUF("    HnaInterval\t\t%0.2f\n", in->cnf->hna_params.emission_interval);
573           else if(first)
574             WRITE_TO_BUF("    #HnaInterval\t%0.2f\n", in->cnf->hna_params.emission_interval);
575           if(in->cnf->hna_params.validity_time != HNA_HOLD_TIME)
576             WRITE_TO_BUF("    HnaValidityTime\t%0.2f\n", in->cnf->hna_params.validity_time);      
577           else if(first)
578             WRITE_TO_BUF("    #HnaValidityTime\t%0.2f\n", in->cnf->hna_params.validity_time);     
579           
580           mult = in->cnf->lq_mult;
581
582           if (mult == NULL)
583             {
584               if(first)
585                 WRITE_TO_BUF("    #LinkQualityMult\tdefault 1.0\n");
586             }
587           else
588             {
589               while (mult != NULL)
590                 {
591                   WRITE_TO_BUF("    LinkQualityMult\t%s %0.2f\n", inet_ntop(cnf->ip_version, &mult->addr, ipv6_buf, sizeof (ipv6_buf)), mult->val);
592                   mult = mult->next;
593                 }
594             }
595
596           if(first)
597             {
598              WRITE_TO_BUF("    # When multiple links exist between hosts\n");;
599              WRITE_TO_BUF("    # the weight of interface is used to determine\n");;
600              WRITE_TO_BUF("    # the link to use. Normally the weight is\n");
601              WRITE_TO_BUF("    # automatically calculated by olsrd based\n");;
602              WRITE_TO_BUF("    # on the characteristics of the interface,\n");;
603              WRITE_TO_BUF("    # but here you can specify a fixed value.\n");;
604              WRITE_TO_BUF("    # Olsrd will choose links with the lowest value.\n");
605              WRITE_TO_BUF("    # Note:\n");;
606              WRITE_TO_BUF("    # Interface weight is used only when LinkQualityLevel is 0.\n");;
607              WRITE_TO_BUF("    # For any other value of LinkQualityLevel, the interface ETX\n");;
608              WRITE_TO_BUF("    # value is used instead.\n\n");;
609             }
610           if(in->cnf->weight.fixed)
611             {
612               WRITE_TO_BUF("    Weight\t %d\n\n", in->cnf->weight.value);
613             }
614           else
615             {
616               if(first)
617                 WRITE_TO_BUF("    #Weight\t 0\n\n");
618             }
619
620           
621           WRITE_TO_BUF("}\n\n");
622           in = in->next;
623           first = OLSR_FALSE;
624         }
625
626     }
627
628
629   WRITE_TO_BUF("\n# END AUTOGENERATED CONFIG\n");
630
631   return size;
632 }
633