X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/558622c1ec8aa12355ef4fdf9963d86ad58c645f..013654cd1af4bb69f31c1c641cdb24bd8b7c58df:/widget/imap.lua
diff --git a/widget/imap.lua b/widget/imap.lua
index 7e83d36..b3d9dc7 100644
--- a/widget/imap.lua
+++ b/widget/imap.lua
@@ -17,63 +17,75 @@ local tonumber = tonumber
-- lain.widget.imap
local function factory(args)
- local imap = { widget = wibox.widget.textbox() }
- local args = args or {}
- local server = args.server
- local mail = args.mail
- local password = args.password
- local port = args.port or 993
- local timeout = args.timeout or 60
- local is_plain = args.is_plain or false
- local followtag = args.followtag or false
- local notify = args.notify or "on"
- local settings = args.settings or function() end
+ local imap = { widget = wibox.widget.textbox() }
+ local args = args or {}
+ local server = args.server
+ local mail = args.mail
+ local password = args.password
+ local port = args.port or 993
+ local timeout = args.timeout or 60
+ local pwdtimeout = args.pwdtimeout or 10
+ local is_plain = args.is_plain or false
+ local followtag = args.followtag or false
+ local notify = args.notify or "on"
+ local settings = args.settings or function() end
local head_command = "curl --connect-timeout 3 -fsm 3"
- local request = "-X 'SEARCH (UNSEEN)'"
+ local request = "-X 'STATUS INBOX (MESSAGES RECENT UNSEEN)'"
if not server or not mail or not password then return end
+ mail_notification_preset = {
+ icon = helpers.icons_dir .. "mail.png",
+ position = "top_left"
+ }
+
helpers.set_map(mail, 0)
if not is_plain then
if type(password) == "string" or type(password) == "table" then
helpers.async(password, function(f) password = f:gsub("\n", "") end)
elseif type(password) == "function" then
- local p = password()
+ imap.pwdtimer = helpers.newtimer(mail .. "-password", pwdtimeout, function()
+ local retrieved_password, try_again = password()
+ if not try_again then
+ imap.pwdtimer:stop() -- stop trying to retrieve
+ password = retrieved_password or "" -- failsafe
+ end
+ end, true, true)
end
end
- function update()
- mail_notification_preset = {
- icon = helpers.icons_dir .. "mail.png",
- position = "top_left"
- }
-
- if followtag then
- mail_notification_preset.screen = awful.screen.focused()
- end
+ function imap.update()
+ -- do not update if the password has not been retrieved yet
+ if type(password) ~= "string" then return end
- local curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:%q %s -k",
+ local curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:'%s' %s -k",
head_command, server, port, mail, password, request)
helpers.async(curl, function(f)
- mailcount = tonumber(f:match("UNSEEN (%d+)"))
+ imap_now = { ["MESSAGES"] = 0, ["RECENT"] = 0, ["UNSEEN"] = 0 }
+
+ for s,d in f:gmatch("(%w+)%s+(%d+)") do imap_now[s] = tonumber(d) end
+ mailcount = imap_now["UNSEEN"] -- backwards compatibility
widget = imap.widget
+
settings()
if notify == "on" and mailcount and mailcount >= 1 and mailcount > helpers.get_map(mail) then
- local nt = mail .. " has " .. mailcount .. " new message"
- if mailcount >= 1 then nt = nt .. "s" end
- naughty.notify { preset = mail_notification_preset, text = nt }
+ if followtag then mail_notification_preset.screen = awful.screen.focused() end
+ naughty.notify {
+ preset = mail_notification_preset,
+ text = string.format("%s has %d new message%s", mail, mailcount, mailcount == 1 and "" or "s")
+ }
end
- helpers.set_map(mail, mailcount)
+ helpers.set_map(mail, imap_now["UNSEEN"])
end)
end
- imap.timer = helpers.newtimer(mail, timeout, update, true, true)
+ imap.timer = helpers.newtimer(mail, timeout, imap.update, true, true)
return imap
end