mirror of
https://github.com/nix-community/home-manager
synced 2025-01-25 18:35:01 +01:00
a3638db009
The `getmail` package will soon be removed from nixpkgs. The `nixos-unstable` channel already has it removed and using the service will result in: error: getmail has been removed from nixpkgs, migrate to getmail6 Upgrade to the getmail6 package which is already available and backwards compatible.
60 lines
1.7 KiB
Nix
60 lines
1.7 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
|
|
cfg = config.services.getmail;
|
|
|
|
accounts =
|
|
filter (a: a.getmail.enable) (attrValues config.accounts.email.accounts);
|
|
|
|
# Note: The getmail service does not expect a path, but just the filename!
|
|
renderConfigFilepath = a:
|
|
if a.primary then "getmailrc" else "getmail${a.name}";
|
|
configFiles =
|
|
concatMapStringsSep " " (a: " --rcfile ${renderConfigFilepath a}") accounts;
|
|
in {
|
|
options = {
|
|
services.getmail = {
|
|
enable = mkEnableOption
|
|
"the getmail systemd service to automatically retrieve mail";
|
|
|
|
frequency = mkOption {
|
|
type = types.str;
|
|
default = "*:0/5";
|
|
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.
|
|
'';
|
|
};
|
|
};
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
assertions = [
|
|
(lib.hm.assertions.assertPlatform "services.getmail" pkgs
|
|
lib.platforms.linux)
|
|
];
|
|
|
|
systemd.user.services.getmail = {
|
|
Unit = { Description = "getmail email fetcher"; };
|
|
Service = { ExecStart = "${pkgs.getmail6}/bin/getmail ${configFiles}"; };
|
|
};
|
|
|
|
systemd.user.timers.getmail = {
|
|
Unit = { Description = "getmail email fetcher"; };
|
|
Timer = {
|
|
OnCalendar = "${cfg.frequency}";
|
|
Unit = "getmail.service";
|
|
};
|
|
Install = { WantedBy = [ "timers.target" ]; };
|
|
};
|
|
|
|
};
|
|
}
|