2014-04-14 15:26:48 +01:00
|
|
|
{ config, lib, pkgs, ... }:
|
2010-04-29 19:54:08 +01:00
|
|
|
|
2014-04-14 15:26:48 +01:00
|
|
|
with lib;
|
2010-04-29 19:54:08 +01:00
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.logrotate;
|
|
|
|
|
2022-02-28 21:53:15 +00:00
|
|
|
pathOpts = { name, ... }: {
|
2020-05-13 19:59:28 +01:00
|
|
|
options = {
|
2020-08-19 17:36:54 +01:00
|
|
|
enable = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = true;
|
|
|
|
description = ''
|
|
|
|
Whether to enable log rotation for this path. This can be used to explicitly disable
|
|
|
|
logging that has been configured by NixOS.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-12-26 11:41:43 +00:00
|
|
|
name = mkOption {
|
2020-05-13 19:59:28 +01:00
|
|
|
type = types.str;
|
2021-12-26 11:41:43 +00:00
|
|
|
internal = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
path = mkOption {
|
|
|
|
type = with types; either str (listOf str);
|
2021-12-28 20:29:53 +00:00
|
|
|
default = name;
|
|
|
|
defaultText = "attribute name";
|
2020-08-19 17:36:54 +01:00
|
|
|
description = ''
|
|
|
|
The path to log files to be rotated.
|
2021-12-26 11:41:43 +00:00
|
|
|
Spaces are allowed and normal shell quoting rules apply,
|
|
|
|
with ', ", and \ characters supported.
|
2020-08-19 17:36:54 +01:00
|
|
|
'';
|
2020-05-13 19:59:28 +01:00
|
|
|
};
|
2020-08-19 17:36:54 +01:00
|
|
|
|
2020-05-13 19:59:28 +01:00
|
|
|
user = mkOption {
|
2020-08-19 17:36:54 +01:00
|
|
|
type = with types; nullOr str;
|
|
|
|
default = null;
|
|
|
|
description = ''
|
|
|
|
The user account to use for rotation.
|
|
|
|
'';
|
2020-05-13 19:59:28 +01:00
|
|
|
};
|
2020-08-19 17:36:54 +01:00
|
|
|
|
2020-05-13 19:59:28 +01:00
|
|
|
group = mkOption {
|
2020-08-19 17:36:54 +01:00
|
|
|
type = with types; nullOr str;
|
|
|
|
default = null;
|
|
|
|
description = ''
|
|
|
|
The group to use for rotation.
|
|
|
|
'';
|
2020-05-13 19:59:28 +01:00
|
|
|
};
|
2020-08-19 17:36:54 +01:00
|
|
|
|
2020-05-13 19:59:28 +01:00
|
|
|
frequency = mkOption {
|
2021-09-03 22:17:28 +01:00
|
|
|
type = types.enum [ "hourly" "daily" "weekly" "monthly" "yearly" ];
|
2020-05-13 19:59:28 +01:00
|
|
|
default = "daily";
|
2020-08-19 17:36:54 +01:00
|
|
|
description = ''
|
|
|
|
How often to rotate the logs.
|
|
|
|
'';
|
2020-05-13 19:59:28 +01:00
|
|
|
};
|
2020-08-19 17:36:54 +01:00
|
|
|
|
2020-05-13 19:59:28 +01:00
|
|
|
keep = mkOption {
|
|
|
|
type = types.int;
|
|
|
|
default = 20;
|
2020-08-19 17:36:54 +01:00
|
|
|
description = ''
|
|
|
|
How many rotations to keep.
|
|
|
|
'';
|
2020-05-13 19:59:28 +01:00
|
|
|
};
|
2020-08-19 17:36:54 +01:00
|
|
|
|
2020-05-13 19:59:28 +01:00
|
|
|
extraConfig = mkOption {
|
|
|
|
type = types.lines;
|
|
|
|
default = "";
|
2020-08-19 17:36:54 +01:00
|
|
|
description = ''
|
|
|
|
Extra logrotate config options for this path. Refer to
|
|
|
|
<link xlink:href="https://linux.die.net/man/8/logrotate"/> for details.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
priority = mkOption {
|
|
|
|
type = types.int;
|
|
|
|
default = 1000;
|
|
|
|
description = ''
|
|
|
|
Order of this logrotate block in relation to the others. The semantics are
|
|
|
|
the same as with `lib.mkOrder`. Smaller values have a greater priority.
|
|
|
|
'';
|
2020-05-13 19:59:28 +01:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-12-26 11:41:43 +00:00
|
|
|
config.name = name;
|
2020-08-19 17:36:54 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
mkConf = pathOpts: ''
|
|
|
|
# generated by NixOS using the `services.logrotate.paths.${pathOpts.name}` attribute set
|
2021-12-26 11:41:43 +00:00
|
|
|
${concatMapStringsSep " " (path: ''"${path}"'') (toList pathOpts.path)} {
|
2020-08-19 17:36:54 +01:00
|
|
|
${optionalString (pathOpts.user != null || pathOpts.group != null) "su ${pathOpts.user} ${pathOpts.group}"}
|
|
|
|
${pathOpts.frequency}
|
|
|
|
rotate ${toString pathOpts.keep}
|
|
|
|
${pathOpts.extraConfig}
|
2020-05-13 19:59:28 +01:00
|
|
|
}
|
|
|
|
'';
|
|
|
|
|
2021-12-26 11:41:43 +00:00
|
|
|
paths = sortProperties (attrValues (filterAttrs (_: pathOpts: pathOpts.enable) cfg.paths));
|
2022-02-27 10:06:44 +00:00
|
|
|
configText = concatStringsSep "\n" (
|
2022-02-28 21:53:15 +00:00
|
|
|
[ "missingok" "notifempty" cfg.extraConfig ] ++ (map mkConf paths)
|
|
|
|
);
|
2022-02-27 10:06:44 +00:00
|
|
|
configFile = pkgs.writeText "logrotate.conf" configText;
|
|
|
|
|
|
|
|
mailOption =
|
|
|
|
# add mail option to service if a mail is requested in config
|
|
|
|
# this ugly match will be replaced by cleaner attribute check in
|
|
|
|
# the near future
|
|
|
|
if builtins.match "(.*[[:space:]])?mail[[:space:]].*" configText != null
|
|
|
|
then "--mail=${pkgs.mailutils}/bin/mail"
|
|
|
|
else "";
|
2010-04-29 19:54:08 +01:00
|
|
|
in
|
|
|
|
{
|
2020-05-13 19:59:28 +01:00
|
|
|
imports = [
|
|
|
|
(mkRenamedOptionModule [ "services" "logrotate" "config" ] [ "services" "logrotate" "extraConfig" ])
|
|
|
|
];
|
|
|
|
|
2010-04-29 19:54:08 +01:00
|
|
|
options = {
|
|
|
|
services.logrotate = {
|
2022-02-11 08:13:38 +00:00
|
|
|
enable = mkEnableOption "the logrotate systemd service" // {
|
|
|
|
default = foldr (n: a: a || n.enable) false (attrValues cfg.paths);
|
|
|
|
defaultText = literalExpression "cfg.paths != {}";
|
|
|
|
};
|
2020-05-13 19:59:28 +01:00
|
|
|
|
|
|
|
paths = mkOption {
|
2020-08-19 17:36:54 +01:00
|
|
|
type = with types; attrsOf (submodule pathOpts);
|
2022-02-28 21:53:15 +00:00
|
|
|
default = { };
|
2020-08-19 17:36:54 +01:00
|
|
|
description = ''
|
|
|
|
Attribute set of paths to rotate. The order each block appears in the generated configuration file
|
2020-08-22 00:38:38 +01:00
|
|
|
can be controlled by the <link linkend="opt-services.logrotate.paths._name_.priority">priority</link> option
|
2020-08-19 17:36:54 +01:00
|
|
|
using the same semantics as `lib.mkOrder`. Smaller values have a greater priority.
|
|
|
|
'';
|
2021-10-03 17:06:03 +01:00
|
|
|
example = literalExpression ''
|
2020-08-19 17:36:54 +01:00
|
|
|
{
|
|
|
|
httpd = {
|
|
|
|
path = "/var/log/httpd/*.log";
|
|
|
|
user = config.services.httpd.user;
|
|
|
|
group = config.services.httpd.group;
|
|
|
|
keep = 7;
|
|
|
|
};
|
|
|
|
|
|
|
|
myapp = {
|
|
|
|
path = "/var/log/myapp/*.log";
|
|
|
|
user = "myuser";
|
|
|
|
group = "mygroup";
|
|
|
|
frequency = "weekly";
|
|
|
|
keep = 5;
|
|
|
|
priority = 1;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
'';
|
2010-04-29 19:54:08 +01:00
|
|
|
};
|
|
|
|
|
2020-05-13 19:59:28 +01:00
|
|
|
extraConfig = mkOption {
|
2010-04-29 19:54:08 +01:00
|
|
|
default = "";
|
2014-10-16 07:20:43 +01:00
|
|
|
type = types.lines;
|
2010-04-29 19:54:08 +01:00
|
|
|
description = ''
|
2020-08-19 17:36:54 +01:00
|
|
|
Extra contents to append to the logrotate configuration file. Refer to
|
|
|
|
<link xlink:href="https://linux.die.net/man/8/logrotate"/> for details.
|
2010-04-29 19:54:08 +01:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2022-02-28 21:53:15 +00:00
|
|
|
assertions = mapAttrsToList
|
|
|
|
(name: pathOpts:
|
|
|
|
{
|
|
|
|
assertion = (pathOpts.user != null) == (pathOpts.group != null);
|
|
|
|
message = ''
|
|
|
|
If either of `services.logrotate.paths.${name}.user` or `services.logrotate.paths.${name}.group` are specified then *both* must be specified.
|
|
|
|
'';
|
|
|
|
}
|
|
|
|
)
|
|
|
|
cfg.paths;
|
2014-07-10 12:11:35 +01:00
|
|
|
|
2020-08-19 17:36:54 +01:00
|
|
|
systemd.services.logrotate = {
|
|
|
|
description = "Logrotate Service";
|
2021-09-03 22:17:28 +01:00
|
|
|
startAt = "hourly";
|
2020-08-19 17:36:54 +01:00
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
Restart = "no";
|
|
|
|
User = "root";
|
2022-02-27 10:06:44 +00:00
|
|
|
ExecStart = "${pkgs.logrotate}/sbin/logrotate ${mailOption} ${configFile}";
|
2020-08-19 17:36:54 +01:00
|
|
|
};
|
2014-07-10 12:11:35 +01:00
|
|
|
};
|
2010-04-29 19:54:08 +01:00
|
|
|
};
|
|
|
|
}
|