summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorShireesh Anjal <anjalshireesh@gmail.com>2011-08-05 01:57:57 -0700
committerShireesh Anjal <anjalshireesh@gmail.com>2011-08-05 01:57:57 -0700
commit879fd2f4d671136d20bb59f3a39890d283650c19 (patch)
tree19d25eda045b19927bd2c743b1b5cec132e4a794
parent3edece70f410569f31c3103375f55b75280da84f (diff)
parentff5573dab24e504247f16c28a41f17f94e731e55 (diff)
Merge pull request #195 from balamurugana/master
enhancement in add_user_cifs_all.py and add_user_cifs.py
-rwxr-xr-xsrc/com.gluster.storage.management.gateway.scripts/src/add_user_cifs.py39
-rwxr-xr-xsrc/com.gluster.storage.management.gateway.scripts/src/update_volume_cifs.py35
-rwxr-xr-xsrc/com.gluster.storage.management.gateway/WebContent/scripts/add_user_cifs_all.py31
-rwxr-xr-xsrc/com.gluster.storage.management.gateway/WebContent/scripts/get_volume_user_cifs.py2
-rwxr-xr-xsrc/com.gluster.storage.management.gateway/WebContent/scripts/update_volume_cifs_all.py60
5 files changed, 151 insertions, 16 deletions
diff --git a/src/com.gluster.storage.management.gateway.scripts/src/add_user_cifs.py b/src/com.gluster.storage.management.gateway.scripts/src/add_user_cifs.py
index 48888744..2bff2a06 100755
--- a/src/com.gluster.storage.management.gateway.scripts/src/add_user_cifs.py
+++ b/src/com.gluster.storage.management.gateway.scripts/src/add_user_cifs.py
@@ -11,6 +11,8 @@ if not p1 in sys.path:
sys.path.append(p1)
if not p2 in sys.path:
sys.path.append(p2)
+import grp
+import pwd
import Globals
import Utils
@@ -19,23 +21,38 @@ def main():
sys.stderr.write("usage: %s UID USERNAME PASSWORD\n" % os.path.basename(sys.argv[0]))
sys.exit(-1)
- uid = sys.argv[1]
+ try:
+ uid = int(sys.argv[1])
+ except ValueError, e:
+ sys.stderr.write("invalid uid %s\n" % sys.argv[1])
+ sys.exit(-2)
userName = sys.argv[2]
password = sys.argv[3]
- if Utils.runCommand("groupadd -g %s %s" % (uid, userName)) != 0:
- Utils.log("failed to add group gid:%s, name:%s\n" % (uid, userName))
- sys.exit(1)
-
- command = ["useradd", "-c", Globals.VOLUME_USER_DESCRIPTION, "-M", "-d", "/", "-s", "/sbin/nologin", "-u", uid, "-g", uid, userName]
- if Utils.runCommand(command) != 0:
- Utils.log("failed to add user uid:%s, name:%s\n" % (uid, userName))
- sys.exit(2)
+ try:
+ groupInfo = grp.getgrnam(userName)
+ if uid != groupInfo.gr_gid:
+ Utils.log("group %s exists with different gid %s\n" % (userName, groupInfo.gr_gid))
+ sys.exit(1)
+ except KeyError, e:
+ if Utils.runCommand("groupadd -g %s %s" % (uid, userName)) != 0:
+ Utils.log("failed to add group %s gid %s\n" % (username, uid))
+ sys.exit(2)
+ try:
+ userInfo = pwd.getpwnam(userName)
+ if uid != userInfo.pw_uid:
+ Utils.log("user %s exists with different uid %s\n" % (userName, userInfo.pw_uid))
+ sys.exit(3)
+ except KeyError, e:
+ command = ["useradd", "-c", Globals.VOLUME_USER_DESCRIPTION, "-M", "-d", "/", "-s", "/sbin/nologin", "-u", str(uid), "-g", str(uid), userName]
+ if Utils.runCommand(command) != 0:
+ Utils.log("failed to add user %s uid %s\n" % (userName, uid))
+ sys.exit(4)
if Utils.runCommand("smbpasswd -s -a %s" % userName,
input="%s\n%s\n" % (password, password)) != 0:
- Utils.log("failed to set smbpassword of user uid:%s, name:%s\n" % (uid, userName))
- sys.exit(3)
+ Utils.log("failed to set smbpassword of user %s\n" % userName)
+ sys.exit(5)
sys.exit(0)
diff --git a/src/com.gluster.storage.management.gateway.scripts/src/update_volume_cifs.py b/src/com.gluster.storage.management.gateway.scripts/src/update_volume_cifs.py
new file mode 100755
index 00000000..d1d0f85f
--- /dev/null
+++ b/src/com.gluster.storage.management.gateway.scripts/src/update_volume_cifs.py
@@ -0,0 +1,35 @@
+#!/usr/bin/python
+# Copyright (C) 2011 Gluster, Inc. <http://www.gluster.com>
+# This file is part of Gluster Management Gateway.
+#
+
+import os
+import sys
+p1 = os.path.abspath(os.path.dirname(sys.argv[0]))
+p2 = "%s/common" % os.path.dirname(p1)
+if not p1 in sys.path:
+ sys.path.append(p1)
+if not p2 in sys.path:
+ sys.path.append(p2)
+import Globals
+import Utils
+import VolumeUtils
+
+def main():
+ if len(sys.argv) < 3:
+ sys.stderr.write("usage: %s VOLUME_NAME USER1 USER2 ...\n" % os.path.basename(sys.argv[0]))
+ sys.exit(-1)
+
+ volumeName = sys.argv[1]
+ userList = sys.argv[2:]
+
+ if not VolumeUtils.writeVolumeCifsConfiguration(volumeName, userList):
+ sys.exit(1)
+ if Utils.runCommand("service smb reload") != 0:
+ Utils.log("Failed to reload smb service")
+ sys.exit(2)
+ sys.exit(0)
+
+
+if __name__ == "__main__":
+ main()
diff --git a/src/com.gluster.storage.management.gateway/WebContent/scripts/add_user_cifs_all.py b/src/com.gluster.storage.management.gateway/WebContent/scripts/add_user_cifs_all.py
index 02855cd7..f1e899ec 100755
--- a/src/com.gluster.storage.management.gateway/WebContent/scripts/add_user_cifs_all.py
+++ b/src/com.gluster.storage.management.gateway/WebContent/scripts/add_user_cifs_all.py
@@ -18,6 +18,22 @@ defaultUid = 1024000
cifsUserFile = "/opt/glustermg/etc/users.cifs"
+def getUid(userName):
+ try:
+ fp = open(cifsUserFile)
+ content = fp.read()
+ fp.close()
+ except IOError, e:
+ Utils.log("failed to read file %s: %s" % (cifsUserFile, str(e)))
+ return False
+
+ for line in content.strip().split():
+ tokens = line.split(":")
+ if tokens[1] == UserName:
+ return int(tokens[0])
+ return None
+
+
def getLastUid():
if not os.path.exists(cifsUserFile):
return defaultUid
@@ -55,13 +71,20 @@ def main():
userName = sys.argv[2]
password = sys.argv[3]
- uid = getLastUid()
+ existingUser = False
+ uid = getUid(userName)
if not uid:
- sys.exit(10)
-
- uid += 1
+ uid = getLastUid()
+ if not uid:
+ sys.exit(10)
+ uid += 1
+ else:
+ existingUser = True
rv = Utils.runCommand("grun.py %s add_user_cifs.py %s %s %s" % (serverFile, uid, userName, password))
+ if existingUser:
+ sys.exit(rv)
+
if rv == 0:
if not setUid(uid, userName):
sys.exit(11)
diff --git a/src/com.gluster.storage.management.gateway/WebContent/scripts/get_volume_user_cifs.py b/src/com.gluster.storage.management.gateway/WebContent/scripts/get_volume_user_cifs.py
index 0593257b..76f8c318 100755
--- a/src/com.gluster.storage.management.gateway/WebContent/scripts/get_volume_user_cifs.py
+++ b/src/com.gluster.storage.management.gateway/WebContent/scripts/get_volume_user_cifs.py
@@ -22,7 +22,7 @@ def main():
sys.stderr.write("usage: %s VOLUME_NAME\n" % os.path.basename(sys.argv[0]))
sys.exit(-1)
- volumeName = sys.argv[2]
+ volumeName = sys.argv[1]
try:
fp = open(cifsVolumeFile)
diff --git a/src/com.gluster.storage.management.gateway/WebContent/scripts/update_volume_cifs_all.py b/src/com.gluster.storage.management.gateway/WebContent/scripts/update_volume_cifs_all.py
new file mode 100755
index 00000000..a4d424b3
--- /dev/null
+++ b/src/com.gluster.storage.management.gateway/WebContent/scripts/update_volume_cifs_all.py
@@ -0,0 +1,60 @@
+#!/usr/bin/python
+# Copyright (C) 2011 Gluster, Inc. <http://www.gluster.com>
+# This file is part of Gluster Management Gateway.
+#
+
+import os
+import sys
+p1 = os.path.abspath(os.path.dirname(sys.argv[0]))
+p2 = "%s/common" % os.path.dirname(p1)
+if not p1 in sys.path:
+ sys.path.append(p1)
+if not p2 in sys.path:
+ sys.path.append(p2)
+import Utils
+
+
+cifsVolumeFile = "/opt/glustermg/etc/volumes.cifs"
+
+
+def updateVolumeCifsConf(volumeName, userList):
+ try:
+ fp = open(cifsVolumeFile)
+ content = fp.read()
+ fp.close()
+ except IOError, e:
+ Utils.log("failed to read file %s: %s" % (cifsVolumeFile, str(e)))
+ return False
+
+ try:
+ fp = open(cifsVolumeFile, "w")
+ for line in content.split():
+ if line.split(":")[0] == volumeName:
+ fp.write("%s:%s\n" % (volumeName, ":".join(userList)))
+ else:
+ fp.write("%s\n" % line)
+ fp.close()
+ except IOError, e:
+ Utils.log("failed to write file %s: %s" % (cifsVolumeFile, str(e)))
+ return False
+ return True
+
+
+def main():
+ if len(sys.argv) < 4:
+ sys.stderr.write("usage: %s SERVER_FILE VOLUME_NAME USER1 USER2 ...\n" % os.path.basename(sys.argv[0]))
+ sys.exit(-1)
+
+ serverFile = sys.argv[1]
+ volumeName = sys.argv[2]
+ userList = sys.argv[3:]
+
+ rv = Utils.runCommand(["grun.py", serverFile, "update_volume_cifs.py", volumeName] + userList)
+ if rv == 0:
+ if not updateVolumeCifsConf(volumeName, userList):
+ sys.exit(11)
+ sys.exit(rv)
+
+
+if __name__ == "__main__":
+ main()