HCoop
/
hcoop
/
domtool2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Server executing client's requested configuration with the right permissions
[hcoop/domtool2.git]
/
src
/
plugins
/
exim.sml
diff --git
a/src/plugins/exim.sml
b/src/plugins/exim.sml
index
112ab5f
..
0744fce
100644
(file)
--- a/
src/plugins/exim.sml
+++ b/
src/plugins/exim.sml
@@
-20,12
+20,22
@@
structure Exim :> EXIM = struct
structure Exim :> EXIM = struct
+open Ast
+
+val dl = ErrorMsg.dummyLoc
+
+val _ = Defaults.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 aliasesChanged = ref false
val aliasesDefaultChanged = ref false
+val hostsChanged = ref false
val () = Slave.registerPreHandler
(fn () => (aliasesChanged := false;
val () = Slave.registerPreHandler
(fn () => (aliasesChanged := false;
- aliasesDefaultChanged := false))
+ aliasesDefaultChanged := false;
+ hostsChanged := false))
val () = Slave.registerFileHandler (fn fs =>
let
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
aliasesChanged := true
else if #file spl = "aliases.default" then
aliasesDefaultChanged := true
+ else if #file spl = "mail" then
+ hostsChanged := true
else
()
end)
else
()
end)
@@
-49,10
+61,26
@@
val () = Slave.registerPostHandler
Slave.concatTo (fn s => s = "aliases.default") Config.Exim.aliasesDefault
else
();
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
()))
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
end