ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/gvpe/src/util.C
(Generate patch)

Comparing gvpe/src/util.C (file contents):
Revision 1.6 by pcg, Wed Apr 2 05:15:00 2003 UTC vs.
Revision 1.14 by pcg, Mon May 10 20:13:10 2004 UTC

1/* 1/*
2 util.C -- process management and other utility functions 2 util.C -- process management and other utility functions
3 Copyright (C) 2003 Marc Lehmann <pcg@goof.com>
3 4
4 Some of these are taken from tinc, see the AUTHORS file. 5 Some of these are taken from tinc, see the AUTHORS file.
5 6
6 This program is free software; you can redistribute it and/or modify 7 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by 8 it under the terms of the GNU General Public License as published by
19*/ 20*/
20 21
21#include "config.h" 22#include "config.h"
22 23
23#include <cstdio> 24#include <cstdio>
25#include <cstdlib>
24#include <cstring> 26#include <cstring>
25 27
26#include <errno.h> 28#include <errno.h>
27#include <signal.h> 29#include <signal.h>
28#include <sys/types.h> 30#include <sys/types.h>
29#include <sys/wait.h> 31#include <sys/wait.h>
30#include <unistd.h> 32#include <unistd.h>
31#include <time.h> 33#include <time.h>
32#include <sys/socket.h>
33#include <netinet/in.h>
34#include <arpa/inet.h>
35 34
36 35#include "netcompat.h"
37#include <sys/mman.h>
38 36
39#include "gettext.h" 37#include "gettext.h"
40#include "pidfile.h" 38#include "pidfile.h"
41#include "dropin.h" 39#include "dropin.h"
42 40
48int 46int
49write_pidfile (void) 47write_pidfile (void)
50{ 48{
51 int pid; 49 int pid;
52 50
53 pid = check_pid (pidfilename); 51 pid = check_pid (conf.pidfilename);
54 52
55 if (pid) 53 if (pid)
56 { 54 {
57 fprintf (stderr, _("A vped is already running with pid %d.\n"), pid); 55 fprintf (stderr, _("A vped is already running with pid %d.\n"), pid);
58 return 1; 56 return 1;
59 } 57 }
60 58
61 /* if it's locked, write-protected, or whatever */ 59 /* if it's locked, write-protected, or whatever */
62 if (!write_pid (pidfilename)) 60 if (!write_pid (conf.pidfilename))
63 return 1; 61 return 1;
64 62
65 return 0; 63 return 0;
66} 64}
67 65
68int 66int
69kill_other (int signal) 67kill_other (int signal)
70{ 68{
71 int pid; 69 int pid;
72 70
73 pid = read_pid (pidfilename); 71 pid = read_pid (conf.pidfilename);
74 72
75 if (!pid) 73 if (!pid)
76 { 74 {
77 fprintf (stderr, _("No other vped is running.\n")); 75 fprintf (stderr, _("No other vped is running.\n"));
78 return 1; 76 return 1;
84 if (kill (pid, signal) && errno == ESRCH) 82 if (kill (pid, signal) && errno == ESRCH)
85 { 83 {
86 fprintf (stderr, _("The vped is no longer running. ")); 84 fprintf (stderr, _("The vped is no longer running. "));
87 85
88 fprintf (stderr, _("Removing stale lock file.\n")); 86 fprintf (stderr, _("Removing stale lock file.\n"));
89 remove_pid (pidfilename); 87 remove_pid (conf.pidfilename);
90 } 88 }
91 89
92 return 0; 90 return 0;
93} 91}
94 92
114 return -1; 112 return -1;
115 } 113 }
116 114
117 /* Now UPDATE the pid in the pidfile, because we changed it... */ 115 /* Now UPDATE the pid in the pidfile, because we changed it... */
118 116
119 if (!write_pid (pidfilename)) 117 if (!write_pid (conf.pidfilename))
120 return -1; 118 return -1;
121 119
122 log_to (LOGTO_SYSLOG); 120 log_to (LOGTO_SYSLOG);
123 } 121 }
124 else 122 else
125 log_to (LOGTO_SYSLOG | LOGTO_STDERR); 123 log_to (LOGTO_SYSLOG | LOGTO_STDERR);
126 124
127 slog (L_INFO, _("vped %s (%s %s) starting"), VERSION, __DATE__, __TIME__); 125 slog (L_INFO, _("vped %s (%s %s) starting"), VERSION, __DATE__, __TIME__);
128 126
129 return 0; 127 return 0;
130}
131
132void
133make_names (void)
134{
135 if (!pidfilename)
136 pidfilename = LOCALSTATEDIR "/run/vped.pid";
137
138 if (!confbase)
139 asprintf (&confbase, "%s/vpe", CONFDIR);
140} 128}
141 129
142void run_script (const run_script_cb &cb, bool wait) 130void run_script (const run_script_cb &cb, bool wait)
143{ 131{
144 int pid; 132 int pid;
146 if ((pid = fork ()) == 0) 134 if ((pid = fork ()) == 0)
147 { 135 {
148 char *filename; 136 char *filename;
149 asprintf (&filename, "%s/%s", confbase, cb()); 137 asprintf (&filename, "%s/%s", confbase, cb());
150 execl (filename, filename, (char *) 0); 138 execl (filename, filename, (char *) 0);
151 exit (255); 139 exit (126);
152 } 140 }
153 else if (pid > 0) 141 else if (pid > 0)
154 { 142 {
155 if (wait) 143 if (wait)
156 { 144 {
157 waitpid (pid, 0, 0); 145 waitpid (pid, 0, 0);
158 /* TODO: check status */ 146 /* TODO: check status */
159 } 147 }
160 } 148 }
161} 149}
150
151#if ENABLE_HTTP_PROXY
152// works like strdup
153u8 *
154base64_encode (const u8 *data, unsigned int len)
155{
156 const static char base64[65] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
157
158 unsigned int t, i;
159 const u8 *end = data + len;
160 u8 *res = new u8 [4 * ((len + 2) / 3) + 1];
161 u8 *out = res;
162
163 while (data <= end - 3)
164 {
165 t = (((data[0] << 8) | data[1]) << 8) | data[2];
166 data += 3;
167
168 *out++ = base64[(t >> 18) & 0x3f];
169 *out++ = base64[(t >> 12) & 0x3f];
170 *out++ = base64[(t >> 6) & 0x3f];
171 *out++ = base64[(t ) & 0x3f];
172 }
173
174 for (t = 0, i = 0; data < end; i++)
175 t = (t << 8) | *data++;
176
177 switch (i)
178 {
179 case 2:
180 *out++ = base64[(t >> 10) & 0x3f];
181 *out++ = base64[(t >> 4) & 0x3f];
182 *out++ = base64[(t << 2) & 0x3f];
183 *out++ = '=';
184 break;
185 case 1:
186 *out++ = base64[(t >> 2) & 0x3f];
187 *out++ = base64[(t << 4) & 0x3f];
188 *out++ = '=';
189 *out++ = '=';
190 break;
191 }
192
193 *out++ = 0;
194
195 return res;
196}
197#endif
198
199void
200id2mac (unsigned int id, void *m)
201{
202 mac &p = *(mac *)m;
203
204 if (id)
205 {
206 p[0] = 0xfe;
207 p[1] = 0xfd;
208 p[2] = 0x80;
209 p[3] = 0x00;
210 p[4] = id >> 8;
211 p[5] = id;
212 }
213 else
214 {
215 p[0] = 0xff;
216 p[1] = 0xff;
217 p[2] = 0xff;
218 p[3] = 0xff;
219 p[4] = 0xff;
220 p[5] = 0xff;
221 }
222}
223

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines