From 21bdf17d577d87a01e3caaad6b96b58746b51f90 Mon Sep 17 00:00:00 2001 From: Alan Pearce Date: Wed, 9 Oct 2019 17:52:28 +0200 Subject: Unify mail setup --- system/satoshipad.nix | 19 ------------------- system/settings/user-interface.nix | 5 ----- user/emacs/.emacs.d/init.el | 14 +++++++------- user/isync/.mbsyncrc | 37 ------------------------------------- user/msmtp/.msmtprc | 17 ----------------- user/satoshipad.nix | 5 +++-- user/settings/isync.nix | 5 ----- user/settings/mail.nix | 25 +++++++++++++++++++++++++ user/settings/msmtp.nix | 5 ----- user/settings/satoshipay.nix | 31 +++++++++++++++++++++++++++++++ 10 files changed, 66 insertions(+), 97 deletions(-) delete mode 100644 user/isync/.mbsyncrc delete mode 100644 user/msmtp/.msmtprc delete mode 100644 user/settings/isync.nix create mode 100644 user/settings/mail.nix delete mode 100644 user/settings/msmtp.nix diff --git a/system/satoshipad.nix b/system/satoshipad.nix index 84d2407f..760181e6 100644 --- a/system/satoshipad.nix +++ b/system/satoshipad.nix @@ -43,23 +43,4 @@ virtualisation.docker.autoPrune.dates = "Mon, 13:00"; system.stateVersion = "18.03"; - - systemd.user.services.mbsync = { - description = "Mailbox synchronisation"; - path = with pkgs; [ python3Packages.keyring ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkgs.isync}/bin/mbsync -Va"; - # ExecStartPost = "${pkgs.myEmacs}/bin/emacsclient -e (mu4e-update-index)"; - }; - }; - - systemd.user.timers.mbsync = { - description = "Mailbox synchronisation timer"; - wantedBy = [ "default.target" ]; - timerConfig = { - OnBootSec = "2m"; - OnUnitActiveSec = "10m"; - }; - }; } diff --git a/system/settings/user-interface.nix b/system/settings/user-interface.nix index 08d390ab..c23eec81 100644 --- a/system/settings/user-interface.nix +++ b/system/settings/user-interface.nix @@ -21,11 +21,6 @@ lxrandr lxtask - python3Packages.keyring - isync - msmtp - html2text - weechat mpv diff --git a/user/emacs/.emacs.d/init.el b/user/emacs/.emacs.d/init.el index 5c30ce82..a6ff1f6c 100644 --- a/user/emacs/.emacs.d/init.el +++ b/user/emacs/.emacs.d/init.el @@ -812,14 +812,14 @@ _p_rev _u_pper _=_: upper/lower _r_esolve (string-equal (system-name) "satoshipad"))) :vars '((user-mail-address . "alan@satoshipay.io") (mu4e-sent-messages-behavior . delete) - (mu4e-drafts-folder . "/satoshipay/Drafts") - (mu4e-sent-folder . "/satoshipay/Sent Mail") - (mu4e-refile-folder . "/satoshipay/All Mail") - (mu4e-trash-folder . "/satoshipay/Bin") + (mu4e-drafts-folder . "/satoshipay/[Gmail]/Drafts") + (mu4e-sent-folder . "/satoshipay/[Gmail]/Sent Mail") + (mu4e-refile-folder . "/satoshipay/[Gmail]/All Mail") + (mu4e-trash-folder . "/satoshipay/[Gmail]/Bin") (mu4e-maildir-shortcuts . (("/satoshipay/INBOX" . ?i) - ("/satoshipay/All Mail" . ?a) - ("/satoshipay/Sent Mail" . ?s) - ("/satoshipay/Spam" . ?p))))))))) + ("/satoshipay/[Gmail]/All Mail" . ?a) + ("/satoshipay/[Gmail]/Sent Mail" . ?s) + ("/satoshipay/[Gmail]/Spam" . ?p))))))))) ;;; Take me to my leader diff --git a/user/isync/.mbsyncrc b/user/isync/.mbsyncrc deleted file mode 100644 index 396bc6a6..00000000 --- a/user/isync/.mbsyncrc +++ /dev/null @@ -1,37 +0,0 @@ -# Globals -Create Both -Remove Both -Expunge Both -CopyArrivalDate yes -FSync no - -## Satoshipay -# Account -IMAPAccount satoshipay.io -Host imap.gmail.com -User alan@satoshipay.io -PassCmd "keyring get satoshipay-google-mail alan@satoshipay.io" -SSLType IMAPS -SSLVersions TLSv1.2 TLSv1.1 - -# Remote -IMAPStore satoshipay.io-remote -Account satoshipay.io - -# Local -MaildirStore satoshipay.io-local -Path ~/mail/satoshipay/ -Inbox ~/mail/satoshipay/INBOX -SubFolders Verbatim - -# Job -Channel satoshipay -Master :satoshipay.io-remote: -Slave :satoshipay.io-local: -Patterns INBOX -SyncState * - -Channel satoshipay-gmail -Master :satoshipay.io-remote:[Gmail]/ -Slave :satoshipay.io-local: -Patterns * !INBOX \ No newline at end of file diff --git a/user/msmtp/.msmtprc b/user/msmtp/.msmtprc deleted file mode 100644 index da5c5daf..00000000 --- a/user/msmtp/.msmtprc +++ /dev/null @@ -1,17 +0,0 @@ -# Set default values for all following accounts. -defaults -auth on -tls on -tls_trust_file /etc/ssl/certs/ca-certificates.crt -logfile ~/.local/log/msmtp.log - -account satoshipay -host smtp.gmail.com -from alan@satoshipay.io -user alan@satoshipay.io -port 465 -tls_starttls off -passwordeval keyring get satoshipay-google-mail alan@satoshipay.io - -# Set a default account -account default : satoshipay diff --git a/user/satoshipad.nix b/user/satoshipad.nix index 3dda7bd1..d5f404c6 100644 --- a/user/satoshipad.nix +++ b/user/satoshipad.nix @@ -10,9 +10,8 @@ ./settings/git.nix ./settings/gnupg.nix ./settings/i3.nix - ./settings/isync.nix ./settings/javascript.nix - ./settings/msmtp.nix + ./settings/mail.nix ./settings/nixos.nix ./settings/rofi.nix ./settings/passwords.nix @@ -25,6 +24,8 @@ ./settings/zsh.nix ]; + accounts.email.accounts.satoshipay.primary = true; + xsession.windowManager.i3 = { config = { assigns = { diff --git a/user/settings/isync.nix b/user/settings/isync.nix deleted file mode 100644 index b96db87d..00000000 --- a/user/settings/isync.nix +++ /dev/null @@ -1,5 +0,0 @@ -{ config, pkgs, ... }: - -{ - home.file.".mbsyncrc".source = ../isync/.mbsyncrc; -} diff --git a/user/settings/mail.nix b/user/settings/mail.nix new file mode 100644 index 00000000..3ce9e548 --- /dev/null +++ b/user/settings/mail.nix @@ -0,0 +1,25 @@ +{ config, pkgs, ... }: + +{ + home.packages = [ + pkgs.html2text + ]; + accounts.email = { + maildirBasePath = "mail"; + }; + programs.mbsync = { + enable = true; + extraConfig = '' + CopyArrivalDate yes + FSync no + ''; + }; + services.mbsync = { + enable = true; + frequency = "*:6/15"; + postExec = "${config.programs.emacs.finalPackage}/bin/emacsclient -e (mu4e-update-index)"; + }; + programs.msmtp = { + enable = true; + }; +} diff --git a/user/settings/msmtp.nix b/user/settings/msmtp.nix deleted file mode 100644 index 45c2f460..00000000 --- a/user/settings/msmtp.nix +++ /dev/null @@ -1,5 +0,0 @@ -{ config, pkgs, ... }: - -{ - home.file.".msmtprc".source = ../msmtp/.msmtprc; -} diff --git a/user/settings/satoshipay.nix b/user/settings/satoshipay.nix index 6516bd59..822f6b6f 100644 --- a/user/settings/satoshipay.nix +++ b/user/settings/satoshipay.nix @@ -49,6 +49,37 @@ in } ]; + accounts.email.accounts.satoshipay = let + address = "alan@satoshipay.io"; + in + { + inherit address; + realName = "Alan Pearce"; + flavor = "gmail.com"; + passwordCommand = "${pkgs.python3Packages.keyring}/bin/keyring get satoshipay-google-mail ${address}"; + folders = { + inbox = "INBOX"; + drafts = "[Gmail]/Drafts"; + sent = "[Gmail]/Sent Mail"; + trash = "[Gmail]/Bin"; + }; + imap = { + tls.enable = true; + }; + smtp = { + tls.enable = true; + }; + mbsync = { + enable = true; + create = "maildir"; + remove = "maildir"; + expunge = "both"; + }; + msmtp = { + enable = true; + }; + }; + home.file.".npmrc".text = '' @satoshipay:registry=https://registry.npmjs.org/ ''; -- cgit 1.4.1