X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/8d3868d7ce528cfc075e246c8935bae2724e0868..f76d33e8cd5bc84f44758e8047294227deb3f29d:/widget/imap.lua
diff --git a/widget/imap.lua b/widget/imap.lua
index 1049d03..7e83d36 100644
--- a/widget/imap.lua
+++ b/widget/imap.lua
@@ -1,24 +1,22 @@
-
--[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luke Bonham
-
+
+ Licensed under GNU General Public License v2
+ * (c) 2013, Luca CPZ
+
--]]
-local helpers = require("lain.helpers")
-local naughty = require("naughty")
-local wibox = require("wibox")
-local string = { format = string.format,
- gsub = string.gsub }
-local type = type
-local tonumber = tonumber
-local setmetatable = setmetatable
+local helpers = require("lain.helpers")
+local naughty = require("naughty")
+local wibox = require("wibox")
+local awful = require("awful")
+local string = string
+local type = type
+local tonumber = tonumber
-- Mail IMAP check
-- lain.widget.imap
-local function worker(args)
+local function factory(args)
local imap = { widget = wibox.widget.textbox() }
local args = args or {}
local server = args.server
@@ -28,6 +26,7 @@ local function worker(args)
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 head_command = "curl --connect-timeout 3 -fsm 3"
@@ -55,23 +54,18 @@ local function worker(args)
mail_notification_preset.screen = awful.screen.focused()
end
- curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:%q %s -k",
- head_command, server, port, mail, password, request)
+ local curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:%q %s -k",
+ head_command, server, port, mail, password, request)
helpers.async(curl, function(f)
- _, mailcount = string.gsub(f, "%d+", "")
- _ = nil
-
+ mailcount = tonumber(f:match("UNSEEN (%d+)"))
widget = imap.widget
settings()
- if mailcount >= 1 and mailcount > helpers.get_map(mail) then
- if mailcount == 1 then
- nt = mail .. " has one new message"
- else
- nt = mail .. " has " .. mailcount .. " new messages"
- end
- naughty.notify({ preset = mail_notification_preset, text = nt })
+ 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 }
end
helpers.set_map(mail, mailcount)
@@ -84,4 +78,4 @@ local function worker(args)
return imap
end
-return setmetatable({}, { __call = function(_, ...) return worker(...) end })
+return factory