ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/gvpe/src/util.h
Revision: 1.27
Committed: Sun Aug 10 01:34:36 2008 UTC (15 years, 9 months ago) by pcg
Content type: text/plain
Branch: MAIN
Changes since 1.26: +7 -11 lines
Log Message:
lots tuning

File Contents

# Content
1 /*
2 util.h -- process management and other utility functions
3 Copyright (C) 1998-2002 Ivo Timmermans <ivo@o2w.nl>
4 2000-2002 Guus Sliepen <guus@sliepen.eu.org>
5 2003-2008 Marc Lehmann <gvpe@schmorp.de>
6
7 This file is part of GVPE.
8
9 GVPE is free software; you can redistribute it and/or modify it
10 under the terms of the GNU General Public License as published by the
11 Free Software Foundation; either version 3 of the License, or (at your
12 option) any later version.
13
14 This program is distributed in the hope that it will be useful, but
15 WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
17 Public License for more details.
18
19 You should have received a copy of the GNU General Public License along
20 with this program; if not, see <http://www.gnu.org/licenses/>.
21
22 Additional permission under GNU GPL version 3 section 7
23
24 If you modify this Program, or any covered work, by linking or
25 combining it with the OpenSSL project's OpenSSL library (or a modified
26 version of that library), containing parts covered by the terms of the
27 OpenSSL or SSLeay licenses, the licensors of this Program grant you
28 additional permission to convey the resulting work. Corresponding
29 Source for a non-source form of such a combination shall include the
30 source code for the parts of OpenSSL used as well as that of the
31 covered work.
32 */
33
34 #ifndef UTIL_H__
35 #define UTIL_H__
36
37 #include <cstring>
38 #include <sys/types.h>
39
40 #include <openssl/rsa.h>
41
42 #include "gettext.h"
43
44 #include "slog.h"
45 #include "ev_cpp.h"
46 #include "callback.h"
47
48 typedef ev_tstamp tstamp;
49
50 /*
51 * check for an existing gvpe for this net, and write pid to pidfile
52 */
53 extern int write_pidfile (void);
54
55 /*
56 * kill older gvpe
57 */
58 extern int kill_other (int signal);
59
60 /*
61 * Detach from current terminal, write pidfile, kill parent
62 */
63 extern int detach (int do_detach);
64
65 /*
66 * check wether the given path is an absolute pathname
67 */
68 #define ABSOLUTE_PATH(c) ((c)[0] == '/')
69
70 /*****************************************************************************/
71
72 typedef u8 mac[6];
73
74 extern void id2mac (unsigned int id, void *m);
75
76 #define mac2id(p) ((p)[0] & 0x01 ? 0 : ((p)[4] << 8) | (p)[5])
77
78 struct sliding_window
79 {
80 u32 v[(WINDOWSIZE + 31) / 32];
81 u32 seq;
82
83 void reset (u32 seqno)
84 {
85 memset (v, -1, sizeof v);
86 seq = seqno;
87 }
88
89 // 0 == ok, 1 == silently ignore, 2 == error, reset
90 int seqno_classify (u32 seqno)
91 {
92 if (seqno <= seq - WINDOWSIZE)
93 return 1;
94 else if (seqno > seq + WINDOWSIZE * 16)
95 return 2;
96 else
97 {
98 while (seqno > seq)
99 {
100 seq++;
101
102 u32 s = seq % WINDOWSIZE;
103 u32 *cell = v + (s >> 5);
104 u32 mask = 1 << (s & 31);
105
106 *cell &= ~mask;
107 }
108
109 u32 s = seqno % WINDOWSIZE;
110 u32 *cell = v + (s >> 5);
111 u32 mask = 1 << (s & 31);
112
113 if (*cell & mask)
114 return 1;
115 else
116 {
117 *cell |= mask;
118 return 0;
119 }
120 }
121 }
122 };
123
124 typedef callback<const char * ()> run_script_cb;
125
126 // run a shell script (or actually an external program).
127 pid_t run_script (const run_script_cb &cb, bool wait);
128
129 #if ENABLE_HTTP_PROXY
130 u8 *base64_encode (const u8 *data, unsigned int len);
131 #endif
132
133 /*****************************************************************************/
134
135 typedef u8 rsaclear[RSA_KEYLEN - RSA_OVERHEAD]; // challenge data;
136 typedef u8 rsacrypt[RSA_KEYLEN]; // encrypted challenge
137
138 static inline void
139 rsa_encrypt (RSA *key, const rsaclear &chg, rsacrypt &encr)
140 {
141 if (RSA_public_encrypt (sizeof chg,
142 (unsigned char *)&chg, (unsigned char *)&encr,
143 key, RSA_PKCS1_OAEP_PADDING) < 0)
144 fatal ("RSA_public_encrypt error");
145 }
146
147 static inline bool
148 rsa_decrypt (RSA *key, const rsacrypt &encr, rsaclear &chg)
149 {
150 return RSA_private_decrypt (sizeof encr,
151 (unsigned char *)&encr, (unsigned char *)&chg,
152 key, RSA_PKCS1_OAEP_PADDING) > 0;
153 }
154
155 #endif
156