]>
git.ipfire.org Git - ipfire-2.x.git/blob - src/misc-progs/sambactrl.c
9 #define BUFFER_SIZE 1024
11 char command
[BUFFER_SIZE
];
13 int main(int argc
, char *argv
[]) {
17 // Check what command is asked
19 fprintf (stderr
, "Missing smbctrl command!\n");
22 } else if (strcmp(argv
[1], "smbuserdisable") == 0) {
23 snprintf(command
, BUFFER_SIZE
-1, "/usr/bin/smbpasswd -d %s >/dev/null", argv
[2]);
26 } else if (strcmp(argv
[1], "smbuserenable") == 0) {
27 snprintf(command
, BUFFER_SIZE
-1, "/usr/bin/smbpasswd -e %s >/dev/null", argv
[2]);
30 } else if (strcmp(argv
[1], "smbuserdelete") == 0) {
31 snprintf(command
, BUFFER_SIZE
-1, "/usr/bin/smbpasswd -x %s >/dev/null", argv
[2]);
34 snprintf(command
, BUFFER_SIZE
-1, "/usr/sbin/userdel %s >/dev/null", argv
[2]);
37 } else if (strcmp(argv
[1], "smbsafeconf") == 0) {
38 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/shares > /var/ipfire/samba/smb.conf");
40 } else if (strcmp(argv
[1], "smbsafeconfpdc") == 0) {
41 safe_system("/bin/cat /var/ipfire/samba/global /var/ipfire/samba/pdc /var/ipfire/samba/shares > /var/ipfire/samba/smb.conf");
43 } else if (strcmp(argv
[1], "smbstop") == 0) {
44 safe_system("/etc/rc.d/init.d/samba stop >/dev/null");
45 safe_system("/usr/local/bin/sambactrl disable");
47 } else if (strcmp(argv
[1], "smbstart") == 0) {
48 safe_system("/etc/rc.d/init.d/samba start >/dev/null");
49 safe_system("/usr/local/bin/sambactrl enable");
51 } else if (strcmp(argv
[1], "smbrestart") == 0) {
52 safe_system("/etc/rc.d/init.d/samba restart >/dev/null");
54 } else if (strcmp(argv
[1], "smbreload") == 0) {
55 safe_system("/etc/rc.d/init.d/samba reload >/dev/null");
57 } else if (strcmp(argv
[1], "smbstatus") == 0) {
58 snprintf(command
, BUFFER_SIZE
-1, "/usr/bin/smbstatus 2>/dev/null");
61 } else if (strcmp(argv
[1], "smbuseradd") == 0) {
62 snprintf(command
, BUFFER_SIZE
-1, "/usr/sbin/groupadd sambauser >/dev/null");
65 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]);
68 snprintf(command
, BUFFER_SIZE
-1, "echo %s:%s | chpasswd", argv
[2], argv
[3]);
71 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]);
74 } else if (strcmp(argv
[1], "smbchangepw") == 0) {
75 snprintf(command
, BUFFER_SIZE
-1, "echo %s:%s | chpasswd", argv
[2], argv
[3]);
78 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]);
81 } else if (strcmp(argv
[1], "readsmbpasswd") == 0) {
82 safe_system("/bin/chown root:nobody /var/ipfire/samba/private >/dev/null");
83 safe_system("/bin/chown root:nobody /var/ipfire/samba/private/smbpasswd >/dev/null");
84 safe_system("/bin/chmod 640 /var/ipfire/samba/private/smbpasswd >/dev/null");
85 safe_system("/bin/chmod 650 /var/ipfire/samba/private >/dev/null");
87 } else if (strcmp(argv
[1], "locksmbpasswd") == 0) {
88 safe_system("/bin/chown root:root /var/ipfire/samba/private >/dev/null");
89 safe_system("/bin/chown root:root /var/ipfire/samba/private/smbpasswd >/dev/null");
90 safe_system("/bin/chmod 600 /var/ipfire/samba/private/smbpasswd >/dev/null");
91 safe_system("/bin/chmod 600 /var/ipfire/samba/private >/dev/null");
93 } else if (strcmp(argv
[1], "enable") == 0) {
94 safe_system("touch /var/ipfire/samba/enable");
95 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc3.d/S45samba");
96 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc0.d/K48samba");
97 safe_system("ln -snf /etc/rc.d/init.d/samba /etc/rc.d/rc6.d/K48samba");
99 } else if (strcmp(argv
[1], "disable") == 0) {
100 safe_system("unlink /var/ipfire/samba/enable");
101 safe_system("rm -rf /etc/rc.d/rc*.d/*samba");
103 } else if (strcmp(argv
[1], "join") == 0) {
105 snprintf(command
, BUFFER_SIZE
- 1, "/usr/bin/net join -U \"%s%%%s\"",
107 return safe_system(command
);
109 fprintf(stderr
, "Wrong number of arguments. Need username and password.\n");