e64abcfdee4eacac5463bd702fbbe2a170de1966
[olsrd.git] / lib / nameservice / src / nameservice.h
1 /*
2  * Copyright (c) 2005, Bruno Randolf <bruno.randolf@4g-systems.biz>
3  * Copyright (c) 2004, Andreas Tonnesen(andreto-at-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 notice, 
11  *   this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above copyright notice, 
13  *   this list of conditions and the following disclaimer in the documentation 
14  *   and/or other materials provided with the distribution.
15  * * Neither the name of the UniK olsr daemon nor the names of its contributors 
16  *   may be used to endorse or promote products derived from this software 
17  *   without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
20  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
21  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
22  * IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
23  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
24  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 
25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY 
26  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 
27  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED 
28  * OF THE POSSIBILITY OF SUCH DAMAGE.
29  *
30  */
31
32  
33 /*
34  * Dynamic linked library for UniK OLSRd
35  */
36
37 #ifndef _NAMESERVICE_PLUGIN
38 #define _NAMESERVICE_PLUGIN
39
40 #include <sys/time.h>
41 #include <regex.h>
42
43 #include "olsr_types.h"
44 #include "interfaces.h"
45 #include "olsr_protocol.h"
46 #include "common/list.h"
47
48 #include "olsrd_plugin.h"
49 #include "nameservice_msg.h"
50 #include "hashing.h"
51 #include "mapwrite.h"
52 #include "mantissa.h"
53
54 #define PLUGIN_NAME     "OLSRD nameservice plugin"
55 #define PLUGIN_VERSION  "0.3"
56 #define PLUGIN_AUTHOR   "Bruno Randolf, Jens Nachtigall, Sven-Ola Tuecke"
57
58 // useful to set for the freifunkfirmware to remove all
59 // calls to olsr_printf by the empty statement ";"
60 //#define olsr_printf(...) ;
61
62 #define MESSAGE_TYPE            130
63 #define PARSER_TYPE             MESSAGE_TYPE
64 #define EMISSION_INTERVAL       120 /* seconds */
65 #define EMISSION_JITTER         25 /* percent */
66 #define NAME_VALID_TIME         1800 /* seconds */
67 #define NAMESERVER_COUNT        3
68
69 #define NAME_PROTOCOL_VERSION   1
70
71 #define MAX_NAME 127
72 #define MAX_FILE 255
73 #define MAX_SUFFIX 63
74
75 #define MID_ENTRIES 1
76 #define MID_MAXLEN 16
77 #define MID_PREFIX "mid%i."
78
79 /**
80  * a linked list of name_entry
81  * if type is NAME_HOST, name is a hostname and ip its IP addr
82  * if type is NAME_FORWARDER, then ip is a dns-server (and name is irrelevant)
83  * if type is NAME_SERVICE, then name is a service-line (and the ip is irrelevant)
84  * if type is NAME_LATLON, then name has 2 floats with lat and lon (and the ip is irrelevant)
85  */
86 struct name_entry
87 {
88         union olsr_ip_addr      ip;
89         olsr_u16_t              type;
90         olsr_u16_t              len;
91         char                    *name;
92         struct name_entry       *next;          /* linked list */
93 };
94
95 /* *
96  * linked list of db_entries for each originator with
97  * originator being its main_addr
98  * 
99  * names points to the name_entry with its hostname, dns-server or
100  * service-line entry
101  *
102  * all the db_entries are hashed in nameservice.c to avoid a too long list
103  * for many nodes in a net
104  *
105  * */
106 struct db_entry
107 {
108         union olsr_ip_addr      originator;     /* IP address of the node this entry describes */
109         struct timer_entry      *db_timer;      /* Validity time */
110         struct name_entry       *names;         /* list of names this originator declares */
111         struct list_node        db_list;        /* linked list of db entries per hash container */
112 };
113
114 /* inline to recast from db_list back to db_entry */
115 LISTNODE2STRUCT(list2db, struct db_entry, db_list);
116
117 #define OLSR_NAMESVC_DB_JITTER 5 /* percent */
118
119 extern struct name_entry *my_names;
120 extern struct list_node latlon_list[HASHSIZE];
121 extern float my_lat, my_lon;
122 extern struct olsr_cookie_info *map_poll_timer_cookie;
123
124 void olsr_expire_write_file_timer(void *);
125 void olsr_namesvc_delete_db_entry(struct db_entry *);
126
127 /* Parser function to register with the sceduler */
128 olsr_bool
129 olsr_parser(union olsr_message *, struct interface *, union olsr_ip_addr *);
130
131 /* callback for periodic timer */
132 void olsr_namesvc_gen(void *);
133
134 int
135 encap_namemsg(struct namemsg *);
136
137 struct name_entry*
138 add_name_to_list(struct name_entry *my_list, const char *value, int type, const union olsr_ip_addr *ip);
139
140 struct name_entry*
141 remove_nonvalid_names_from_list(struct name_entry *my_list, int type);
142
143 void 
144 free_all_list_entries(struct list_node *) ;
145
146 void
147 decap_namemsg(struct name *from_packet, struct name_entry **to, olsr_bool *this_table_changed );
148
149 void
150 insert_new_name_in_list(union olsr_ip_addr *, struct list_node *,
151                         struct name *, olsr_bool *, olsr_reltime);
152
153 olsr_bool
154 allowed_hostname_or_ip_in_service(const char *service_line, const regmatch_t *hostname_or_ip);
155
156 void
157 update_name_entry(union olsr_ip_addr *, struct namemsg *, int, olsr_reltime);
158
159 void
160 write_hosts_file(void);
161
162 void
163 write_services_file(void);
164
165 void
166 write_resolv_file(void);
167
168 int
169 register_olsr_param(char *key, char *value);
170
171 void 
172 free_name_entry_list(struct name_entry **list);
173
174 olsr_bool
175 allowed_ip(const union olsr_ip_addr *addr);
176
177 olsr_bool
178 allowed_service(const char *service_line);
179
180 olsr_bool
181 is_name_wellformed(const char *service_line);
182
183 olsr_bool
184 is_service_wellformed(const char *service_line);
185
186 olsr_bool
187 is_service_wellformed(const char *service_line);
188
189 olsr_bool
190 is_latlon_wellformed(const char *latlon_line);
191
192 olsr_bool
193 get_isdefhna_latlon(void);
194
195 void
196 lookup_defhna_latlon(union olsr_ip_addr *ip);
197
198 const char*
199 lookup_name_latlon(union olsr_ip_addr *ip);
200
201 void
202 write_latlon_file(void);
203
204 char*  
205 create_packet(struct name *to, struct name_entry *from);
206
207 void
208 name_constructor(void);
209
210 void
211 name_destructor(void);
212
213 int
214 name_init(void);
215
216 #endif
217
218
219 /*
220  * Local Variables:
221  * c-basic-offset: 2
222  * indent-tabs-mode: nil
223  * End:
224  */