@@ -0,0 +1,3 @@ | |||||
github: lukesmithxyz | |||||
custom: ["https://lukesmith.xyz/donate", "https://paypal.me/lukemsmith", "https://lukesmith.xyz/crypto"] | |||||
patreon: lukesmith |
@@ -3,13 +3,13 @@ | |||||
Get this great stuff without effort: | Get this great stuff without effort: | ||||
- A full-featured and autoconfigured email client on the terminal with neomutt | - 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 | |||||
- Mail stored offline so you can view and write email while you're away from internet and keep backups | |||||
Specifically, this wizard: | Specifically, this wizard: | ||||
- Determines your email server's IMAP and SMTP servers and ports | - Determines your email server's IMAP and SMTP servers and ports | ||||
- Creates dotfiles for `neomutt`, `isync`, and `msmtp` appropriate for your email address | - 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 | |||||
- Encrypts and locally stores your password for easy remote access, accessible only by your GPG key | |||||
- Handles as many as nine separate email accounts automatically | - Handles as many as nine separate email accounts automatically | ||||
- Auto-creates bindings to switch between accounts or between mailboxes | - 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 | - Can automatically set mail updates as often as you want to sync your mail and update you when new mail arrives | ||||
@@ -48,7 +48,7 @@ There's a chance of errors if you use a slow-release distro like Ubuntu, Debian | |||||
- `lynx` - view HTML email in neomutt. | - `lynx` - view HTML email in neomutt. | ||||
- `notmuch` - index and search mail. Install it and run `notmuch setup`, tell it that your mail is in `~/.local/share/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. | - `notmuch` - index and search mail. Install it and run `notmuch setup`, tell it that your mail is in `~/.local/share/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 syncthing mail with `mailsync` | |||||
- `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. | - `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. | - 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 the repo and directions out [here](https://github.com/cruegge/pam-gnupg). | - `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 the repo and directions out [here](https://github.com/cruegge/pam-gnupg). | ||||
@@ -105,12 +105,12 @@ mutt-wizard is free/libre software, licensed under the GPLv3. | |||||
## Watch out for these things: | ## Watch out for these things: | ||||
- Gmail accounts can now create 'App Password' to use with """less secure""" applications. This password is single use (ie. for setup) and will be stored and encrypted locally. Enabling third-party applications requires turning off two-factor authentication and this will circumvent that. You might also need to manually "Enable IMAP" in the settings. | - Gmail accounts can now create 'App Password' to use with """less secure""" applications. This password is single use (ie. for setup) and will be stored and encrypted locally. Enabling third-party applications requires turning off two-factor authentication and this will circumvent that. 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. | |||||
- Protonmail bridge is prone to timing out. Watch out for this while adding an account. If the bridge times out, try again. | |||||
- Protonmail accounts will require you to set up "Protonmail Bridge" to access PM's IMAP and SMTP servers. Configure that before running mutt-wizard. Note that when mutt-wizard asks for a password, you should put in your [bridge password](https://protonmail.com/bridge/thunderbird#3), not your account password. | |||||
- Protonmail bridge is prone to timing out. Watch out for this while adding an account. If the bridge times out, try again. It might help to [increase the timeout](https://protonmail.com/support/knowledge-base/thunderbird-connection-server-timed-error/) in your `mbsyncrc`. | |||||
- 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. | - 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. | - `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 | ## To-do | ||||
- Add ~~Mac OS~~/BSD compatibility (the script is confired to work for Mac OS now) | |||||
- Add ~~Mac OS~~/~~BSD~~ compatibility (the script is confirmed to work for Mac OS and FreeBSD 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) | - ~~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) |
@@ -12,24 +12,25 @@ ping -q -c 1 1.1.1.1 > /dev/null || { echo "No internet connection detected."; e | |||||
command -v notify-send >/dev/null || echo "Note that \`libnotify\` or \`libnotify-send\` should be installed for pop-up mail notifications with this script." | command -v notify-send >/dev/null || echo "Note that \`libnotify\` or \`libnotify-send\` should be installed for pop-up mail notifications with this script." | ||||
# Required to display notifications if run as a cronjob: | # Required to display notifications if run as a cronjob: | ||||
DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$(id -u)/bus | |||||
export DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$(id -u)/bus | |||||
export DISPLAY=:0.0 | export DISPLAY=:0.0 | ||||
# For individual configurations: | # For individual configurations: | ||||
[ -d "$HOME/.local/share/password-store" ] && export PASSWORD_STORE_DIR="$HOME/.local/share/password-store" | [ -d "$HOME/.local/share/password-store" ] && export PASSWORD_STORE_DIR="$HOME/.local/share/password-store" | ||||
pgrep i3blocks >/dev/null && STATUSBAR="i3blocks" || STATUSBAR="dwmblocks" | |||||
# Settings are different for MacOS (Darwin) systems. | # Settings are different for MacOS (Darwin) systems. | ||||
if [ "$(uname)" = "Darwin" ]; then | if [ "$(uname)" = "Darwin" ]; then | ||||
notify() { osascript -e "display notification \"$2 in $1\" with title \"You've got Mail\" subtitle \"Account: $account\"" && sleep 2 ;} | notify() { osascript -e "display notification \"$2 in $1\" with title \"You've got Mail\" subtitle \"Account: $account\"" && sleep 2 ;} | ||||
messageinfo() { osascript -e "display notification with title \"📧 $from\" subtitle \"$subject\"" ;} | |||||
else | else | ||||
notify() { notify-send --app-name="mutt-wizard" "mutt-wizard" "📬 $2 new mail(s) in \`$1\` account." ;} | notify() { notify-send --app-name="mutt-wizard" "mutt-wizard" "📬 $2 new mail(s) in \`$1\` account." ;} | ||||
messageinfo() { notify-send --app-name="mutt-wizard" "📧$from:" "$subject" ;} | |||||
fi | fi | ||||
# Check account for new mail. Notify if there is new content. | # Check account for new mail. Notify if there is new content. | ||||
syncandnotify() { | syncandnotify() { | ||||
acc="$(echo "$account" | sed "s/.*\///")" | acc="$(echo "$account" | sed "s/.*\///")" | ||||
mbsync "$acc" | |||||
mbsync "$opts" "$acc" | |||||
new=$(find "$HOME/.local/share/mail/$acc/INBOX/new/" "$HOME/.local/share/mail/$acc/Inbox/new/" "$HOME/.local/share/mail/$acc/inbox/new/" -type f -newer "$HOME/.config/mutt/.mailsynclastrun" 2> /dev/null) | new=$(find "$HOME/.local/share/mail/$acc/INBOX/new/" "$HOME/.local/share/mail/$acc/Inbox/new/" "$HOME/.local/share/mail/$acc/inbox/new/" -type f -newer "$HOME/.config/mutt/.mailsynclastrun" 2> /dev/null) | ||||
newcount=$(echo "$new" | sed '/^\s*$/d' | wc -l) | newcount=$(echo "$new" | sed '/^\s*$/d' | wc -l) | ||||
if [ "$newcount" -gt "0" ]; then | if [ "$newcount" -gt "0" ]; then | ||||
@@ -37,8 +38,8 @@ syncandnotify() { | |||||
for file in $new; do | for file in $new; do | ||||
# Extract subject and sender from mail. | # 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:]]*$//') | 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 --app-name="mutt-wizard" "📧$from:" "$subject" & | |||||
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') | |||||
messageinfo & | |||||
done | done | ||||
fi | fi | ||||
} | } | ||||
@@ -47,11 +48,13 @@ syncandnotify() { | |||||
if [ "$#" -eq "0" ]; then | if [ "$#" -eq "0" ]; then | ||||
accounts="$(awk '/^Channel/ {print $2}' "$HOME/.mbsyncrc")" | accounts="$(awk '/^Channel/ {print $2}' "$HOME/.mbsyncrc")" | ||||
else | else | ||||
for arg in "$@"; do | |||||
[ "${arg%${arg#?}}" = '-' ] && opts="${opts:+${opts} }${arg}" && shift 1 | |||||
done | |||||
accounts=$* | accounts=$* | ||||
fi | fi | ||||
echo " 🔃" > /tmp/imapsyncicon_"$USER" | |||||
( pkill -RTMIN+12 "${STATUSBAR:?}" >/dev/null 2>&1 ) 2>/dev/null | |||||
( kill -46 "$(pidof "${STATUSBAR:-dwmblocks}")" >/dev/null 2>&1 ) 2>/dev/null | |||||
# Parallelize multiple accounts | # Parallelize multiple accounts | ||||
for account in $accounts | for account in $accounts | ||||
@@ -60,8 +63,7 @@ do | |||||
done | done | ||||
wait | wait | ||||
rm -f /tmp/imapsyncicon_"$USER" | |||||
( pkill -RTMIN+12 "${STATUSBAR:?}" >/dev/null 2>&1 ) 2>/dev/null | |||||
( kill -46 "$(pidof "${STATUSBAR:-dwmblocks}")" >/dev/null 2>&1 ) 2>/dev/null | |||||
notmuch new 2>/dev/null | notmuch new 2>/dev/null | ||||
@@ -3,11 +3,11 @@ | |||||
command -V gpg >/dev/null 2>&1 && GPG="gpg" || GPG="gpg2" | command -V gpg >/dev/null 2>&1 && GPG="gpg" || GPG="gpg2" | ||||
[ -z ${PASSWORD_STORE_DIR+x} ] && PASSWORD_STORE_DIR="$HOME/.password-store" | [ -z ${PASSWORD_STORE_DIR+x} ] && PASSWORD_STORE_DIR="$HOME/.password-store" | ||||
[ -r "$PASSWORD_STORE_DIR/.gpg-id" ] && | [ -r "$PASSWORD_STORE_DIR/.gpg-id" ] && | ||||
"$GPG" --list-secret-keys $(cat "$PASSWORD_STORE_DIR/.gpg-id") >/dev/null 2>&1 || { | |||||
"$GPG" --list-secret-keys "$(cat "$PASSWORD_STORE_DIR/.gpg-id")" >/dev/null 2>&1 || { | |||||
printf "\`pass\` must be installed and initialized to encrypt passwords.\\nBe sure it is installed and run \`pass init <yourgpgemail>\`.\\nIf you don't have a GPG public private key pair, run \`%s --full-gen-key\` first.\\n" "$GPG" | printf "\`pass\` must be installed and initialized to encrypt passwords.\\nBe sure it is installed and run \`pass init <yourgpgemail>\`.\\nIf you don't have a GPG public private key pair, run \`%s --full-gen-key\` first.\\n" "$GPG" | ||||
exit | exit | ||||
} | } | ||||
! command -v mbsync >/dev/null && printf "\`mbsync\` must be installed to run mutt-wizard.\\n" && exit | |||||
! command -v mbsync >/dev/null && printf "\`mbsync (isync package)\` must be installed to run mutt-wizard.\\n" && exit | |||||
prefix="/usr/local" | prefix="/usr/local" | ||||
muttdir="$HOME/.config/mutt" # Main mutt config location | muttdir="$HOME/.config/mutt" # Main mutt config location | ||||
@@ -50,12 +50,11 @@ $starttlsoff | |||||
" | " | ||||
mbsync_profile="IMAPStore $title-remote | mbsync_profile="IMAPStore $title-remote | ||||
Host $imap | Host $imap | ||||
Port $iport | |||||
Port $iport | |||||
User $login | User $login | ||||
PassCmd \"pass mutt-wizard-$title\" | PassCmd \"pass mutt-wizard-$title\" | ||||
AuthMechs LOGIN | AuthMechs LOGIN | ||||
SSLType $ssltype | SSLType $ssltype | ||||
AuthMech LOGIN | |||||
CertificateFile $sslcert | CertificateFile $sslcert | ||||
MaildirStore $title-local | MaildirStore $title-local | ||||
@@ -88,6 +87,11 @@ set header_cache = $cachedir/$title/headers | |||||
set message_cachedir = $cachedir/$title/bodies | set message_cachedir = $cachedir/$title/bodies | ||||
set mbox_type = Maildir | set mbox_type = Maildir | ||||
set crypt_autosign = yes | |||||
set crypt_opportunistic_encrypt = yes | |||||
set pgp_self_encrypt = yes | |||||
set pgp_default_key = $keyid | |||||
bind index,pager gg noop | bind index,pager gg noop | ||||
bind index,pager g noop | bind index,pager g noop | ||||
bind index,pager M noop | bind index,pager M noop | ||||
@@ -101,14 +105,20 @@ mutt_profile="# vim: filetype=neomuttrc | |||||
# muttrc file for account $title | # muttrc file for account $title | ||||
set realname = \"$realname\" | set realname = \"$realname\" | ||||
set from = \"$fulladdr\" | set from = \"$fulladdr\" | ||||
set sendmail = \"$prefix/bin/msmtp -a $title\" | |||||
set sendmail = \"msmtp -a $title\" | |||||
alias me $realname <$fulladdr> | alias me $realname <$fulladdr> | ||||
set folder = \"imaps://$fulladdr@$imap:$iport\" | |||||
set folder = \"imaps://$login@$imap:$iport\" | |||||
set imap_user = \"$login\" | set imap_user = \"$login\" | ||||
set header_cache = $cachedir/$title/headers | set header_cache = $cachedir/$title/headers | ||||
set message_cachedir = $cachedir/$title/bodies | set message_cachedir = $cachedir/$title/bodies | ||||
set imap_pass = \"\`pass mutt-wizard-$title\`\" | set imap_pass = \"\`pass mutt-wizard-$title\`\" | ||||
set crypt_autosign = yes | |||||
set crypt_opportunistic_encrypt = yes | |||||
set pgp_self_encrypt = yes | |||||
set pgp_default_key = $keyid | |||||
set mbox_type = Maildir | set mbox_type = Maildir | ||||
set ssl_starttls = yes | set ssl_starttls = yes | ||||
set ssl_force_tls = yes | set ssl_force_tls = yes | ||||
@@ -127,6 +137,7 @@ fi | |||||
askinfo() { \ | askinfo() { \ | ||||
printf "Insert the \033[31memail address\033[0m that you want to autoconfigure for mutt/mbsync\\n\tEmail: \033[36m" | printf "Insert the \033[31memail address\033[0m that you want to autoconfigure for mutt/mbsync\\n\tEmail: \033[36m" | ||||
read -r fulladdr | read -r fulladdr | ||||
keyid=$("$GPG" --list-keys --with-colons "$fulladdr" | awk -F: '/^pub:/ { print $5 }') | |||||
printf "\033[0m" | printf "\033[0m" | ||||
while ! echo "$fulladdr" | grep "$emailre" >/dev/null; do | while ! echo "$fulladdr" | grep "$emailre" >/dev/null; do | ||||
printf "That is not a valid \033[31memail address\033[0m, please retype the desired email.\\n\\nEmail: \033[36m\t" | printf "That is not a valid \033[31memail address\033[0m, please retype the desired email.\\n\\nEmail: \033[36m\t" | ||||
@@ -137,7 +148,7 @@ askinfo() { \ | |||||
search_query=$domain | search_query=$domain | ||||
case "$domain" in | case "$domain" in | ||||
protonmail.com|protonmail.ch|pm.me) | protonmail.com|protonmail.ch|pm.me) | ||||
search_query='protonmail.com' && break;; | |||||
search_query='protonmail.com' && return 1;; | |||||
*) | *) | ||||
while : ; do | while : ; do | ||||
printf "\nIs your email hosted with Protonmail? [yes/no] " | printf "\nIs your email hosted with Protonmail? [yes/no] " | ||||
@@ -292,7 +303,7 @@ choosecron() { ! pgrep cron >/dev/null && echo "No cron manager running. Install | |||||
read -r minnum | read -r minnum | ||||
printf "\033[0m" | printf "\033[0m" | ||||
done | done | ||||
(crontab -l; echo "*/$minnum * * * * $(type mailsync | cut -d' ' -f3)") | crontab - && | |||||
(crontab -l; echo "*/$minnum * * * * $(type mailsync | cut -d' ' -f3)") >/dev/null | crontab - && | |||||
echo "Cronjob added. Mail will sync every $minnum minutes. Be sure you have your cron manager running." | echo "Cronjob added. Mail will sync every $minnum minutes. Be sure you have your cron manager running." | ||||
fi ;} | fi ;} | ||||
@@ -322,7 +333,7 @@ name=$realname | |||||
primary_email=$fulladdr | primary_email=$fulladdr | ||||
[new] | [new] | ||||
tags=unread;inbox; | tags=unread;inbox; | ||||
ignore= | |||||
ignore=.mbsyncstate;.uidvalidity | |||||
[search] | [search] | ||||
exclude_tags=deleted;spam; | exclude_tags=deleted;spam; | ||||
[maildir] | [maildir] | ||||
@@ -331,7 +342,7 @@ synchronize_flags=true | |||||
gpg_path=$GPG" | gpg_path=$GPG" | ||||
echo "$nmbasic" > "$NOTMUCH_CONFIG" ;} | echo "$nmbasic" > "$NOTMUCH_CONFIG" ;} | ||||
trap 'echo -e "\033[0m\n"; exit' STOP INT ABRT KILL | |||||
trap 'echo -e "\033[0m\n"; exit' INT ABRT | |||||
case "$1" in | case "$1" in | ||||
ls) list ;; | ls) list ;; | ||||
@@ -1,7 +1,7 @@ | |||||
#!/bin/sh | #!/bin/sh | ||||
# Helps open a file with xdg-open from mutt in a external program without weird side effects. | # Helps open a file with xdg-open from mutt in a external program without weird side effects. | ||||
[ $(uname) = "Darwin" ] && opener="open" || opener="setsid xdg-open" | |||||
[ "$(uname)" = "Darwin" ] && opener="open" || opener="setsid xdg-open" | |||||
mkdir -p "/tmp/$USER-mutt-tmp" | mkdir -p "/tmp/$USER-mutt-tmp" | ||||
file="/tmp/$USER-mutt-tmp/$(basename "$1")" | file="/tmp/$USER-mutt-tmp/$(basename "$1")" | ||||
rm -f "$file" | rm -f "$file" | ||||
@@ -6,7 +6,7 @@ mw \- mutt-wizard \- autoconfigure email accounts for neomutt and isync | |||||
<command> | <command> | ||||
.SH DESCRIPTION | .SH DESCRIPTION | ||||
.B mw | .B mw | ||||
takes a user email account and sets up a terminal-based email interface with it for | |||||
takes a user email account and sets up a terminal-based email interface for it with | |||||
.B neomutt. | .B neomutt. | ||||
This can include offline email with | This can include offline email with | ||||
.B isync/mbsync | .B isync/mbsync | ||||
@@ -56,7 +56,7 @@ Neither | |||||
.B delete | .B delete | ||||
or | or | ||||
.B purge | .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. | |||||
will delete downloaded mail for safety (and time)'s sake. If you want to delete downloaded mail, do so manually by removing it from the directory above. | |||||
.TP | .TP | ||||
.B Default settings | .B Default settings | ||||
The mutt-wizard has many default settings that focus on making it aesthetically pleasing and supplying more vim-like bindings. These can be found in | The mutt-wizard has many default settings that focus on making it aesthetically pleasing and supplying more vim-like bindings. These can be found in | ||||
@@ -4,6 +4,7 @@ ADDRESS,IMAP,imap port,SMTP,smtp port | |||||
aaathats3as.com,mail.cock.li,993,mail.cock.li,587 | aaathats3as.com,mail.cock.li,993,mail.cock.li,587 | ||||
accountant.com,imap.mail.com,993,smtp.mail.com,587 | accountant.com,imap.mail.com,993,smtp.mail.com,587 | ||||
activist.com,imap.mail.com,993,smtp.mail.com,587 | activist.com,imap.mail.com,993,smtp.mail.com,587 | ||||
ad.unsw.edu.au,outlook.office365.com,993,smtp.office365.com,587 | |||||
adexec.com,imap.mail.com,993,smtp.mail.com,587 | adexec.com,imap.mail.com,993,smtp.mail.com,587 | ||||
airmail.cc,mail.cock.li,993,mail.cock.li,587 | airmail.cc,mail.cock.li,993,mail.cock.li,587 | ||||
allergist.com,imap.mail.com,993,smtp.mail.com,587 | allergist.com,imap.mail.com,993,smtp.mail.com,587 | ||||
@@ -44,6 +45,7 @@ chef.net,imap.mail.com,993,smtp.mail.com,587 | |||||
chemist.com,imap.mail.com,993,smtp.mail.com,587 | chemist.com,imap.mail.com,993,smtp.mail.com,587 | ||||
chrissx.ga,chrissx.ga,993,chrissx.ga,25 | chrissx.ga,chrissx.ga,993,chrissx.ga,25 | ||||
clarkson.edu,imap.gmail.com,993,smtp.gmail.com,587 | clarkson.edu,imap.gmail.com,993,smtp.gmail.com,587 | ||||
clasnet.sunyocc.edu,outlook.office365.com,993,smtp.office365.com,587 | |||||
clerk.com,imap.mail.com,993,smtp.mail.com,587 | clerk.com,imap.mail.com,993,smtp.mail.com,587 | ||||
clubmember.org,imap.mail.com,993,smtp.mail.com,587 | clubmember.org,imap.mail.com,993,smtp.mail.com,587 | ||||
cmail.carleton.ca,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | cmail.carleton.ca,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | ||||
@@ -87,6 +89,7 @@ forthnet.gr,mail.forthnet.gr,993,smtp-auth.forthnet.gr,465 | |||||
fsmpi.rwth-aachen.de,mail.fsmpi.rwth-aachen.de,993,mail.fsmpi.rwth-aachen.de,465 | fsmpi.rwth-aachen.de,mail.fsmpi.rwth-aachen.de,993,mail.fsmpi.rwth-aachen.de,465 | ||||
fsu-jena,exchange.uni-jena.de,993,smtp.uni-jena.de,587 | fsu-jena,exchange.uni-jena.de,993,smtp.uni-jena.de,587 | ||||
getbackinthe.kitchen,mail.cock.li,993,mail.cock.li,587 | getbackinthe.kitchen,mail.cock.li,993,mail.cock.li,587 | ||||
gcc.edu,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | |||||
gmail.com,imap.gmail.com,993,smtp.gmail.com,587 | gmail.com,imap.gmail.com,993,smtp.gmail.com,587 | ||||
gmx.at,imap.gmx.net,993,mail.gmx.net,587 | gmx.at,imap.gmx.net,993,mail.gmx.net,587 | ||||
gmx.com,imap.gmx.net,993,mail.gmx.net,587 | gmx.com,imap.gmx.net,993,mail.gmx.net,587 | ||||
@@ -166,6 +169,7 @@ 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 | 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 | ||||
librem.one,imap.librem.one,993,smtp.librem.one,465 | |||||
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 | ||||
live.de,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | live.de,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | ||||
@@ -236,6 +240,7 @@ sapo.pt,imap.sapo.pt,993,smtp.sapo.pt,587 | |||||
smail.inf.h-brs.de,imap.inf.h-brs.de,993,smtp.inf.h-brs.de,587 | smail.inf.h-brs.de,imap.inf.h-brs.de,993,smtp.inf.h-brs.de,587 | ||||
southwales.ac.uk,imap.gmail.com,993,smtp.gmail.com,587 | southwales.ac.uk,imap.gmail.com,993,smtp.gmail.com,587 | ||||
spoko.pl,imap.poczta.onet.pl,993,smtp.poczta.onet.pl,465 | spoko.pl,imap.poczta.onet.pl,993,smtp.poczta.onet.pl,465 | ||||
st.amu.edu.pl,outlook.office365.com,993,smtp.office365.com,587 | |||||
stevens.edu,imap.outlook.com,993,smtp.outlook.com,587 | stevens.edu,imap.outlook.com,993,smtp.outlook.com,587 | ||||
stronzi.org,mail.autistici.org,993,smtp.autistici.org,465 | stronzi.org,mail.autistici.org,993,smtp.autistici.org,465 | ||||
stud.tu-darmstadt.de,imap.stud.tu-darmstadt.de,993,smtp.tu-darmstadt.de,465 | stud.tu-darmstadt.de,imap.stud.tu-darmstadt.de,993,smtp.tu-darmstadt.de,465 | ||||
@@ -243,7 +248,7 @@ stud.uis.no,outlook.office365.com,993,smtp.office365.com,587 | |||||
stud.uni-bamberg.de,outlook.office365.com,993,smtp.office365.com,587 | stud.uni-bamberg.de,outlook.office365.com,993,smtp.office365.com,587 | ||||
student.rmit.edu.au,outlook.office365.com,993,smtp.office365.com,587 | student.rmit.edu.au,outlook.office365.com,993,smtp.office365.com,587 | ||||
student.tuwien.ac.at,mail.student.tuwien.ac.at,993,mail.student.tuwien.ac.at,587 | student.tuwien.ac.at,mail.student.tuwien.ac.at,993,mail.student.tuwien.ac.at,587 | ||||
studenti.unipi.it,outlook.office365.com,995,smtp.office365.com,587 | |||||
studenti.unipi.it,outlook.office365.com,993,smtp.office365.com,587 | |||||
students.southwales.ac.uk,imap.gmail.com,993,smtp.gmail.com,587 | students.southwales.ac.uk,imap.gmail.com,993,smtp.gmail.com,587 | ||||
studio.unibo.it,outlook.office365.com,993,smtp.office365.com,587 | studio.unibo.it,outlook.office365.com,993,smtp.office365.com,587 | ||||
studio.unibo.it,outlook.office365.com,993,smtp.office365.com,587 | studio.unibo.it,outlook.office365.com,993,smtp.office365.com,587 | ||||
@@ -301,4 +306,7 @@ zaclys.net,mail.zaclys.net,993,mail.zaclys.net,465 | |||||
zoho.com,imap.zoho.com,993,smtp.zoho.com,465 | zoho.com,imap.zoho.com,993,smtp.zoho.com,465 | ||||
zohomail.eu,imap.zoho.eu,993,smtp.zoho.eu,465 | zohomail.eu,imap.zoho.eu,993,smtp.zoho.eu,465 | ||||
ymail.com,imap.mail.yahoo.com,993,smtp.mail.yahoo.com,465 | ymail.com,imap.mail.yahoo.com,993,smtp.mail.yahoo.com,465 | ||||
gcc.edu,imap-mail.outlook.com,993,smtp-mail.outlook.com,587 | |||||
unilodz.eu,outlook.office365.com,993,smtp.office365.com,587 | |||||
ethz.ch,mail.ethz.ch,993,mail.ethz.ch,587 | |||||
bocken.org,imap.gmail.com,993,smtp.gmail.com,465 | |||||
vxempire.xyz,vxempire.xyz,993,vxempire.xyz,587 |
@@ -5,3 +5,4 @@ image/*; openfile %s ; | |||||
video/*; setsid mpv --quiet %s &; copiousoutput | video/*; setsid mpv --quiet %s &; copiousoutput | ||||
application/pdf; openfile %s ; | application/pdf; openfile %s ; | ||||
application/pgp-encrypted; gpg -d '%s'; copiousoutput; | application/pgp-encrypted; gpg -d '%s'; copiousoutput; | ||||
application/pgp-keys; gpg --import '%s'; copiousoutput; |
@@ -46,7 +46,7 @@ bind index U undelete-message | |||||
bind index L limit | bind index L limit | ||||
bind index h noop | bind index h noop | ||||
bind index l display-message | bind index l display-message | ||||
bind index <space> tag-entry | |||||
bind index,query <space> tag-entry | |||||
#bind browser h goto-parent | #bind browser h goto-parent | ||||
macro browser h '<change-dir><kill-line>..<enter>' "Go to parent folder" | macro browser h '<change-dir><kill-line>..<enter>' "Go to parent folder" | ||||
bind index,pager H view-raw-message | bind index,pager H view-raw-message | ||||