Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
119 lines
3.4 KiB
Nix
119 lines
3.4 KiB
Nix
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}:
|
|
|
|
let
|
|
cfg = config.services.prometheus.exporters.postfix;
|
|
inherit (lib)
|
|
mkOption
|
|
types
|
|
mkIf
|
|
escapeShellArg
|
|
concatStringsSep
|
|
optional
|
|
;
|
|
in
|
|
{
|
|
port = 9154;
|
|
extraOpts = {
|
|
package = lib.mkPackageOption pkgs "prometheus-postfix-exporter" { };
|
|
group = mkOption {
|
|
type = types.str;
|
|
description = ''
|
|
Group under which the postfix exporter shall be run.
|
|
It should match the group that is allowed to access the
|
|
`showq` socket in the `queue/public/` directory.
|
|
Defaults to `services.postfix.setgidGroup` when postfix is enabled.
|
|
'';
|
|
};
|
|
telemetryPath = mkOption {
|
|
type = types.str;
|
|
default = "/metrics";
|
|
description = ''
|
|
Path under which to expose metrics.
|
|
'';
|
|
};
|
|
logfilePath = mkOption {
|
|
type = types.path;
|
|
default = "/var/log/postfix_exporter_input.log";
|
|
example = "/var/log/mail.log";
|
|
description = ''
|
|
Path where Postfix writes log entries.
|
|
This file will be truncated by this exporter!
|
|
'';
|
|
};
|
|
showqPath = mkOption {
|
|
type = types.path;
|
|
default = "/var/lib/postfix/queue/public/showq";
|
|
example = "/var/spool/postfix/public/showq";
|
|
description = ''
|
|
Path where Postfix places its showq socket.
|
|
'';
|
|
};
|
|
systemd = {
|
|
enable = mkOption {
|
|
type = types.bool;
|
|
default = true;
|
|
description = ''
|
|
Whether to enable reading metrics from the systemd journal instead of from a logfile
|
|
'';
|
|
};
|
|
unit = mkOption {
|
|
type = types.str;
|
|
default = "postfix.service";
|
|
description = ''
|
|
Name of the postfix systemd unit.
|
|
'';
|
|
};
|
|
slice = mkOption {
|
|
type = types.nullOr types.str;
|
|
default = null;
|
|
description = ''
|
|
Name of the postfix systemd slice.
|
|
This overrides the {option}`systemd.unit`.
|
|
'';
|
|
};
|
|
journalPath = mkOption {
|
|
type = types.nullOr types.path;
|
|
default = null;
|
|
description = ''
|
|
Path to the systemd journal.
|
|
'';
|
|
};
|
|
};
|
|
};
|
|
serviceOpts = {
|
|
after = mkIf cfg.systemd.enable [ cfg.systemd.unit ];
|
|
serviceConfig = {
|
|
DynamicUser = false;
|
|
# By default, each prometheus exporter only gets AF_INET & AF_INET6,
|
|
# but AF_UNIX is needed to read from the `showq`-socket.
|
|
RestrictAddressFamilies = [ "AF_UNIX" ];
|
|
SupplementaryGroups = mkIf cfg.systemd.enable [ "systemd-journal" ];
|
|
ExecStart = ''
|
|
${lib.getExe cfg.package} \
|
|
--web.listen-address ${cfg.listenAddress}:${toString cfg.port} \
|
|
--web.telemetry-path ${cfg.telemetryPath} \
|
|
--postfix.showq_path ${escapeShellArg cfg.showqPath} \
|
|
${concatStringsSep " \\\n " (
|
|
cfg.extraFlags
|
|
++ optional cfg.systemd.enable "--systemd.enable"
|
|
++ optional cfg.systemd.enable (
|
|
if cfg.systemd.slice != null then
|
|
"--systemd.slice ${cfg.systemd.slice}"
|
|
else
|
|
"--systemd.unit ${cfg.systemd.unit}"
|
|
)
|
|
++ optional (
|
|
cfg.systemd.enable && (cfg.systemd.journalPath != null)
|
|
) "--systemd.journal_path ${escapeShellArg cfg.systemd.journalPath}"
|
|
++ optional (!cfg.systemd.enable) "--postfix.logfile_path ${escapeShellArg cfg.logfilePath}"
|
|
)}
|
|
'';
|
|
};
|
|
};
|
|
}
|