mirror of
https://github.com/kmein/niveum
synced 2026-03-18 19:11:08 +01:00
feat(mail): add mail-sync service
This commit is contained in:
@@ -1,5 +1,7 @@
|
|||||||
{ config, pkgs, lib, ... }:
|
{ config, pkgs, lib, ... }:
|
||||||
let
|
let
|
||||||
|
pass_ = file: "echo ${lib.escapeShellArg (lib.strings.fileContents file)}";
|
||||||
|
|
||||||
generateTaggingScript = filters:
|
generateTaggingScript = filters:
|
||||||
let
|
let
|
||||||
template = { tags, query, message ? "tagging ${query} -> ${lib.concatStringsSep " " tags}", ... }: ''
|
template = { tags, query, message ? "tagging ${query} -> ${lib.concatStringsSep " " tags}", ... }: ''
|
||||||
@@ -8,22 +10,6 @@ let
|
|||||||
'';
|
'';
|
||||||
in lib.concatStringsSep "\n" (map template filters);
|
in lib.concatStringsSep "\n" (map template filters);
|
||||||
|
|
||||||
taggingConfig = [
|
|
||||||
{
|
|
||||||
query = "from:nebenan.de";
|
|
||||||
tags = [ "-inbox" "-unread" ];
|
|
||||||
}
|
|
||||||
{
|
|
||||||
query = "subject:fd-noti";
|
|
||||||
tags = [ "-inbox -unread" ];
|
|
||||||
}
|
|
||||||
{
|
|
||||||
query = "subject:miaEngiadina AND subject:\"PR run failed\"";
|
|
||||||
tags = [ "+deleted" ];
|
|
||||||
}
|
|
||||||
];
|
|
||||||
|
|
||||||
pass = id: "${pkgs.pass}/bin/pass ${id}";
|
|
||||||
enableDefaults = lib.recursiveUpdate {
|
enableDefaults = lib.recursiveUpdate {
|
||||||
mbsync = {
|
mbsync = {
|
||||||
enable = true;
|
enable = true;
|
||||||
@@ -36,10 +22,28 @@ let
|
|||||||
|
|
||||||
much-pkg = pkgs.haskellPackages.callCabal2nix "much" <niveum/submodules/much> {};
|
much-pkg = pkgs.haskellPackages.callCabal2nix "much" <niveum/submodules/much> {};
|
||||||
much = pkgs.haskell.lib.dontHaddock much-pkg;
|
much = pkgs.haskell.lib.dontHaddock much-pkg;
|
||||||
|
|
||||||
|
mail-sync = pkgs.writers.writeDashBin "mail-sync" ''
|
||||||
|
${pkgs.isync}/bin/mbsync --all
|
||||||
|
${pkgs.notmuch}/bin/notmuch new
|
||||||
|
'';
|
||||||
in {
|
in {
|
||||||
|
environment.variables.NOTMUCH_CONFIG = config.home-manager.users.me.home.sessionVariables.NOTMUCH_CONFIG;
|
||||||
|
|
||||||
|
systemd.services.mail-sync = {
|
||||||
|
enable = true;
|
||||||
|
wants = [ "network-online.target" ];
|
||||||
|
startAt = "*:0/15";
|
||||||
|
serviceConfig.User = "kfm";
|
||||||
|
environment.NOTMUCH_CONFIG = config.home-manager.users.me.home.sessionVariables.NOTMUCH_CONFIG;
|
||||||
|
script = "${mail-sync}/bin/mail-sync";
|
||||||
|
};
|
||||||
|
|
||||||
environment.systemPackages = [
|
environment.systemPackages = [
|
||||||
pkgs.neomutt
|
pkgs.neomutt
|
||||||
|
|
||||||
|
mail-sync
|
||||||
|
|
||||||
(pkgs.writers.writeDashBin "mua" ''
|
(pkgs.writers.writeDashBin "mua" ''
|
||||||
if [ $# -eq 0 ]; then
|
if [ $# -eq 0 ]; then
|
||||||
${much}/bin/much-kmein
|
${much}/bin/much-kmein
|
||||||
@@ -48,17 +52,13 @@ in {
|
|||||||
fi
|
fi
|
||||||
'')
|
'')
|
||||||
|
|
||||||
(pkgs.writers.writeDashBin "mail-fetch" ''
|
(pkgs.writers.writeDashBin "mail-clean" ''
|
||||||
${pkgs.isync}/bin/mbsync --all
|
|
||||||
${pkgs.notmuch}/bin/notmuch new
|
|
||||||
'')
|
|
||||||
|
|
||||||
(pkgs.writers.writeDashBin "mail-rm-deleted" ''
|
|
||||||
${pkgs.notmuch}/bin/notmuch search --output files --format=text0 tag:deleted | ${pkgs.findutils}/bin/xargs -r0 rm
|
${pkgs.notmuch}/bin/notmuch search --output files --format=text0 tag:deleted | ${pkgs.findutils}/bin/xargs -r0 rm
|
||||||
${pkgs.notmuch}/bin/notmuch new
|
${pkgs.notmuch}/bin/notmuch new
|
||||||
'')
|
'')
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
home-manager.users.me = {
|
home-manager.users.me = {
|
||||||
programs.msmtp.enable = true;
|
programs.msmtp.enable = true;
|
||||||
|
|
||||||
@@ -68,7 +68,22 @@ in {
|
|||||||
enable = true;
|
enable = true;
|
||||||
new.tags = [ "unread" "inbox" ];
|
new.tags = [ "unread" "inbox" ];
|
||||||
search.excludeTags = [ "deleted" "spam" ];
|
search.excludeTags = [ "deleted" "spam" ];
|
||||||
hooks.postNew = generateTaggingScript taggingConfig;
|
hooks.postNew = generateTaggingScript [
|
||||||
|
{
|
||||||
|
query = "to:miaengiadina-pwa@noreply.github.com AND subject:\"PR run failed\"";
|
||||||
|
tags = [ "+deleted" ];
|
||||||
|
}
|
||||||
|
{
|
||||||
|
query = lib.concatStringsSep " OR " [
|
||||||
|
"from:noreply-local-guides@google.com"
|
||||||
|
"from:google-maps-noreply@google.com"
|
||||||
|
"subject:fd-noti"
|
||||||
|
"from:nebenan.de"
|
||||||
|
"to:miaengiadina-pwa@noreply.github.com"
|
||||||
|
];
|
||||||
|
tags = [ "-inbox -unread" ];
|
||||||
|
}
|
||||||
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
accounts.email.maildirBasePath = "${config.users.users.me.home}/mail";
|
accounts.email.maildirBasePath = "${config.users.users.me.home}/mail";
|
||||||
@@ -89,7 +104,7 @@ in {
|
|||||||
userName = "kieran@fysi.tech";
|
userName = "kieran@fysi.tech";
|
||||||
address = "kieran@fysi.tech";
|
address = "kieran@fysi.tech";
|
||||||
realName = config.niveum.user.name;
|
realName = config.niveum.user.name;
|
||||||
passwordCommand = pass "mail/kieran@fysi.tech";
|
passwordCommand = pass_ <shared-secrets/fastmail/fysi>;
|
||||||
};
|
};
|
||||||
cock = enableDefaults {
|
cock = enableDefaults {
|
||||||
primary = false;
|
primary = false;
|
||||||
@@ -109,7 +124,7 @@ in {
|
|||||||
userName = "2210@cock.li";
|
userName = "2210@cock.li";
|
||||||
address = "2210@cock.li";
|
address = "2210@cock.li";
|
||||||
realName = "2210";
|
realName = "2210";
|
||||||
passwordCommand = pass "mail/2210@cock.li";
|
passwordCommand = pass_ <shared-secrets/cock/2210>;
|
||||||
};
|
};
|
||||||
kieran-gmail = enableDefaults {
|
kieran-gmail = enableDefaults {
|
||||||
primary = false;
|
primary = false;
|
||||||
@@ -117,7 +132,7 @@ in {
|
|||||||
address = "kieran.meinhardt@gmail.com";
|
address = "kieran.meinhardt@gmail.com";
|
||||||
realName = config.niveum.user.name;
|
realName = config.niveum.user.name;
|
||||||
userName = "kieran.meinhardt";
|
userName = "kieran.meinhardt";
|
||||||
passwordCommand = pass "mail/kieran.meinhardt@gmail.com";
|
passwordCommand = pass_ <shared-secrets/gmail/kieran.meinhardt>;
|
||||||
folders = {
|
folders = {
|
||||||
drafts = "[Gmail]/Entw&APw-rfe";
|
drafts = "[Gmail]/Entw&APw-rfe";
|
||||||
sent = "[Gmail]/Gesendet";
|
sent = "[Gmail]/Gesendet";
|
||||||
@@ -130,7 +145,7 @@ in {
|
|||||||
address = "amroplay@gmail.com";
|
address = "amroplay@gmail.com";
|
||||||
realName = config.niveum.user.name;
|
realName = config.niveum.user.name;
|
||||||
userName = "amroplay";
|
userName = "amroplay";
|
||||||
passwordCommand = pass "mail/amroplay@gmail.com";
|
passwordCommand = pass_ <shared-secrets/gmail/amroplay>;
|
||||||
folders = {
|
folders = {
|
||||||
drafts = "[Gmail]/Drafts";
|
drafts = "[Gmail]/Drafts";
|
||||||
sent = "[Gmail]/Sent Mail";
|
sent = "[Gmail]/Sent Mail";
|
||||||
@@ -155,14 +170,14 @@ in {
|
|||||||
address = "kieran.meinhardt@posteo.net";
|
address = "kieran.meinhardt@posteo.net";
|
||||||
realName = config.niveum.user.name;
|
realName = config.niveum.user.name;
|
||||||
userName = "kieran.meinhardt@posteo.net";
|
userName = "kieran.meinhardt@posteo.net";
|
||||||
passwordCommand = pass "shared/posteo/password";
|
passwordCommand = pass_ <shared-secrets/posteo/password>;
|
||||||
};
|
};
|
||||||
hu-berlin = enableDefaults {
|
hu-berlin = enableDefaults {
|
||||||
primary = false;
|
primary = false;
|
||||||
address = "meinhark@hu-berlin.de";
|
address = "meinhark@hu-berlin.de";
|
||||||
realName = config.niveum.user.name;
|
realName = config.niveum.user.name;
|
||||||
userName = "meinhark";
|
userName = "meinhark";
|
||||||
passwordCommand = pass "shared/eduroam/password";
|
passwordCommand = pass_ <shared-secrets/eduroam/password>;
|
||||||
smtp = {
|
smtp = {
|
||||||
host = "mailhost.cms.hu-berlin.de";
|
host = "mailhost.cms.hu-berlin.de";
|
||||||
port = 25;
|
port = 25;
|
||||||
|
|||||||
Reference in New Issue
Block a user