lain/imap.md

2.3 KiB

<- widgets

Shows mail count in a textbox fetching over IMAP.

myimapcheck = lain.widgets.imap(args)

New mails are notified like this:

+--------------------------------------------+
| +---+                                      |
| |\ /| donald@disney.org has 3 new messages |
| +---+                                      |
+--------------------------------------------+

The function takes a table as argument. Required table parameters are:

Variable Meaning Type
server Mail server string
mail User mail string
password User password string

while the optional are:

Variable Meaning Type Default
port IMAP port int 993
timeout Refresh timeout seconds int 60
is_plain Define whether password is a plain password (true) or a function that retrieves it (false) boolean false
settings User settings function

Let's focus better on is_plain.

The reason why it's false by default is to discourage the habit of storing passwords in plain files.

You can set your password in plain like this:

myimapcheck = lain.widgets.imap({
    is_plain = true,
    password = "myplainpassword",
    [...]
})

and you'll have the same security provided by ~/.netrc.

Or you can use a keyring, like python keyring:

myimapcheck = lain.widgets.imap({
    is_plain = true,
    password = "myplainpassword",
    server   = "mail.autistici.org",
    mail     = "dada@anche.no",
})

When is_plain == false, it executes password before using it, so you can also use whatever password fetching solution you want.

settings can use the value mailcount, an integer greater or equal to zero, and can modify mail_notification_preset table, which will be the preset for the naughty notifications. Check here for the list of variables it can contain.

Default definition:

mail_notification _preset = {
   icon = lain/icons/mail.png,
   position = "top_left"
}

Note that mailcount is 0 either if there are no new mails or credentials are invalid, so make sure you get the right settings.

output

A textbox.