From d19ff162769f4cd616ada443887865634084d1be Mon Sep 17 00:00:00 2001 From: Luke Smith Date: Wed, 2 Jan 2019 11:38:42 -0500 Subject: [PATCH] potential changes --- etc/mailsync.sh | 2 +- etc/muttimage.sh | 6 +- mutt-wizard.sh | 302 ++++++++++++++++++++++++++++++----------------- muttrc | 8 +- 4 files changed, 206 insertions(+), 112 deletions(-) diff --git a/etc/mailsync.sh b/etc/mailsync.sh index ced17f9..95131e8 100755 --- a/etc/mailsync.sh +++ b/etc/mailsync.sh @@ -20,7 +20,7 @@ else notify() { mpv --really-quiet ~/.config/mutt/etc/notify.opus & pgrep -x dunst && notify-send -i ~/.config/mutt/etc/email.gif "$2 new mail(s) in \`$1\` account." ;} fi -echo 🔃 > ~/.config/mutt/.dl +echo " 🔃" > ~/.config/mutt/.dl pkill -RTMIN+12 i3blocks # Run offlineimap. You can feed this script different settings. diff --git a/etc/muttimage.sh b/etc/muttimage.sh index b67de83..9dd5441 100755 --- a/etc/muttimage.sh +++ b/etc/muttimage.sh @@ -1,8 +1,8 @@ -#! /bin/sh - +#!/bin/sh + #### Determine size of Terminal height=`stty size | awk 'BEGIN {FS = " "} {print $1;}'` width=`stty size | awk 'BEGIN {FS = " "} {print $2;}'` - + ### Display Image / offset with mutt bar echo -e "2;3;\n0;1;210;20;$((width*7-250));$((height*14-100));0;0;0;0;$1\n4;\n3;" | /usr/lib/w3m/w3mimgdisplay & diff --git a/mutt-wizard.sh b/mutt-wizard.sh index 72b1cd9..54b391e 100755 --- a/mutt-wizard.sh +++ b/mutt-wizard.sh @@ -1,17 +1,22 @@ #!/usr/bin/env bash -[ "$(uname)" == "Darwin" ] && os=".macos" +if [ "$(uname)" == "Darwin" ]; +then + sslcert="/etc/ssl/certs/ca-certificates.crt" +else + sslcert="/usr/local/etc/openssl/cert.pem" +fi muttdir="$HOME/.config/mutt" namere="^[a-z_][a-z0-9_-]*$" -emailre=".+@.+\..+" +emailre=".+@.+\\..+" createMailboxes() { \ tmpdir=$(mktemp -d) offlineimap --info -a "$1" 2&> "$tmpdir"/log sed -n '/^Folderlist/,/^Folderlist/p' "$tmpdir"/log | - grep "^ " | sed -e "s/\//./g;s/(.*//g;s/^ //g" > "$tmpdir"/lognew - while read box; do mkdir -p "$HOME/.mail/$1/$box"; done <"$tmpdir"/lognew ;} + grep "^ " | sed -e "s/\\//./g;s/(.*//g;s/^ //g" > "$tmpdir"/lognew + while read -r box; do mkdir -p "$HOME/.mail/$1/$box"; done <"$tmpdir"/lognew ;} testSync() { (crontab -l | grep mailsync.sh && removeSync) || addSync ;} @@ -19,17 +24,109 @@ addSync() { min=$(dialog --inputbox "How many minutes should be between mail syn (crontab -l; echo "*/$min * * * * eval \"export $(egrep -z DBUS_SESSION_BUS_ADDRESS /proc/$(pgrep -u $LOGNAME -x i3)/environ)\"; "$muttdir"/etc/mailsync.sh") | crontab - && dialog --msgbox "Cronjob successfully added. Remember you may need to restart or tell systemd/etc. to start your cron manager for this to take effect." 7 60 ;} -removeSync() { ((crontab -l | sed -e '/mailsync.sh/d') | crontab - >/dev/null) && dialog --msgbox "Cronjob successfully removed. To reactivate, select this option again." 6 60 ;} +removeSync() { ( (crontab -l | sed -e '/mailsync.sh/d') | crontab - >/dev/null) && dialog --msgbox "Cronjob successfully removed. To reactivate, select this option again." 6 60 ;} + +msmtp_header="defaults +auth on +tls on +tls_trust_file $sslcert +logfile ~/.msmtp.log +" + +offlineimap_header="[general] +accounts = +starttls = yes +ssl = true +pythonfile = ~/.config/mutt/credentials/imappwd.py +" + +getprofiles() { \ +offlineimap_profile=" +[Account $title] +localrepository = $title-local +remoterepository = $title-remote + +[Repository $title-remote] +auth_mechanisms = LOGIN +type = $type +remoteuser = $login +remotepasseval = mailpasswd(\"$title\") +remoteport = $iport +sslline = $sslcert +$ifgoogleline + +[Repository $title-local] +type = Maildir +localfolders = ~/.mail/$title +" + +msmtp_profile=" + +account $title +host $smtp +port $sport +from $login +user $login +passwordeval \"gpg -d --quiet --for-your-eyes-only --no-tty ~/.config/mutt/credentials/$title.gpg | sed -e '\$a\\'\" +" + +mutt_profile="# vim: filetype=neomuttrc +# muttrc file for account $title +set realname = \"$realname\" +set from = \"$fulladdr\" +set sendmail = \"/usr/bin/msmtp -a $title\" +set folder = \"~/.mail/$title\" +set header_cache = ~/.config/mutt/accounts/$title/cache/headers +set message_cachedir = ~/.config/mutt/accounts/$title/cache/bodies +set certificate_file = ~/.config/mutt/accounts/$title/certificates +source \"~/.config/mutt/credentials/getmuttpass $title |\" + +alias me $realname <$fulladdr> + +set mbox_type = Maildir +set ssl_starttls = yes +set ssl_force_tls = yes + +bind index,pager gg noop +bind index,pager g noop +bind index gg first-entry +unmailboxes * +" + +mbsync_profile="IMAPAccount $title +Host $imap +User $login +PassCmd \"gpg -d ~/.config/mutt/credentials/$title.gpg\" +SSLType IMAPS +CertificateFile $sslcert + +IMAPStore $title-remote +Account $title + +MaildirStore $title-local +Subfolders Verbatim +Path ~/.mail/$title +Inbox ~/.mail/$title/INBOX + +Channel $title +Master :$title-remote: +Slave :$title-local: + +Ceate Both +SyncState * +" + +} changePassword() { \ gpgemail=$( dialog --title "Luke's mutt/offlineIMAP password wizard" --inputbox "Insert the email address with which you originally created your GPG key pair. This is NOT necessarily the email you want to configure." 10 60 3>&1 1>&2 2>&3 3>&- ) while ! [[ "${gpgemail}" =~ ${emailre} ]]; do gpgemail=$(dialog --no-cancel --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "That's not a valid email address. Please input the entire address." 10 60 3>&1 1>&2 2>&3 3>&1) done - dialog --title "Luke's mutt/offlineIMAP password wizard" --passwordbox "Enter the new password for the \"$1\" account." 10 60 2> /tmp/$1 - gpg2 -r "$gpgemail" --encrypt /tmp/$1 || (dialog --title "GPG decryption failed." --msgbox "GPG decryption failed. This is either because you do not have a GPG key pair or because your distro uses GPG1 and you thus need to symlink /usr/bin/gpg2 to /usr/bin/gpg." 7 60 && break) - shred -u /tmp/$1 - mv /tmp/$1.gpg "$muttdir"/credentials/ + dialog --title "Luke's mutt/offlineIMAP password wizard" --passwordbox "Enter the new password for the \"$1\" account." 10 60 2> "/tmp/$1" + gpg2 -r "$gpgemail" --encrypt "/tmp/$1" || (dialog --title "GPG decryption failed." --msgbox "GPG decryption failed. This is either because you do not have a GPG key pair or because your distro uses GPG1 and you thus need to symlink /usr/bin/gpg2 to /usr/bin/gpg." 7 60 && break) + shred -u "/tmp/$1" + mv "/tmp/$1.gpg" "$muttdir"/credentials/ dialog --title "Finalizing your account." --infobox "The account \"$title\"'s password has been changed. Now attempting to configure mail directories... This may take several seconds..." 10 70 @@ -37,7 +134,7 @@ changePassword() { \ detectMailboxes "$title" dialog --title "Password changed." --msgbox "Your \"$fulladdr\" password has been changed. To start the download of your mail, you can manually run \`offlineimap -a $title\` in a terminal. The first sync may take some time depending on the amount of your mail." 8 60 ;} -chooseDetect() { for x in $(grep "^accounts =" ~/.offlineimaprc | sed -e 's/accounts =\( \)//g;s/\(,\) /\n/g;'); do detectMailboxes $x; done && detectSuccess ;} +chooseDetect() { for x in $(grep "^accounts =" ~/.offlineimaprc | sed -e 's/accounts =\( \)//g;s/\(,\) /\n/g;'); do detectMailboxes "$x"; done && detectSuccess ;} detectWarning() { \ dialog --title "Mailbox detect requirement" --yesno "In order for the mailbox detection system to work, you must have @@ -60,48 +157,50 @@ gt for move to Trash These shortcuts will only work if your email system does have that particular folder (i.e. if your email system has a Junk folder, but not a Trash folder, 'gt' will not work, etc." 20 60 ;} formatShortcut() { \ - while read data; do - echo "macro index,pager g$1 \"$data\" \"Go to $2.\"" >> "$muttdir"/accounts/$3.muttrc + while read -r data; do + echo "macro index,pager g$1 \"$data\" \"Go to $2.\"" >> "$muttdir/accounts/$3.muttrc" done ;} gen_delim() { \ delim="=" - for i in `seq $(( $1 - 1 ))` + for i in $(seq $(( $1 - 1 ))) do delim="$delim-" done echo $delim ;} detectMailboxes() { \ - find ~/.mail/$1 -maxdepth 1 -mindepth 1 -type d | sed -e "s/.*\///g;s/^/=/g" > /tmp/$1_boxes + find ~/.mail/"$1" -maxdepth 1 -mindepth 1 -type d | sed -e "s/.*\\///g;s/^/=/g" > "/tmp/$1_boxes" sidebar_width=$(sed -n -e '/^set sidebar_width/p' "$muttdir"/muttrc | awk -F'=' '{print $2}') - delim=$(gen_delim $sidebar_width) - oneline=$(sed -e "s/^\|$/\"/g" /tmp/$1_boxes | tr "\n" " ") + delim=$(gen_delim "$sidebar_width") + oneline=$(sed -e "s/^\\|$/\"/g" "/tmp/$1_boxes" | tr "\\n" " ") oneline="=$1 $delim $oneline" - sed -i "/^mailboxes\|^set record\|^set postponed\|^set trash\|^set spoolfile/d" "$muttdir"/accounts/$1.muttrc - echo mailboxes $oneline >> "$muttdir"/accounts/$1.muttrc - sed -i "/^macro index,pager g/d" "$muttdir"/accounts/$1.muttrc - grep -i /tmp/$1_boxes -e inbox | sed 1q | formatShortcut i inbox $1 - grep -i /tmp/$1_boxes -e sent | sed 1q | formatShortcut s sent $1 - grep -i /tmp/$1_boxes -e draft | sed 1q | formatShortcut d drafts $1 - grep -i /tmp/$1_boxes -e trash | sed 1q | formatShortcut t trash $1 - grep -i /tmp/$1_boxes -e spam | sed 1q | formatShortcut S spam $1 - grep -i /tmp/$1_boxes -e archive | sed 1q | formatShortcut a archive $1 - spoolfile=$(grep -i /tmp/$1_boxes -e inbox | sed -e 's/=/+/g' | sed 1q) - record=$(grep -i /tmp/$1_boxes -e sent | sed -e 's/=/+/g' | sed 1q) - postponed=$(grep -i /tmp/$1_boxes -e draft | sed -e 's/=/+/g' | sed 1q) - trash=$(grep -i /tmp/$1_boxes -e trash | sed -e 's/=/+/g' | sed 1q) - echo "set spoolfile = \"$spoolfile\"" >> "$muttdir"/accounts/$1.muttrc - echo "set record = \"$record\"" >> "$muttdir"/accounts/$1.muttrc - echo "set postponed = \"$postponed\"" >> "$muttdir"/accounts/$1.muttrc - echo "set trash = \"$trash\"" >> "$muttdir"/accounts/$1.muttrc ;} + sed -i "/^mailboxes\\|^set record\\|^set postponed\\|^set trash\\|^set spoolfile/d" "$muttdir/accounts/$1.muttrc" + echo mailboxes "$oneline" >> "$muttdir/accounts/$1.muttrc" + sed -i "/^macro index,pager g/d" "$muttdir/accounts/$1.muttrc" + grep -i "/tmp/$1_boxes" -e inbox | sed 1q | formatShortcut i inbox "$1" + grep -i "/tmp/$1_boxes" -e sent | sed 1q | formatShortcut s sent "$1" + grep -i "/tmp/$1_boxes" -e draft | sed 1q | formatShortcut d drafts "$1" + grep -i "/tmp/$1_boxes" -e trash | sed 1q | formatShortcut t trash "$1" + grep -i "/tmp/$1_boxes" -e spam | sed 1q | formatShortcut S spam "$1" + grep -i "/tmp/$1_boxes" -e junk | sed 1q | formatShortcut j junk "$1" + grep -i "/tmp/$1_boxes" -e archive | sed 1q | formatShortcut a archive "$1" + spoolfile=$(grep -i "/tmp/$1_boxes" -e inbox | sed -e 's/=/+/g' | sed 1q) + record=$(grep -i "/tmp/$1_boxes" -e sent | sed -e 's/=/+/g' | sed 1q) + postponed=$(grep -i "/tmp/$1_boxes" -e draft | sed -e 's/=/+/g' | sed 1q) + trash=$(grep -i "/tmp/$1_boxes" -e trash | sed -e 's/=/+/g' | sed 1q) + { echo "set spoolfile = \"$spoolfile\""; + echo "set record = \"$record\""; + echo "set postponed = \"$postponed\""; + echo "set trash = \"$trash\""; } >> "$muttdir/accounts/$1.muttrc" + } # Get all accounts in ~/.offlineimaprc and load into variable `accounts`. getAccounts() { \ grep "^accounts =" ~/.offlineimaprc | sed -e 's/accounts =\( \)//g;s/\(,\) /\n/g;' | nl --number-format=ln > /tmp/numbered accounts=() - while read n s ; do - accounts+=($n "$s" off) + while read -r n s ; do + accounts+=("$n" "$s" off) done < /tmp/numbered ;} # Yields a menu of available accounts. @@ -120,13 +219,13 @@ inventory() { \ removeAccount() { sed -ie " /Account $1]/,/Account/{//!d} /Account $1]/d - s/ $1\(,\|$\)//g - s/=$1\(,\|$\)/=/g + s/ $1\\(,\\|$\\)//g + s/=$1\\(,\\|$\\)/=/g s/,$//g " ~/.offlineimaprc - rm "$muttdir"/accounts/$1.muttrc - rm "$muttdir"/credentials/$1.gpg - rm -rf "$muttdir"/accounts/$1 + rm "$muttdir/accounts/$1.muttrc" + rm "$muttdir/credentials/$1.gpg" + rm -rf "$muttdir/accounts/$1" sed -i "/$1.muttrc/d" "$muttdir"/personal.muttrc ;} manual() { \ @@ -136,89 +235,80 @@ manual() { \ sport=$( dialog --inputbox "What is your server's SMTP port number? (Usually 587 or 465)" 10 60 3>&1 1>&2 2>&3 3>&- ) ;} -addloop() { fulladdr=$( dialog --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "Insert the full email address for the account you want to configure." 10 60 3>&1 1>&2 2>&3 3>&- ) -while ! [[ "${fulladdr}" =~ ${emailre} ]]; do - fulladdr=$(dialog --no-cancel --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "That's not a valid email address. Please input the entire address." 10 60 3>&1 1>&2 2>&3 3>&1) -done -# Check to see if domain is in domain list -serverinfo=$(grep -w ^${fulladdr##*@} "$muttdir"/autoconf/domains.csv) +addloop() { \ + serverlist=$(mktemp -u) + curl -sL https://raw.githubusercontent.com/LukeSmithxyz/mutt-wizard/master/autoconf/domains.csv 2>/dev/null > "$serverlist" & + fulladdr=$( dialog --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "Insert the full email address for the account you want to configure." 10 60 3>&1 1>&2 2>&3 3>&- ) + while ! [[ "${fulladdr}" =~ ${emailre} ]]; do + fulladdr=$(dialog --no-cancel --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "That's not a valid email address. Please input the entire address." 10 60 3>&1 1>&2 2>&3 3>&1) + done + # Check to see if domain is in domain list + serverinfo=$(grep -w "^${fulladdr##*@}" "$serverlist") if [ -z "$serverinfo" ]; then manual else # Read in server data as variables -IFS=, read service imap iport smtp sport <&1 1>&2 2>&3 3>&- ) -title=$(dialog --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "Give a short, one-word name for this email account that will differentiate it from other email accounts." 10 60 3>&1 1>&2 2>&3 3>&1) || exit -while ! [[ "${title}" =~ ${namere} ]]; do - title=$(dialog --no-cancel --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "Account title not valid. Give a username beginning with a letter, with only lowercase letters, - or _." 10 60 3>&1 1>&2 2>&3 3>&1) -done -login=$(dialog --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "If you have a username for the \"$title\" account which is different from your email address, enter it here. Otherwise leave this prompt blank." 10 60 3>&1 1>&2 2>&3 3>&- ) -# Sets the repo type and other variables for the sed regex. -if [[ "$service" == "gmail.com" ]]; - then - type="Gmail" - delet="remotehost" - else - type="IMAP" - delet="Gmail]\/" -fi -if [[ -z "$login" ]]; - then - login=$fulladdr -fi -# The replacements -replacement=" - s/\$realname/$realname/g; - s/\$title/$title/g; - s/\$fulladdr/$fulladdr/g; - s/\$imap/$imap/g; - s/\$iport/$iport/g; - s/\$smtp/$smtp/g; - s/\$sport/$sport/g; - s/\$type/$type/g; - s/\$login/$login/g; - /$delet/d" -# Gets the first unused shortcut number in the muttrc and puts it in $idnum. -grep "i[0-9]" "$muttdir/personal.muttrc" | awk '{print $3}' | sed -e 's/i//g' > /tmp/mutt_used -echo -e "1\\n2\\n3\\n4\\n5\\n6\\n7\\n8\\n9" > /tmp/mutt_all_possible -idnum=$(diff /tmp/mutt_all_possible /tmp/mutt_used | sed -n 2p | awk '{print $2}') -addAccount \ -;} + realname=$( dialog --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "Enter the full name you'd like to be identified by on this email account." 10 60 3>&1 1>&2 2>&3 3>&- ) + title=$(dialog --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "Give a short, one-word name for this email account that will differentiate it from other email accounts." 10 60 3>&1 1>&2 2>&3 3>&1) || exit + while ! [[ "${title}" =~ ${namere} ]]; do + title=$(dialog --no-cancel --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "Account title not valid. Give a username beginning with a letter, with only lowercase letters, - or _." 10 60 3>&1 1>&2 2>&3 3>&1) + done + login=$(dialog --title "Luke's mutt/offlineIMAP autoconfig" --inputbox "If you have a username for the \"$title\" account which is different from your email address, enter it here. Otherwise leave this prompt blank." 10 60 3>&1 1>&2 2>&3 3>&- ) + # Sets the repo type and other variables for the sed regex. + if [[ "$service" == "gmail.com" ]]; + then + type="Gmail" + ifgoogleline="remotehost = $imap" + else + type="IMAP" + ifgoogleline="folderfilter = lambda foldername: foldername not in ['[Gmail]/All Mail']" + fi + [[ -z "$login" ]] && login=$fulladdr + # Gets the first unused shortcut number in the muttrc and puts it in $idnum. + grep "i[0-9]" "$muttdir/personal.muttrc" | awk '{print $3}' | sed -e 's/i//g' > /tmp/mutt_used + echo -e "1\\n2\\n3\\n4\\n5\\n6\\n7\\n8\\n9" > /tmp/mutt_all_possible + idnum=$(diff /tmp/mutt_all_possible /tmp/mutt_used | sed -n 2p | awk '{print $2}') + addAccount \ + ;} addAccount() { # First, adding the encrypted password. - dialog --title "Luke's mutt/offlineIMAP password wizard" --passwordbox "Enter the password for the \"$title\" account." 10 60 2> /tmp/$title - gpg2 -r $gpgemail --encrypt /tmp/$title || (dialog --title "GPG decryption failed." --msgbox "GPG decryption failed. This is either because you do not have a GPG key pair or because your distro uses GPG1 and you thus need to symlink /usr/bin/gpg2 to /usr/bin/gpg." 7 60 && break) + dialog --title "Luke's mutt/offlineIMAP password wizard" --passwordbox "Enter the password for the \"$title\" account." 10 60 2> "/tmp/$title" + gpg2 -r "$gpgemail" --encrypt "/tmp/$title" || (dialog --title "GPG decryption failed." --msgbox "GPG decryption failed. This is either because you do not have a GPG key pair or because your distro uses GPG1 and you thus need to symlink /usr/bin/gpg2 to /usr/bin/gpg." 7 60 && break) shred -u "/tmp/$title" mv "/tmp/$title.gpg" "$muttdir"/credentials/ # Adding directory structure for cache. mkdir -p "$muttdir/accounts/$title/cache/bodies" + # Prepare the account's config variables. + getprofiles + # Creating the offlineimaprc if it doesn't exist already. - if [ ! -f ~/.offlineimaprc ]; then cp "$muttdir"/autoconf/offlineimap_header"$os" ~/.offlineimaprc; fi - sed -e "$replacement" "$muttdir"/autoconf/offlineimap_profile"$os" >> ~/.offlineimaprc + [ ! -f ~/.offlineimaprc ] && echo "$offlineimap_header" > ~/.offlineimaprc + echo "$offlineimap_profile" >> ~/.offlineimaprc mkdir -p "$HOME/.mail/$title" # Creating msmtprc if it doesn't exist already. - if [ ! -f ~/.msmtprc ]; then cp "$muttdir"/autoconf/msmtprc_header ~/.msmtprc; fi - sed -e "$replacement" "$muttdir"/autoconf/msmtprc_profile >> ~/.msmtprc + [ ! -f ~/.msmtprc ] && echo "$msmtp_header" > ~/.msmtprc + echo "$msmtp_profile" >> ~/.msmtprc # Add the mutt profile. - sed -e "$replacement" "$muttdir"/autoconf/mutt_profile > "$muttdir/accounts/$title.muttrc" + echo "$mutt_profile" >> "$muttdir/accounts/$title.muttrc" # Add a numbered shortcut in the muttrc - echo "macro index,pager i$idnum 'source \"$muttdir\"/accounts/$title.muttrc!;'" >> "$muttdir"/personal.muttrc + echo "macro index,pager i$idnum 'source \"$muttdir\"/accounts/$title.muttrc!;'" >> "$muttdir/personal.muttrc" # Add to offlineimaprc sync list. - sed -i.bu "s/^accounts =.*[a-zA-Z]$/&, $title/g;s/^accounts =\\s*$/accounts = $title/g" ~/.offlineimaprc && rm ~/.offlineimaprc.bu + sed -i "s/^accounts =.*[a-zA-Z]$/&, $title/g;s/^accounts =\\s*$/accounts = $title/g" ~/.offlineimaprc # Makes account default if there is no default account. - grep "$muttdir"/personal.muttrc -e "^source .*accounts.*" >/dev/null && echo there || \ - echo "source ${muttdir}/accounts/$title.muttrc" >> "$muttdir"/personal.muttrc + grep "$muttdir/personal.muttrc" -e "^source .*accounts.*" >/dev/null || \ + echo "source ${muttdir}/accounts/$title.muttrc" >> "$muttdir/personal.muttrc" dialog --title "Finalizing your account." --infobox "The account \"$title\" has been added. Now attempting to configure mail directories... @@ -238,10 +328,10 @@ chooseAdd() { \ addloop done ;} -wipe () { rm "$HOME/.offlineimaprc" +wipe () { rm -f "$HOME/.offlineimaprc" rm -rf "$muttdir"/accounts rm -f "$muttdir"/credentials/*gpg - rm "$muttdir"/personal.muttrc ;} + rm -f "$muttdir"/personal.muttrc ;} while : ; do @@ -258,16 +348,16 @@ choice=$(dialog --title "Luke's mutt/offlineIMAP wizard" --nocancel \ 3>&1 1>&2 2>&3 3>&1 ) case $choice in -0) dialog --title "Accounts detected" --msgbox "The following accounts have been detected: + 0) dialog --title "Accounts detected" --msgbox "The following accounts have been detected: $(grep ~/.offlineimaprc -e "^accounts =" | sed 's/accounts =//g') " 6 60;; -1) chooseAdd;; -2) testSync;; -3) detectWarning && chooseDetect;; -4) inventory && for i in $userchoices; do changePassword "$i" ; done;; -5) inventory && for i in $userchoices; do removeAccount "$i" ; done;; -6) (dialog --defaultno --title "Wipe all custom neomutt/offlineIMAP settings?" --yesno "Would you like to wipe all of the mutt/offlineIMAP settings generated by the system?" 6 60 && wipe) ;; -7) clear && break ;; -*) echo "Unable to read response from dialog. Exiting." >&2; exit 2 + 1) chooseAdd;; + 2) testSync;; + 3) detectWarning && chooseDetect;; + 4) inventory && for i in $userchoices; do changePassword "$i" ; done;; + 5) inventory && for i in $userchoices; do removeAccount "$i" ; done;; + 6) (dialog --defaultno --title "Wipe all custom neomutt/offlineIMAP settings?" --yesno "Would you like to wipe all of the mutt/offlineIMAP settings generated by the system?" 6 60 && wipe) ;; + 7) clear && break ;; + *) echo "Unable to read response from dialog. Exiting." >&2; exit 2 esac done diff --git a/muttrc b/muttrc index c40d4cf..525d125 100644 --- a/muttrc +++ b/muttrc @@ -42,8 +42,8 @@ bind index,pager R group-reply bind index,pager \031 previous-undeleted # Mouse wheel bind index,pager \005 next-undeleted # Mouse wheel macro index,pager S -macro index,pager \Cu |urlscan\n -macro index,pager ,, |urlscan\n +macro index,pager \Cu "|urlscan\n" +macro index,pager ,, "|urlscan\n" # View attachments properly. bind attach view-mailcap @@ -56,6 +56,10 @@ set forward_quote # include message in forwards set reverse_name # reply as whomever it was to set include # include message in replies +set query_command="abook --mutt-query '%s'" +macro index,pager a "abook --add-email" "Add this sender to Abook" +bind editor complete-query + #Ctrl-R to mark all as read macro index \Cr "T~UN." "mark all messages as read"