Convert some plugins to new logger
[olsrd.git] / lib / dyn_gw_plain / src / olsrd_dyn_gw_plain.c
1
2 /*
3  * The olsr.org Optimized Link-State Routing daemon(olsrd)
4  * Copyright (c) 2004-2009, the olsr.org team - see HISTORY file
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * * Redistributions of source code must retain the above copyright
12  *   notice, this list of conditions and the following disclaimer.
13  * * Redistributions in binary form must reproduce the above copyright
14  *   notice, this list of conditions and the following disclaimer in
15  *   the documentation and/or other materials provided with the
16  *   distribution.
17  * * Neither the name of olsr.org, olsrd nor the names of its
18  *   contributors may be used to endorse or promote products derived
19  *   from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  *
34  * Visit http://www.olsr.org for more information.
35  *
36  * If you find this software useful feel free to make a donation
37  * to the project. For more information see the website or contact
38  * the copyright holders.
39  *
40  */
41
42 #include "olsrd_dyn_gw_plain.h"
43 #include "olsr_types.h"
44 #include "ipcalc.h"
45 #include "scheduler.h"
46 #include "olsr.h"
47 #include "olsr_cookie.h"
48 #include "olsr_ip_prefix_list.h"
49 #include "olsr_logging.h"
50
51 #include <stdio.h>
52 #include <string.h>
53 #include <stdlib.h>
54 #include <net/route.h>
55 #include <unistd.h>
56 #include <errno.h>
57
58 #define PLUGIN_INTERFACE_VERSION 5
59
60 static int has_inet_gateway;
61 static struct olsr_cookie_info *event_timer_cookie;
62 static union olsr_ip_addr gw_net;
63 static union olsr_ip_addr gw_netmask;
64
65 /**
66  * Plugin interface version
67  * Used by main olsrd to check plugin interface version
68  */
69 int
70 olsrd_plugin_interface_version(void)
71 {
72   return PLUGIN_INTERFACE_VERSION;
73 }
74
75 static const struct olsrd_plugin_parameters plugin_parameters[] = {
76 };
77
78 void
79 olsrd_get_plugin_parameters(const struct olsrd_plugin_parameters **params, int *size)
80 {
81   *params = plugin_parameters;
82   *size = ARRAYSIZE(plugin_parameters);
83 }
84
85 /**
86  * Initialize plugin
87  * Called after all parameters are passed
88  */
89 int
90 olsrd_plugin_init(void)
91 {
92   OLSR_INFO(LOG_PLUGINS, "OLSRD dyn_gw_plain plugin by Sven-Ola\n");
93
94   gw_net.v4.s_addr = INET_NET;
95   gw_netmask.v4.s_addr = INET_PREFIX;
96
97   has_inet_gateway = 0;
98
99   /* Remove all local Inet HNA entries */
100   while (ip_prefix_list_remove(&olsr_cnf->hna_entries, &gw_net, olsr_netmask_to_prefix(&gw_netmask), olsr_cnf->ip_version)) {
101     OLSR_DEBUG(LOG_PLUGINS, "HNA Internet gateway deleted\n");
102   }
103
104   /* create the cookie */
105   event_timer_cookie = olsr_alloc_cookie("DynGW Plain: Event", OLSR_COOKIE_TYPE_TIMER);
106
107   /* Register the GW check */
108   olsr_start_timer(3 * MSEC_PER_SEC, 0, OLSR_TIMER_PERIODIC, &olsr_event, NULL, event_timer_cookie->ci_id);
109
110   return 1;
111 }
112
113 int
114 check_gw(union olsr_ip_addr *net, union olsr_ip_addr *mask)
115 {
116   char buff[1024], iface[17];
117   uint32_t gate_addr, dest_addr, netmask;
118   unsigned int iflags;
119   int num, metric, refcnt, use;
120   int retval = 0;
121
122   FILE *fp = fopen(PROCENTRY_ROUTE, "r");
123
124   if (!fp) {
125     OLSR_WARN(LOG_PLUGINS, "Cannot read proc file %s: %s\n", PROCENTRY_ROUTE, strerror(errno));
126     return -1;
127   }
128
129   rewind(fp);
130
131   /*
132      OLSR_PRINTF(DEBUGLEV, "Genmask         Destination     Gateway         "
133      "Flags Metric Ref    Use Iface\n");
134    */
135   while (fgets(buff, 1023, fp)) {
136 #if !defined REMOVE_DEBUG
137     struct ipaddr_str buf;
138 #endif
139     num =
140       sscanf(buff, "%16s %128X %128X %X %d %d %d %128X \n", iface, &dest_addr, &gate_addr, &iflags, &refcnt, &use, &metric,
141              &netmask);
142
143     if (num < 8) {
144       continue;
145     }
146     OLSR_DEBUG(LOG_PLUGINS, "%-15s %-15s %-15s %-6d %-2d %7d %s\n",
147         olsr_ip_to_string(&buf, (union olsr_ip_addr *)&netmask),
148         olsr_ip_to_string(&buf, (union olsr_ip_addr *)&dest_addr),
149         olsr_ip_to_string(&buf, (union olsr_ip_addr *)&gate_addr),
150         metric, refcnt, use, iface);
151
152     if (                        /* (iflags & RTF_GATEWAY) && */
153          (iflags & RTF_UP) && (metric == 0) && (netmask == mask->v4.s_addr) && (dest_addr == net->v4.s_addr)) {
154       OLSR_DEBUG(LOG_PLUGINS, "INTERNET GATEWAY VIA %s detected in routing table.\n", iface);
155       retval = 1;
156     }
157
158   }
159
160   fclose(fp);
161
162   if (retval == 0) {
163     OLSR_DEBUG(LOG_PLUGINS, "No Internet GWs detected...\n");
164   }
165
166   return retval;
167 }
168
169 /**
170  * Scheduled event to update the hna table,
171  * called from olsrd main thread to keep the hna table thread-safe
172  */
173 void
174 olsr_event(void *foo __attribute__ ((unused)))
175 {
176   int res = check_gw(&gw_net, &gw_netmask);
177   if (1 == res && 0 == has_inet_gateway) {
178     OLSR_DEBUG(LOG_PLUGINS, "Adding OLSR local HNA entry for Internet\n");
179     ip_prefix_list_add(&olsr_cnf->hna_entries, &gw_net, olsr_netmask_to_prefix(&gw_netmask));
180     has_inet_gateway = 1;
181   } else if (0 == res && 1 == has_inet_gateway) {
182     /* Remove all local Inet HNA entries */
183     while (ip_prefix_list_remove(&olsr_cnf->hna_entries, &gw_net, olsr_netmask_to_prefix(&gw_netmask), olsr_cnf->ip_version)) {
184       OLSR_DEBUG(LOG_PLUGINS, "Removing OLSR local HNA entry for Internet\n");
185     }
186     has_inet_gateway = 0;
187   }
188 }
189
190 /*
191  * Local Variables:
192  * c-basic-offset: 2
193  * indent-tabs-mode: nil
194  * End:
195  */