@include "json.awk"
# Save email addresses
-BEGIN { json_load("var/mail.txt", mail_enable) }
-END { json_save("var/mail.txt", mail_enable) }
+END {
+ json_save("var/mail.json", mail_enable)
+}
-# Email notifications
BEGIN {
- mail_hist = 60 # Send 60 seconds of backlog
- mail_delay = 60 # Wait 60 seconds after last mention before mailing
-
- mail_from = NICK "<andy753421@gmail.com>"
- mail_err = "If you received this message in error,\n" \
- "someone in #rhnoise is being a jerk"
+ json_load("var/mail.json", mail_enable)
+ for (_user in mail_enable)
+ debug("watching " mail_enable[_user] " for " _user)
+}
- for (_user in mail_enable)
+TO == NICK && /^sync/ {
+ json_load("var/mail.json", mail_enable)
+ for (_user in mail_enable)
debug("watching " mail_enable[_user] " for " _user)
}
+# Email notifications
+BEGIN {
+ mail_hist = 5*60 # If the users has not spoken withn mail_before before
+ mail_before = 5*60 # someone mentions their name and does not reply within
+ mail_after = 5*60 # mail_after seconds, email them hist seconds of the backlog
+
+ mail_from = NICK "<andy753421@gmail.com>"
+ mail_err = "If you received this message in error,\n" \
+ "someone in #rhnoise is being a jerk"
+}
+
function mail_send(addr, subj, body,
sendmail, errmsg)
{
for (si = 1; si <= sn; si++) {
sec = ss[si]
mn = length(mail_log[chan][sec])
- for (mi = 0; mi < mn; mi++) {
+ for (mi = 0; mi < mn; mi++) {
msg = mail_log[chan][sec][mi]
if (sec > mail_ready[user][chan] - mail_hist) {
if (msg ~ user)
}
}
}
- privmsg(chan, "notifying " user " at " addr)
+ say(chan, "notifying " user " at " addr)
mail_send(addr, "Message for " user " in " chan, body)
delete mail_ready[user][chan]
}
for (chan in mail_ready[user]) {
ready = mail_ready[user][chan]
delay = systime() - ready
- if (ready && delay > mail_delay)
+ if (ready && delay > mail_after)
mail_prep(user, chan)
}
}
reply("well fine then")
delete mail_enable[$2]
delete mail_ready[$2]
+ delete mail_seen[$2]
}
TO == NICK &&
reply("well fine then")
delete mail_enable[FROM]
delete mail_ready[FROM]
+ delete mail_seen[FROM]
}
TO == NICK &&
}
DST ~ /^#.*/ {
- for (_user in mail_enable)
- if ($0 ~ "\\<"_user"\\>") {
+ for (_user in mail_enable) {
+ _idle = systime() - mail_seen[_user]
+ if ($0 ~ "\\<"_user"\\>" && _idle > mail_before) {
mail_ready[_user][DST] = systime()
debug("queueing messages to " DST " for " _user)
}
+ }
}
FROM in mail_enable {
delete mail_ready[FROM]
+ mail_seen[FROM] = systime()
debug("clearing message for " FROM)
}