* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*)
-(* Driver for server *)
+(* Driver for admin requests *)
+
+fun requestPerms user =
+ case Main.requestListPerms user of
+ NONE => ()
+ | SOME classes =>
+ (print ("Permissions for " ^ user ^ ":\n");
+ app (fn (class, values) =>
+ (print (class ^ ":");
+ app (fn value => print (" " ^ value)) values;
+ print "\n")) classes)
val _ =
case CommandLine.arguments () of
- ["grant", user, class, value] => Main.requestGrant {user = user, class = class, value = value}
+ ["shutdown"] => Main.requestShutdown ()
+ | ["grant", user, class, value] => Main.requestGrant {user = user, class = class, value = value}
+ | ["revoke", user, class, value] => Main.requestRevoke {user = user, class = class, value = value}
+ | ["perms", user] => requestPerms user
+ | ["perms"] => requestPerms (Posix.SysDB.Passwd.name (Posix.SysDB.getpwuid (Posix.ProcEnv.getuid ())))
+ | ["whohas", class, value] =>
+ (case Main.requestWhoHas {class = class, value = value} of
+ NONE => ()
+ | SOME users =>
+ (print ("whohas " ^ class ^ " / " ^ value ^ ":");
+ app (fn user => print (" " ^ user)) users;
+ print "\n"))
+ | "rmdom" :: doms => Main.requestRmdom doms
+ | ["regen"] => Main.requestRegen ()
+ | ["rmuser", user] => Main.requestRmuser user
+ | ["ping"] => OS.Process.exit (Main.requestPing ())
+ | ["slave-shutdown"] => Main.requestSlaveShutdown ()
+ | ["slave-ping"] => OS.Process.exit (Main.requestSlavePing ())
+ | ["package", node, pkg] => OS.Process.exit (Main.requestApt {node = node, pkg = pkg})
+ | ["cron", node, uname] => OS.Process.exit (Main.requestCron {node = node, uname = uname})
+ | ["ftp", node, uname] => OS.Process.exit (Main.requestFtp {node = node, uname = uname})
| _ => print "Invalid command-line arguments\n"