summary refs log tree commit diff
path: root/nixos
diff options
context:
space:
mode:
authorYannick Markus <ym@ymarkus.dev>2022-12-21 12:29:48 +0100
committerYannick Markus <ym@ymarkus.dev>2022-12-21 12:29:48 +0100
commit060f0dd496b10c5516de48977f268505a51ab116 (patch)
treea3929c13c4c611b5a01e89ee521be17d6b39ac54 /nixos
parente7f345ca81f4f5513c4e73f3f7b3a3d045f74845 (diff)
downloadnixpkgs-060f0dd496b10c5516de48977f268505a51ab116.tar
nixpkgs-060f0dd496b10c5516de48977f268505a51ab116.tar.gz
nixpkgs-060f0dd496b10c5516de48977f268505a51ab116.tar.bz2
nixpkgs-060f0dd496b10c5516de48977f268505a51ab116.tar.lz
nixpkgs-060f0dd496b10c5516de48977f268505a51ab116.tar.xz
nixpkgs-060f0dd496b10c5516de48977f268505a51ab116.tar.zst
nixpkgs-060f0dd496b10c5516de48977f268505a51ab116.zip
nixos/alertmanager: add checkConfig option
Diffstat (limited to 'nixos')
-rw-r--r--nixos/modules/services/monitoring/prometheus/alertmanager.nix24
1 files changed, 20 insertions, 4 deletions
diff --git a/nixos/modules/services/monitoring/prometheus/alertmanager.nix b/nixos/modules/services/monitoring/prometheus/alertmanager.nix
index 0c0931d3d29..987f17c2c6e 100644
--- a/nixos/modules/services/monitoring/prometheus/alertmanager.nix
+++ b/nixos/modules/services/monitoring/prometheus/alertmanager.nix
@@ -6,10 +6,12 @@ let
   cfg = config.services.prometheus.alertmanager;
   mkConfigFile = pkgs.writeText "alertmanager.yml" (builtins.toJSON cfg.configuration);
 
-  checkedConfig = file: pkgs.runCommand "checked-config" { buildInputs = [ cfg.package ]; } ''
-    ln -s ${file} $out
-    amtool check-config $out
-  '';
+  checkedConfig = file:
+    if cfg.checkConfig then
+      pkgs.runCommand "checked-config" { buildInputs = [ cfg.package ]; } ''
+        ln -s ${file} $out
+        amtool check-config $out
+      '' else file;
 
   alertmanagerYml = let
     yml = if cfg.configText != null then
@@ -70,6 +72,20 @@ in {
         '';
       };
 
+      checkConfig = mkOption {
+        type = types.bool;
+        default = true;
+        description = lib.mdDoc ''
+          Check configuration with `amtool check-config`. The call to `amtool` is
+          subject to sandboxing by Nix.
+
+          If you use credentials stored in external files
+          (`environmentFile`, etc),
+          they will not be visible to `amtool`
+          and it will report errors, despite a correct configuration.
+        '';
+      };
+
       logFormat = mkOption {
         type = types.nullOr types.str;
         default = null;