]> www.infradead.org Git - users/dhowells/kafs-utils.git/commitdiff
Implement "bos {adduser,removeuser}"
authorDavid Howells <dhowells@redhat.com>
Sun, 13 Apr 2014 11:46:16 +0000 (12:46 +0100)
committerDavid Howells <dhowells@redhat.com>
Sun, 13 Apr 2014 11:46:16 +0000 (12:46 +0100)
Signed-off-by: David Howells <dhowells@redhat.com>
suite/commands/bos/adduser.py [new file with mode: 0644]
suite/commands/bos/removeuser.py [new file with mode: 0644]

diff --git a/suite/commands/bos/adduser.py b/suite/commands/bos/adduser.py
new file mode 100644 (file)
index 0000000..907db17
--- /dev/null
@@ -0,0 +1,63 @@
+#
+# AFS Server management toolkit: Add a super user
+# -*- coding: utf-8 -*-
+#
+
+__copyright__ = """
+Copyright (C) 2014 Red Hat, Inc. All Rights Reserved.
+Written by David Howells (dhowells@redhat.com)
+
+This program is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public Licence version 2 as
+published by the Free Software Foundation.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+GNU General Public Licence for more details.
+
+You should have received a copy of the GNU General Public Licence
+along with this program; if not, write to the Free Software
+Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+"""
+
+from afs.argparse import *
+import kafs
+import sys
+
+help = "Add a privileged user to the UserList file"
+
+command_arguments = [
+    [ "server",         get_bosserver,          "rs",         "<machine name>" ],
+    [ "user",           get_strings,            "rm",         "<user name>+" ],
+    [ "cell",           get_cell,               "os",         "<cell name>" ],
+    [ "noauth",         get_auth,               "fn" ],
+    [ "localauth",      get_auth,               "fn" ],
+    [ "verbose",        get_dummy,              "fn" ],
+    [ "encrypt",        get_dummy,              "fn" ],
+]
+
+cant_combine_arguments = [
+    ( "cell",           "localauth" ),
+    ( "noauth",         "localauth" ),
+]
+
+description = r"""
+Add a privileged user to the UserList file
+"""
+
+def main(params):
+    exitcode = 0
+    cell = params["cell"]
+    bos_conn = cell.open_bos_server(params["server"], params)
+
+    for i in params["user"]:
+        try:
+            ret = kafs.BOZO_AddSUser(bos_conn, i)
+        except kafs.RemoteAbort as e:
+            if str(e) == "Aborted 17":
+                print("bos: failed to add user", i, "(File exists)", file=sys.stderr)
+                exitcode = 1
+            else:
+                raise
+    return exitcode
diff --git a/suite/commands/bos/removeuser.py b/suite/commands/bos/removeuser.py
new file mode 100644 (file)
index 0000000..1b2612d
--- /dev/null
@@ -0,0 +1,63 @@
+#
+# AFS Server management toolkit: Remove a super user
+# -*- coding: utf-8 -*-
+#
+
+__copyright__ = """
+Copyright (C) 2014 Red Hat, Inc. All Rights Reserved.
+Written by David Howells (dhowells@redhat.com)
+
+This program is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public Licence version 2 as
+published by the Free Software Foundation.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+GNU General Public Licence for more details.
+
+You should have received a copy of the GNU General Public Licence
+along with this program; if not, write to the Free Software
+Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+"""
+
+from afs.argparse import *
+import kafs
+import sys
+
+help = "Remove a privileged user from the UserList file"
+
+command_arguments = [
+    [ "server",         get_bosserver,          "rs",         "<machine name>" ],
+    [ "user",           get_strings,            "rm",         "<user name>+" ],
+    [ "cell",           get_cell,               "os",         "<cell name>" ],
+    [ "noauth",         get_auth,               "fn" ],
+    [ "localauth",      get_auth,               "fn" ],
+    [ "verbose",        get_dummy,              "fn" ],
+    [ "encrypt",        get_dummy,              "fn" ],
+]
+
+cant_combine_arguments = [
+    ( "cell",           "localauth" ),
+    ( "noauth",         "localauth" ),
+]
+
+description = r"""
+Remove a privileged user from the UserList file
+"""
+
+def main(params):
+    exitcode = 0
+    cell = params["cell"]
+    bos_conn = cell.open_bos_server(params["server"], params)
+
+    for i in params["user"]:
+        try:
+            ret = kafs.BOZO_DeleteSUser(bos_conn, i)
+        except kafs.RemoteAbort as e:
+            if str(e) == "Aborted 2":
+                print("bos: failed to delete user", i, "(no such user)", file=sys.stderr)
+                exitcode = 1
+            else:
+                raise
+    return exitcode