Mutt is one of the most rewarding programs one can use, but can be a pain in the ass to configure. Since my job is making power-user tools available for the masses I want to create a tool that automates most of mutt configuration so that users can simply give their email address and get a /comfy/ setup. At that, I don’t just want a mutt wizard, but an offlineIMAP wizard, so users can easily access their mail offline as well, and a wizard that makes it easy to store passwords securely using gpg.
The mutt-wizard is all of this in a simple ncurses menu. It’s really just a little bash script, but one that can save countless people thousands of combined manhours of frustratingly trying to get all the moving pieces working together.
The system takes an email and autodetect its server settings, generating a muttrc and offlineimaprc profile automatically. If it can’t do so, it simply prompts you for these (which you can easily look up) and will put them all in the right places. You get:
i
prefix in mutt: i1
: first email account, i5
: fifth, etc.gi
: go to inbox, gs
to sent mail, ga
to archive, gS
to spam, gd
to drafts, etc.Yes! At this point, the only problems are the unexpected ones. Please try it, and if you do run into problems, email me at luke@lukesmith.xyz! I’ve tried the system personally on Gmail, Teknik.io, cock.li and Yandex, while others have tried other providers.
One email provider which I think will not work (and will never work) is Proton Mail, but that’s only because they require encryption through their web client IIRC.
Note also that Gmail and some providers require you to enable sign-ins from third-party (or as they call it “less secure”) applications to be able to load mail with mutt and offlineimap. Be sure to enable that!
dialog, neomutt and offlineimap should be installed. The contents of this repo should go directly in ~/.config/mutt/
and run from there. You also need to have a GPG public/private key pair for the wizard to automatically store your passwords. Otherwise you’ll have to store them insecurely in plaintext files without the help of the wizard.
Just run mutt-wizard.sh
for all the options, to install an account:
offlineimap
or offlineimap -a <your account name>
. This will start downloading all your mail for offline access.Whenever you want to check for mail, just run the offlineimap
command again.
Look at the code. The script takes the passwords you give it, encrypts them immediately with your own GPG key, and shreds the leftovers. Nothing malicious; it’s all there! If it makes you comfortable you can even run the script offline at first.
If you use mutt with a particular host or domain, put your server information in domains.csv
! This will make everyone else who uses your email provider’s life much easier!
Or you can help monetarily via Patreon or Paypal!
Mail is stored in ~/.mail
. mutt configs and caches for each account are in ~/.config/mutt/accounts/
. Encypted passwords are in ~/.config/mutt/credentials
. A “personal” muttrc, with the macros for switching accounts and the default config is in ~/.config/mutt/personal.muttrc
.
domains.csv
, possibly porting the Thunderbird autoconfigure settings.