]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/imap.lua
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
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.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
local naughty = require("naughty")
local wibox = require("wibox")
local naughty = require("naughty")
local wibox = require("wibox")
local string = { format = string.format,
gsub = string.gsub }
local tonumber = tonumber
local string = { format = string.format,
gsub = string.gsub }
local tonumber = tonumber
-- lain.widgets.imap
local function worker(args)
-- lain.widgets.imap
local function worker(args)
- local imap = {}
- local args = args or {}
+ local imap = {}
+ local args = args or {}
- local server = args.server
- local mail = args.mail
- local password = args.password
+ 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 settings = args.settings or function() end
+ local port = args.port or 993
+ local timeout = args.timeout or 60
+ local is_plain = args.is_plain or false
+ local followmouse = args.followmouse or false
+ local settings = args.settings or function() end
- local head_command = "curl --connect-timeout 1 -fsm 3"
+ local head_command = "curl --connect-timeout 3 -fsm 3"
local request = "-X 'SEARCH (UNSEEN)'"
helpers.set_map(mail, 0)
local request = "-X 'SEARCH (UNSEEN)'"
helpers.set_map(mail, 0)
- if not is_plain
- then
- local f = io.popen(password)
- password = f:read("*a"):gsub("\n", "")
- f:close()
+ if not is_plain then
+ password = helpers.read_pipe(password):gsub("\n", "")
end
imap.widget = wibox.widget.textbox('')
end
imap.widget = wibox.widget.textbox('')
- curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:%s %s -k",
+ if followmouse then
+ mail_notification_preset.screen = mouse.screen
+ end
+
+ curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:%q %s -k",
head_command, server, port, mail, password, request)
async.request(curl, function(f)
head_command, server, port, mail, password, request)
async.request(curl, function(f)
- ws = f:read("*a")
- f:close()
-
- _, mailcount = string.gsub(ws, "%d+", "")
+ _, mailcount = string.gsub(f, "%d+", "")
_ = nil
widget = imap.widget
_ = nil
widget = imap.widget
end
naughty.notify({
preset = mail_notification_preset,
end
naughty.notify({
preset = mail_notification_preset,
- text = nt,
- screen = client.focus and client.focus.screen or 1