@@ -3,4 +3,4 @@ personal.muttrc | |||||
*.gpg | *.gpg | ||||
*.pyc | *.pyc | ||||
accounts/ | accounts/ | ||||
*mailsynclastrun | |||||
*mw.lastrun |
@@ -1,159 +0,0 @@ | |||||
# mutt-wizard | |||||
Get this great stuff without effort: | |||||
- A full-featured and autoconfigured email client on the terminal with neomutt | |||||
- Mail stored offline so you can view and write email while away from internet and keep backups | |||||
Specifically, this wizard: | |||||
- Determines your email server's IMAP and SMTP servers and ports | |||||
- Creates dotfiles for `neomutt`, `isync`, and `msmtp` appropriate for your email address | |||||
- Encrypts and stores locally your password for easy remote access, accessible only by your GPG key | |||||
- Handles as many as nine separate email accounts automatically | |||||
- Auto-creates bindings to switch between accounts or between mailboxes | |||||
- Can automatically set mail updates as often as you want to sync your mail and update you when new mail arrives | |||||
- Provides sensible defaults and an attractive appearance for the neomutt email client | |||||
- If mutt-wizard doesn't know your server's IMAP/SMTP info by default, it will prompt you for them and will put them in all the right places. | |||||
## Install and Use | |||||
``` | |||||
git clone https://github.com/LukeSmithxyz/mutt-wizard | |||||
cd mutt-wizard | |||||
sudo make install | |||||
``` | |||||
User of Arch-based distros can also install mutt-wizard from the AUR as [mutt-wizard-git](https://aur.archlinux.org/packages/mutt-wizard-git/). | |||||
*NOTE:* If you have used an older version of mutt-wizard, especially when it used to use `offlineimap`, you need to remove your old configs. | |||||
Back up what's important and run: | |||||
``` | |||||
rm -rf ~/.config/mutt ~/.msmtprc ~/.config/msmtp ~/.offlineimap ~/.offlineimaprc ~/.config/offlineimap ~/.mbsyncrc | |||||
``` | |||||
The mutt-wizard is run with the command `mw`. | |||||
It also installs the `mailsync` command. | |||||
Once everything is setup, you'll use `neomutt` to access your mail. | |||||
- `mw add` -- add a new email account | |||||
- `mw ls` -- list existing accounts | |||||
- `mw pass` -- revise an account's password | |||||
- `mw delete` -- deleted an added account | |||||
- `mw purge` -- delete all accounts and settings | |||||
- `mw cron` -- toggle/configure a cronjob to sync mail | |||||
## Dependencies | |||||
- `neomutt` - the email client | |||||
- `isync` - downloads and syncs the mail (required at install) | |||||
- `msmtp` - sends the email | |||||
- `pass` - safely encrypts passwords (required at install) | |||||
There's a chance of errors if you use a slow-release distro like Ubuntu, Debian or Mint. | |||||
If you get errors in `neomutt`, install the most recent version manually or manually remove the offending lines in the config in `/usr/share/mutt-wizard/mutt-wizard.muttrc`. | |||||
### Optional | |||||
- `w3m` - view HTML email and images in neomutt. | |||||
- `notmuch` - index and search mail. | |||||
Install it and run `notmuch setup`. | |||||
Tell it where your mail is (`$MAILDIR` or `~/Mail`). | |||||
Although, `mw` will do this automatically, if you haven't set notmuch up before. | |||||
You can run it in mutt with `ctrl-f`. | |||||
Run `notmuch new` to process new mail. | |||||
Although, the included `mailsync` script does this for you. | |||||
- `libnotify`/`libnotify-bin` - allows notifications when syncing mail with `mailsync` | |||||
- `abook` - a terminal-based address book. | |||||
Pressing tab while typing an address to send mail to will suggest contacts that are in your abook. | |||||
- A cron manager - if you want to enable the auto-sync feature. | |||||
- `pam-gnupg` - this is a more general program that I use. | |||||
It automatically logs you into your GPG key on login so you will never need to input your password once logged on to your system. | |||||
Check out the repo and directions [here](https://github.com/cruegge/pam-gnupg). | |||||
- `urlview` - outputs urls in mail to browser. | |||||
## Neomutt user interface | |||||
To give you an example of the interface, here's an idea: | |||||
- `m` - send mail (uses your default `$EDITOR` to write) | |||||
- `j`/`k` and `d`/`u` - vim-like bindings to go down and up (or `d`/`u` to go down/up a page). | |||||
- `l` - open mail, or attachment page or attachment | |||||
- `h` - the opposite of `l` | |||||
- `D` - delete mail | |||||
- `r`/`R` - reply/reply all to highlighted mail | |||||
- `s` - save selected mail or selected attachment | |||||
- `gs`,`gi`,`ga`,`gd`,`gS` - Press `g` followed by another letter to change mailbox: `s`ent, `i`nbox, `a`rchive, `d`rafts, `S`pam, etc. | |||||
- `M` and `C` - For `M`ove and `C`opy: follow them with one of the mailbox letters above, i.e. `MS` means "move to Spam". | |||||
- `i#` - Press `i` followed by a number 1-9 to go to a different account. | |||||
If you add 9 accounts via mutt-wizard, they will each be assigned a number. | |||||
- `a` to add address/person to abook and `Tab` while typing address to complete one from book. | |||||
- `?` - see all keyboard shortcuts | |||||
- `ctrl-j`/`ctrl-k` - move up and down in sidebar, `ctrl-o` opens mailbox. | |||||
- `ctrl-b` - open a menu to select a url you want to open in you browser (needs urlview). | |||||
- `gm / gM` - call mutt-wizard's mailsync for one / all mail accounts | |||||
## New stuff and improvements since the original release | |||||
- honors `$MAILDIR`, `$XDG_CONFIG_HOME`, `$XDG_CACHE_HOME`, if defined. | |||||
- `gm/gM` to sync mail inside `mutt`, as `o/O` has a `mutt` assignment already. | |||||
- Make channel name equal to email address to avoid choosing a new name for the same thing. | |||||
- `isync`/`mbsync` has replaced `offlineimap` as the backend. | |||||
Offlineimap was error-prone, bloated, used obsolete Python 2 modules and required separate steps to install the system. | |||||
- `mw` is now an installed program instead of just a script needed to be kept in your mutt folder. | |||||
- `dialog` is no longer used (le bloat) and the interface is simply text commands. | |||||
- More autogenerated shortcuts that allow quickly moving and copying mail between boxes. | |||||
- More elegant attachment handling. | |||||
Image/video/pdf attachments without relying on the neomutt instance. | |||||
- abook integration by default. | |||||
- The messy template files and other directories have been moved or removed, leaving a clean config folder. | |||||
- msmtp configs moved to `~/.config/` and mail default location moved to `~/Mail`, reducing mess in `~`. | |||||
- `pass` is used as a password manager instead of separately saving passwords. | |||||
- Script is POSIX sh compliant. | |||||
- Error handling for the many people who don't read or follow directions. | |||||
Less errors generally. | |||||
- Addition of a manual `man mw`. | |||||
## Help the Project! | |||||
- Try mutt-wizard out on weird machines and weird email addresses and report any errors. | |||||
- Open a PR to add new server information into `domains.csv` so their users can more easily use mutt-wizard. | |||||
- If nothing else, [Donate!](https://paypal.me/LukeMSmith) | |||||
See Luke's website [here](https://lukesmith.xyz). | |||||
Email him at [luke@lukesmith.xyz](mailto:luke@lukesmith.xyz). | |||||
mutt-wizard is free/libre software, licensed under the GPLv3. | |||||
## Details for Tinkerers | |||||
- The critical `mutt`/`neomutt` files are in `~/.config/mutt/` (or `$XDG_CONFIG_HOME/mutt`) | |||||
- Put whatever global settings you want into `muttrc`. | |||||
`mutt-wizard` will add some lines to this file which you shouldn't remove unless you know what you're doing. | |||||
But you can move them up/down over your personal config lines if you need to. | |||||
If you get binding conflict errors in mutt, you might need to do this. | |||||
- Each of the accounts that `mutt-wizard` generates will have custom settings set in a separate file in `accounts/`. | |||||
You can edit these freely if you want to tinker with settings specific to an account. | |||||
- In `/usr/share/mutt-wizard` are several global config files, including `mutt-wizard`'s default settings. | |||||
You can overwride this in your `muttrc` if you wish. | |||||
To avoid insertion of the line sourcing the default settings, | |||||
have a commented `# source /usr/share/mutt-wizard/mutt-wizard.muttrc` in your muttrc. | |||||
## Watch out for these things: | |||||
- For Gmail accounts, remember also to enable third-party ("""less secure""") applications before attempting installation. | |||||
You might also need to manually "Enable IMAP" in the settings. | |||||
- Protonmail accounts will require you to set up "Protonmail Bridge" to access PM's IMAP and SMTP servers. | |||||
Configure that before running mutt-wizard. | |||||
- If you have a university email, or enterprise-hosted email for work, there might be other hurdles or two-factor authentication you have to jump through. | |||||
Some, for example, will want you to create a separate IMAP password, etc. | |||||
- `isync` is not fully UTF-8 compatible, so non-Latin characters may be garbled (although sync should succeed). | |||||
`mw` will also not autocreate mailbox shortcuts since it is looking for English mailbox names. | |||||
I strongly recommend you to set your email language to English on your mail server to avoid these problems. | |||||
## To-do | |||||
- Add ~~Mac OS~~/BSD compatibility (the script should work for Mac OS now) | |||||
- ~~Out-of-the-box compatibility with Protonmail Bridge~~ (I believe this is done, but more bug-testing is welcome since I don't have PM) | |||||
- Option to keep configuration for accounts that failed to connect (maybe) |
@@ -0,0 +1,327 @@ | |||||
========================================= | |||||
mw(1) Version 2.0 \| mutt-wizard man page | |||||
========================================= | |||||
.. To test man page: | |||||
.. | |||||
.. pandoc README.rst -s -t man | /usr/bin/man -l - | |||||
.. | |||||
.. The generate: | |||||
.. | |||||
.. pandoc README.rst -s -t man -o mw.1 | |||||
NAME | |||||
==== | |||||
**mw** — mutt-wizard - add, list, remove email configurations for mbsync, getmail and mutt. Sync email without mutt. | |||||
SYNOPSIS | |||||
======== | |||||
**mw** [<command>|<email>] | |||||
| **mw** Same as *mw sync* | |||||
| **mw add** Add and configure an email address (9 max.) | |||||
| **mw list** List configured accounts | |||||
| **mw remove** Pick an account to remove | |||||
| **mw purge** Remove all accounts and settings | |||||
| **mw cron** Enable or disable an autosync via cronjob | |||||
| **mw sync** Sync mail based on config in *.config/isync/mbsyncrc* and *.config/getmail/\** | |||||
| **mw –help\|-h** Print this message | |||||
| **mw –version\|-v** Print version | |||||
DESCRIPTION | |||||
=========== | |||||
**mw** configures **mbsync**, **getmail**, **msmtp** and **mutt** in one go. | |||||
**mutt** stands for **mutt** or **neomutt**. | |||||
**mw** asks the user for the information it needs. | |||||
They cannot be provided as parameters to the command. | |||||
It is still possible to script **mw** by defining variables. | |||||
See the commands section. | |||||
*mutt-wizard.muttrc* is linked in your *muttrc*. | |||||
Have this line there, if you prefer your own settings:: | |||||
# source /usr/share/mutt-wizard/mutt-wizard.muttrc | |||||
You will need to keep the binding of *i,g,C,M* to *noop*, though, | |||||
because of the generated bindings in the account muttrc. | |||||
COMMANDS | |||||
======== | |||||
Without command parameter **sync** is assumed. | |||||
If the parameter contains @ an email is assumed and synced. | |||||
*add* | |||||
Add new email | |||||
First you decide, whether you want to configure | |||||
- **mbsync**, **getmail**, **msmtp** to sync emails independently from **mutt** using **mw**, | |||||
- or just **mutt**. | |||||
For an IMAP server **mutt** becomes very slow. | |||||
So normally you enter **yes** here. | |||||
**mw** asks you the **email address**. | |||||
**mw** has a **database** of IMAP4/POP3 and SMTP servers and ports. | |||||
If you are lucky, your email server is there. | |||||
Else **mw** will prompt you. | |||||
Add an email without questions, e.g.:: | |||||
a=x.y@gmail.com mwtype=offline mwaddr=$a mwlogin=$a mwpass=mutt-wizard-$a mwserverinfo="gmail.com,imap.gmail.com,993,smtp.gmail.com,587" mwname="your name" mw add | |||||
*mwserverinfo* can be omitted, if the email domain is in the accompanied *domains.csv*. | |||||
*ls|list* | |||||
List all email accounts configured by mutt-wizard | |||||
*rm|remove* | |||||
Remove the configuration files for an already configured email | |||||
Remove without questions the email whose generated muttrc starts with 1:: | |||||
mwpick=1 mw rm <<<y | |||||
*purge* | |||||
Removes all mw generated mutt settings and | |||||
| *.config/mutt/accounts/1-\** | |||||
| *.config/isync/mbsyncrc* | |||||
| *.config/getmail/\** | |||||
| *.config/msmtp/config* | |||||
Files are under *.config* or *$XDG_CONFIG_HOME* | |||||
If you don't want questions:: | |||||
mw purge <<<y | |||||
*cron* | |||||
Toggle a cronjob that periodically syncs mail | |||||
Without questions:: | |||||
mwcronremove=yes mw cron | |||||
mwcronminutes=99 mw cron | |||||
*sync* | |||||
Syncs mail for all email accounts managed by **mw** (whose paths end in the email). | |||||
This is the default, if no parameter is given. | |||||
If an email address is given, only that email is synced. | |||||
Every **mw** sync run will re-generate the **mutt** configuration | |||||
from the configuration files for **mbsync**, **getmail** and **msmtp**. | |||||
So you could edit them after or not use *mw add* at all. | |||||
Just keep the *Path*, *path* and *account* ending in the email address. | |||||
DEPENDENCIES | |||||
============ | |||||
Required for email setup or operation: | |||||
- *pass* - `pass <https://www.passwordstore.org/>`__ safely encrypts passwords | |||||
- *gnupg* - needed by *pass* | |||||
- *mutt/neomutt* - the email client (*mutt* untested). | |||||
- *isync’s mbsync* - syncs the mail | |||||
- *getmail* - used for POP3 | |||||
- *msmtp* - sends the email | |||||
Optional: | |||||
- *w3m* - view HTML email and images in **mutt**. | |||||
- *notmuch* - index and search mail. | |||||
If the configuration file *$NOTMUCH_CONFIG* is not there, | |||||
*mw add* will create it. | |||||
- *libnotify* - allows notifications when syncing mail with **mw** | |||||
- *abook* - a terminal-based address book. | |||||
- A cron manager (e.g. *cronie*) - if you want to enable the auto-sync | |||||
feature. | |||||
- *pam-gnupg* - To provide your GPG key at login and never after. | |||||
See `directions <https://github.com/cruegge/pam-gnupg>`__. | |||||
Alternatively avoid constant password requests by increasing | |||||
- *default-cache-ttl* and *max-cache-ttl* in *gpg-agent.conf* | |||||
- *urlscan* - outputs urls in mail | |||||
INSTALLATION | |||||
============ | |||||
:: | |||||
git clone https://github.com/rpuntaie/mutt-wizard | |||||
cd mutt-wizard | |||||
sudo make install | |||||
MUTT CONFIGURATION | |||||
================== | |||||
Once everything is setup, you’ll use **mutt** to access your mail. | |||||
The accompanied *mutt-wizard.muttrc* modifies some **mutt** defaults. | |||||
Look there for a complete list. | |||||
Here an overview: | |||||
- *?* - see all keyboard shortcuts | |||||
**syncing** | |||||
- *gm / gM* - call mutt-wizard’s *mw sync* for one / all mail accounts | |||||
**mailboxes,accounts** | |||||
- *ixy* - To go to **mailbox**. | |||||
- *Mxy*, *Cxy* - For Move and Copy to the according mailbox, | |||||
e.g. *Msp* means "move to Spam". | |||||
- *i[1-9]* - go to another **account**. | |||||
*xy* are | |||||
- the two first letters of a mailbox or | |||||
- first letter of first + second letter of second path entry | |||||
**searching** | |||||
- *S* - search for a mail using *notmuch* | |||||
- *gl* - limit by substring of subject | |||||
- *gL* - undo limit | |||||
**composing** | |||||
- *ga* - to add address/person to *abook* and *Tab* while typing | |||||
address to complete one from book. | |||||
- *m/r/gr/f* - new/reply/group reply/forward **message**, | |||||
using your default *$EDITOR* to write. | |||||
Then you enter the **compose screen**. | |||||
- *a* - to add attachments | |||||
- *s/t/c/b/d* - to change the subject/to/CC/BCC/description. | |||||
- *S* - to change the signature/encryption | |||||
- *y* - to send the mail. | |||||
**delete,undelete,save** | |||||
- *dd* - delete mail | |||||
- *u* - undelete | |||||
- *$* - apply the mailbox changes *set trash* is set per default. | |||||
Deleted mails will land there. | |||||
- *s* - save selected mail or selected attachment | |||||
**moving around** | |||||
- *gu* - open a menu to select a url you want to open in you browser | |||||
(needs urlscan). | |||||
- *j*/*k* - next/previous mail, *J/K* same, without skipping deleted, | |||||
and also when viewing mails | |||||
- *ctrl-d/f*/*ctrl-u/b* - down and up a half page / full page | |||||
- *l* - open mail, or attachment page or attachment | |||||
- *h* - the opposite of *l* | |||||
**sidebar** | |||||
- *B* - toggles | |||||
- *ctrl-j*/*ctrl-k* - move up and down | |||||
- *ctrl-l/o* - opens mailbox | |||||
**input field/command line** | |||||
- *ctrl-u* clears the line | |||||
- *ctrl-a*, *ctrl-e* go to beginning or end | |||||
- *ctrl-g* aborts | |||||
DETAILS | |||||
======= | |||||
**Encoding/Language** | |||||
*isync* is not fully UTF-8 compatible. | |||||
**mw** assumes english mailbox names. | |||||
Set your email language to English on your mail server. | |||||
**Mail location** | |||||
Mail is downloaded to a folders named after your emails in *$MAILDIR*. | |||||
*$MAILDIR* defaults to *$HOME/Mail/*. | |||||
Neither **mw remove** nor **mw purge** will delete downloaded mail. | |||||
**Gmail accounts** | |||||
For Gmail allow "less-secure" applications: | |||||
<https://support.google.com/accounts/answer/6010255>. | |||||
Do this before running mutt-wizard. | |||||
**Protonmail accounts** | |||||
Protonmail users must use the Protonmail Bridge | |||||
<https://protonmail.com/bridge/> | |||||
to access their IMAP and SMTP servers. | |||||
Do this before running mutt-wizard. | |||||
FILES | |||||
===== | |||||
*/user/bin/mw* | |||||
The main script to manage and sync emails. | |||||
*/user/bin/mwimage*, */user/bin/mwopen* | |||||
Used by the mailcap file that comes with mutt-wizard. | |||||
*/usr/share/mutt-wizard/mutt-wizard.muttrc* | |||||
Default mutt settings. | |||||
*/usr/share/mutt-wizard/mailcap* | |||||
Default mailcap file. | |||||
*/usr/share/mutt-wizard/domains.csv* | |||||
Email server database. | |||||
BUGS | |||||
==== | |||||
GitHub Issues: <https://github.com/rpuntaie/mutt-wizard/issues> | |||||
AUTHORS | |||||
======= | |||||
*Luke Smith* <luke@lukesmith.xyz> | |||||
Original author, started in 2018. | |||||
Github <https://github.com/lukesmithxyz/mutt-wizard> | |||||
Gitlab <https://gitlab.com/lukesmithxyz/mutt-wizard> | |||||
*Roland Puntaier* <roland.puntaier@gmail.com> | |||||
Bugfixes, Improvements in 2019. | |||||
GitHub: <https://github.com/rpuntaie/mutt-wizard> | |||||
LICENSE | |||||
======= | |||||
GPLv3 | |||||
SEE ALSO | |||||
======== | |||||
**neomutt**\ (1), **neomuttrc**\ (1) **mbsync**\ (1), **msmtp**\ (1), | |||||
**notmuch**\ (1), **abook**\ (1) |
@@ -1,82 +0,0 @@ | |||||
#!/usr/bin/env sh | |||||
# Sync mail and give notification if there is new mail. | |||||
case "$(uname)" in | |||||
Linux) prefix="/usr" ;; | |||||
*) prefix="/usr/local" ;; | |||||
esac | |||||
export PATH=$PATH:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin | |||||
export DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$(id -u)/bus | |||||
export DISPLAY=:0.0 | |||||
if [[ -z $PASSWORD_STORE_DIR ]]; then | |||||
[ -d "$HOME/.local/share/password-store" ] && export PASSWORD_STORE_DIR="$HOME/.local/share/password-store" | |||||
fi | |||||
configdir=${XDG_CONFIG_HOME:-$HOME/.config} | |||||
maildir="${MAILDIR:-$HOME/Mail}" | |||||
lastrun=${XDG_CACHE_HOME:-$HOME/.cache}/.mailsynclastrun | |||||
if [[ -f $configdir/isync/mbsyncrc ]]; then | |||||
mbsyncrc="$configdir/isync/mbsyncrc" | |||||
else | |||||
mbsyncrc="$HOME/.mbsyncrc" | |||||
fi | |||||
mbsyncbin="$prefix/bin/mbsync -c $mbsyncrc" | |||||
# Run only if user logged in (prevent cron errors) | |||||
pgrep -u "$USER" >/dev/null || { echo "$USER not logged in; sync will not run."; exit ;} | |||||
# Run only if not already running in other instance | |||||
pgrep -x mbsync >/dev/null && { echo "mbsync is already running." ; exit ;} | |||||
# Checks for internet connection and set notification script. | |||||
ping -q -c 1 1.1.1.1 > /dev/null || { echo "No internet connection detected."; exit ;} | |||||
command -v notify-send >/dev/null || echo "Note that \`libnotify\` or \`libnotify-send\` should be installed for pop-up mail notifications with this script." | |||||
# Settings are different for MacOS (Darwin) systems. | |||||
if [ "$(uname)" = "Darwin" ]; then | |||||
notify() { osascript -e "display notification \"$2 in $1\" with title \"You've got Mail\" subtitle \"Account: $account\"" && sleep 2 ;} | |||||
else | |||||
notify() { notify-send "mutt-wizard" "📬 $2 new mail(s) in \`$1\` account." ;} | |||||
fi | |||||
# Check account for new mail. Notify if there is new content. | |||||
syncandnotify() { | |||||
acc="$(echo "$account" | sed "s/.*\///")" | |||||
$mbsyncbin "$acc" | |||||
new=$(find "$maildir/$acc/INBOX/new/" "$maildir/$acc/Inbox/new/" "$maildir/$acc/inbox/new/" -type f -newer "$lastrun" 2> /dev/null) | |||||
newcount=$(echo "$new" | sed '/^\s*$/d' | wc -l) | |||||
if [ "$newcount" -gt "0" ]; then | |||||
notify "$acc" "$newcount" & | |||||
for file in $new; do | |||||
# Extract subject and sender from mail. | |||||
from=$(awk '/^From: / && ++n ==1,/^\<.*\>:/' "$file" | perl -CS -MEncode -ne 'print decode("MIME-Header", $_)' | awk '{ $1=""; if (NF>=3)$NF=""; print $0 }' | sed 's/^[[:blank:]]*[\"'\''\<]*//;s/[\"'\''\>]*[[:blank:]]*$//') | |||||
subject=$(awk '/^Subject: / && ++n == 1,/^\<.*\>: / && ++i == 2' "$file" | head -n-1 | perl -CS -MEncode -ne 'print decode("MIME-Header", $_)' | sed 's/^Subject: //' | sed 's/^{[[:blank:]]*[\"'\''\<]*//;s/[\"'\''\>]*[[:blank:]]*$//' | tr -d '\n') | |||||
notify-send "📧$from:" "$subject" & | |||||
done | |||||
fi | |||||
} | |||||
# Sync accounts passed as argument or all. | |||||
if [ "$#" -eq "0" ]; then | |||||
accounts="$(awk '/^Group .*@.*/ {print $2}' "$mbsyncrc")" | |||||
accounts+=" $(awk '/^Channel .*@.*/ {print $2}' "$mbsyncrc")" | |||||
else | |||||
accounts=$* | |||||
fi | |||||
echo " 🔃" > /tmp/imapsyncicon_"$USER" | |||||
pkill -RTMIN+12 i3blocks >/dev/null 2>&1 | |||||
# Parallelize multiple accounts | |||||
for account in $accounts | |||||
do | |||||
syncandnotify & | |||||
done | |||||
wait | |||||
rm -f /tmp/imapsyncicon_"$USER" | |||||
pkill -RTMIN+12 i3blocks >/dev/null 2>&1 | |||||
notmuch new 2>/dev/null | |||||
#Create a touch file that indicates the time of the last run of mailsync | |||||
touch "$lastrun" |
@@ -0,0 +1,52 @@ | |||||
History (newest first) | |||||
Generate man page from readme, to avoid duplicate descriptions. | |||||
Readme in rst instead of md. | |||||
Separate changelog.txt. | |||||
Add tests and made bug fixes | |||||
*urlscan* instead of *urlview* | |||||
*wm* generates *mutt* config on every full sync, | |||||
- to reflect changes in mailboxes in the shortcuts | |||||
- to reflect changes in *mbsync/getmail* config in *mutt* config | |||||
*wm* integrates *mailsync*, | |||||
not to overload the system namespace and because of code reuse | |||||
*remove|rm* instead of *delete*, *list|ls* instead of only *ls* | |||||
Make channel name equal to email address | |||||
to avoid choosing a new name for the same thing. | |||||
Other more vim-like shortcut changes | |||||
*gm/gM* to sync mail inside *mutt*, as *o/O* has a *mutt* assignment already. | |||||
Honor *$MAILDIR*, *$XDG_CONFIG_HOME*, *$XDG_CACHE_HOME*, if defined. | |||||
`isync`/`mbsync` has replaced `offlineimap` as the backend. | |||||
Offlineimap was error-prone, bloated, used obsolete Python 2 modules and required separate steps to install the system. | |||||
`mw` is now an installed program instead of just a script needed to be kept in your mutt folder. | |||||
`dialog` is no longer used (less bloat) and the interface is simply text commands. | |||||
More autogenerated shortcuts that allow quickly moving and copying mail between boxes. | |||||
More elegant attachment handling. | |||||
Image/video/pdf attachments without relying on the neomutt instance. | |||||
abook integration by default. | |||||
The messy template files and other directories have been moved or removed, leaving a clean config folder. | |||||
msmtp configs moved to `~/.config/` and mail default location moved to `~/Mail`, reducing mess in `~`. | |||||
`pass` is used as a password manager instead of separately saving passwords. | |||||
Script is POSIX sh compliant. | |||||
Addition of a manual `man mw`. |
@@ -1,242 +1,424 @@ | |||||
.TH MW 1 mutt-wizard | |||||
.\" Automatically generated by Pandoc 2.7.3 | |||||
.\" | |||||
.TH "mw" "1" "" "Version 2.0" "mutt-wizard man page" | |||||
.hy | |||||
.SH NAME | .SH NAME | ||||
mw \- mutt-wizard \- autoconfigure email accounts for neomutt and isync | |||||
.PP | |||||
\f[B]mw\f[R] \[em] mutt-wizard - add, list, remove email configurations | |||||
for mbsync, getmail and mutt. | |||||
Sync email without mutt. | |||||
.SH SYNOPSIS | .SH SYNOPSIS | ||||
.B mw | |||||
<command> | |||||
.PP | |||||
\f[B]mw\f[R] [<command>|<email>] | |||||
.PP | |||||
\f[B]mw\f[R] Same as \f[I]mw sync\f[R] | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[B]mw add\f[R] Add and configure an email address (9 max.) | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[B]mw list\f[R] List configured accounts | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[B]mw remove\f[R] Pick an account to remove | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[B]mw purge\f[R] Remove all accounts and settings | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[B]mw cron\f[R] Enable or disable an autosync via cronjob | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[B]mw sync\f[R] Sync mail based on config in | |||||
\f[I].config/isync/mbsyncrc\f[R] and \f[I].config/getmail/*\f[R] | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[B]mw \[en]help|-h\f[R] Print this message | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[B]mw \[en]version|-v\f[R] Print version | |||||
.SH DESCRIPTION | .SH DESCRIPTION | ||||
.B mw | |||||
takes a user email account and sets up a terminal-based email interface with it for | |||||
.B neomutt. | |||||
This can include offline email with | |||||
.B isync/mbsync | |||||
and configs for | |||||
.B msmtp | |||||
for sending mail, and passwords automatically encrypted and stored with | |||||
.B pass. | |||||
.PP | |||||
\f[B]mw\f[R] configures \f[B]mbsync\f[R], \f[B]getmail\f[R], | |||||
\f[B]msmtp\f[R] and \f[B]mutt\f[R] in one go. | |||||
\f[B]mutt\f[R] stands for \f[B]mutt\f[R] or \f[B]neomutt\f[R]. | |||||
.PP | |||||
\f[B]mw\f[R] asks the user for the information it needs. | |||||
They cannot be provided as parameters to the command. | |||||
It is still possible to script \f[B]mw\f[R] by defining variables. | |||||
See the commands section. | |||||
.PP | |||||
\f[I]mutt-wizard.muttrc\f[R] is linked in your \f[I]muttrc\f[R]. | |||||
Have this line there, if you prefer your own settings: | |||||
.IP | |||||
.nf | |||||
\f[C] | |||||
# source /usr/share/mutt-wizard/mutt-wizard.muttrc | |||||
\f[R] | |||||
.fi | |||||
.PP | |||||
You will need to keep the binding of \f[I]i,g,C,M\f[R] to | |||||
\f[I]noop\f[R], though, because of the generated bindings in the account | |||||
muttrc. | |||||
.SH COMMANDS | .SH COMMANDS | ||||
.TP | |||||
.B add | |||||
configure an email account | |||||
.TP | |||||
.B ls | |||||
list all email accounts configured by mutt-wizard | |||||
.TP | |||||
.B delete | |||||
delete the configuration files for an already configured email account | |||||
.TP | |||||
.B purge | |||||
totally purge all local mutt-wizard/mbync/msmtp settings | |||||
.TP | |||||
.B cron | |||||
toggle a cronjob that will automatically sync mail with | |||||
.B mailsync | |||||
as often as you wish | |||||
.PP | |||||
Without command parameter \f[B]sync\f[R] is assumed. | |||||
If the parameter contains \[at] an email is assumed and synced. | |||||
.PP | |||||
\f[I]add\f[R] | |||||
.RS | |||||
.PP | |||||
Add new email | |||||
.PP | |||||
First you decide, whether you want to configure | |||||
.IP \[bu] 2 | |||||
\f[B]mbsync\f[R], \f[B]getmail\f[R], \f[B]msmtp\f[R] to sync emails | |||||
independently from \f[B]mutt\f[R] using \f[B]mw\f[R], | |||||
.IP \[bu] 2 | |||||
or just \f[B]mutt\f[R]. | |||||
For an IMAP server \f[B]mutt\f[R] becomes very slow. | |||||
So normally you enter \f[B]yes\f[R] here. | |||||
.PP | |||||
\f[B]mw\f[R] asks you the \f[B]email address\f[R]. | |||||
.PP | |||||
\f[B]mw\f[R] has a \f[B]database\f[R] of IMAP4/POP3 and SMTP servers and | |||||
ports. | |||||
If you are lucky, your email server is there. | |||||
Else \f[B]mw\f[R] will prompt you. | |||||
.PP | |||||
Add an email without questions, e.g.: | |||||
.IP | |||||
.nf | |||||
\f[C] | |||||
a=x.y\[at]gmail.com mwtype=offline mwaddr=$a mwlogin=$a mwpass=mutt-wizard-$a mwserverinfo=\[dq]gmail.com,imap.gmail.com,993,smtp.gmail.com,587\[dq] mwname=\[dq]your name\[dq] mw add | |||||
\f[R] | |||||
.fi | |||||
.PP | |||||
\f[I]mwserverinfo\f[R] can be omitted, if the email domain is in the | |||||
accompanied \f[I]domains.csv\f[R]. | |||||
.RE | |||||
.PP | |||||
\f[I]ls|list\f[R] | |||||
.RS | |||||
.PP | |||||
List all email accounts configured by mutt-wizard | |||||
.RE | |||||
.PP | |||||
\f[I]rm|remove\f[R] | |||||
.RS | |||||
.PP | |||||
Remove the configuration files for an already configured email | |||||
.PP | |||||
Remove without questions the email whose generated muttrc starts with 1: | |||||
.IP | |||||
.nf | |||||
\f[C] | |||||
mwpick=1 mw rm <<<y | |||||
\f[R] | |||||
.fi | |||||
.RE | |||||
.PP | |||||
\f[I]purge\f[R] | |||||
.RS | |||||
.PP | |||||
Removes all mw generated mutt settings and | |||||
.PP | |||||
\f[I].config/mutt/accounts/1-*\f[R] | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[I].config/isync/mbsyncrc\f[R] | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[I].config/getmail/*\f[R] | |||||
.PD 0 | |||||
.P | |||||
.PD | |||||
\f[I].config/msmtp/config\f[R] | |||||
.PP | |||||
Files are under \f[I].config\f[R] or \f[I]$XDG_CONFIG_HOME\f[R] | |||||
.PP | |||||
If you don\[aq]t want questions: | |||||
.IP | |||||
.nf | |||||
\f[C] | |||||
mw purge <<<y | |||||
\f[R] | |||||
.fi | |||||
.RE | |||||
.PP | |||||
\f[I]cron\f[R] | |||||
.RS | |||||
.PP | |||||
Toggle a cronjob that periodically syncs mail | |||||
.PP | |||||
Without questions: | |||||
.IP | |||||
.nf | |||||
\f[C] | |||||
mwcronremove=yes mw cron | |||||
mwcronminutes=99 mw cron | |||||
\f[R] | |||||
.fi | |||||
.RE | |||||
.PP | |||||
\f[I]sync\f[R] | |||||
.RS | |||||
.PP | |||||
Syncs mail for all email accounts managed by \f[B]mw\f[R] (whose paths | |||||
end in the email). | |||||
.PP | |||||
This is the default, if no parameter is given. | |||||
If an email address is given, only that email is synced. | |||||
.PP | |||||
Every \f[B]mw\f[R] sync run will re-generate the \f[B]mutt\f[R] | |||||
configuration from the configuration files for \f[B]mbsync\f[R], | |||||
\f[B]getmail\f[R] and \f[B]msmtp\f[R]. | |||||
So you could edit them after or not use \f[I]mw add\f[R] at all. | |||||
.PP | |||||
Just keep the \f[I]Path\f[R], \f[I]path\f[R] and \f[I]account\f[R] | |||||
ending in the email address. | |||||
.RE | |||||
.SH DEPENDENCIES | |||||
.PP | |||||
Required for email setup or operation: | |||||
.IP \[bu] 2 | |||||
\f[I]pass\f[R] - pass (https://www.passwordstore.org/) safely encrypts | |||||
passwords | |||||
.IP \[bu] 2 | |||||
\f[I]gnupg\f[R] - needed by \f[I]pass\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]mutt/neomutt\f[R] - the email client (\f[I]mutt\f[R] untested). | |||||
.IP \[bu] 2 | |||||
\f[I]isync\[cq]s mbsync\f[R] - syncs the mail | |||||
.IP \[bu] 2 | |||||
\f[I]getmail\f[R] - used for POP3 | |||||
.IP \[bu] 2 | |||||
\f[I]msmtp\f[R] - sends the email | |||||
.PP | |||||
Optional: | |||||
.IP \[bu] 2 | |||||
\f[I]w3m\f[R] - view HTML email and images in \f[B]mutt\f[R]. | |||||
.IP \[bu] 2 | |||||
\f[I]notmuch\f[R] - index and search mail. | |||||
If the configuration file \f[I]$NOTMUCH_CONFIG\f[R] is not there, | |||||
\f[I]mw add\f[R] will create it. | |||||
.IP \[bu] 2 | |||||
\f[I]libnotify\f[R] - allows notifications when syncing mail with | |||||
\f[B]mw\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]abook\f[R] - a terminal-based address book. | |||||
.IP \[bu] 2 | |||||
A cron manager (e.g.\ *cronie*) - if you want to enable the auto-sync | |||||
feature. | |||||
.IP \[bu] 2 | |||||
\f[I]pam-gnupg\f[R] - To provide your GPG key at login and never after. | |||||
See directions (https://github.com/cruegge/pam-gnupg). | |||||
.RS 2 | |||||
.PP | |||||
Alternatively avoid constant password requests by increasing | |||||
.IP \[bu] 2 | |||||
\f[I]default-cache-ttl\f[R] and \f[I]max-cache-ttl\f[R] in | |||||
\f[I]gpg-agent.conf\f[R] | |||||
.RE | |||||
.IP \[bu] 2 | |||||
\f[I]urlscan\f[R] - outputs urls in mail | |||||
.SH INSTALLATION | |||||
.IP | |||||
.nf | |||||
\f[C] | |||||
git clone https://github.com/rpuntaie/mutt-wizard | |||||
cd mutt-wizard | |||||
sudo make install | |||||
\f[R] | |||||
.fi | |||||
.SH MUTT CONFIGURATION | |||||
.PP | |||||
Once everything is setup, you\[cq]ll use \f[B]mutt\f[R] to access your | |||||
mail. | |||||
.PP | |||||
The accompanied \f[I]mutt-wizard.muttrc\f[R] modifies some | |||||
\f[B]mutt\f[R] defaults. | |||||
Look there for a complete list. | |||||
.PP | |||||
Here an overview: | |||||
.IP \[bu] 2 | |||||
\f[I]?\f[R] - see all keyboard shortcuts | |||||
.PP | |||||
\f[B]syncing\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]gm / gM\f[R] - call mutt-wizard\[cq]s \f[I]mw sync\f[R] for one / | |||||
all mail accounts | |||||
.PP | |||||
\f[B]mailboxes,accounts\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]ixy\f[R] - To go to \f[B]mailbox\f[R]. | |||||
.IP \[bu] 2 | |||||
\f[I]Mxy\f[R], \f[I]Cxy\f[R] - For Move and Copy to the according | |||||
mailbox, e.g.\ *Msp* means \[dq]move to Spam\[dq]. | |||||
.IP \[bu] 2 | |||||
\f[I]i[1-9]\f[R] - go to another \f[B]account\f[R]. | |||||
.RS 2 | |||||
.PP | |||||
\f[I]xy\f[R] are | |||||
.IP \[bu] 2 | |||||
the two first letters of a mailbox or | |||||
.IP \[bu] 2 | |||||
first letter of first + second letter of second path entry | |||||
.RE | |||||
.PP | |||||
\f[B]searching\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]S\f[R] - search for a mail using \f[I]notmuch\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]gl\f[R] - limit by substring of subject | |||||
.IP \[bu] 2 | |||||
\f[I]gL\f[R] - undo limit | |||||
.PP | |||||
\f[B]composing\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]ga\f[R] - to add address/person to \f[I]abook\f[R] and | |||||
\f[I]Tab\f[R] while typing address to complete one from book. | |||||
.IP \[bu] 2 | |||||
\f[I]m/r/gr/f\f[R] - new/reply/group reply/forward \f[B]message\f[R], | |||||
using your default \f[I]$EDITOR\f[R] to write. | |||||
Then you enter the \f[B]compose screen\f[R]. | |||||
.IP \[bu] 2 | |||||
\f[I]a\f[R] - to add attachments | |||||
.IP \[bu] 2 | |||||
\f[I]s/t/c/b/d\f[R] - to change the subject/to/CC/BCC/description. | |||||
.IP \[bu] 2 | |||||
\f[I]S\f[R] - to change the signature/encryption | |||||
.IP \[bu] 2 | |||||
\f[I]y\f[R] - to send the mail. | |||||
.PP | |||||
\f[B]delete,undelete,save\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]dd\f[R] - delete mail | |||||
.IP \[bu] 2 | |||||
\f[I]u\f[R] - undelete | |||||
.IP \[bu] 2 | |||||
\f[I]$\f[R] - apply the mailbox changes \f[I]set trash\f[R] is set per | |||||
default. | |||||
Deleted mails will land there. | |||||
.IP \[bu] 2 | |||||
\f[I]s\f[R] - save selected mail or selected attachment | |||||
.PP | |||||
\f[B]moving around\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]gu\f[R] - open a menu to select a url you want to open in you | |||||
browser (needs urlscan). | |||||
.IP \[bu] 2 | |||||
\f[I]j\f[R]/\f[I]k\f[R] - next/previous mail, \f[I]J/K\f[R] same, | |||||
without skipping deleted, and also when viewing mails | |||||
.IP \[bu] 2 | |||||
\f[I]ctrl-d/f\f[R]/\f[I]ctrl-u/b\f[R] - down and up a half page / full | |||||
page | |||||
.IP \[bu] 2 | |||||
\f[I]l\f[R] - open mail, or attachment page or attachment | |||||
.IP \[bu] 2 | |||||
\f[I]h\f[R] - the opposite of \f[I]l\f[R] | |||||
.PP | |||||
\f[B]sidebar\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]B\f[R] - toggles | |||||
.IP \[bu] 2 | |||||
\f[I]ctrl-j\f[R]/\f[I]ctrl-k\f[R] - move up and down | |||||
.IP \[bu] 2 | |||||
\f[I]ctrl-l/o\f[R] - opens mailbox | |||||
.PP | |||||
\f[B]input field/command line\f[R] | |||||
.IP \[bu] 2 | |||||
\f[I]ctrl-u\f[R] clears the line | |||||
.IP \[bu] 2 | |||||
\f[I]ctrl-a\f[R], \f[I]ctrl-e\f[R] go to beginning or end | |||||
.IP \[bu] 2 | |||||
\f[I]ctrl-g\f[R] aborts | |||||
.SH DETAILS | .SH DETAILS | ||||
.PP | |||||
\f[B]Encoding/Language\f[R] | |||||
.RS | |||||
.PP | |||||
\f[I]isync\f[R] is not fully UTF-8 compatible. | |||||
\f[B]mw\f[R] assumes english mailbox names. | |||||
Set your email language to English on your mail server. | |||||
.RE | |||||
.PP | |||||
\f[B]Mail location\f[R] | |||||
.RS | |||||
.PP | |||||
Mail is downloaded to a folders named after your emails in | |||||
\f[I]$MAILDIR\f[R]. | |||||
\f[I]$MAILDIR\f[R] defaults to \f[I]$HOME/Mail/\f[R]. | |||||
Neither \f[B]mw remove\f[R] nor \f[B]mw purge\f[R] will delete | |||||
downloaded mail. | |||||
.RE | |||||
.PP | |||||
\f[B]Gmail accounts\f[R] | |||||
.RS | |||||
.PP | |||||
For Gmail allow \[dq]less-secure\[dq] applications: | |||||
<<https://support.google.com/accounts/answer/6010255>>. | |||||
Do this before running mutt-wizard. | |||||
.RE | |||||
.PP | |||||
\f[B]Protonmail accounts\f[R] | |||||
.RS | |||||
.PP | |||||
Protonmail users must use the Protonmail Bridge | |||||
<<https://protonmail.com/bridge/>> to access their IMAP and SMTP | |||||
servers. | |||||
Do this before running mutt-wizard. | |||||
.RE | |||||
.SH FILES | |||||
.TP | .TP | ||||
.B Mail location | |||||
If the user chooses to keep offline email with | |||||
.B isync, | |||||
it will be kept in | |||||
.I $MAILDIR | |||||
which defaults to | |||||
.I $HOME/mail/. | |||||
.B notmuch | |||||
can be used to index and search this mail by giving this directory when first running | |||||
.B notmuch setup. | |||||
If you have not set up notmuch before, mutt-wizard will automatically set it up in the background the first time you add an account. | |||||
.TP | |||||
.B muttrc files | |||||
mutt-wizard will create a muttrc file for each created account holding account-specific details. These will appear in | |||||
.I $XDG_CONFIG_HOME/mutt/accounts/. | |||||
$XGD_CONFIG_HOME default to ~/.config. | |||||
Note that mutt-wizard will also source these files and create the bindings to switch between them, and these will appear in your default | |||||
.I $XDG_CONFIG_HOME/mutt/muttrc | |||||
file. | |||||
.TP | |||||
.B Mail deletion | |||||
Neither | |||||
.B delete | |||||
or | |||||
.B purge | |||||
will delete downloaded mail for for safety (and time)'s sake. If you want to delete downloaded mail, do so manually by removing it from the directory above. | |||||
.TP | |||||
.B Default settings | |||||
mutt-wizard has many default settings that focus on making it aesthetically pleasing and supplying more vim-like bindings. These can be found in | |||||
.I /usr/share/mutt-wizard/mutt-wizard.muttrc | |||||
and the default mailcap file can be found in | |||||
.I | |||||
/usr/share/mutt-wizard/mailcap. | |||||
Any of these settings can be overwritten in | |||||
.I $XDG_CONFIG_HOME/mutt/muttrc, | |||||
but be mindful that your overriding binds should appear after the | |||||
.I | |||||
mutt-wizard.muttrc | |||||
file is sourced. | |||||
.TP | |||||
.B Detecting server settings | |||||
mutt-wizard has a repository of email services and their server information kept in | |||||
.I /usr/share/mutt-wizard/domains.csv | |||||
which is used to automatically configure email settings. | |||||
If your email provider is not found there, it will prompt you to input your email service's IMAP and SMTP server information which can usually be found by searching online. | |||||
If you would like to help develop mutt-wizard for others, you are invited to add this service information to | |||||
.I domains.csv | |||||
on mutt-wizard's Github <https://github.com/lukesmithxyz/mutt-wizard> or Gitlab <https://gitlab.com/lukesmithxyz/mutt-wizard> pages. | |||||
.B \f[I]/user/bin/mw\f[R] | |||||
The main script to manage and sync emails. | |||||
.TP | .TP | ||||
.B Gmail accounts | |||||
Google will require you to allow "less-secure" (third party) applications or use two-factor authentication in order to access their IMAP servers to download your mail. | |||||
If you use Gmail, be sure to handle this before running mutt-wizard <https://support.google.com/accounts/answer/6010255>. | |||||
.B Protonmail accounts | |||||
Protonmail users must use the Protonmail Bridge <https://protonmail.com/bridge/> to access their IMAP and SMTP servers. | |||||
This too should be configured before running mutt-wizard. | |||||
.B Enterprise and university accounts | |||||
Many universities and businesses might host their domain's email via Google or another service. | |||||
This often requires a special IMAP/SMTP-specific password that you must generate and use. | |||||
Again, mutt-wizard can handle these systems, but only once they've been set up. | |||||
.B \f[I]/user/bin/mwimage\f[R], \f[I]/user/bin/mwopen\f[R] | |||||
Used by the mailcap file that comes with mutt-wizard. | |||||
.TP | .TP | ||||
.B Password decryption | |||||
mutt-wizard uses | |||||
.I pass | |||||
and therefore | |||||
.I gpg | |||||
to decrypt your passwords. | |||||
Provided your GPG key has a password, this might mean that you will be prompted for your GPG password the first time you sync or send mail in a session. | |||||
Once your password is cached, it might also expire later as well. | |||||
Because of this I strongly recommend the program | |||||
.I pam-gnupg | |||||
<https://github.com/cruegge/pam-gnupg> which automatically unlocks your GPG password on login and keeps it active. | |||||
This gives you secure access to all your email accounts on your system without ever having to input a password. | |||||
If you don't want to use this program, you can also increase the cache time of an inputted GPG password with the | |||||
.I default-cache-ttl | |||||
and | |||||
.I max-cache-ttl | |||||
variables in your | |||||
.I | |||||
gpg-agent.conf. | |||||
.SH MUTT-WIZARD'S NEOMUTT CONFIGURATION | |||||
Here is a list of not only mutt-wizard's particular defaults, but what you need, to get the most out of email accounts configured with mutt-wizard. | |||||
.B \f[I]/usr/share/mutt-wizard/mutt-wizard.muttrc\f[R] | |||||
Default mutt settings. | |||||
.TP | .TP | ||||
.B Color | |||||
mutt-wizard's default settings add color to messages in the index and color mail details to make them easier to see. | |||||
New mail, in addition to being marked by the typical N, will also be bold. | |||||
.B \f[I]/usr/share/mutt-wizard/mailcap\f[R] | |||||
Default mailcap file. | |||||
.TP | .TP | ||||
.B Movement with h/j/k/l | |||||
Use vim keys to move down | |||||
.I j | |||||
or up | |||||
.I k | |||||
in mail, while | |||||
.I l | |||||
opens mail, then the attachment view, then an attachment, while | |||||
.I h | |||||
is the reverse. | |||||
While mail is open, go to next or previous mail with | |||||
.I J | |||||
and | |||||
.I K. | |||||
In the mail index, | |||||
.I d | |||||
and | |||||
.I u | |||||
go down and up by a half page and | |||||
.I gg | |||||
and | |||||
.I G | |||||
go to the very top and very bottom. | |||||
.TP | |||||
.B Search mail | |||||
If you have | |||||
.B notmuch | |||||
configured with your proper mail directory (see above), you may run | |||||
.I ctrl-f | |||||
to search for mail containing any given sequence. | |||||
Even without notmuch, | |||||
.I L | |||||
limits mail, showing only those with the given sequence in the subject while | |||||
.I A | |||||
shows all mail (same as limiting to "all"). | |||||
.TP | |||||
.B Deleting mail | |||||
.I D | |||||
deletes mail, while | |||||
.I U | |||||
undeletes it (type in mail number to get to deleted mail). Note that | |||||
.I S | |||||
saves your mailbox, finalizing deletion. If you have a | |||||
.I Trash | |||||
box, deleted mail is moved there. If you want it to skip that and simply be deleted, comment out or remove the | |||||
.I set trash | |||||
line in that account's muttrc. | |||||
.TP | |||||
.B Send mail | |||||
.I m | |||||
creates a new mail message; | |||||
.I r | |||||
replies to the selected message; | |||||
.I R | |||||
replies all to the selected message and | |||||
.I f | |||||
fowards the selected message. | |||||
.TP | |||||
.B Compose mail screen | |||||
Once you write mail and save the buffer you will be brought to the compose screen. Press | |||||
.I a | |||||
to add attachments, use | |||||
.I s/t/c/b/d | |||||
to change the subject/to/CC/BCC/description. Press | |||||
.I S | |||||
to change the signature/encryption. Press | |||||
.I y | |||||
to send the mail. | |||||
.TP | |||||
.B Saving and autocompleting email addresses with abook | |||||
Install the optional dependency abook and you will be able to save the sender's email address with | |||||
.I a. | |||||
Once this is done, when you are typing in any email/contact prompt, you may press | |||||
.I Tab | |||||
to find contacts matching your input. Although abook is often used with mutt, it is also a useful program in its own right. | |||||
.TP | |||||
.B Switching and moving mail between mailboxes | |||||
The | |||||
.I g | |||||
key can be paired with several other keys to automatically move to another mailbox: gi: Inbox; gs: Sent; gd: Drafts; ga: Archive; gS: Spam; gj: Junk; gt: Trash. These bindings will only be present for accounts that have the boxes in question. Instead of | |||||
.I g, | |||||
you can also press | |||||
.I C | |||||
to copy mail or | |||||
.I M | |||||
to move mail to the same boxes. | |||||
.TP | |||||
.B Switching between accounts | |||||
mutt-wizard can configure as many as nine accounts each numbered by the lowest available number when configured. Press | |||||
.I i | |||||
followed by an account's number to change to that account: i2, i5, etc. | |||||
.I ctrl-b | |||||
to open a menu to select a url you want to open in you browser. | |||||
.B \f[I]/usr/share/mutt-wizard/domains.csv\f[R] | |||||
Email server database. | |||||
.SH BUGS | |||||
.PP | |||||
GitHub Issues: <<https://github.com/rpuntaie/mutt-wizard/issues>> | |||||
.SH AUTHORS | |||||
.TP | .TP | ||||
.B Sidebar | |||||
mutt-wizard enables the sidebar by default which displays your account's boxes with mail tallies. | |||||
.I B | |||||
will toggle the sidebar. Move up and down in it with | |||||
.I ctrl-k/j. | |||||
Open a box with | |||||
.I ctrl-o. | |||||
.B \f[I]Luke Smith\f[R] <<luke@lukesmith.xyz>> | |||||
Original author, started in 2018. | |||||
.RS | |||||
.PP | |||||
Github <<https://github.com/lukesmithxyz/mutt-wizard>> | |||||
.PP | |||||
Gitlab <<https://gitlab.com/lukesmithxyz/mutt-wizard>> | |||||
.RE | |||||
.TP | .TP | ||||
.B More information | |||||
Remember that you can press | |||||
.I ? | |||||
at any time in neomutt to get a list of all key-bindings and functions. This list can also vary for different context menus. | |||||
.SH AUTHORS | |||||
Written by Luke Smith <luke@lukesmith.xyz> originally in 2018. | |||||
.B \f[I]Roland Puntaier\f[R] <<roland.puntaier@gmail.com>> | |||||
Bugfixes, Improvements in 2019. | |||||
.RS | |||||
.PP | |||||
GitHub: <<https://github.com/rpuntaie/mutt-wizard>> | |||||
.RE | |||||
.SH LICENSE | .SH LICENSE | ||||
.PP | |||||
GPLv3 | GPLv3 | ||||
.SH SEE ALSO | .SH SEE ALSO | ||||
.BR neomutt (1), | |||||
.BR neomuttrc (1) | |||||
.BR mbsync (1), | |||||
.BR msmtp (1), | |||||
.BR notmuch (1), | |||||
.BR abook (1) | |||||
.PP | |||||
\f[B]neomutt\f[R](1), \f[B]neomuttrc\f[R](1) \f[B]mbsync\f[R](1), | |||||
\f[B]msmtp\f[R](1), \f[B]notmuch\f[R](1), \f[B]abook\f[R](1) |
@@ -157,6 +157,7 @@ inventati.org,mail.autistici.org,993,smtp.autistici.org,465 | |||||
itu.dk,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | itu.dk,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | ||||
kipras.org,mail.kipras.org,993,mail.kipras.org,587 | kipras.org,mail.kipras.org,993,mail.kipras.org,587 | ||||
krutt.org,mail.autistici.org,993,smtp.autistici.org,465 | krutt.org,mail.autistici.org,993,smtp.autistici.org,465 | ||||
kth.se,webmail.kth.se,993,smtp.kth.se,587 | |||||
lavabit.com,lavabit.com,993,lavabit.com,587 | lavabit.com,lavabit.com,993,lavabit.com,587 | ||||
linuxmail.org,imap.mail.com,993,smtp.mail.com,587 | linuxmail.org,imap.mail.com,993,smtp.mail.com,587 | ||||
live.com,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | live.com,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | ||||
@@ -263,3 +264,5 @@ yandex.net,imap.yandex.com,993,smtp.yandex.com,587 | |||||
yandex.ru,imap.yandex.com,993,smtp.yandex.com,587 | yandex.ru,imap.yandex.com,993,smtp.yandex.com,587 | ||||
yandex.ua,imap.yandex.com,993,smtp.yandex.com,587 | yandex.ua,imap.yandex.com,993,smtp.yandex.com,587 | ||||
zoho.com,imap.zoho.com,993,smtp.zoho.com,465 | zoho.com,imap.zoho.com,993,smtp.zoho.com,465 | ||||
mailo.com,mail.mailo.com,993,mail.mailo.com,465 | |||||
chello.at,mail.upcmail.at,995,mail.upcmail.at,465 |
@@ -1,7 +1,7 @@ | |||||
text/plain; $EDITOR %s ; | text/plain; $EDITOR %s ; | ||||
text/html; openfile %s ; nametemplate=%s.html | |||||
text/html; mwopen %s ; nametemplate=%s.html | |||||
text/html; w3m -I %{charset} -T text/html; copiousoutput; | text/html; w3m -I %{charset} -T text/html; copiousoutput; | ||||
image/*; muttimage %s ; copiousoutput | |||||
image/*; mwimage %s ; copiousoutput | |||||
video/*; setsid mpv --quiet %s &; copiousoutput | video/*; setsid mpv --quiet %s &; copiousoutput | ||||
application/pdf; openfile %s ; | |||||
application/pdf; mwopen %s ; | |||||
application/pgp-encrypted; gpg -d '%s'; copiousoutput; | application/pgp-encrypted; gpg -d '%s'; copiousoutput; |
@@ -1,8 +1,15 @@ | |||||
# vim: filetype=neomuttrc | # vim: filetype=neomuttrc | ||||
# This file contains all of mutt-wizard's default settings. | |||||
# | |||||
# This file contains all of mutt-wizard's defaults. | |||||
# mutt-wizard will have this file sourced from your muttrc. | # mutt-wizard will have this file sourced from your muttrc. | ||||
# The vim-like key binding has been established by comparing different dotfiles. | |||||
# You can change bindings after the sourcing of the defaults. | |||||
# Or you can keep mutt-wizard from sourcing its defaults with this comment in your muttrc: | |||||
# #source /usr/share/mutt-wizard/mutt-wizard.muttrc | |||||
# | |||||
# In the interest of seamless updating, do not edit this file. | # In the interest of seamless updating, do not edit this file. | ||||
# If you want to override any settings, set those in your muttrc. | |||||
# ==================== SETTINGS ==================== # | |||||
set mailcap_path = /usr/share/mutt-wizard/mailcap | set mailcap_path = /usr/share/mutt-wizard/mailcap | ||||
set date_format="%y/%m/%d %I:%M%p" | set date_format="%y/%m/%d %I:%M%p" | ||||
set index_format="%2C %zs %?X?A& ? %D %-15.15F %s (%-4.4c)" | set index_format="%2C %zs %?X?A& ? %D %-15.15F %s (%-4.4c)" | ||||
@@ -10,64 +17,21 @@ set sort = 'reverse-date' | |||||
set smtp_authenticators = 'gssapi:login' | set smtp_authenticators = 'gssapi:login' | ||||
set query_command = "abook --mutt-query '%s'" | set query_command = "abook --mutt-query '%s'" | ||||
set rfc2047_parameters = yes | set rfc2047_parameters = yes | ||||
set sleep_time = 0 # Pause 0 seconds for informational messages | |||||
set markers = no # Disables the `+` displayed at line wraps | |||||
set mark_old = no # Unread mail stay unread until read | |||||
set mime_forward = yes # attachments are forwarded with mail | |||||
set wait_key = no # mutt won't ask "press key to continue" | |||||
set fast_reply # skip to compose when replying | |||||
set fcc_attach # save attachments with the body | |||||
set forward_format = "Fwd: %s" # format of subject when forwarding | |||||
set forward_quote # include message in forwards | |||||
set reverse_name # reply as whomever it was to | |||||
set include # include message in replies | |||||
set mail_check=60 # to avoid lags using IMAP with some email providers (yahoo for example) | |||||
auto_view text/html # automatically show html (mailcap uses w3m) | |||||
set sleep_time = 0 # Pause 0 seconds for informational messages | |||||
set markers = no # Disables the `+` displayed at line wraps | |||||
set mark_old = no # Unread mail stay unread until read | |||||
set mime_forward = yes # attachments are forwarded with mail | |||||
set wait_key = no # mutt won't ask "press key to continue" | |||||
set fast_reply # skip to compose when replying | |||||
set fcc_attach # save attachments with the body | |||||
set forward_format = "Fwd: %s" # format of subject when forwarding | |||||
set forward_quote # include message in forwards | |||||
set reverse_name # reply as whomever it was to | |||||
set include # include message in replies | |||||
set mail_check=60 # to avoid lags using IMAP with some email providers (yahoo for example) | |||||
auto_view text/html # automatically show html (mailcap uses w3m) | |||||
auto_view application/pgp-encrypted | auto_view application/pgp-encrypted | ||||
alternative_order text/plain text/enriched text/html | alternative_order text/plain text/enriched text/html | ||||
bind index,pager i noop | |||||
bind index,pager g noop | |||||
bind index,pager M noop | |||||
bind index,pager C noop | |||||
bind index \Cf noop | |||||
# General rebindings | |||||
bind attach <return> view-mailcap | |||||
bind attach l view-mailcap | |||||
bind editor <space> noop | |||||
bind pager,attach h exit | |||||
bind pager j next-line | |||||
bind pager k previous-line | |||||
bind pager l view-attachments | |||||
bind index gg first-entry | |||||
bind index G last-entry | |||||
bind index D delete-message | |||||
bind index U undelete-message | |||||
bind index L limit | |||||
bind index h noop | |||||
bind index l display-message | |||||
#bind browser h goto-parent | |||||
macro browser h '<change-dir><kill-line>..<enter>' "Go to parent folder" | |||||
bind index,pager H view-raw-message | |||||
bind browser l select-entry | |||||
bind pager,browser gg top-page | |||||
bind pager,browser G bottom-page | |||||
bind index,pager,browser d half-down | |||||
bind index,pager,browser u half-up | |||||
bind index,pager S sync-mailbox | |||||
bind index,pager R group-reply | |||||
bind index \031 previous-undeleted # Mouse wheel | |||||
bind index \005 next-undeleted # Mouse wheel | |||||
bind pager \031 previous-line # Mouse wheel | |||||
bind pager \005 next-line # Mouse wheel | |||||
bind editor <Tab> complete-query | |||||
macro index,pager a "|abook --add-email\n" 'add sender to abook' | |||||
macro index \Cr "T~U<enter><tag-prefix><clear-flag>N<untag-pattern>.<enter>" "mark all messages as read" | |||||
macro index \Cf "<enter-command>unset wait_key<enter><shell-escape>read -p 'Enter a search term to find with notmuch: ' x; echo \$x >\${XDG_CACHE_HOME:-~/.cache}/mutt_terms<enter><limit>~i \"\`notmuch search --output=messages \$(cat \${XDG_CACHE_HOME:-~/.cache}/mutt_terms) | head -n 600 | perl -le '@a=<>;s/\^id:// for@a;$,=\"|\";print@a' | perl -le '@a=<>; chomp@a; s/\\+/\\\\+/ for@a;print@a' \`\"<enter>" "show only messages matching a notmuch pattern" | |||||
macro index A "<limit>all\n" "show all messages (undo limit)" | |||||
# Sidebar mappings | # Sidebar mappings | ||||
set sidebar_visible = yes | set sidebar_visible = yes | ||||
set sidebar_width = 20 | set sidebar_width = 20 | ||||
@@ -75,6 +39,62 @@ set sidebar_short_path = yes | |||||
set sidebar_next_new_wrap = yes | set sidebar_next_new_wrap = yes | ||||
set mail_check_stats | set mail_check_stats | ||||
set sidebar_format = '%B%?F? [%F]?%* %?N?%N/? %?S?%S?' | set sidebar_format = '%B%?F? [%F]?%* %?N?%N/? %?S?%S?' | ||||
# ==================== settings ==================== # | |||||
# =================== SHORTCUTS ==================== # | |||||
# Non-standard, more vim-like key mappings | |||||
# | |||||
# Free keys | |||||
bind index h noop | |||||
bind index,pager d noop #used for dX | |||||
bind index,pager i noop #used for goto iXY and i[1-9] in account muttrc (XY = 2 mailbox letters) | |||||
bind index,pager M noop #used for CXY, "move" to XY in account muttrc | |||||
bind index,pager C noop #used for CXY, "copy" to XY in account muttrc | |||||
bind pager,attach,browser,index g noop | |||||
# Moving between views the vim way | |||||
bind attach,index gg first-entry | |||||
bind attach,index G last-entry | |||||
bind pager,browser gg top-page | |||||
bind pager,browser G bottom-page | |||||
bind pager G bottom | |||||
bind pager k previous-line | |||||
bind pager j next-line | |||||
# l gets from index to mail to attachents to system view via mailcap | |||||
# h back vim-like (q by mutt) | |||||
bind index l display-message | |||||
bind browser l select-entry | |||||
bind pager l view-attachments | |||||
bind attach l view-mailcap | |||||
bind attach <return> view-mailcap | |||||
bind pager,attach h exit | |||||
macro browser h '<change-dir><kill-line>..<enter>' "Go to parent folder" | |||||
# Moving inside view as in vim | |||||
bind attach,index,pager,browser \Cd half-down | |||||
bind attach,index,pager,browser \Cu half-up | |||||
bind attach,browser,pager,index \Cf next-page | |||||
bind attach,browser,pager,index \Cb previous-page | |||||
bind browser,pager,index \Ce next-line | |||||
bind browser,pager,index \Cy previous-line | |||||
# and using mouse | |||||
bind index \031 previous-undeleted # Mouse wheel | |||||
bind index \005 next-undeleted # Mouse wheel | |||||
bind pager \031 previous-line # Mouse wheel | |||||
bind pager \005 next-line # Mouse wheel | |||||
# | |||||
# Using other dX and gX keys | |||||
bind index gl limit | |||||
macro index gL "<limit>all\n" "show all messages (undo limit)" | |||||
# Threads | |||||
bind browser,pager,index N search-opposite | |||||
bind pager,index dT delete-thread | |||||
bind pager,index dt delete-subthread | |||||
bind pager,index gt next-thread | |||||
bind pager,index gT previous-thread | |||||
bind index za collapse-thread | |||||
bind index zA collapse-all | |||||
bind index - collapse-thread | |||||
bind index _ collapse-all | |||||
# Sidebar (J/K goes to previou/next mail by mutt) | |||||
bind index,pager \Ck sidebar-prev | bind index,pager \Ck sidebar-prev | ||||
bind index,pager \Cj sidebar-next | bind index,pager \Cj sidebar-next | ||||
bind index,pager \Co sidebar-open | bind index,pager \Co sidebar-open | ||||
@@ -82,19 +102,37 @@ bind index,pager \Cl sidebar-open | |||||
bind index,pager \Cp sidebar-prev-new | bind index,pager \Cp sidebar-prev-new | ||||
bind index,pager \Cn sidebar-next-new | bind index,pager \Cn sidebar-next-new | ||||
bind index,pager B sidebar-toggle-visible | bind index,pager B sidebar-toggle-visible | ||||
# Edit the vim way | |||||
# D, U = delete/undelete by pattern by mutt | |||||
bind pager,index dd delete-message #u is undelete by mutt | |||||
bind index,pager gr group-reply #R is recall postponed by mutt | |||||
bind editor <space> noop | |||||
bind editor <Tab> complete-query | |||||
bind index,pager V view-raw-message | |||||
# Other | |||||
bind pager t display-toggle-weed | |||||
# | |||||
# Macros | |||||
macro index \Cr "<tag-pattern>~U<enter>\ | |||||
<tag-prefix><clear-flag>N<untag-pattern>.<enter>" \ | |||||
"mark all messages as read" | |||||
macro index,pager ga "|abook --add-email\n" 'add sender to abook' #"a" alone, add to alias | |||||
macro index S "<enter-command>unset wait_key<enter><shell-escape>read -p 'Enter a search term to find with notmuch: ' x; echo \$x >\${XDG_CACHE_HOME:-~/.cache}/mutt_terms<enter><limit>~i \"\`notmuch search --output=messages \$(cat \${XDG_CACHE_HOME:-~/.cache}/mutt_terms) | head -n 600 | perl -le '@a=<>;s/\^id:// for@a;$,=\"|\";print@a' | perl -le '@a=<>; chomp@a; s/\\+/\\\\+/ for@a;print@a' \`\"<enter>" \ | |||||
"show only messages matching a notmuch pattern" | |||||
macro pager gu "|urlscan<enter>" "call urlscan to open links" | |||||
# =================== shortcuts ==================== # | |||||
# Default index colors: | |||||
## ===================== COLOR ===================== # | |||||
# Default index colors | |||||
color index yellow default '.*' | color index yellow default '.*' | ||||
color index_author red default '.*' | color index_author red default '.*' | ||||
color index_number blue default | color index_number blue default | ||||
color index_subject cyan default '.*' | color index_subject cyan default '.*' | ||||
# New mail is boldened: | |||||
# New mail is boldened | |||||
color index brightyellow black "~N" | color index brightyellow black "~N" | ||||
color index_author brightred black "~N" | color index_author brightred black "~N" | ||||
color index_subject brightcyan black "~N" | color index_subject brightcyan black "~N" | ||||
# Other colors and aesthetic settings: | |||||
# Other colors and aesthetic settings | |||||
mono bold bold | mono bold bold | ||||
mono underline underline | mono underline underline | ||||
mono indicator reverse | mono indicator reverse | ||||
@@ -124,8 +162,7 @@ color signature brightgreen default | |||||
color bold black default | color bold black default | ||||
color underline black default | color underline black default | ||||
color normal default default | color normal default default | ||||
# Regex highlighting: | |||||
# Regex highlighting | |||||
color header blue default ".*" | color header blue default ".*" | ||||
color header brightmagenta default "^(From)" | color header brightmagenta default "^(From)" | ||||
color header brightcyan default "^(Subject)" | color header brightcyan default "^(Subject)" | ||||
@@ -149,3 +186,4 @@ color body brightyellow red "^gpg: BAD signature from.*" | |||||
mono body bold "^gpg: Good signature" | mono body bold "^gpg: Good signature" | ||||
mono body bold "^gpg: BAD signature from.*" | mono body bold "^gpg: BAD signature from.*" | ||||
color body red default "([a-z][a-z0-9+-]*://(((([a-z0-9_.!~*'();:&=+$,-]|%[0-9a-f][0-9a-f])*@)?((([a-z0-9]([a-z0-9-]*[a-z0-9])?)\\.)*([a-z]([a-z0-9-]*[a-z0-9])?)\\.?|[0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+)(:[0-9]+)?)|([a-z0-9_.!~*'()$,;:@&=+-]|%[0-9a-f][0-9a-f])+)(/([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*(;([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*)*(/([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*(;([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*)*)*)?(\\?([a-z0-9_.!~*'();/?:@&=+$,-]|%[0-9a-f][0-9a-f])*)?(#([a-z0-9_.!~*'();/?:@&=+$,-]|%[0-9a-f][0-9a-f])*)?|(www|ftp)\\.(([a-z0-9]([a-z0-9-]*[a-z0-9])?)\\.)*([a-z]([a-z0-9-]*[a-z0-9])?)\\.?(:[0-9]+)?(/([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*(;([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*)*(/([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*(;([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*)*)*)?(\\?([-a-z0-9_.!~*'();/?:@&=+$,]|%[0-9a-f][0-9a-f])*)?(#([-a-z0-9_.!~*'();/?:@&=+$,]|%[0-9a-f][0-9a-f])*)?)[^].,:;!)? \t\r\n<>\"]" | color body red default "([a-z][a-z0-9+-]*://(((([a-z0-9_.!~*'();:&=+$,-]|%[0-9a-f][0-9a-f])*@)?((([a-z0-9]([a-z0-9-]*[a-z0-9])?)\\.)*([a-z]([a-z0-9-]*[a-z0-9])?)\\.?|[0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+)(:[0-9]+)?)|([a-z0-9_.!~*'()$,;:@&=+-]|%[0-9a-f][0-9a-f])+)(/([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*(;([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*)*(/([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*(;([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*)*)*)?(\\?([a-z0-9_.!~*'();/?:@&=+$,-]|%[0-9a-f][0-9a-f])*)?(#([a-z0-9_.!~*'();/?:@&=+$,-]|%[0-9a-f][0-9a-f])*)?|(www|ftp)\\.(([a-z0-9]([a-z0-9-]*[a-z0-9])?)\\.)*([a-z]([a-z0-9-]*[a-z0-9])?)\\.?(:[0-9]+)?(/([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*(;([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*)*(/([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*(;([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*)*)*)?(\\?([-a-z0-9_.!~*'();/?:@&=+$,]|%[0-9a-f][0-9a-f])*)?(#([-a-z0-9_.!~*'();/?:@&=+$,]|%[0-9a-f][0-9a-f])*)?)[^].,:;!)? \t\r\n<>\"]" | ||||
## ===================== color ===================== # |
@@ -6,50 +6,50 @@ echo | |||||
bats --tap test_mw.bats | bats --tap test_mw.bats | ||||
echo | echo | ||||
echo Integration tests with a working email: | |||||
echo | |||||
echo "Integration tests need working email $mwaddr" | |||||
echo "CTRL-C to skip" | |||||
#modify | #modify | ||||
if [[ -z $MAILDIR ]] || [[ -z $mwaddr ]]; then | |||||
if [ -z "$MAILDIR" ] || [ -z "$mwaddr" ]; then | |||||
echo "First do:" | echo "First do:" | ||||
[[ -z $MAILDIR ]] && echo "export MAILDIR=..." | |||||
[[ -z $mwaddr ]] && echo "export mwaddr=your.email@gmail.com" | |||||
[ -z "$MAILDIR" ] && echo "export MAILDIR=..." | |||||
[ -z "$mwaddr" ] && echo "export mwaddr=your.email@gmail.com" | |||||
exit | exit | ||||
fi | fi | ||||
cd .. && sudo make install && OK="OK" | cd .. && sudo make install && OK="OK" | ||||
if [[ "$OK" == "OK" ]]; then | |||||
if [ "$OK" = "OK" ]; then | |||||
echo "Warning: Out with CTRL-C if your mail (config) files are important here." | echo "Warning: Out with CTRL-C if your mail (config) files are important here." | ||||
export mwmaildir=$MAILDIR | export mwmaildir=$MAILDIR | ||||
export mwname='r n' | export mwname='r n' | ||||
export mwlogin=$mwaddr | export mwlogin=$mwaddr | ||||
export mwpass="${mwpass:-mutt-wizard-$mwaddr}" | export mwpass="${mwpass:-mutt-wizard-$mwaddr}" | ||||
mwaccmutt="${mwaddr//[.@]/_}" | |||||
mwaccmaildir="$mwmaildir/$mwaccmutt" # folder name as shown by mutt and opens with gf in vim | |||||
mwaccmaildir="$mwmaildir/$mwaddr" | |||||
rm -rf $mwaccmaildir | rm -rf $mwaccmaildir | ||||
[ -f "${PASSWORD_STORE_DIR:-~/.password-store}/$mwpass.gpg" ] || pass insert $mwpass | [ -f "${PASSWORD_STORE_DIR:-~/.password-store}/$mwpass.gpg" ] || pass insert $mwpass | ||||
echo "= manual test 1 =" | |||||
echo "= Test 1 =" | |||||
mwtype=online mw add | mwtype=online mw add | ||||
echo "=> In another window, start mutt and verify that mails are shown" | |||||
echo "=> Then anwer with N" | |||||
echo "=> In another prompt, start mutt and verify that mails are shown" | |||||
echo "=> Then answer with N" | |||||
mw purge | mw purge | ||||
rm -rf $mwaccmaildir | rm -rf $mwaccmaildir | ||||
echo "= manual test 2 =" | |||||
echo "= Test 2 =" | |||||
mwtype=offline mw add | mwtype=offline mw add | ||||
mailsync | |||||
echo "=> In another window, start mutt and verify that mails are shown" | |||||
mw | |||||
echo "=> In another prompt, start mutt and verify that mails are shown" | |||||
echo "=> Press i1, wait, press i2. Verify that mutt is fast again after i2." | echo "=> Press i1, wait, press i2. Verify that mutt is fast again after i2." | ||||
echo "=> Press gm and gM, to start mailsync." | |||||
echo "=> Anwer with y." | |||||
echo "=> Press gm and gM, to start mw sync." | |||||
echo "=> Answer with Y and check that mbsyncrc, msmtp/config and mutt/accounts are gone." | |||||
mw purge | mw purge | ||||
rm -rf $mwaccmaildir | |||||
fi | fi | ||||
cd $CD | cd $CD |
@@ -12,22 +12,35 @@ run_only_test() { | |||||
fi | fi | ||||
} | } | ||||
# these are called for every test | |||||
setup() | setup() | ||||
{ | { | ||||
#run_only_test 4 | |||||
#run_only_test 6 | |||||
rm -rf mwtesttmp | |||||
XDG_CONFIG_HOME=mwtesttmp/config \ | XDG_CONFIG_HOME=mwtesttmp/config \ | ||||
MAILDIR=mwtesttmp/share/mail \ | MAILDIR=mwtesttmp/share/mail \ | ||||
XDG_CACHE_HOME=mwtesttmp/cache \ | XDG_CACHE_HOME=mwtesttmp/cache \ | ||||
prefix="$PWD" \ | |||||
source ../bin/mw | source ../bin/mw | ||||
export NOTMUCH_CONFIG=mwtesttmp/config/notmuch-config | export NOTMUCH_CONFIG=mwtesttmp/config/notmuch-config | ||||
export mwname="real name" | export mwname="real name" | ||||
export mwaddr="full.addr@gmail.com" | export mwaddr="full.addr@gmail.com" | ||||
export mwlogin="$mwaddr" | export mwlogin="$mwaddr" | ||||
export mwmailboxes="[Gmail]/INBOX" | |||||
export mwshare=$PWD/../share | export mwshare=$PWD/../share | ||||
function pass() { return 0; } | function pass() { return 0; } | ||||
export pass | export pass | ||||
function _mwcheckinternet() { return 0; } | |||||
export _mwcheckinternet | |||||
function _mwcheckcert() { return 0; } | |||||
export _mwcheckcert | |||||
function pgrep() { return 0; } | |||||
export pgrep | |||||
function crontab() { echo 'none'; } | |||||
export crontab | |||||
function _mwsyncandnotify() { echo "$mwaddr"; } | |||||
export _mwsyncandnotify | |||||
} | } | ||||
teardown() | teardown() | ||||
{ | { | ||||
if [ -z "$TEST_FUNCTION" ] | if [ -z "$TEST_FUNCTION" ] | ||||
@@ -36,52 +49,97 @@ teardown() | |||||
fi | fi | ||||
} | } | ||||
#1 | |||||
# 1 | |||||
@test "check config" { | @test "check config" { | ||||
[ "$mwmbsyncrc" = "mwtesttmp/config/isync/mbsyncrc" ] | [ "$mwmbsyncrc" = "mwtesttmp/config/isync/mbsyncrc" ] | ||||
[ "$mwmsmtprc" = "mwtesttmp/config/msmtp/config" ] | [ "$mwmsmtprc" = "mwtesttmp/config/msmtp/config" ] | ||||
} | } | ||||
#2 | |||||
# 2 | |||||
@test "add online" { | @test "add online" { | ||||
export mwtype=online | |||||
rm -rf mwtesttmp | |||||
export mailboxes="[Gmail]/Drafts" | |||||
run mwadd | |||||
mwtype="online" run _mwadd | |||||
[ -f mwtesttmp/config/mutt/muttrc ] | [ -f mwtesttmp/config/mutt/muttrc ] | ||||
[ -f mwtesttmp/config/mutt/accounts/1-$mwaddr.muttrc ] | |||||
[ -f mwtesttmp/config/mutt/accounts/1-$mwaddr.mwonofftype.online.muttrc ] | |||||
[ "$(cat mwtesttmp/config/isync/mbsyncrc | sed -ne '/^\s*\w/p')" = "" ] | [ "$(cat mwtesttmp/config/isync/mbsyncrc | sed -ne '/^\s*\w/p')" = "" ] | ||||
[ ! "$(cat mwtesttmp/config/msmtp/config | sed -ne '/^account/p')" = "" ] | |||||
[ "$(cat mwtesttmp/config/msmtp/config | sed -ne '/^account/p')" = "" ] | |||||
[ ! "$(cat mwtesttmp/config/mutt/accounts/1-$mwaddr.mwonofftype.online.muttrc | sed -ne '/smtp_url/p')" = "" ] | |||||
[ ! -f mwtesttmp/config/notmuch-config ] | [ ! -f mwtesttmp/config/notmuch-config ] | ||||
} | } | ||||
#3 | |||||
# 3 | |||||
@test "add offline unsuccessful" { | @test "add offline unsuccessful" { | ||||
export mwtype=offline | |||||
rm -rf mwtesttmp | |||||
run mwadd | |||||
export mwmailboxes="[Gmail]/OTHER" | |||||
mwtype="offline" run _mwadd | |||||
[ -f mwtesttmp/config/mutt/muttrc ] | [ -f mwtesttmp/config/mutt/muttrc ] | ||||
[ -d mwtesttmp/config/mutt/accounts ] | [ -d mwtesttmp/config/mutt/accounts ] | ||||
[ ! -f mwtesttmp/config/mutt/accounts/1-$mwaddr.muttrc ] | |||||
[ ! -f mwtesttmp/config/mutt/accounts/1-$mwaddr.mwonofftype.offline.muttrc ] | |||||
[ "$(cat mwtesttmp/config/isync/mbsyncrc | sed -ne '/^\s*\w/p')" = "" ] | [ "$(cat mwtesttmp/config/isync/mbsyncrc | sed -ne '/^\s*\w/p')" = "" ] | ||||
[ "$(cat mwtesttmp/config/msmtp/config | sed -ne '/^account/p')" = "" ] | [ "$(cat mwtesttmp/config/msmtp/config | sed -ne '/^account/p')" = "" ] | ||||
[ ! -f mwtesttmp/config/notmuch-config ] | [ ! -f mwtesttmp/config/notmuch-config ] | ||||
} | } | ||||
#4 | |||||
# 4 | |||||
@test "add offline successfully" { | @test "add offline successfully" { | ||||
export mwtype=offline | |||||
export mailboxes="[Gmail]/Drafts" | |||||
rm -rf mwtesttmp | |||||
run mwadd | |||||
mwtype="offline" run _mwadd | |||||
[ -f mwtesttmp/config/mutt/muttrc ] | [ -f mwtesttmp/config/mutt/muttrc ] | ||||
[ -d mwtesttmp/config/mutt/accounts ] | [ -d mwtesttmp/config/mutt/accounts ] | ||||
[ -f mwtesttmp/config/mutt/accounts/1-$mwaddr.muttrc ] | |||||
[ -f mwtesttmp/config/mutt/accounts/1-$mwaddr.mwonofftype.offline.muttrc ] | |||||
[ -f mwtesttmp/config/notmuch-config ] | [ -f mwtesttmp/config/notmuch-config ] | ||||
cat mwtesttmp/config/isync/mbsyncrc | sed -ne '/^\s*\w/p' | |||||
[ ! "$(cat mwtesttmp/config/isync/mbsyncrc | sed -ne '/^\s*\w/p')" = "" ] | [ ! "$(cat mwtesttmp/config/isync/mbsyncrc | sed -ne '/^\s*\w/p')" = "" ] | ||||
[ ! "$(cat mwtesttmp/config/msmtp/config | sed -ne '/^account/p')" = "" ] | [ ! "$(cat mwtesttmp/config/msmtp/config | sed -ne '/^account/p')" = "" ] | ||||
run mwlist | |||||
[ "$(cat mwtesttmp/config/mutt/accounts/1-$mwaddr.mwonofftype.online.muttrc | sed -ne '/smtp_url/p')" = "" ] | |||||
run _mwlist | |||||
[ "$(echo $lines | awk '{print $2}')" = "$mwaddr" ] | [ "$(echo $lines | awk '{print $2}')" = "$mwaddr" ] | ||||
} | } | ||||
# 5 | |||||
@test "delete account" { | |||||
mwtype="online" run _mwadd | |||||
mwtype="offline" run _mwadd | |||||
pick_delete() | |||||
{ | |||||
_mwpick delete && _mwdelete | |||||
} | |||||
export pick_delete | |||||
mwpick="1" run pick_delete | |||||
[ ! -f mwtesttmp/config/mutt/accounts/1-$mwaddr.mwonofftype.online.muttrc ] | |||||
[ ! "$(cat mwtesttmp/config/isync/mbsyncrc | sed -ne '/^\s*\w/p')" = "" ] | |||||
[ ! "$(cat mwtesttmp/config/msmtp/config | sed -ne '/^account/p')" = "" ] | |||||
} | |||||
# 6 | |||||
@test "cron" { | |||||
mwcronminutes=99 run _mwcron | |||||
chkline="${lines[1]}" | |||||
[ "${chkline::16}" = "mw cronjob added" ] | |||||
function crontab() { echo 'mw sync'; } | |||||
export crontab | |||||
mwcronremove=y run _mwcron | |||||
chkline="${lines[1]}" | |||||
[ "${chkline#*cronjob}" = " removed." ] | |||||
} | |||||
# 7 | |||||
@test "sync" { | |||||
mwtype="offline" run _mwadd | |||||
function pgrep() { [ "$1" = "-u" ] && return 0 || return 1; } | |||||
export pgrep | |||||
run _mwsync | |||||
[ "${lines// /}" = "full.addr@gmail.com" ] | |||||
} | |||||
# 8 | |||||
@test "add pop" { | |||||
export mwaddr="full.addr@chello.at" | |||||
mwtype="offline" run _mwadd | |||||
[ -f mwtesttmp/config/mutt/muttrc ] | |||||
[ -d mwtesttmp/config/mutt/accounts ] | |||||
[ -f mwtesttmp/config/mutt/accounts/1-$mwaddr.mwonofftype.offline.muttrc ] | |||||
[ -f mwtesttmp/config/notmuch-config ] | |||||
[ ! "$(cat mwtesttmp/config/msmtp/config | sed -ne '/^account/p')" = "" ] | |||||
[ ! "$(cat mwtesttmp/config/getmail/$mwaddr | sed -ne '/^\s*\w/p')" = "" ] | |||||
run _mwlist | |||||
[ "$(echo $lines | awk '{print $2}')" = "$mwaddr" ] | |||||
} |