7e1a240caa17a3b1eb46441ad01d4f1f59a83538
[olsrd.git] / src / cfgparser / cfgfile_gen.c
1 /*
2  * The olsr.org Optimized Link-State Routing daemon(olsrd)
3  * Copyright (c) 2005, Andreas Tonnesen(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 "builddata.h"
43 #include "../ipcalc.h"
44 #include "../net_olsr.h"
45 #include "../common/autobuf.h"
46 #include "../egressTypes.h"
47
48 #include <stdarg.h>
49 #include <stdio.h>
50 #include <string.h>
51 #include <errno.h>
52 #include <sys/types.h>
53 #include <netinet/in.h>
54 #include <arpa/inet.h>
55
56 #ifdef __linux__
57 #include <linux/rtnetlink.h>
58 #else
59 #define RTPROT_BOOT 3
60 #endif
61
62 int olsrd_write_cnf(struct olsrd_config *cnf, const char *fname) {
63   FILE *fd;
64   struct autobuf abuf;
65
66   fd = fopen(fname, "w");
67
68   if (fd == NULL) {
69     fprintf(stderr, "Could not open file %s for writing\n%s\n", fname, strerror(errno));
70     return -1;
71   }
72
73   printf("Writing config to file \"%s\".... ", fname);
74   abuf_init(&abuf, 1024);
75   olsrd_write_cnf_autobuf(&abuf, cnf);
76   if (fwrite(abuf.buf, abuf.len, 1, fd) < (size_t)abuf.len) {
77     fprintf(stderr, "Error, could not write the complete config file.\n");
78   }
79   abuf_free(&abuf);
80   fclose(fd);
81
82   printf("DONE\n");
83
84   return 1;
85 }
86
87 static int
88 if_appendf(struct autobuf *autobuf, bool comments, const char *fmt, ...)  __attribute__ ((format(printf, 3, 4)));
89
90 static int
91 if_appendf(struct autobuf *autobuf, bool comments, const char *fmt, ...)
92 {
93   int rv;
94   va_list ap;
95   char *first;
96
97   if (!comments) {
98     va_start(ap, fmt);
99     first = va_arg(ap, char*);
100     va_end(ap);
101     if (*first) {
102       return 0;
103     }
104   }
105
106   va_start(ap, fmt);
107   rv = abuf_vappendf(autobuf, fmt, ap);
108   va_end(ap);
109   return rv;
110 }
111
112 static void olsrd_write_if_autobuf(struct autobuf *out, struct olsrd_config *cnf, struct if_config_options *cnfi, bool comments) {
113   struct ipaddr_str ipbuf;
114   struct olsr_lq_mult *mult;
115
116   abuf_puts(out, "{\n");
117   if (comments) abuf_appendf(out,
118     "    # Interface Mode is used to prevent unnecessary\n"
119     "    # packet forwarding on switched ethernet interfaces\n"
120     "    # valid Modes are \"mesh\" and \"ether\"\n"
121     "    # (default is \"%s\")\n"
122     "\n", OLSR_IF_MODE[DEF_IF_MODE]);
123   if_appendf(out, comments, "    %sMode \"%s\"\n",
124       cnfi->mode == DEF_IF_MODE ? "# " : "",
125       OLSR_IF_MODE[cnfi->mode]);
126   if (comments) abuf_puts(out,
127     "\n"
128     "    # IPv4 broadcast address for outgoing OLSR packets.\n"
129     "    # One useful example would be 255.255.255.255\n"
130     "    # The second useful value would be to\n"
131     "    # specify the peer address of an ptp-tunnel.\n"
132     "    # another name of this parameter is \"IPv4Multicast\"\n"
133     "    # (default is 0.0.0.0, which triggers the usage of the\n"
134     "    # interface broadcast IP)\n"
135     "\n");
136   if_appendf(out, comments, "    %sIp4Broadcast      %s\n",
137       cnfi->ipv4_multicast.v4.s_addr == 0 ? "# " : "",
138       inet_ntop(AF_INET, &cnfi->ipv4_multicast, ipbuf.buf, sizeof(ipbuf)));
139   if (comments) abuf_appendf(out,
140     "\n"
141     "    # IPv6 multicast address\n"
142     "    # (default is %s, the manet-router linklocal multicast)\n"
143     "\n", inet_ntop(AF_INET6, &ipv6_def_multicast, ipbuf.buf, sizeof(ipbuf)));
144   if_appendf(out, comments, "    %sIPv6Multicast %s\n",
145       memcmp(&cnfi->ipv6_multicast, &ipv6_def_multicast, sizeof(ipv6_def_multicast)) == 0 ? "# " : "",
146       inet_ntop(AF_INET6, &cnfi->ipv6_multicast, ipbuf.buf, sizeof(ipbuf)));
147   if (comments) abuf_puts(out,
148     "\n"
149     "    # IPv4 src address for outgoing OLSR packages\n"
150     "    # (default is 0.0.0.0, which triggers usage of the interface IP)\n"
151     "\n");
152   if_appendf(out, comments, "    %sIPv4Src %s\n",
153       cnfi->ipv4_src.v4.s_addr == 0 ? "# " : "",
154       inet_ntop(AF_INET, &cnfi->ipv4_src, ipbuf.buf, sizeof(ipbuf)));
155   if (comments) abuf_puts(out,
156     "\n"
157     "    # IPv6 src prefix. OLSRd will choose one of the interface IPs\n"
158     "    # which matches the prefix of this parameter.\n"
159     "    # (default is 0::/0, which triggers the usage\n"
160     "    # of a not-linklocal interface IP)\n"
161     "\n");
162   {
163     int saved = cnf->ip_version;
164     cnf->ip_version = AF_INET6;
165     if_appendf(out, comments, "    %sIPv6Src %s\n",
166       cnfi->ipv6_src.prefix_len == 0 ? "# " : "",
167           olsr_ip_prefix_to_string(&cnfi->ipv6_src));
168     cnf->ip_version = saved;
169   }
170   if (comments) abuf_appendf(out,
171     "\n"
172     "    # Emission intervals in seconds.\n"
173     "    # If not defined, Freifunk network defaults are used.\n"
174     "    # (defaults: Hello = %.1f/%.1f,  TC  = %.1f/%.1f,\n"
175     "    #            MID   = %.1f/%.1f, HNA = %.1f/%.1f)\n"
176     "\n",
177     (double)HELLO_INTERVAL, (double)NEIGHB_HOLD_TIME,
178     (double)TC_INTERVAL,    (double)TOP_HOLD_TIME,
179     (double)MID_INTERVAL,   (double)MID_HOLD_TIME,
180     (double)HNA_INTERVAL,   (double)HNA_HOLD_TIME
181     );
182   if_appendf(out, comments, "    %sHelloInterval       %3.1f\n",
183       cnfi->hello_params.emission_interval == HELLO_INTERVAL ? "# " : "",
184       (double)cnfi->hello_params.emission_interval);
185   if_appendf(out, comments, "    %sHelloValidityTime   %3.1f\n",
186       cnfi->hello_params.validity_time == NEIGHB_HOLD_TIME ? "# " : "",
187       (double)cnfi->hello_params.validity_time);
188   if_appendf(out, comments, "    %sTcInterval          %3.1f\n",
189       cnfi->tc_params.emission_interval == TC_INTERVAL ? "# " : "",
190       (double)cnfi->tc_params.emission_interval);
191   if_appendf(out, comments, "    %sTcValidityTime      %3.1f\n",
192       cnfi->tc_params.validity_time == TOP_HOLD_TIME ? "# " : "",
193       (double)cnfi->tc_params.validity_time);
194   if_appendf(out, comments, "    %sMidInterval         %3.1f\n",
195       cnfi->mid_params.emission_interval == MID_INTERVAL ? "# " : "",
196       (double)cnfi->mid_params.emission_interval);
197   if_appendf(out, comments, "    %sMidValidityTime     %3.1f\n",
198       cnfi->mid_params.validity_time == MID_HOLD_TIME ? "# " : "",
199       (double)cnfi->mid_params.validity_time);
200   if_appendf(out, comments, "    %sHnaInterval         %3.1f\n",
201       cnfi->hna_params.emission_interval == HNA_INTERVAL ? "# " : "",
202       (double)cnfi->hna_params.emission_interval);
203   if_appendf(out, comments, "    %sHnaValidityTime     %3.1f\n",
204       cnfi->hna_params.validity_time == HNA_HOLD_TIME ? "# " : "",
205       (double)cnfi->hna_params.validity_time);
206   if (comments) abuf_puts(out,
207     "\n"
208     "    # When multiple links exist between hosts\n"
209     "    # the weight of interface is used to determine\n"
210     "    # the link to use. Normally the weight is\n"
211     "    # automatically calculated by olsrd based\n"
212     "    # on the characteristics of the interface,\n"
213     "    # but here you can specify a fixed value.\n"
214     "    # Olsrd will choose links with the lowest value.\n"
215     "    # Note:\n"
216     "    # Interface weight is used only when LinkQualityLevel is set to 0.\n"
217     "    # For any other value of LinkQualityLevel, the interface ETX\n"
218     "    # value is used instead.\n");
219   if_appendf(out, comments, "    %sWeight %d\n",
220       !cnfi->weight.fixed ? "# " : "",
221       cnfi->weight.value);
222   if (comments) abuf_puts(out,
223     "\n"
224     "    # If a certain route should be preferred\n"
225     "    # or ignored by the mesh, the Link Quality\n"
226     "    # value of a node can be multiplied with a factor\n"
227     "    # entered here. In the example the route\n"
228     "    # using 192.168.0.1 would rather be ignored.\n"
229     "    # A multiplier of 0.5 will result in a small\n"
230     "    # (bad) LinkQuality value and a high (bad)\n"
231     "    # ETX value.\n"
232     "    # Note:\n"
233     "    # Link quality multiplier is used only when\n"
234     "    # LinkQualityLevel is greater than 0.\n"
235     "\n");
236   mult = cnfi->lq_mult;
237
238   if (mult == NULL) {
239     if (comments) {
240       abuf_puts(out, "    # example 1: reduce LQ to 192.168.0.1 by half\n");
241       abuf_puts(out, "    # LinkQualityMult 192.168.0.1 0.5\n");
242       abuf_puts(out, "\n");
243       abuf_puts(out, "    # example 2: reduce LQ to all nodes on this interface by 20%\n");
244       abuf_puts(out, "    # LinkQualityMult default 0.8\n");
245     }
246   } else {
247     while (mult != NULL) {
248       if_appendf(out, comments, "    LinkQualityMult    %s %0.2f\n",
249           olsr_ip_to_string(&ipbuf, &mult->addr),
250           (double)((float)(mult->value) / 65536.0f));
251       mult = mult->next;
252     }
253   }
254   abuf_puts(out, "}\n");
255 }
256
257 void olsrd_write_cnf_autobuf(struct autobuf *out, struct olsrd_config *cnf) {
258   struct ip_prefix_list *hna = cnf->hna_entries;
259   struct olsr_if *interf = cnf->interfaces;
260   struct plugin_entry *plugins = cnf->plugins;
261   struct plugin_param *pl_param;
262   struct ip_prefix_list *ipc_nets = cnf->ipc_nets;
263
264   struct ipaddr_str ipbuf;
265   bool first;
266
267   abuf_appendf(out, "#\n"
268       "# Configuration file for %s\n"
269       "# automatically generated by olsrd-cnf parser v. %s\n"
270       "#\n"
271       "\n",
272       olsrd_version, PARSER_VERSION);
273   abuf_appendf(out,
274     "# OLSR.org routing daemon config file\n"
275     "# This file contains ALL available options and explanations about them\n"
276     "#\n"
277     "# Lines starting with a # are discarded\n"
278     "#\n"
279     "\n"
280     "#### ATTENTION for IPv6 users ####\n"
281     "# Because of limitations in the parser IPv6 addresses must NOT\n"
282     "# begin with a \":\", so please add a \"0\" as a prefix.\n"
283     "\n"
284     "###########################\n"
285     "### Basic configuration ###\n"
286     "###########################\n"
287     "# keep this settings at the beginning of your first configuration file\n"
288     "\n"
289     "# Debug level (0-9)\n"
290     "# If set to 0 the daemon runs in the background, unless \"NoFork\" is set to true\n"
291     "# (default is %u)\n"
292     "\n", DEF_DEBUGLVL);
293   abuf_appendf(out, "%sDebugLevel  %d\n",
294       cnf->debug_level == DEF_DEBUGLVL ? "# " : "",
295       cnf->debug_level);
296   abuf_appendf(out,
297     "\n"
298     "# IP version to use (4 or 6)\n"
299     "# (default is %u)\n"
300     "\n", (DEF_IP_VERSION == AF_INET) ? 4 : 6);
301   abuf_appendf(out, "%sIpVersion %d\n",
302       cnf->ip_version == DEF_IP_VERSION ? "# " : "",
303       cnf->ip_version == AF_INET ? 4 : 6);
304   abuf_appendf(out,
305     "\n"
306     "#################################\n"
307     "### OLSRd agent configuration ###\n"
308     "#################################\n"
309     "# this parameters control the settings of the routing agent which are not\n"
310     "# related to the OLSR protocol and it's extensions\n"
311     "\n"
312     "# Clear the screen each time the internal state changes\n"
313     "# (default is %s)\n"
314     "\n", DEF_CLEAR_SCREEN ? "yes" : "no");
315   abuf_appendf(out, "%sClearScreen     %s\n",
316       cnf->clear_screen == DEF_CLEAR_SCREEN ? "# " : "",
317       cnf->clear_screen ? "yes" : "no");
318   abuf_appendf(out,
319     "\n"
320     "# Should olsrd keep on running even if there are\n"
321     "# no interfaces available? This is a good idea\n"
322     "# for a PCMCIA/USB hotswap environment.\n"
323     "# (default is %s)\n"
324     "\n", DEF_ALLOW_NO_INTS ? "yes" : "no");
325   abuf_appendf(out, "%sAllowNoInt  %s\n",
326       cnf->allow_no_interfaces == DEF_ALLOW_NO_INTS ? "# " : "",
327       cnf->allow_no_interfaces ? "yes" : "no");
328   abuf_puts(out,
329     "\n"
330     "# LockFile\n"
331     "# The lockfile is used to prevent multiple OLSR instances running at the same\n"
332     "# time.\n"
333     "# (Linux/BSD default is \"/var/run/olsrd-ipv(4/6).lock\")\n"
334     "# (Win32     default is \"[configfile]-ipv(4/6).lock\")\n"
335     "\n");
336   {
337     char * lockfile_default = olsrd_get_default_lockfile(cnf);
338     abuf_appendf(out, "%sLockFile \"%s\"\n",
339         !strcmp(cnf->lock_file, lockfile_default) ? "# " : "",
340         cnf->lock_file);
341     free(lockfile_default);
342   }
343   abuf_appendf(out,
344     "\n"
345     "# Polling rate for OLSR sockets in seconds (float).\n"
346     "# (default is %.2f)\n"
347     "\n", (double)DEF_POLLRATE);
348   abuf_appendf(out, "%sPollrate  %.2f\n",
349       cnf->pollrate == (float)DEF_POLLRATE ? "# " : "",
350       (double)cnf->pollrate);
351   abuf_appendf(out,
352     "\n"
353     "# Interval to poll network interfaces for configuration changes (in seconds).\n"
354     "# Linux systems can detect interface statechange via netlink sockets.\n"
355     "# (default is %.1f)\n"
356     "\n", (double)DEF_NICCHGPOLLRT);
357   abuf_appendf(out, "%sNicChgsPollInt  %.1f\n",
358       cnf->nic_chgs_pollrate == (float)DEF_NICCHGPOLLRT ? "# " : "",
359       (double)cnf->nic_chgs_pollrate);
360   abuf_appendf(out,
361     "\n"
362     "# TOS(type of service) value for the IP header of control traffic.\n"
363     "# (default is %u)\n"
364     "\n", DEF_TOS);
365   abuf_appendf(out, "%sTosValue %u\n",
366       cnf->tos == DEF_TOS ? "# " : "",
367       cnf->tos);
368   abuf_appendf(out,
369     "\n"
370     "# FIBMetric controls the metric value of the host-routes OLSRd sets.\n"
371     "# - \"flat\" means that the metric value is always 2 (or as configured\n"
372     "#   with FIBMetricDefault). This is the preferred value because it helps\n"
373     "#   the linux kernel routing to clean up older routes\n"
374     "# - \"correct\" use the hopcount as the metric value.\n"
375     "# - \"approx\" use the hopcount as the metric value too, but does only update the\n"
376     "#   hopcount if the nexthop changes too\n"
377     "# (default is \"%s\")\n"
378     "\n", FIB_METRIC_TXT[DEF_FIB_METRIC]);
379   abuf_appendf(out, "%sFIBMetric \"%s\"\n",
380       cnf->fib_metric == DEF_FIB_METRIC ? "# " : "",
381       FIB_METRIC_TXT[cnf->fib_metric]);
382   abuf_appendf(out,
383     "\n"
384     "# Default FIB metric.\n"
385     "# The kernel FIB does not need to know the metric of a route.\n"
386     "# This saves us from enqueuing/dequeueing hopcount only changes.\n"
387     "# (default is %u)\n"
388     "\n", DEF_FIB_METRIC_DEFAULT);
389   abuf_appendf(out, "%sFIBMetricDefault %u\n",
390       cnf->fib_metric_default == DEF_FIB_METRIC_DEFAULT? "# " : "",
391       cnf->fib_metric_default);
392   abuf_appendf(out,
393     "\n"
394     "#######################################\n"
395     "### Linux specific OLSRd extensions ###\n"
396     "#######################################\n"
397     "# these parameters are only working on linux at the moment, but might become\n"
398     "# useful on BSD in the future\n"
399     "\n"
400     "# SrcIpRoutes tells OLSRd to set the Src flag of host routes to the originator-ip\n"
401     "# of the node. In addition to this an additional localhost device is created\n"
402     "# to make sure the returning traffic can be received.\n"
403     "# (default is \"%s\")\n"
404     "\n", DEF_USE_SRCIP_ROUTES ? "yes" : "no");
405   abuf_appendf(out, "%sSrcIpRoutes %s\n",
406       cnf->use_src_ip_routes == DEF_USE_SRCIP_ROUTES ? "# " : "",
407       cnf->use_src_ip_routes ? "yes" : "no");
408   abuf_appendf(out,
409     "\n"
410     "# Specify the proto tag to be used for routes olsr inserts into kernel\n"
411     "# currently only implemented for linux\n"
412     "# valid values under linux are 1 .. 254\n"
413     "# 1 gets remapped by olsrd to 0 UNSPECIFIED (1 is reserved for ICMP redirects)\n"
414     "# 2 KERNEL routes (not very wise to use)\n"
415     "# 3 BOOT (should in fact not be used by routing daemons)\n"
416     "# 4 STATIC\n"
417     "# 8 .. 15 various routing daemons (gated, zebra, bird, & co)\n"
418     "# (default is %u which gets replaced by an OS-specific default value;\n"
419     "# %u (BOOT) under linux (for backward compatibility)\n"
420     "\n", DEF_RTPROTO, RTPROT_BOOT);
421   {
422     int expected = DEF_RTPROTO;
423 #ifdef __linux__
424     expected = RTPROT_BOOT;
425 #endif
426     abuf_appendf(out, "%sRtProto %u\n",
427         cnf->rt_proto == expected ? "# " : "",
428         cnf->rt_proto == expected ? DEF_RTPROTO : cnf->rt_proto);
429   }
430   abuf_appendf(out,
431     "\n"
432     "# Specifies the routing Table olsr uses\n"
433     "# RtTable is for host routes, RtTableDefault for the route to the default\n"
434     "# internet gateway (2 in case of IPv6+NIIT) and RtTableTunnel is for\n"
435     "# routes to the ipip tunnels, valid values are 1 to 254\n"
436     "# There is a special parameter \"auto\" (choose default below)\n"
437     "# (with    smartgw: default is %u/%u/%u)\n"
438     "# (without smartgw: default is %u/%u/%u, linux main table)\n"
439     "\n",
440     DEF_SGW_RT_TABLE_NR, DEF_SGW_RT_TABLE_DEFAULT_NR, DEF_SGW_RT_TABLE_TUNNEL_NR,
441     DEF_RT_TABLE_NR, DEF_RT_TABLE_DEFAULT_NR, DEF_RT_TABLE_TUNNEL_NR);
442   if (!cnf->smart_gw_active) {
443     abuf_appendf(out, "%sRtTable        %u\n",
444         cnf->rt_table == DEF_RT_TABLE_NR ? "# " : "",
445         cnf->rt_table);
446     abuf_appendf(out, "%sRtTableDefault %u\n",
447         cnf->rt_table_default == DEF_RT_TABLE_DEFAULT_NR ? "# " : "",
448         cnf->rt_table_default);
449     abuf_appendf(out, "%sRtTableTunnel  %u\n",
450         cnf->rt_table_tunnel == DEF_RT_TABLE_TUNNEL_NR ? "# " : "",
451         cnf->rt_table_tunnel);
452   } else {
453     abuf_appendf(out, "%sRtTable        %u\n",
454         cnf->rt_table == DEF_SGW_RT_TABLE_NR ? "# " : "",
455         cnf->rt_table);
456     abuf_appendf(out, "%sRtTableDefault %u\n",
457         cnf->rt_table_default == DEF_SGW_RT_TABLE_DEFAULT_NR ? "# " : "",
458         cnf->rt_table_default);
459     abuf_appendf(out, "%sRtTableTunnel  %u\n",
460         cnf->rt_table_tunnel == DEF_SGW_RT_TABLE_TUNNEL_NR ? "# " : "",
461         cnf->rt_table_tunnel);
462   }
463   abuf_appendf(out,
464     "\n"
465     "# Specifies the policy rule priorities for the three routing tables and\n"
466     "# a special rule for smartgateway routing (see README-Olsr-Extensions)\n"
467     "# Priorities can only be set if three different routing tables are set.\n"
468     "# if set the values must obey to condition\n"
469     "# RtTablePriority less than RtTableDefaultOlsrPriority\n"
470     "# less than RtTableTunnelPriority less than RtTableDefaultPriority\n"
471     "# There are two special parameters, \"auto\" (choose fitting to SmartGW\n"
472     "# mode) and \"none\" (do not set policy rule)\n"
473     "# (with    smartgw: default is %d/%u/%u/%u)\n"
474     "# (without smartgw: default is %d/%d   /%d   /%d   )\n"
475     "\n",
476     DEF_SGW_RT_TABLE_PRI,
477     DEF_SGW_RT_TABLE_PRI_BASE + DEF_SGW_RT_TABLE_DEFAULTOLSR_PRI_ADDER,
478     DEF_SGW_RT_TABLE_PRI_BASE + DEF_SGW_RT_TABLE_DEFAULTOLSR_PRI_ADDER + DEF_SGW_RT_TABLE_TUNNEL_PRI_ADDER,
479     DEF_SGW_RT_TABLE_PRI_BASE + DEF_SGW_RT_TABLE_DEFAULTOLSR_PRI_ADDER + DEF_SGW_RT_TABLE_TUNNEL_PRI_ADDER + DEF_SGW_RT_TABLE_DEFAULT_PRI_ADDER,
480     DEF_RT_TABLE_PRI,
481     DEF_RT_TABLE_DEFAULTOLSR_PRI,
482     DEF_RT_TABLE_TUNNEL_PRI,
483     DEF_RT_TABLE_DEFAULT_PRI);
484   if (!cnf->smart_gw_active) {
485     if (cnf->rt_table_pri == DEF_RT_TABLE_PRI) {
486       abuf_appendf(out, "# RtTablePriority            %d\n",
487           cnf->rt_table_pri);
488     } else {
489       abuf_appendf(out, "RtTablePriority            %u\n",
490           cnf->rt_table_pri);
491     }
492     if (cnf->rt_table_defaultolsr_pri == DEF_RT_TABLE_DEFAULTOLSR_PRI) {
493       abuf_appendf(out, "# RtTableDefaultOlsrPriority %d\n",
494           cnf->rt_table_defaultolsr_pri);
495     } else {
496       abuf_appendf(out, "RtTableDefaultOlsrPriority %u\n",
497           cnf->rt_table_defaultolsr_pri);
498     }
499     if (cnf->rt_table_tunnel_pri == DEF_RT_TABLE_TUNNEL_PRI) {
500       abuf_appendf(out, "# RtTableTunnelPriority      %d\n",
501           cnf->rt_table_tunnel_pri);
502     } else {
503       abuf_appendf(out, "RtTableTunnelPriority      %u\n",
504           cnf->rt_table_tunnel_pri);
505     }
506     if (cnf->rt_table_default_pri == DEF_RT_TABLE_DEFAULT_PRI) {
507       abuf_appendf(out, "# RtTableDefaultPriority     %d\n",
508           cnf->rt_table_default_pri);
509     } else {
510       abuf_appendf(out, "RtTableDefaultPriority     %u\n",
511           cnf->rt_table_default_pri);
512     }
513   } else {
514     if (cnf->rt_table_pri == DEF_SGW_RT_TABLE_PRI) {
515       abuf_appendf(out, "# RtTablePriority            %d\n",
516           cnf->rt_table_pri);
517     } else {
518       abuf_appendf(out, "RtTablePriority            %u\n",
519           cnf->rt_table_pri);
520     }
521     abuf_appendf(out, "%sRtTableDefaultOlsrPriority %u\n",
522         cnf->rt_table_defaultolsr_pri == (DEF_SGW_RT_TABLE_PRI_BASE + DEF_SGW_RT_TABLE_DEFAULTOLSR_PRI_ADDER) ? "# " : "",
523         cnf->rt_table_defaultolsr_pri);
524
525     abuf_appendf(out, "%sRtTableTunnelPriority      %u\n",
526         cnf->rt_table_tunnel_pri == (DEF_SGW_RT_TABLE_PRI_BASE + DEF_SGW_RT_TABLE_DEFAULTOLSR_PRI_ADDER + DEF_SGW_RT_TABLE_TUNNEL_PRI_ADDER) ? "# " : "",
527         cnf->rt_table_tunnel_pri);
528
529     abuf_appendf(out, "%sRtTableDefaultPriority     %u\n",
530         cnf->rt_table_default_pri == (DEF_SGW_RT_TABLE_PRI_BASE + DEF_SGW_RT_TABLE_DEFAULTOLSR_PRI_ADDER + DEF_SGW_RT_TABLE_TUNNEL_PRI_ADDER + DEF_SGW_RT_TABLE_DEFAULT_PRI_ADDER) ? "# " : "",
531         cnf->rt_table_default_pri);
532   }
533   abuf_appendf(out,
534     "\n"
535     "# Activates (in IPv6 mode) the automatic use of NIIT\n"
536     "# (see README-Olsr-Extensions)\n"
537     "# (default is \"%s\")\n"
538     "\n", DEF_USE_NIIT ? "yes" : "no");
539   abuf_appendf(out, "%sUseNiit %s\n",
540       cnf->use_niit == DEF_USE_NIIT ? "# " : "",
541       cnf->use_niit ? "yes" : "no");
542   abuf_appendf(out,
543     "\n"
544     "# Activates the smartgateway ipip tunnel feature.\n"
545     "# See README-Olsr-Extensions for a description of smartgateways.\n"
546     "# (default is \"%s\")\n"
547     "\n", DEF_SMART_GW ? "yes" : "no");
548   abuf_appendf(out, "%sSmartGateway %s\n",
549       cnf->smart_gw_active == DEF_SMART_GW ? "# " : "",
550       cnf->smart_gw_active ? "yes" : "no");
551   abuf_appendf(out,
552     "\n"
553     "# Signals that the server tunnel must always be removed on shutdown,\n"
554     "# irrespective of the interface up/down state during startup.\n"
555     "# (default is \"%s\")\n"
556     "\n", DEF_SMART_GW_ALWAYS_REMOVE_SERVER_TUNNEL ? "yes" : "no");
557   abuf_appendf(out, "%sSmartGatewayAlwaysRemoveServerTunnel %s\n",
558       cnf->smart_gw_always_remove_server_tunnel == DEF_SMART_GW_ALWAYS_REMOVE_SERVER_TUNNEL ? "# " : "",
559       cnf->smart_gw_always_remove_server_tunnel ? "yes" : "no");
560   abuf_appendf(out,
561     "\n"
562     "# Determines the maximum number of gateways that can be in use at any given\n"
563     "# time. This setting is used to mitigate the effects of breaking connections\n"
564     "# (due to the selection of a new gateway) on a dynamic network.\n"
565     "# (default is %u)\n"
566     "\n", DEF_GW_USE_COUNT);
567   abuf_appendf(out, "%sSmartGatewayUseCount %d\n",
568       cnf->smart_gw_use_count == DEF_GW_USE_COUNT ? "# " : "",
569       cnf->smart_gw_use_count);
570   abuf_appendf(out,
571     "\n"
572     "# Determines the take-down percentage for a non-current smart gateway tunnel.\n"
573     "# If the cost of the current smart gateway tunnel is less than this percentage\n"
574     "# of the cost of the non-current smart gateway tunnel, then the non-current smart\n"
575     "# gateway tunnel is taken down because it is then presumed to be 'too expensive'.\n"
576     "# This setting is only relevant when SmartGatewayUseCount is larger than 1;\n"
577     "# a value of 0 will result in the tunnels not being taken down proactively.\n"
578     "# (default is %u)\n"
579     "\n", DEF_GW_TAKEDOWN_PERCENTAGE);
580   abuf_appendf(out, "%sSmartGatewayTakeDownPercentage %d\n",
581       cnf->smart_gw_takedown_percentage == DEF_GW_TAKEDOWN_PERCENTAGE ? "# " : "",
582       cnf->smart_gw_takedown_percentage);
583   abuf_puts(out,
584     "\n"
585     "# Determines the policy routing script that is executed during startup and\n"
586     "# shutdown of olsrd. The script is only executed when SmartGatewayUseCount\n"
587     "# is set to a value larger than 1. The script must setup policy routing\n"
588     "# rules such that multi-gateway mode works. A sample script is included.\n"
589     "# (default is not set)\n"
590     "\n");
591   abuf_appendf(out, "%sSmartGatewayPolicyRoutingScript %s\n",
592       !cnf->smart_gw_policyrouting_script ? "# " : "",
593       !cnf->smart_gw_policyrouting_script ? "" : cnf->smart_gw_policyrouting_script);
594   abuf_puts(out,
595     "\n"
596     "# Determines the egress interfaces that are part of the multi-gateway setup and\n"
597     "# therefore only relevant when SmartGatewayUseCount is larger than 1 (in which\n"
598     "# case it must be explicitly set).\n"
599     "# (default is not set)\n"
600     "\n");
601   abuf_appendf(out, "%sSmartGatewayEgressInterfaces",
602       !cnf->smart_gw_egress_interfaces ? "# " : "");
603   {
604     struct sgw_egress_if * sgwegressif = olsr_cnf->smart_gw_egress_interfaces;
605     while (sgwegressif) {
606       abuf_appendf(out, " \"%s\"", sgwegressif->name);
607       sgwegressif = sgwegressif->next;
608     }
609     abuf_puts(out, "\n");
610   }
611   abuf_appendf(out,
612     "\n"
613     "# SmartGatewayEgressFile declares the file that contains the bandwidth\n"
614     "# parameters of the egress interfaces declared by SmartGatewayEgressInterfaces.\n"
615     "# Every line in the file declares bandwidth parameters of an egress interface,\n"
616     "# with the format:\n"
617     "#   # this is a comment\n"
618     "#   interface=upstream,downstream,pathcost,network/prefix,gateway\n"
619     "# Only the upstream and downstream fields are mandatory, the other fields are\n"
620     "# optional. An empty field signifies that its default should be used.\n"
621     "# The field defaults are:\n"
622     "#   upstream           = 0 (Kbps)\n"
623     "#   downstream         = 0 (Kbps)\n"
624     "#   pathcost           = 0 (dimensionless, 1024 is equivalent to 1 hop)\n"
625     "#   network/prefix     = no default / not set\n"
626     "#                        - network is an IP address\n"
627     "#                        - prefix is a number in the range [0, 24] for IPv4\n"
628     "#                          and in the range [0, 128] for IPv6\n"
629     "#   gateway            = no default / not set (IP address)\n"
630     "# (default is %s)\n"
631     "\n", DEF_GW_EGRESS_FILE);
632   {
633     bool def = !cnf->smart_gw_egress_file || !strcmp(cnf->smart_gw_egress_file, DEF_GW_EGRESS_FILE);
634     abuf_appendf(out, "%sSmartGatewayEgressFile %s\n",
635       def ? "# " : "", def ? DEF_GW_EGRESS_FILE : cnf->smart_gw_egress_file);
636   }
637   abuf_appendf(out,
638     "\n"
639     "# SmartGatewayEgressFilePeriod determines the period (in milliseconds) on which\n"
640     "# the SmartGatewayEgressFile is checked for changes and processed if changed.\n"
641     "# (default is %u)\n"
642     "\n", DEF_GW_EGRESS_FILE_PERIOD);
643   abuf_appendf(out, "%sSmartGatewayEgressFilePeriod %u\n",
644       cnf->smart_gw_egress_file_period == DEF_GW_EGRESS_FILE_PERIOD ? "# " : "",
645       cnf->smart_gw_egress_file_period);
646   abuf_appendf(out,
647     "\n"
648     "# Declares the file that is written by olsrd to contain the status of the smart\n"
649     "# gateways and is only relevant when SmartGatewayUseCount is larger than 1.\n"
650     "# (default is %s)\n"
651       "\n", "<not set>");
652     {
653       bool def = !cnf->smart_gw_status_file || !strlen(cnf->smart_gw_status_file);
654       abuf_appendf(out, "%sSmartGatewayStatusFile %s\n",
655         def ? "# " : "", def ? "<not set>" : cnf->smart_gw_status_file);
656     }
657   abuf_appendf(out,
658     "\n"
659     "# Determines the routing tables offset for multi-gateway policy routing tables\n"
660     "# See the policy routing script for an explanation.\n"
661     "# (default is %u)\n"
662     "\n", DEF_GW_OFFSET_TABLES);
663   abuf_appendf(out, "%sSmartGatewayTablesOffset %u\n",
664       cnf->smart_gw_offset_tables == DEF_GW_OFFSET_TABLES ? "# " : "",
665       cnf->smart_gw_offset_tables);
666   abuf_appendf(out,
667     "\n"
668     "# Determines the policy routing rules offset for multi-gateway policy routing\n"
669     "# rules. See the policy routing script for an explanation.\n"
670     "# (default is %u, which indicates that the rules and tables should be aligned and\n"
671     "# puts this value at SmartGatewayTablesOffset - # egress interfaces -\n"
672     "# # olsr interfaces)\n"
673     "\n", DEF_GW_OFFSET_RULES);
674   abuf_appendf(out, "%sSmartGatewayRulesOffset %u\n",
675       cnf->smart_gw_offset_rules == DEF_GW_OFFSET_RULES ? "# " : "",
676       cnf->smart_gw_offset_rules);
677   abuf_appendf(out,
678     "\n"
679     "# Allows the selection of a smartgateway with NAT (only for IPv4)\n"
680     "# (default is \"%s\")\n"
681     "\n", DEF_GW_ALLOW_NAT ? "yes" : "no");
682   abuf_appendf(out, "%sSmartGatewayAllowNAT %s\n",
683       cnf->smart_gw_allow_nat == DEF_GW_ALLOW_NAT ? "# " : "",
684       cnf->smart_gw_allow_nat ? "yes" : "no");
685   abuf_appendf(out,
686     "\n"
687     "# Determines the period (in milliseconds) on which a new smart gateway\n"
688     "# selection is performed.\n"
689     "# (default is %u milliseconds)\n"
690     "\n", DEF_GW_PERIOD);
691   abuf_appendf(out, "%sSmartGatewayPeriod %d\n",
692       cnf->smart_gw_period == DEF_GW_PERIOD ? "# " : "",
693       cnf->smart_gw_period);
694   abuf_appendf(out,
695     "\n"
696     "# Determines the number of times the link state database must be stable\n"
697     "# before a new smart gateway is selected.\n"
698     "# (default is %u)\n"
699     "\n", DEF_GW_STABLE_COUNT);
700   abuf_appendf(out, "%sSmartGatewayStableCount %d\n",
701       cnf->smart_gw_stablecount == DEF_GW_STABLE_COUNT ? "# " : "",
702       cnf->smart_gw_stablecount);
703   abuf_appendf(out,
704     "\n"
705     "# When another gateway than the current one has a cost of less than the cost\n"
706     "# of the current gateway multiplied by SmartGatewayThreshold then the smart\n"
707     "# gateway is switched to the other gateway. The unit is percentage.\n"
708     "# (default is %u)\n"
709     "\n", DEF_GW_THRESH);
710   abuf_appendf(out, "%sSmartGatewayThreshold %d\n",
711       cnf->smart_gw_thresh == DEF_GW_THRESH ? "# " : "",
712       cnf->smart_gw_thresh);
713   abuf_appendf(out,
714     "\n"
715     "# The weighing factor for the gateway uplink bandwidth (exit link, uplink).\n"
716     "# See README-Olsr-Extensions for a description of smart gateways.\n"
717     "# (default is %lu)\n"
718     "\n", (long unsigned int)DEF_GW_WEIGHT_EXITLINK_UP);
719   abuf_appendf(out, "%sSmartGatewayWeightExitLinkUp %d\n",
720       cnf->smart_gw_weight_exitlink_up == DEF_GW_WEIGHT_EXITLINK_UP ? "# " : "",
721       cnf->smart_gw_weight_exitlink_up);
722   abuf_appendf(out,
723     "\n"
724     "# The weighing factor for the gateway downlink bandwidth (exit link, downlink).\n"
725     "# See README-Olsr-Extensions for a description of smart gateways.\n"
726     "# (default is %lu)\n"
727     "\n", (long unsigned int)DEF_GW_WEIGHT_EXITLINK_DOWN);
728   abuf_appendf(out, "%sSmartGatewayWeightExitLinkDown %d\n",
729       cnf->smart_gw_weight_exitlink_down == DEF_GW_WEIGHT_EXITLINK_DOWN ? "# " : "",
730       cnf->smart_gw_weight_exitlink_down);
731   abuf_appendf(out,
732     "\n"
733     "# The weighing factor for the ETX costs.\n"
734     "# See README-Olsr-Extensions for a description of smart gateways.\n"
735     "# (default is %u)\n"
736     "\n", DEF_GW_WEIGHT_ETX);
737   abuf_appendf(out, "%sSmartGatewayWeightEtx %d\n",
738       cnf->smart_gw_weight_etx == DEF_GW_WEIGHT_ETX ? "# " : "",
739       cnf->smart_gw_weight_etx);
740   abuf_appendf(out,
741     "\n"
742     "# The divider for the ETX costs.\n"
743     "# See README-Olsr-Extensions for a description of smart gateways.\n"
744     "# (default is %u)\n"
745     "\n", DEF_GW_DIVIDER_ETX);
746   abuf_appendf(out, "%sSmartGatewayDividerEtx %d\n",
747       cnf->smart_gw_divider_etx == DEF_GW_DIVIDER_ETX ? "# " : "",
748       cnf->smart_gw_divider_etx);
749   abuf_appendf(out,
750     "\n"
751     "# Defines what kind of Uplink this node will publish as a\n"
752     "# smartgateway. The existence of the uplink is detected by\n"
753     "# a route to 0.0.0.0/0, ::ffff:0:0/96 and/or 2000::/3.\n"
754     "# possible values are \"none\", \"ipv4\", \"ipv6\", \"both\"\n"
755     "# (default is \"%s\")\n"
756     "\n", GW_UPLINK_TXT[DEF_GW_TYPE]);
757   abuf_appendf(out, "%sSmartGatewayUplink \"%s\"\n",
758       cnf->smart_gw_type == DEF_GW_TYPE ? "# " : "",
759       GW_UPLINK_TXT[cnf->smart_gw_type]);
760   abuf_appendf(out,
761     "\n"
762     "# Specifies if the local ipv4 uplink use NAT\n"
763     "# (default is \"%s\")\n"
764     "\n", DEF_GW_UPLINK_NAT ? "yes" : "no");
765   abuf_appendf(out, "%sSmartGatewayUplinkNAT %s\n",
766       cnf->smart_gw_uplink_nat == DEF_GW_UPLINK_NAT ? "# " : "",
767       cnf->smart_gw_uplink_nat ? "yes" : "no");
768   abuf_appendf(out,
769     "\n"
770     "# Specifies the speed of the uplink in kilobit/s.\n"
771     "# First parameter is upstream, second parameter is downstream\n"
772     "# (default is %u/%u)\n"
773     "\n", DEF_UPLINK_SPEED, DEF_DOWNLINK_SPEED);
774   abuf_appendf(out, "%sSmartGatewaySpeed %d %d\n",
775       cnf->smart_gw_uplink == DEF_UPLINK_SPEED && cnf->smart_gw_downlink == DEF_DOWNLINK_SPEED ? "# " : "",
776       cnf->smart_gw_uplink, cnf->smart_gw_downlink);
777   abuf_puts(out,
778     "\n"
779     "# Specifies the EXTERNAL ipv6 prefix of the uplink. A prefix\n"
780     "# length of more than 64 is not allowed.\n"
781     "# (default is 0::/0)\n"
782     "\n");
783   abuf_appendf(out, "%sSmartGatewayPrefix %s\n",
784       cnf->smart_gw_prefix.prefix_len == 0 ? "# " : "",
785       olsr_ip_prefix_to_string(&cnf->smart_gw_prefix));
786   abuf_appendf(out,
787     "\n"
788     "##############################\n"
789     "### OLSR protocol settings ###\n"
790     "##############################\n"
791     "\n"
792     "# For testing purposes it may be nice to use another port for olsrd\n"
793     "# for using another port than the IANA assigned one\n"
794     "# for a production network, there should be a good reason!!\n"
795     "# valid values are integers greater than 1, please be careful with\n"
796     "# using reserved port numbers\n"
797     "# (default is %u, the IANA assigned olsr-port)\n"
798     "\n", DEF_OLSRPORT);
799   abuf_appendf(out, "%sOlsrPort %u\n",
800       cnf->olsrport == DEF_OLSRPORT ? "# " : "",
801       cnf->olsrport);
802   abuf_puts(out,
803     "\n"
804     "# Sets the main IP (originator ip) of the router. This IP will NEVER\n"
805     "# change during the uptime of olsrd.\n"
806     "# (default is 0.0.0.0, which triggers usage of the IP of the first interface)\n"
807     "\n");
808   abuf_appendf(out, "MainIp %s\n",
809       olsr_ip_to_string(&ipbuf, &cnf->main_addr));
810   abuf_appendf(out,
811     "\n"
812     "# The fixed willingness to use (0-7)\n"
813     "# If not set willingness will be calculated\n"
814     "# dynamically based on battery/power status\n"
815     "# (default is %u)\n"
816     "\n", DEF_WILLINGNESS);
817   abuf_appendf(out, "%sWillingness     %u\n",
818       cnf->willingness == DEF_WILLINGNESS ? "# " : "",
819       cnf->willingness);
820   abuf_puts(out,
821     "\n"
822     "# HNA (Host network association) allows the OLSR to announce\n"
823     "# additional IPs or IP subnets to the net that are reachable\n"
824     "# through this node.\n"
825     "# Syntax for HNA4 is \"network-address    network-mask\"\n"
826     "# Syntax for HNA6 is \"network-address    prefix-length\"\n"
827     "# (default is no HNA)\n");
828   abuf_appendf(out, "Hna%u\n"
829     "{\n",
830     cnf->ip_version == AF_INET ? 4 : 6);
831   while (hna) {
832     struct ipaddr_str strbuf;
833     abuf_appendf(out, "    %s\n", olsr_ip_prefix_to_string(&hna->net));
834     hna = hna->next;
835   }
836   abuf_appendf(out,
837     "}\n"
838     "\n"
839     "# Hysteresis for link sensing (only for hopcount metric)\n"
840     "# Hysteresis adds more robustness to the link sensing\n"
841     "# but delays neighbor registration.\n"
842     "# (default is %s)\n"
843     "\n", DEF_USE_HYST ? "yes" : "no");
844   abuf_appendf(out, "%sUseHysteresis %s\n",
845       cnf->use_hysteresis == DEF_USE_HYST ? "# " : "",
846       cnf->use_hysteresis ? "yes" : "no");
847   abuf_appendf(out,
848     "\n"
849     "# Hysteresis parameters (only for hopcount metric)\n"
850     "# Do not alter these unless you know what you are doing!\n"
851     "# Set to auto by default. Allowed values are floating point\n"
852     "# values in the interval 0,1\n"
853     "# THR_LOW must always be lower than THR_HIGH!!\n"
854     "# (default is %.2f/%.2f/%.2f)\n"
855     "\n", (double)HYST_SCALING, (double)HYST_THRESHOLD_HIGH, (double)HYST_THRESHOLD_LOW);
856   abuf_appendf(out, "%sHystScaling  %.2f\n",
857       cnf->hysteresis_param.scaling == (float)HYST_SCALING ? "# " : "",
858       (double)cnf->hysteresis_param.scaling);
859   abuf_appendf(out, "%sHystThrHigh  %.2f\n",
860       cnf->hysteresis_param.thr_high == (float)HYST_THRESHOLD_HIGH ? "# " : "",
861       (double)cnf->hysteresis_param.thr_high);
862   abuf_appendf(out, "%sHystThrLow   %.2f\n",
863       cnf->hysteresis_param.thr_low == (float)HYST_THRESHOLD_LOW ? "# " : "",
864       (double)cnf->hysteresis_param.thr_low);
865   abuf_appendf(out,
866     "\n"
867     "# TC redundancy\n"
868     "# Specifies how much neighbor info should be sent in\n"
869     "# TC messages. Because of a design problem in the 0.5.x\n"
870     "# dijkstra implementation this value must be set to 2.\n"
871     "# 2 - send all neighbors\n"
872     "# (default is %u)\n"
873     "\n", TC_REDUNDANCY);
874   abuf_appendf(out, "%sTcRedundancy  %d\n",
875       cnf->tc_redundancy == TC_REDUNDANCY ? "# " : "",
876       cnf->tc_redundancy);
877   abuf_appendf(out,
878     "\n"
879     "# MPR coverage specifies how many MPRs a node should\n"
880     "# try select to reach every 2 hop neighbor. Because of\n"
881     "# a design problem in the 0.5.x dijkstra algorithm this\n"
882     "# value should be set to 7.\n"
883     "# (default is %u)\n"
884     "\n", MPR_COVERAGE);
885   abuf_appendf(out, "%sMprCoverage %d\n",
886       cnf->mpr_coverage == MPR_COVERAGE ? "# " : "",
887       cnf->mpr_coverage);
888   abuf_appendf(out,
889     "\n"
890     "################################\n"
891     "### OLSR protocol extensions ###\n"
892     "################################\n"
893     "\n"
894     "# Link quality level switch between hopcount and\n"
895     "# cost-based (mostly ETX) routing. Because of\n"
896     "# a design problem in the 0.5.x dijkstra algorithm this\n"
897     "# value should not be set to 1.\n"
898     "# 0 = do not use link quality\n"
899     "# 2 = use link quality for MPR selection and routing\n"
900     "# (default is %u)\n"
901     "\n", DEF_LQ_LEVEL);
902   abuf_appendf(out, "%sLinkQualityLevel %d\n",
903       cnf->lq_level == DEF_LQ_LEVEL ? "# " : "",
904       cnf->lq_level);
905   abuf_appendf(out,
906     "\n"
907     "# Link quality algorithm (only for lq level 2)\n"
908     "# (see README-Olsr-Extensions)\n"
909     "# - \"etx_float\", a floating point  ETX with exponential aging\n"
910     "# - \"etx_fpm\", same as ext_float, but with integer arithmetic\n"
911     "# - \"etx_ff\" (ETX freifunk), an etx variant which use all OLSR\n"
912     "#   traffic (instead of only hellos) for ETX calculation\n"
913     "# - \"etx_ffeth\", an incompatible variant of etx_ff that allows\n"
914     "#   ethernet links with ETX 0.1.\n"
915     "# (default is \"%s\")\n"
916     "\n", DEF_LQ_ALGORITHM);
917   abuf_appendf(out, "%sLinkQualityAlgorithm    \"%s\"\n",
918       cnf->lq_algorithm == NULL ? "# " : "",
919       cnf->lq_algorithm == NULL ? DEF_LQ_ALGORITHM : cnf->lq_algorithm);
920   abuf_appendf(out,
921     "\n"
922     "# Link quality aging factor (only for lq level 2)\n"
923     "# Tuning parameter for etx_float and etx_fpm, smaller values\n"
924     "# mean slower changes of ETX value. (allowed values are\n"
925     "# between 0.01 and 1.0)\n"
926     "# (default is %.2f)\n"
927     "\n", (double)DEF_LQ_AGING);
928   abuf_appendf(out, "%sLinkQualityAging %.2f\n",
929       cnf->lq_aging == (float)DEF_LQ_AGING ? "# " : "",
930       (double)cnf->lq_aging);
931   abuf_appendf(out,
932     "\n"
933     "# Fisheye mechanism for TCs (0 meansoff, 1 means on)\n"
934     "# (default is %u)\n"
935     "\n", DEF_LQ_FISH);
936   abuf_appendf(out, "%sLinkQualityFishEye  %d\n",
937       cnf->lq_fish == DEF_LQ_FISH ? "# " : "",
938       cnf->lq_fish);
939   abuf_appendf(out,
940     "\n"
941     "#\n"
942     "# NatThreshold\n"
943     "#\n"
944     "# (currently this is only in the freifunk firmware)\n"
945     "# If the NAT-Endpoint (the preferred 0/0 HNA emitting node)\n"
946     "# is to be changed, the ETX value of the current 0/0 is\n"
947     "# multiplied with the NatThreshold value before being\n"
948     "# compared to the new one.\n"
949     "# The parameter can be a value between 0.1 and 1.0, but\n"
950     "# should be close to 1.0 if changed.\n"
951     "# WARNING: This parameter should not be used together with\n"
952     "# the etx_ffeth metric !!\n"
953     "# (default is %.1f)\n"
954     "\n", (double)DEF_LQ_NAT_THRESH);
955   abuf_appendf(out, "%sNatThreshold  %.1f\n",
956       cnf->lq_nat_thresh == (float)DEF_LQ_NAT_THRESH ? "# " : "",
957       (double)cnf->lq_nat_thresh);
958
959   abuf_puts(out,
960     "\n"
961     "#############################################################\n"
962     "### Configuration of the IPC to the windows GUI interface ###\n"
963     "#############################################################\n"
964     "\n"
965     "IpcConnect\n"
966     "{\n"
967     "     # Determines how many simultaneously\n"
968     "     # IPC connections that will be allowed\n"
969     "     # Setting this to 0 disables IPC\n"
970     "\n");
971   abuf_appendf(out, "     %sMaxConnections  %d\n",
972       cnf->ipc_connections == DEF_IPC_CONNECTIONS ? "# " : "",
973       cnf->ipc_connections);
974   abuf_puts(out,
975     "\n"
976     "     # By default only 127.0.0.1 is allowed\n"
977     "     # to connect. Here allowed hosts and networks can\n"
978     "     # be added\n"
979     "\n");
980
981   while (ipc_nets) {
982     if (ipc_nets->net.prefix_len == olsr_cnf->maxplen) {
983       abuf_appendf(out, "    Host %s\n", olsr_ip_to_string(&ipbuf, &ipc_nets->net.prefix));
984     } else {
985       abuf_appendf(out, "    Net  %s\n", olsr_ip_prefix_to_string(&ipc_nets->net));
986     }
987     ipc_nets = ipc_nets->next;
988   }
989   abuf_puts(out,
990     "}\n"
991     "\n"
992     "#####################################\n"
993     "### Example plugin configurations ###\n"
994     "#####################################\n"
995     "# Olsrd plugins to load\n"
996     "# This must be the absolute path to the file\n"
997     "# or the loader will use the following scheme:\n"
998     "# - Try the paths in the LD_LIBRARY_PATH\n"
999     "#   environment variable.\n"
1000     "# - The list of libraries cached in /etc/ld.so.cache\n"
1001     "# - /lib, followed by /usr/lib\n"
1002     "\n");
1003
1004   while (plugins) {
1005     abuf_appendf(out, "LoadPlugin \"%s\" {\n", plugins->name);
1006     pl_param = plugins->params;
1007     while (pl_param) {
1008       abuf_appendf(out, "    PlParam \"%s\" \"%s\"\n", pl_param->key, pl_param->value);
1009       pl_param = pl_param->next;
1010     }
1011     abuf_puts(out, "}\n"
1012         "\n");
1013     plugins = plugins->next;
1014   }
1015
1016   abuf_puts(out,
1017     "#############################################\n"
1018     "### OLSRD default interface configuration ###\n"
1019     "#############################################\n"
1020     "# the default interface section can have the same values as the following\n"
1021     "# interface configuration. It will allow you so set common options for all\n"
1022     "# interfaces.\n"
1023     "\n"
1024     "InterfaceDefaults\n");
1025   olsrd_write_if_autobuf(out, cnf, cnf->interface_defaults, false);
1026   abuf_puts(out,
1027     "\n"
1028     "######################################\n"
1029     "### OLSRd Interfaces configuration ###\n"
1030     "######################################\n"
1031     "# multiple interfaces can be specified for a single configuration block\n"
1032     "# multiple configuration blocks can be specified\n"
1033     "\n");
1034   first = true;
1035   while (interf) {
1036     abuf_appendf(out, "Interface \"%s\"\n", interf->name);
1037     olsrd_write_if_autobuf(out, cnf, interf->cnf, first);
1038
1039     first = false;
1040     interf = interf->next;
1041   }
1042
1043   abuf_puts(out,
1044       "\n"
1045       "# END AUTOGENERATED CONFIG\n");
1046 }
1047 /*
1048  * Local Variables:
1049  * c-basic-offset: 2
1050  * indent-tabs-mode: nil
1051  * End:
1052  */