Merge branch 'master' into master
This commit is contained in:
13
bin/mailsync
13
bin/mailsync
@ -1,17 +1,20 @@
|
||||
#!/usr/bin/env sh
|
||||
# Sync mail and give notification if there is new mail.
|
||||
|
||||
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
|
||||
[ -d "$HOME/.local/share/password-store" ] && export PASSWORD_STORE_DIR="$HOME/.local/share/password-store"
|
||||
|
||||
# Run only if user logged in (prevent cron errors)
|
||||
pgrep -u "$USER" >/dev/null || exit
|
||||
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 && exit
|
||||
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 || exit
|
||||
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."
|
||||
|
||||
export DISPLAY=:0.0
|
||||
|
||||
# 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 ;}
|
||||
|
7
bin/mw
7
bin/mw
@ -22,7 +22,7 @@ muttrc="$muttdir/muttrc"
|
||||
msmtprc="$HOME/.config/msmtp/config"
|
||||
ssltype="IMAPS" # This is later changed to `None` later in the script if using Protonmail
|
||||
|
||||
for x in "/etc/ssl/certs/ca-certificates.crt" "/etc/pki/tls/certs/ca-bundle.crt" "/etc/ssl/ca-bundle.pem" "/etc/pki/tls/cacert.pem" "/etc/pki/ca-trust/extracted/pem/tls-ca-bundle.pem" "/etc/ssl/cert.pem"
|
||||
for x in "/etc/ssl/certs/ca-certificates.crt" "/etc/pki/tls/certs/ca-bundle.crt" "/etc/ssl/ca-bundle.pem" "/etc/pki/tls/cacert.pem" "/etc/pki/ca-trust/extracted/pem/tls-ca-bundle.pem" "/etc/ssl/cert.pem" "/usr/local/share/ca-certificates/"
|
||||
do
|
||||
[ -f "$x" ] && sslcert="$x" && break
|
||||
done || { echo "CA Certificate not found. Please install one or link it to /etc/ssl/certs/ca-certificates.crt" && exit 1 ;}
|
||||
@ -103,7 +103,7 @@ set folder = \"imaps://$fulladdr@$imap:$iport\"
|
||||
set imap_user = \"$login\"
|
||||
set header_cache = $cachedir/$title/headers
|
||||
set message_cachedir = $cachedir/$title/bodies
|
||||
set imap_pass = \`pass mutt-wizard-$title\`
|
||||
set imap_pass = \"\`pass mutt-wizard-$title\`\"
|
||||
|
||||
set mbox_type = Maildir
|
||||
set ssl_starttls = yes
|
||||
@ -190,7 +190,7 @@ EOF
|
||||
}
|
||||
|
||||
protonfinger() { printf "Getting Protonmail bridge fingerprint...\\n"
|
||||
fingerprint="$(msmtp --serverinfo --tls --tls-certcheck=off -a "$title")" || return 1
|
||||
fingerprint="$(msmtp --serverinfo --host=127.0.0.1 --port=1025 --tls --tls-certcheck=off)" || return 1
|
||||
sed -ibu "s/account $title/&\ntls_trust_file\ntls_fingerprint $fingerprint/" "$msmtprc" ; rm -f "$msmtprc"bu
|
||||
}
|
||||
|
||||
@ -289,6 +289,7 @@ asktype() { while : ; do
|
||||
|
||||
purge() { confirm "delete all account data" || exit
|
||||
rm -rf "$mbsyncrc" "$accdir" "$HOME/.config/msmtp" "$cachedir"
|
||||
crontab -l | sed '/mailsync/d' | crontab - >/dev/null
|
||||
echo "All configs and account settings have been purged."
|
||||
sed -ibu "/\# mw-autogenerated/d" "$muttrc" ; rm -f "$muttrc"bu
|
||||
}
|
||||
|
Reference in New Issue
Block a user