]> git.ipfire.org Git - people/pmueller/ipfire-2.x.git/blob - src/misc-progs/sambactrl.c
Die beiden Control Dateien angepasst
[people/pmueller/ipfire-2.x.git] / src / misc-progs / sambactrl.c
1 #include <stdio.h>
2 #include <string.h>
3 #include <stdlib.h>
4 #include <unistd.h>
5 #include <sys/types.h>
6 #include <fcntl.h>
7 #include "setuid.h"
8
9 #define BUFFER_SIZE 1024
10
11 char command[BUFFER_SIZE];
12
13 int main(int argc, char *argv[])
14 {
15
16 if (!(initsetuid()))
17 exit(1);
18
19 // Check what command is asked
20 if (argc==1)
21 {
22 fprintf (stderr, "Missing smbctrl command!\n");
23 return 1;
24 }
25
26 if (strcmp(argv[1], "smbuserdisable")==0)
27 {
28 snprintf(command, BUFFER_SIZE-1, "/usr/bin/smbpasswd -d %s >/dev/null", argv[2]);
29 safe_system(command);
30 return 0;
31 }
32
33 if (strcmp(argv[1], "smbuserenable")==0)
34 {
35 snprintf(command, BUFFER_SIZE-1, "/usr/bin/smbpasswd -e %s >/dev/null", argv[2]);
36 safe_system(command);
37 return 0;
38 }
39
40 if (strcmp(argv[1], "smbuserdelete")==0)
41 {
42 snprintf(command, BUFFER_SIZE-1, "/usr/bin/smbpasswd -x %s >/dev/null", argv[2]);
43 safe_system(command);
44 snprintf(command, BUFFER_SIZE-1, "/usr/sbin/userdel %s >/dev/null", argv[2]);
45 safe_system(command);
46 return 0;
47 }
48
49 if (strcmp(argv[1], "smbsafeconf")==0)
50 {
51 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/shares > /var/ipfire/samba/smb.conf");
52 return 0;
53 }
54
55 if (strcmp(argv[1], "smbsafeconfcups")==0)
56 {
57 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/shares /var/ipfire/samba/printer > /var/ipfire/samba/smb.conf");
58 return 0;
59 }
60
61 if (strcmp(argv[1], "smbsafeconfpdc")==0)
62 {
63 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/pdc /var/ipfire/samba/shares > /var/ipfire/samba/smb.conf");
64 return 0;
65 }
66
67 if (strcmp(argv[1], "smbsafeconfpdccups")==0)
68 {
69 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/pdc /var/ipfire/samba/shares /var/ipfire/samba/printer > /var/ipfire/samba/smb.conf");
70 return 0;
71 }
72
73 if (strcmp(argv[1], "smbglobalreset")==0)
74 {
75 safe_system("/bin/cat /var/ipfire/samba/default.global /var/ipfire/samba/shares > /var/ipfire/samba/smb.conf");
76 safe_system("/bin/cat /var/ipfire/samba/default.settings > /var/ipfire/samba/settings");
77 safe_system("/bin/cat /var/ipfire/samba/default.global > /var/ipfire/samba/global");
78 safe_system("/bin/cat /var/ipfire/samba/default.pdc > /var/ipfire/samba/pdc");
79 return 0;
80 }
81
82 if (strcmp(argv[1], "smbsharesreset")==0)
83 {
84 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/default.shares > /var/ipfire/samba/smb.conf");
85 safe_system("/bin/cat /var/ipfire/samba/default.shares > /var/ipfire/samba/shares");
86 return 0;
87 }
88
89 if (strcmp(argv[1], "smbprinterreset")==0)
90 {
91 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/shares /var/default.printer > /var/ipfire/samba/smb.conf");
92 safe_system("/bin/cat /var/ipfire/samba/default.printer > /var/ipfire/samba/printer");
93 return 0;
94 }
95
96 if (strcmp(argv[1], "smbstop")==0)
97 {
98 safe_system("/etc/rc.d/init.d/samba stop >/dev/null");
99 safe_system("rm -rf /etc/rc.d/rc*.d/*samba");
100 return 0;
101 }
102
103 if (strcmp(argv[1], "smbstart")==0)
104 {
105 safe_system("/etc/rc.d/init.d/samba start >/dev/null");
106 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc3.d/S45samba");
107 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc0.d/K48samba");
108 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc6.d/K48samba");
109 return 0;
110 }
111
112 if (strcmp(argv[1], "smbrestart")==0)
113 {
114 safe_system("/etc/rc.d/init.d/samba restart >/dev/null");
115 return 0;
116 }
117
118 if (strcmp(argv[1], "smbreload")==0)
119 {
120 safe_system("/etc/rc.d/init.d/samba reload >/dev/null");
121 return 0;
122 }
123
124 if (strcmp(argv[1], "smbstatus")==0)
125 {
126 snprintf(command, BUFFER_SIZE-1, "/usr/bin/smbstatus 2>/dev/null");
127 safe_system(command);
128 return 0;
129 }
130
131 if (strcmp(argv[1], "smbuseradd")==0)
132 {
133 snprintf(command, BUFFER_SIZE-1, "/usr/sbin/groupadd sambauser >/dev/null");
134 safe_system(command);
135 snprintf(command, BUFFER_SIZE-1, "/usr/sbin/useradd -c 'Samba User' -m -g %s -s %s %s >/dev/null", argv[4], argv[5], argv[2]);
136 safe_system(command);
137 snprintf(command, BUFFER_SIZE-1, "echo %s:%s | chpasswd", argv[2], argv[3]);
138 safe_system(command);
139 snprintf(command, BUFFER_SIZE-1, "/usr/bin/printf '%s\n%s\n' | /usr/bin/smbpasswd -as %s >/dev/null", argv[3], argv[3], argv[2]);
140 safe_system(command);
141 return 0;
142 }
143
144 if (strcmp(argv[1], "smbpcadd")==0)
145 {
146 snprintf(command, BUFFER_SIZE-1, "/usr/sbin/groupadd sambawks >/dev/null");
147 safe_system(command);
148 snprintf(command, BUFFER_SIZE-1, "/usr/sbin/useradd -c 'Samba Workstation' -g %s -s %s %s >/dev/null", argv[3], argv[4], argv[2]);
149 safe_system(command);
150 snprintf(command, BUFFER_SIZE-1, "/usr/bin/smbpasswd -a -m %s >/dev/null", argv[2]);
151 safe_system(command);
152 return 0;
153 }
154
155 if (strcmp(argv[1], "smbchangepw")==0)
156 {
157 snprintf(command, BUFFER_SIZE-1, "echo %s:%s | chpasswd", argv[2], argv[3]);
158 safe_system(command);
159 snprintf(command, BUFFER_SIZE-1, "/usr/bin/printf '%s\n%s\n' | /usr/bin/smbpasswd -as %s >/dev/null", argv[3], argv[3], argv[2]);
160 safe_system(command);
161 return 0;
162 }
163
164 if (strcmp(argv[1], "readsmbpasswd")==0)
165 {
166 safe_system("/bin/chown root:nobody /var/ipfire/samba/private >/dev/null");
167 safe_system("/bin/chown root:nobody /var/ipfire/samba/private/smbpasswd >/dev/null");
168 safe_system("/bin/chmod 640 /var/ipfire/samba/private/smbpasswd >/dev/null");
169 safe_system("/bin/chmod 650 /var/ipfire/samba/private >/dev/null");
170 return 0;
171 }
172
173 if (strcmp(argv[1], "locksmbpasswd")==0)
174 {
175 safe_system("/bin/chown root:root /var/ipfire/samba/private >/dev/null");
176 safe_system("/bin/chown root:root /var/ipfire/samba/private/smbpasswd >/dev/null");
177 safe_system("/bin/chmod 600 /var/ipfire/samba/private/smbpasswd >/dev/null");
178 safe_system("/bin/chmod 600 /var/ipfire/samba/private >/dev/null");
179 return 0;
180 }
181 if (strcmp(argv[1], "enable")==0)
182 {
183 safe_system("touch /var/ipfire/samba/enable");
184 safe_system("/etc/rc.d/init.d/samba start");
185 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc3.d/S45samba");
186 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc0.d/K48samba");
187 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc6.d/K48samba");
188 return 0;
189 }
190
191 if (strcmp(argv[1], "disable")==0)
192 {
193 safe_system("unlink /var/ipfire/samba/enable");
194 safe_system("/etc/rc.d/init.d/samba stop");
195 safe_system("rm -rf /etc/rc.d/rc*.d/*samba");
196 return 0;
197 }
198 return 0;
199 }