X-Git-Url: https://git.hcoop.net/hcoop/domtool2.git/blobdiff_plain/3ae703b6dff72066727eb5087151c4be8d439ed3..fec6c9c4b9c4cccad963d6c918a83bb522fca969:/src/domain.sml diff --git a/src/domain.sml b/src/domain.sml index 700fac1..82367ce 100644 --- a/src/domain.sml +++ b/src/domain.sml @@ -27,6 +27,7 @@ structure SS = DataStructures.StringSet val ssl_context = ref (NONE : OpenSSL.context option) fun set_context ctx = ssl_context := SOME ctx +fun get_context () = valOf (!ssl_context) val nodes = map #1 Config.nodeIps val nodeMap = foldl (fn ((node, ip), mp) => SM.insert (mp, node, ip)) @@ -235,6 +236,10 @@ val _ = Env.type_one "node" Env.string validNode +val _ = Env.type_one "mime_type" + Env.string + (CharVector.exists (fn ch => ch = #"/")) + val _ = Env.registerFunction ("your_ip_to_ip", fn [e] => SOME e | _ => NONE) @@ -277,7 +282,8 @@ val masterD = (EApp ((EVar "internalMaster", dl), (EString Config.masterNode, dl)), dl) -val slavesD = (EList (map (fn s => (EString s, dl)) Config.slaveNodes), dl) +val slavesD = (EList (map (fn s => (EString s, dl)) + (List.filter (fn x => List.exists (fn y => y = x) (Config.dnsNodes_all @ Config.dnsNodes_admin)) Config.slaveNodes)), dl) val _ = Defaults.registerDefault ("Aliases", (TList (TBase "your_domain", dl), dl), @@ -989,4 +995,15 @@ val () = Env.registerAction ("domainHost", (EString (host ^ "." ^ currentDomain ()), dl)) | (_, args) => Env.badArgs ("domainHost", args)) +val ouc = ref (fn () => ()) + +fun registerOnUsersChange f = + let + val f' = !ouc + in + ouc := (fn () => (f' (); f ())) + end + +fun onUsersChange () = !ouc () + end