collectd: add pidFile option, change default pid to /var/run/collectd.pid

Changed files
+16 -4
nixos
modules
services
monitoring
+16 -4
nixos/modules/services/monitoring/collectd.nix
···
conf = pkgs.writeText "collectd.conf" ''
BaseDir "${cfg.dataDir}"
-
PIDFile "${cfg.dataDir}/collectd.pid"
+
PIDFile "${cfg.pidFile}"
AutoLoadPlugin ${if cfg.autoLoadPlugin then "true" else "false"}
Hostname ${config.networking.hostName}
···
default = "/var/lib/collectd";
description = ''
Data directory for collectd agent.
+
'';
+
type = path;
+
};
+
+
pidFile = mkOption {
+
default = "/var/run/collectd.pid";
+
description = ''
+
Location of collectd pid file.
'';
type = path;
};
···
wantedBy = [ "multi-user.target" ];
serviceConfig = {
-
ExecStart = "${pkgs.collectd}/sbin/collectd -C ${conf} -P ${cfg.dataDir}/collectd.pid";
+
ExecStart = "${pkgs.collectd}/sbin/collectd -C ${conf} -P ${cfg.pidFile}";
Type = "forking";
-
PIDFile = "${cfg.dataDir}/collectd.pid";
+
PIDFile = cfg.pidFile;
User = optional (cfg.user!="root") cfg.user;
PermissionsStartOnly = true;
};
preStart = ''
mkdir -m 0700 -p ${cfg.dataDir}
-
if [ "$(id -u)" = 0 ]; then chown -R ${cfg.user} ${cfg.dataDir}; fi
+
install -D /dev/null ${cfg.pidFile}
+
if [ "$(id -u)" = 0 ]; then
+
chown -R ${cfg.user} ${cfg.dataDir};
+
chown ${cfg.user} ${cfg.pidFile}
+
fi
'';
};