]> git.ipfire.org Git - ipfire-2.x.git/blob - src/misc-progs/sambactrl.c
Samba-Update von Maniac...
[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", argv[2]);
29 safe_system(command);
30 printf(command);
31 return 0;
32 }
33
34 if (strcmp(argv[1], "smbuserenable")==0)
35 {
36 snprintf(command, BUFFER_SIZE-1, "/usr/bin/smbpasswd -e %s", argv[2]);
37 safe_system(command);
38 printf(command);
39 return 0;
40 }
41
42 if (strcmp(argv[1], "smbuserdelete")==0)
43 {
44 snprintf(command, BUFFER_SIZE-1, "/usr/bin/smbpasswd -x %s", argv[2]);
45 safe_system(command);
46 printf(command);
47 snprintf(command, BUFFER_SIZE-1, "/usr/sbin/userdel %s", argv[2]);
48 safe_system(command);
49 printf(command);
50 return 0;
51 }
52
53 if (strcmp(argv[1], "smbsafeconf")==0)
54 {
55 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/shares > /var/ipfire/samba/smb.conf");
56 return 0;
57 }
58
59 if (strcmp(argv[1], "smbglobalreset")==0)
60 {
61 safe_system("/bin/cat /var/ipfire/samba/default.global /var/ipfire/samba/shares > /var/ipfire/samba/smb.conf");
62 safe_system("/bin/cat /var/ipfire/samba/default.settings > /var/ipfire/samba/settings");
63 return 0;
64 }
65
66 if (strcmp(argv[1], "smbsharesreset")==0)
67 {
68 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/default.shares > /var/ipfire/samba/smb.conf");
69 safe_system("/bin/cat /var/ipfire/samba/default.shares > /var/ipfire/samba/shares");
70 return 0;
71 }
72
73 if (strcmp(argv[1], "smbrestart")==0)
74 {
75 return 0;
76 }
77
78 if (strcmp(argv[1], "smbstop")==0)
79 {
80 return 0;
81 }
82
83 if (strcmp(argv[1], "smbstart")==0)
84 {
85 return 0;
86 }
87
88 if (strcmp(argv[1], "smbuseradd")==0)
89 {
90 snprintf(command, BUFFER_SIZE-1, "/usr/sbin/useradd -c 'Samba User' -d /opt/samba -g 2110 -p %s -s /bin/false %s", argv[3], argv[2]);
91 safe_system(command);
92 printf(command);
93 snprintf(command, BUFFER_SIZE-1, "/usr/bin/printf '%s\n%s\n' | /usr/bin/smbpasswd -as %s", argv[3], argv[3], argv[2]);
94 safe_system(command);
95 printf(command);
96 return 0;
97 }
98
99 if (strcmp(argv[1], "smbchangepw")==0)
100 {
101 snprintf(command, BUFFER_SIZE-1, "/usr/bin/printf '%s\n%s\n' | /usr/bin/smbpasswd -as %s", argv[3], argv[3], argv[2]);
102 safe_system(command);
103 printf(command);
104 return 0;
105 }
106
107 if (strcmp(argv[1], "readsmbpasswd")==0)
108 {
109 safe_system("/bin/chown root:nobody /var/ipfire/samba/private");
110 safe_system("/bin/chown root:nobody /var/ipfire/samba/private/smbpasswd");
111 safe_system("/bin/chmod 640 /var/ipfire/samba/private/smbpasswd");
112 safe_system("/bin/chmod 650 /var/ipfire/samba/private");
113 return 0;
114 }
115
116 if (strcmp(argv[1], "locksmbpasswd")==0)
117 {
118 safe_system("/bin/chown root:root /var/ipfire/samba/private");
119 safe_system("/bin/chown root:root /var/ipfire/samba/private/smbpasswd");
120 safe_system("/bin/chmod 600 /var/ipfire/samba/private/smbpasswd");
121 safe_system("/bin/chmod 600 /var/ipfire/samba/private");
122 return 0;
123 }
124
125 if (strcmp(argv[1], "smbechotest")==0)
126 {
127 sprintf(command, BUFFER_SIZE-1, "/usr/bin/printf %s %s", argv[2], argv[3]);
128 printf(command);
129 safe_system(command);
130 return 0;
131 }
132 }