* applied patches from the most recent FreiFunkFirmware (and fixed compile errors...
[olsrd.git] / lib / secure / src / olsrd_secure.h
1 /*
2  * Secure OLSR plugin
3  * http://www.olsr.org
4  *
5  * Copyright (c) 2004, Andreas T√łnnesen(andreto@olsr.org)
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or 
9  * without modification, are permitted provided that the following 
10  * conditions are met:
11  *
12  * * Redistributions of source code must retain the above copyright 
13  *   notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above copyright 
15  *   notice, this list of conditions and the following disclaimer in 
16  *   the documentation and/or other materials provided with the 
17  *   distribution.
18  * * Neither the name of olsrd, olsr.org nor the names of its 
19  *   contributors may be used to endorse or promote products derived 
20  *   from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
33  *POSSIBILITY OF SUCH DAMAGE.
34  *
35  */
36
37 /*
38  * Dynamic linked library example for UniK OLSRd
39  */
40
41 #ifndef _OLSRD_PLUGIN_TEST
42 #define _OLSRD_PLUGIN_TEST
43
44 #include "secure_messages.h"
45
46 #include "hashing.h"
47
48
49 #define KEYFILE "/etc/olsrd.d/olsrd_secure_key"
50
51 /* Schemes */
52 #define ONE_CHECKSUM          1
53
54 /* Algorithm definitions */
55 #define SHA1_INCLUDING_KEY   1
56 #define MD5_INCLUDING_KEY   2
57
58 #ifdef USE_OPENSSL
59 #define SIGNATURE_SIZE 20
60 #else
61 #define SIGNATURE_SIZE 16
62 #endif
63
64 #define KEYLENGTH      16
65
66 #define UPPER_DIFF 3
67 #define LOWER_DIFF -3
68
69 char aes_key[16];
70 /* Seconds of slack allowed */
71 #define SLACK 3
72
73 /* Timestamp node */
74 struct stamp
75 {
76   union olsr_ip_addr addr;
77   /* Timestamp difference */
78   int diff;
79   olsr_u32_t challenge;
80   olsr_u8_t validated;
81   clock_t valtime; /* Validity time */
82   clock_t conftime; /* Reconfiguration time */
83   struct stamp *prev;
84   struct stamp *next;
85 };
86
87 /* Seconds to cache a valid timestamp entry */
88 #define TIMESTAMP_HOLD_TIME 30
89 /* Seconds to cache a not verified timestamp entry */
90 #define EXCHANGE_HOLD_TIME 5
91
92 struct stamp timestamps[HASHSIZE];
93
94 /* Input interface */
95 struct interface *olsr_in_if;
96
97 /* Timeout function to register with the sceduler */
98 void
99 olsr_timeout(void);
100
101
102 /* Event function to register with the sceduler */
103 void
104 olsr_event(void);
105
106 int
107 send_challenge(union olsr_ip_addr *);
108
109 int
110 ifchange(struct interface *, int);
111
112 int
113 send_cres(union olsr_ip_addr *, union olsr_ip_addr *, olsr_u32_t, struct stamp *);
114
115 int
116 send_rres(union olsr_ip_addr *, union olsr_ip_addr *, olsr_u32_t);
117
118 int
119 parse_challenge(char *);
120
121 int
122 parse_cres(char *);
123
124 int
125 parse_rres(char *);
126
127 int
128 check_auth(char *, int *);
129
130 void
131 ipc_action(int);
132
133 int
134 ipc_send(char *, int);
135
136 int
137 add_signature(olsr_u8_t *, int*);
138
139 int
140 validate_packet(char *, int*);
141
142 void
143 packet_parser(int);
144
145 void
146 timeout_timestamps(void*);
147
148 int
149 check_timestamp(union olsr_ip_addr *, time_t);
150
151 struct stamp *
152 lookup_timestamp_entry(union olsr_ip_addr *);
153
154 int
155 read_key_from_file(char *);
156
157 int
158 secure_plugin_init(void);
159
160 void
161 secure_plugin_exit(void);
162
163 int
164 plugin_ipc_init(void);
165
166 #endif