]>
Commit | Line | Data |
---|---|---|
d56fc335 MT |
1 | /* This file is part of the IPFire Firewall. |
2 | * | |
3 | * This program is distributed under the terms of the GNU General Public | |
4 | * Licence. See the file COPYING for details. | |
5 | * | |
6 | */ | |
7 | ||
8 | #include <stdlib.h> | |
9 | #include <stdio.h> | |
10 | #include <string.h> | |
11 | #include <unistd.h> | |
12 | #include <sys/types.h> | |
13 | #include <fcntl.h> | |
14 | #include "setuid.h" | |
15 | ||
16 | int main(int argc, char *argv[]) { | |
17 | ||
18 | if (!(initsetuid())) | |
19 | exit(1); | |
20 | ||
21 | if (argc < 2) { | |
22 | fprintf(stderr, "\nNo argument given.\n\nsquidctrl (start|stop|restart|flush)\n\n"); | |
23 | exit(1); | |
24 | } | |
25 | ||
26 | if (strcmp(argv[1], "start") == 0) { | |
27 | safe_system("/etc/rc.d/init.d/squid start"); | |
28 | } else if (strcmp(argv[1], "stop") == 0) { | |
29 | safe_system("/etc/rc.d/init.d/squid stop"); | |
30 | } else if (strcmp(argv[1], "restart") == 0) { | |
31 | safe_system("/etc/rc.d/init.d/squid restart"); | |
32 | } else if (strcmp(argv[1], "flush") == 0) { | |
33 | safe_system("/etc/rc.d/init.d/squid flush"); | |
34 | } else if (strcmp(argv[1], "enable") == 0) { | |
35 | safe_system("ln -fs ../init.d/squid /etc/rc.d/rc3.d/S99squid >/dev/null 2>&1"); | |
0d909a4a MT |
36 | safe_system("ln -fs ../init.d/squid /etc/rc.d/rc0.d/K00squid >/dev/null 2>&1"); |
37 | safe_system("ln -fs ../init.d/squid /etc/rc.d/rc6.d/K00squid >/dev/null 2>&1"); | |
d56fc335 MT |
38 | } else if (strcmp(argv[1], "disable") == 0) { |
39 | safe_system("rm -f /etc/rc.d/rc*.d/*squid >/dev/null 2>&1"); | |
40 | } else { | |
3ef6c343 | 41 | fprintf(stderr, "\nBad argument given.\n\nsquidctrl (start|stop|restart|flush)\n\n"); |
d56fc335 MT |
42 | exit(1); |
43 | } | |
44 | ||
45 | return 0; | |
46 | } |