cc547345e74dc9a0ffdc15e269ab7908650a97ec
[olsrd.git] / lib / poprouting / src / olsrd_poprouting.c
1 /*
2  * The olsr.org Optimized Link-State Routing daemon (olsrd)
3  *
4  * (c) by the OLSR project
5  *
6  * See our Git repository to find out who worked on this file
7  * and thus is a copyright holder on it.
8  *
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  *
15  * * Redistributions of source code must retain the above copyright
16  *   notice, this list of conditions and the following disclaimer.
17  * * Redistributions in binary form must reproduce the above copyright
18  *   notice, this list of conditions and the following disclaimer in
19  *   the documentation and/or other materials provided with the
20  *   distribution.
21  * * Neither the name of olsr.org, olsrd nor the names of its
22  *   contributors may be used to endorse or promote products derived
23  *   from this software without specific prior written permission.
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
28  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
29  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
30  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
31  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
32  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
33  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
35  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36  * POSSIBILITY OF SUCH DAMAGE.
37  *
38  * Visit http://www.olsr.org for more information.
39  *
40  * If you find this software useful feel free to make a donation
41  * to the project. For more information see the website or contact
42  * the copyright holders.
43  *
44  */
45
46 #include "olsrd_poprouting.h"
47
48 #include <unistd.h>
49
50 #include "info/info_types.h"
51 #include "info/http_headers.h"
52 #include "olsr.h"
53 #include "scheduler.h"
54
55 float timer = 0.0f;
56 float hello_mult = 10.0f;
57 float tc_mult = 60.0f;
58
59 unsigned long long get_supported_commands_mask(void) {
60   return SIW_POPROUTING;
61 }
62
63 bool isCommand(const char *str, unsigned long long siw) {
64   bool r;
65   const char *prefix, s[2] = "=";
66   char *string, *cmd, *s_timer;
67   string = strdup(str);
68   switch (siw) {
69     case SIW_POPROUTING_HELLO:
70       prefix = "/helloTimer";
71       break;
72
73     case SIW_POPROUTING_TC:
74       prefix = "/tcTimer";
75       break;
76
77     case SIW_POPROUTING_HELLO_MULT:
78       prefix = "/helloTimerMult";
79       break;
80
81     case SIW_POPROUTING_TC_MULT:
82       prefix = "/tcTimerMult";
83       break;
84
85     default:
86       return false;
87   }
88   cmd = strtok(string, s);
89   s_timer = strtok(NULL, s);
90   if (s_timer) {
91     timer = atof(s_timer);
92   } else {
93     timer = 0;
94   }
95
96   r = !strcmp(cmd, prefix) && (timer >= 0);
97
98   free(string);
99
100   return r;
101 }
102
103 void output_error(struct autobuf *abuf, unsigned int status, const char * req __attribute__((unused)), bool http_headers) {
104   if (http_headers || (status == INFO_HTTP_OK)) {
105     return;
106   }
107
108   /* !http_headers && !INFO_HTTP_OK */
109
110   if (status == INFO_HTTP_NOCONTENT) {
111     /* wget can't handle output of zero length */
112     abuf_puts(abuf, "\n");
113   } else {
114     abuf_appendf(abuf, "error: %s\n", httpStatusToReply(status));
115   }
116 }
117
118 void set_hello_timer(struct autobuf *abuf) {
119   struct olsr_if *in;
120   assert(abuf);
121   in = olsr_cnf->interfaces;
122   if (timer != 0.0f) {
123     char response[20];
124     sprintf(response, "hello:%.2f\n", (double) in->cnf->hello_params.emission_interval);
125     abuf_puts(abuf, response);
126     return;
127   }
128
129   while (in != NULL ) {
130     olsr_printf(1, "(POPROUTING) Setting Hello Timer=%f for interface %s\n", (double) timer, in->name);
131     //olsr_change_timer(in->interf->hello_gen_timer, timer * MSEC_PER_SEC, 0, 1);
132     in->interf->hello_gen_timer->timer_period = timer * MSEC_PER_SEC;
133     in->interf->hello_gen_timer->timer_jitter_pct = POPROUTING_JITTER; // Jitter to 5%
134     in->cnf->hello_params.emission_interval = timer;
135     in->cnf->hello_params.validity_time = timer * hello_mult;
136     in->interf->valtimes.hello = reltime_to_me(in->cnf->hello_params.validity_time * MSEC_PER_SEC);
137     in->interf->hello_etime = in->cnf->hello_params.emission_interval * MSEC_PER_SEC;
138     in = in->next;
139   }
140   abuf_puts(abuf, "0\n");
141   return;
142 }
143
144 void set_tc_timer(struct autobuf *abuf) {
145   struct olsr_if *in;
146   in = olsr_cnf->interfaces;
147   if (timer != 0.0f) {
148     char response[20];
149     sprintf(response, "tc:%.2f\n", (double) in->cnf->tc_params.emission_interval);
150     abuf_puts(abuf, response);
151     return;
152   }
153
154   while (in != NULL ) {
155     olsr_printf(1, "(POPROUTING) Setting Tc Timer=%f for interface %s\n", (double) timer, in->name);
156     //olsr_change_timer(in->interf->tc_gen_timer, timer * MSEC_PER_SEC, 0, 1);
157     in->interf->tc_gen_timer->timer_period = timer * MSEC_PER_SEC;
158     in->interf->tc_gen_timer->timer_jitter_pct = POPROUTING_JITTER; // Jitter to 5%
159     in->cnf->tc_params.emission_interval = timer;
160     in->cnf->tc_params.validity_time = timer * tc_mult;
161     in->interf->valtimes.tc = reltime_to_me(in->cnf->tc_params.validity_time * MSEC_PER_SEC);
162     in = in->next;
163   }
164   abuf_puts(abuf, "0\n");
165   return;
166 }
167
168 void set_tc_timer_mult(struct autobuf *abuf) {
169   float current_timer;
170   struct olsr_if *in;
171   assert(abuf);
172   in = olsr_cnf->interfaces;
173   if (timer != 0.0f) {
174     char response[20];
175     sprintf(response, "tc_mult:%.2f\n", (double) tc_mult);
176     abuf_puts(abuf, response);
177     return;
178   } else {
179     tc_mult = timer;
180   }
181
182   while (in != NULL ) {
183     olsr_printf(1, "(POPROUTING) Setting Tc Timer Mult=%f for interface %s\n", (double) tc_mult, in->name);
184     current_timer = in->cnf->tc_params.emission_interval;
185     in->cnf->tc_params.validity_time = current_timer * tc_mult;
186     in->interf->valtimes.tc = reltime_to_me(in->cnf->tc_params.validity_time * MSEC_PER_SEC);
187     in = in->next;
188   }
189   abuf_puts(abuf, "0\n");
190   return;
191 }
192
193 void set_hello_timer_mult(struct autobuf *abuf) {
194   float current_timer;
195   struct olsr_if *in;
196   assert(abuf);
197   in = olsr_cnf->interfaces;
198   if (timer != 0.0f) {
199     char response[20];
200     sprintf(response, "hello_mult:%.2f\n", (double) hello_mult);
201     abuf_puts(abuf, response);
202     return;
203   } else {
204     hello_mult = timer;
205   }
206
207   while (in != NULL ) {
208     olsr_printf(1, "(POPROUTING) Setting Hello Timer Mult=%f for interface %s\n", (double) hello_mult, in->name);
209     current_timer = in->cnf->hello_params.emission_interval;
210     in->cnf->hello_params.validity_time = current_timer * hello_mult;
211     in->interf->valtimes.hello = reltime_to_me(in->cnf->hello_params.validity_time * MSEC_PER_SEC);
212     in = in->next;
213   }
214   abuf_puts(abuf, "0\n");
215   return;
216 }