Skip to content

bAndie91/gemlv

Repository files navigation

This is a readme for gemlv and emlv.

gemlv

Email viewer and composer for email files, in GTK

Screenshots

email viewer view html email simple addressbook composer context menu address auto completion

Features

  • display headers
    • only which are significant for end-users
    • toggle "show all headers"
    • highlight email addresses
    • convert Date to local timezone
    • Reply-By and Expires headers, show warning if time is over
  • view plain text message, or a filtered attachment
    • configure multiple filters for non-text attachments
    • change font or turn monospace on/off, font zoom, preserve selected font
    • wrap lines, wrap letters, no wrap
    • show link for Content-Location if applicable
  • display attachments and other MIME parts in tree view
    • select first text/plain or text/html part at beginning
    • show attached filenames, and their mime type
    • Drag-and-Drop from attachment panel
  • email parts (attachments) can be opened with external program (mimeopen-gui)
  • save attachments (MIME parts)
    • save as:
      • single files
      • more files at once in a folder
      • preserving multipart structure (ie. save in directory tree)
    • preverse modification time, permissions if specified in attachment (Content-Disposition header modification_date and posix_mode parameters respectively)
    • preserve symlinks
    • save Message-ID, Content-Type in Extended Attributes
  • Encryption
    • decrypt encrypted Email when open (MIME/PGP format is supported)
    • verify GPG signatures, warn if mismatch
      • both attached signature and signature which is embedded in the pgp message
    • encrypt message and attachments before send (MIME/PGP format)
      • hide Bcc recipients in the encrypted message
      • obfuscate RFC822 headers and put their cleartext content in an inline text/rfc822-headers part (as per IETF draft-autocrypt-lamps-protected-headers-02)
    • sign email message and attachments (MIME/PGP)
    • set Autocrypt header
      • remove UIDs from the gpg public key which are not disclosed in the current email, so protecting these email addresses from leakage
    • sign and encrypt headers too (headers repeated both in the encapsulated email and in a text/rfc822-headers MIME part)
  • Libravatar and Gravatar support
    • you can configure the URLs to fetch the avatar picture of the email sender:
      • files in precedence: ~/.config/gemlv/prop/avatar/url_templates.json, /etc/gemlv/prop/avatar/url_templates.json
      • mini template-language to access email address, libravatar hostnames, lower-case, upper-case, hash, ...
    • save avatar picture with the source URL in xattributes
  • remember UI elements size and position
  • button to unsubscribe from newsletters, mailing lists
  • report as spam/ham
    • supported spam-db networks and filters:
      • razor
      • pyzor
      • bogofilter
    • move Email file into / out from Spam folder
    • override spam-report command on user/system level (~/.local/share/gemlv/report-spam, /etc/gemlv/report-spam)
  • writing Email
    • send by standard sendmail -ti command
      • can interrupt sending process
      • pass SENDMAIL_FROM and SENDMAIL_RCPT environment variables to help sendmail decide where to route (if your sendmail needs this)
    • you can add usual headers (From, Reply-To, To, Cc, Bcc) and arbitrary ones as well
      • email address syntax is validated
      • pick date and time from calendar when adding date-time headers
    • can edit message by external program (mimeopen-gui)
    • options
      • set Importance and Priority by a toolbar toggle
      • ask Disposition Notification by a toolbar toggle
    • addressbook
      • read plain email addresses from files line by line (~/Mail/.addressbook and ~/Mail/.addressbook.d/*)
      • automatically save addresses to which you send emails (~/Mail/.addressbook.d/gemlv.auto)
      • auto completion on address fields
      • suggest "From" addresses based on past correspondences with the given recipients (need to run scan-participants regurarly to populate database)
    • auto save drafts to ~/.cache/gemlv/drafts/
      • you can find and open draft emails there in case of something crashed
    • support ~/.signature and multiple user signature files in ~/Mail/.signatures/*
  • reply options
    • consider Reply-To field
    • set References, In-Reply-To headers
    • quote plain text message in the new email
    • Reply To All: reply to sender, to all recipients, to the mailing list, except ourself
    • Reply To List
    • Forward: attach original email, not quote
    • send Disposition Notification voluntarily
      • even for messages have not explicitely requested it
      • it generates the response message conforming to the Accept-Language header (if gemlv translation is available)
    • store replied/forwarded/MDN-sent states in file Extended Attribute
  • attachments in compose mode
    • attach files, symlinks and even whole directories recursively
      • by browsing them
      • by drag-and-drop
    • attach data blobs by drag-and-drop
    • rename attachments in place
    • remove, reorder attachments
    • use that Transport Encoding (quoted-printable, base64) which provides smaller encoded data for a given clear data
    • store file's modification time, POSIX permission bits in Content-Disposition header
  • CLI options
    • viewer mode (gemlv raw_email.eml)
    • compose mode (gemlv --compose)
    • addresses (repeat for more recipients)
      • --from 'Anna Lastname <anna@example.net>'
      • --to bud@example.net --to Carl\ \<carl@example.net\> --to '"Lastname, David" <dave@example.net>'
      • --cc ...
      • --bcc ...
    • subject (--subject "...")
    • message body (--message "...")
    • attachments (--attach file1 --attachment file2 --attach dir1/)
    • full mailto link (--mailto "mailto:%22Buddy%22%20%3Cbud@example.net%3E?subject=awesome%20email%20client"), RFC2368, RFC6068
  • hotkeys
    • Ctrl-Q Quit
    • Ctrl-W Close compose window
    • Ctrl-S Save attachment(s) in viewer mode; save draft in composer mode
    • Ctrl-Shift-S Save draft as...
    • Ctrl-O Open attachment with external program
    • Ctrl-N Compose new Email
    • Ctrl-Shift-R Reply
    • Ctrl-R Reply to All
    • Ctrl-F Forward message with envelope (headers and attachments)
    • Ctrl-Shift-F Forward message (body only)
    • Ctrl-U Filter/Unfilter rich text (non-plain text, eg: html, pdf, ...)
    • Ctrl-H Show/Hide uncommon headers
    • F4 Edit draft message with external program
    • Alt-A Open built-in addressbook browser
    • Shift-Down Pop up auto completion (on header input boxes in composer mode)

Autocrypt implementation status

  • header parsing: compliant parsing of the Autocrypt header
  • keygen: secret key generation follows Autocrypt UI guidance
    • call sensible GPG UI program to generate key
  • peerstate: state is kept according to spec
  • header inject
    • gemlv sends Autocrypt header when crypto-sign is turned on
  • recommend: implements Autocrypt recommendation
  • encrypt: encrypts outgoing messages properly
    • body
    • headers
    • attachments
  • setup message: proper generation and processing of Autocrypt Setup Message
  • setup process: follows guidance with respect to Autocrypt account setup
  • gossip
    • send Autocrypt-Gossip headers
    • process incoming Autocrypt and Autocrypt-Gossip headers
  • uid decorative: UID in key data is only used for decorative purposes, and in particular not for looking up keys for an e-mail address.

CLI options

usage: gemlv [-h] [--compose] [--from ADDRESS] [--to ADDRESS] [--cc ADDRESS]
             [--bcc ADDRESS] [--subject STRING] [--message STRING]
             [--mailto URL] [--attach FILE] [--localedir DIR]
             [--opener COMMAND] [--header STRING]
             [FILE]

positional arguments:
  FILE                  Raw Email file for read or continue editing (default:
                        None)

optional arguments:
  -h, --help            show this help message and exit
  --compose             Write a new Email (default: False)
  --from ADDRESS        New Email's writer's name and address (default: None)
  --to ADDRESS          New Email's Recipients, repeatable (default: None)
  --cc ADDRESS          Carbon Copy Recipients, repeatable (default: None)
  --bcc ADDRESS         Blind Carbon Copy Recipients, repeatable (default:
                        None)
  --subject STRING      Subject (default: None)
  --message STRING      Message body (default: None)
  --mailto URL          Full 'mailto:' link (default: None)
  --attach FILE, --attachment FILE
                        Attachment file's path, repeatable (default: None)
  --localedir DIR       L10n base directory (default: None)
  --opener COMMAND      File opener command (default: mimeopen-gui)
  --header STRING       Add custom header(s) to the new Email (default: None)

Installation Notes

Included modules are installed into /usr/lib/python2.7 by default. If your python installation does not include it in sys.path (PYTHONPATH), create a file called gemlv.pth in the "site" directory, that is the site module searches for additional module paths, then write /usr/lib/python2.7 in it. You can get the "site" directory by eg. import site; print site.getsitepackages()[0].

Dependencies

not exhaustive lists

Non-optional Dependencies

Optional Dependencies

  • pyexiv2 or piexif
  • fuzzywuzzy
  • sqlite3
  • dnspython (for Libravatar support)

Compatibility

FAQ

Q. Support feature-rich HTML-rendering?

A. No. HTML-rendering is a huge job on its own right; does not fit into one program - one job paradigm for me. I built in filters for several media types (including html), you can define more filter for one mime type as well. Though it's not capable of feature-rich rendering with images, css, interactive content, nor anything like that. There are embedable libs for this purpose out there, but I doubt any html renderer engine can work on the long-term on one hand, and I don't belive any reasonable ground to send so full-featured html around in emails on the other hand (except as attachments which you can open externally or just save).

Q. Where can I configure incoming/outgoing email server address/hostname/portnumber/ssl/tls/starttls options?

A. Nowhere. It's just a viewer for raw email files (and composer). You may setup an other program to acquire your emails and save them in a directory, or use some virtual filesystem (fuse) which presents your IMAP/POP3 mailbox as a conventional filesystem. I personally donwload my emails by getmail4 preserving IMAP folder structure.

Q. I get error when about to send email. Why?

A. Consult the docs of your sendmail installation. If you have not any, install a tool providing sendmail command; there are more of them.

Q. Python 2 ?

A. Yes. It is not banned. Is it?

Q. How to edit the addressbook? The "Edit" button does not work…

A. The addressbook is just plain text files at ~/Mail/.addressbook and ~/Mail/.addressbook.d/*, one address line (real name + email address) per line. Edit it with any text editor. The "Edit" button runs the default file opener program to open the addressbook file(s) for editing.

Q. When the composer window opens up the header field is frozen and I can not click on it.

A. It seems to be some sort of gtk bug. Just scroll over it and it thaws.

Inspiration

Many UI parts are inspired by Sylpheed/Claws-mail.

emlv

Email viewer for console/terminal

CLI options

usage: emlv [-h] [--list | --extract INDEX | --save INDEX] [--plaintext]
            [--html] [--header HEADER] [--header-filter COMMAND]
            [--body-filter COMMAND] [--attachments-filter COMMAND]
            [FILE [FILE ...]]

Display RFC-822 email file(s) headers, content, and attachments, list MIME parts, extract attachments from it.
Without --list or --extract option, i.e. read-mode, display the first text/plain part as content (or text/html if no plain text part found).

It searches executables named <MAIN> and <MAIN>_<SUB> in ~/.local/bin/emlv-filter/ to filter content with MIME type <MAIN>/<SUB> through them.
You can disable this by "--body_filter=-" parameter.

positional arguments:
  FILE                  Process the given FILEs as raw RFC-822 emails. Read
                        STDIN if FILE is not given.

optional arguments:
  -h, --help            show this help message and exit
  --list, -l            List all MIME parts in email files given in FILE.
  --extract INDEX, -x INDEX
                        Extract MIME part specified by INDEX to stdout. See
                        --list to get the indices of each part of a MIME-
                        multipart file. This option may be repeated.
  --save INDEX, -s INDEX
                        Save MIME part specified by INDEX to file. The output
                        file name is either the attachment's name if it's
                        given, or "attached-email-INDEX.eml" if the attachment
                        is itself an Email, or "attachment-INDEX.dat"
                        otherwise. This option may be repeated.
  --plaintext           Always take the first text/plain part as content.
                        Default is to fall back to text/html if no text/plain
                        found.
  --html                Take the first text/html part as content, not
                        text/plain. Option --body-filter is also recommended
                        here.
  --header HEADER, -H HEADER
                        Extra headers to show in read-mode besides Return-
                        Path, X-X-Sender, X-Sender, Sender, From,
                        Organization, Reply-To, To, Cc, Delivered-To, Subject,
                        Date, Importance, Priority, X-Priority, X-MSMail-
                        Priority, Reply-By, Expires, X-Spam. Wildcards are
                        supported.
  --header-filter COMMAND, -fh COMMAND
                        Filter the headers through this command.
  --body-filter COMMAND, -fb COMMAND
                        Filter the message body through this command.
  --attachments-filter COMMAND, -fa COMMAND
                        Filter the table of attachments through this command
                        (in read-mode).

Project issues, bugs, feature requests, ideas

  1. clone repo
  2. use git-bug to open a new ticket in this repo
  3. find one or more person in the commit history to make contact with
  4. send the URL of your git clone to them (via email or other channel), and request them to pull (git-bug issues and/or branches as well) from you