X-Git-Url: https://git.hcoop.net/hcoop/domtool2.git/blobdiff_plain/8df2e702cf3e5ed9b8433585b357bbcd9f0d623e..19f3c4e664808d8dafabd9674635d9069bafd7cb:/src/plugins/exim.sml diff --git a/src/plugins/exim.sml b/src/plugins/exim.sml index 112ab5f..20e27dd 100644 --- a/src/plugins/exim.sml +++ b/src/plugins/exim.sml @@ -20,12 +20,22 @@ structure Exim :> EXIM = struct +open Ast + +val dl = ErrorMsg.dummyLoc + +val _ = Main.registerDefault ("MailNodes", + (TList (TBase "node", dl), dl), + (fn () => (EList (map (fn s => (EString s, dl)) Config.Exim.aliasTo), dl))) + val aliasesChanged = ref false val aliasesDefaultChanged = ref false +val hostsChanged = ref false val () = Slave.registerPreHandler (fn () => (aliasesChanged := false; - aliasesDefaultChanged := false)) + aliasesDefaultChanged := false; + hostsChanged := false)) val () = Slave.registerFileHandler (fn fs => let @@ -35,6 +45,8 @@ val () = Slave.registerFileHandler (fn fs => aliasesChanged := true else if #file spl = "aliases.default" then aliasesDefaultChanged := true + else if #file spl = "mail" then + hostsChanged := true else () end) @@ -49,10 +61,26 @@ val () = Slave.registerPostHandler Slave.concatTo (fn s => s = "aliases.default") Config.Exim.aliasesDefault else (); - if !aliasesChanged orelse !aliasesDefaultChanged then + if !hostsChanged then + Slave.enumerateTo (fn s => s = "mail") ":" Config.Exim.handleDomains + else + (); + if !aliasesChanged orelse !aliasesDefaultChanged + orelse !hostsChanged then Slave.shellF ([Config.Exim.reload], fn cl => "Error reloading exim with " ^ cl) else ())) + +val () = Env.actionV_none "handleMail" + (fn env => + let + val nodes = Env.env (Env.list Env.string) (env, "MailNodes") + in + app (fn node => TextIO.closeOut + (Domain.domainFile {node = node, + name = "mail"})) nodes + end) + end