X-Git-Url: https://git.hcoop.net/hcoop/domtool2.git/blobdiff_plain/08a04eb413e8ee58ee35affc5c4125b622ea75c4..71ba8736cf965c9766aeb53810179e789e863846:/src/acl.sml diff --git a/src/acl.sml b/src/acl.sml index 0adfb4b..be30fdf 100644 --- a/src/acl.sml +++ b/src/acl.sml @@ -44,6 +44,18 @@ fun queryAll user = (class, SS.foldr (op::) [] values) :: out) [] classes +fun users () = SM.foldri (fn (user, _, ls) => user :: ls) [] (!acl) + +fun whoHas {class, value} = + SM.foldri (fn (user, classes, users) => + case SM.find (classes, class) of + NONE => users + | SOME values => + if SS.member (values, value) then + user :: users + else + users) [] (!acl) + fun class {user, class} = case SM.find (!acl, user) of NONE => SS.empty @@ -115,15 +127,21 @@ fun write fname = TextIO.output (outf, value))) val writeClasses = SM.appi (fn (class, values) => - (TextIO.output (outf, class); - writeValues values; - TextIO.output (outf, "\n"))) + if SS.isEmpty values then + () + else + (TextIO.output (outf, class); + writeValues values; + TextIO.output (outf, "\n"))) val writeUsers = SM.appi (fn (user, classes) => - (TextIO.output (outf, user); - TextIO.output (outf, "\n"); - writeClasses classes; - TextIO.output (outf, "\n"))) + if SM.numItems classes = 0 then + () + else + (TextIO.output (outf, user); + TextIO.output (outf, "\n"); + writeClasses classes; + TextIO.output (outf, "\n"))) in writeUsers (!acl); TextIO.closeOut outf