home-manager/modules/services/getmail.nix

56 lines
1.6 KiB
Nix
Raw Normal View History

2018-06-12 21:40:05 +02:00
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.services.getmail;
2018-06-12 21:40:05 +02:00
2020-02-02 00:39:17 +01:00
accounts =
filter (a: a.getmail.enable) (attrValues config.accounts.email.accounts);
2018-06-12 21:40:05 +02:00
# Note: The getmail service does not expect a path, but just the filename!
2020-02-02 00:39:17 +01:00
renderConfigFilepath = a:
if a.primary then "getmailrc" else "getmail${a.name}";
configFiles =
concatMapStringsSep " " (a: " --rcfile ${renderConfigFilepath a}") accounts;
in {
2018-06-12 21:40:05 +02:00
options = {
services.getmail = {
2020-02-02 00:39:17 +01:00
enable = mkEnableOption
"the getmail systemd service to automatically retrieve mail";
2018-06-12 21:40:05 +02:00
frequency = mkOption {
type = types.str;
default = "*:0/5";
2018-06-12 21:40:05 +02:00
example = "hourly";
description = ''
The refresh frequency. Check <literal>man systemd.time</literal> for
more information on the syntax. If you use a gpg-agent in
combination with the passwordCommand, keep the poll
frequency below the cache-ttl value (as set by the
<literal>default</literal>) to avoid pinentry asking
permanently for a password.
2018-06-12 21:40:05 +02:00
'';
};
};
};
config = mkIf cfg.enable {
systemd.user.services.getmail = {
2020-02-02 00:39:17 +01:00
Unit = { Description = "getmail email fetcher"; };
Service = { ExecStart = "${pkgs.getmail}/bin/getmail ${configFiles}"; };
2018-06-12 21:40:05 +02:00
};
systemd.user.timers.getmail = {
2020-02-02 00:39:17 +01:00
Unit = { Description = "getmail email fetcher"; };
2018-06-12 21:40:05 +02:00
Timer = {
OnCalendar = "${cfg.frequency}";
Unit = "getmail.service";
};
2020-02-02 00:39:17 +01:00
Install = { WantedBy = [ "timers.target" ]; };
2018-06-12 21:40:05 +02:00
};
2018-06-12 21:40:05 +02:00
};
}