All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@git.madduck.net.
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
4 Licensed under GNU General Public License v2
5 * (c) 2013, Luke Bonham
9 local helpers = require("lain.helpers")
11 local shell = require("awful.util").shell
12 local naughty = require("naughty")
13 local wibox = require("wibox")
15 local string = { format = string.format,
17 local tonumber = tonumber
19 local setmetatable = setmetatable
24 local function worker(args )
25 local imap = helpers.make_widget_textbox()
26 local args = args or {}
27 local server = args.server
28 local mail = args.mail
29 local password = args.password
30 local port = args.port or 993
31 local timeout = args.timeout or 60
32 local is_plain = args.is_plain or false
33 local followtag = args.followtag or false
34 local settings = args.settings or function() end
36 local head_command = "curl --connect-timeout 3 -fsm 3"
37 local request = "-X 'SEARCH (UNSEEN)'"
39 helpers.set_map(mail, 0)
42 helpers.async(string.format("%s -s '%s'", shell, password), function(f)
43 password = f:gsub("\n", "")
48 mail_notification_preset = {
49 icon = helpers.icons_dir .. "mail.png",
54 mail_notification_preset.screen = awful.screen.focused()
57 curl = string.format("%s -c '%s --url imaps://%s:%s/INBOX -u %s:%q %s -k'",
58 shell, head_command, server, port, mail, password, request)
60 helpers.async(curl, function(f)
61 _, mailcount = string.gsub(f, "%d+", "")
66 if mailcount >= 1 and mailcount > helpers.get_map(mail) then
67 if mailcount == 1 then
68 nt = mail .. " has one new message"
70 nt = mail .. " has <b>" .. mailcount .. "</b> new messages"
72 naughty.notify({ preset = mail_notification_preset, text = nt })
75 helpers.set_map(mail, mailcount)
80 helpers.newtimer(mail, timeout, update)
82 return setmetatable(imap, { __index = imap.widget })
85 return setmetatable({}, { __call = function(_, ...) return worker(...) end })