1caa886f6c
The module is indeed very large but allows configuring every aspect of icingaweb2. The built-in monitoring module is in an own file because there are actually more (third-party) modules and this structure means every module can get an own file.
157 lines
5 KiB
Nix
157 lines
5 KiB
Nix
{ config, lib, pkgs, ... }: with lib; let
|
||
cfg = config.services.icingaweb2.modules.monitoring;
|
||
|
||
configIni = ''
|
||
[security]
|
||
protected_customvars = "${concatStringsSep "," cfg.generalConfig.protectedVars}"
|
||
'';
|
||
|
||
backendsIni = let
|
||
formatBool = b: if b then "1" else "0";
|
||
in concatStringsSep "\n" (mapAttrsToList (name: config: ''
|
||
[${name}]
|
||
type = "ido"
|
||
resource = "${config.resource}"
|
||
disabled = "${formatBool config.disabled}"
|
||
'') cfg.backends);
|
||
|
||
transportsIni = concatStringsSep "\n" (mapAttrsToList (name: config: ''
|
||
[${name}]
|
||
type = "${config.type}"
|
||
${optionalString (config.instance != null) ''instance = "${config.instance}"''}
|
||
${optionalString (config.type == "local" || config.type == "remote") ''path = "${config.path}"''}
|
||
${optionalString (config.type != "local") ''
|
||
host = "${config.host}"
|
||
${optionalString (config.port != null) ''port = "${toString config.port}"''}
|
||
user${optionalString (config.type == "api") "name"} = "${config.username}"
|
||
''}
|
||
${optionalString (config.type == "api") ''password = "${config.password}"''}
|
||
${optionalString (config.type == "remote") ''resource = "${config.resource}"''}
|
||
'') cfg.transports);
|
||
|
||
in {
|
||
options.services.icingaweb2.modules.monitoring = with types; {
|
||
enable = mkOption {
|
||
type = bool;
|
||
default = true;
|
||
description = "Whether to enable the icingaweb2 monitoring module.";
|
||
};
|
||
|
||
generalConfig = {
|
||
mutable = mkOption {
|
||
type = bool;
|
||
default = false;
|
||
description = "Make config.ini of the monitoring module mutable (e.g. via the web interface).";
|
||
};
|
||
|
||
protectedVars = mkOption {
|
||
type = listOf str;
|
||
default = [ "*pw*" "*pass*" "community" ];
|
||
description = "List of string patterns for custom variables which should be excluded from user’s view.";
|
||
};
|
||
};
|
||
|
||
mutableBackends = mkOption {
|
||
type = bool;
|
||
default = false;
|
||
description = "Make backends.ini of the monitoring module mutable (e.g. via the web interface).";
|
||
};
|
||
|
||
backends = mkOption {
|
||
default = { "icinga" = { resource = "icinga_ido"; }; };
|
||
description = "Monitoring backends to define";
|
||
type = attrsOf (submodule ({ name, ... }: {
|
||
options = {
|
||
name = mkOption {
|
||
visible = false;
|
||
default = name;
|
||
type = str;
|
||
description = "Name of this backend";
|
||
};
|
||
|
||
resource = mkOption {
|
||
type = str;
|
||
description = "Name of the IDO resource";
|
||
};
|
||
|
||
disabled = mkOption {
|
||
type = bool;
|
||
default = false;
|
||
description = "Disable this backend";
|
||
};
|
||
};
|
||
}));
|
||
};
|
||
|
||
mutableTransports = mkOption {
|
||
type = bool;
|
||
default = true;
|
||
description = "Make commandtransports.ini of the monitoring module mutable (e.g. via the web interface).";
|
||
};
|
||
|
||
transports = mkOption {
|
||
default = {};
|
||
description = "Command transports to define";
|
||
type = attrsOf (submodule ({ name, ... }: {
|
||
options = {
|
||
name = mkOption {
|
||
visible = false;
|
||
default = name;
|
||
type = str;
|
||
description = "Name of this transport";
|
||
};
|
||
|
||
type = mkOption {
|
||
type = enum [ "api" "local" "remote" ];
|
||
default = "api";
|
||
description = "Type of this transport";
|
||
};
|
||
|
||
instance = mkOption {
|
||
type = nullOr str;
|
||
default = null;
|
||
description = "Assign a icinga instance to this transport";
|
||
};
|
||
|
||
path = mkOption {
|
||
type = str;
|
||
description = "Path to the socket for local or remote transports";
|
||
};
|
||
|
||
host = mkOption {
|
||
type = str;
|
||
description = "Host for the api or remote transport";
|
||
};
|
||
|
||
port = mkOption {
|
||
type = nullOr str;
|
||
default = null;
|
||
description = "Port to connect to for the api or remote transport";
|
||
};
|
||
|
||
username = mkOption {
|
||
type = str;
|
||
description = "Username for the api or remote transport";
|
||
};
|
||
|
||
password = mkOption {
|
||
type = str;
|
||
description = "Password for the api transport";
|
||
};
|
||
|
||
resource = mkOption {
|
||
type = str;
|
||
description = "SSH identity resource for the remote transport";
|
||
};
|
||
};
|
||
}));
|
||
};
|
||
};
|
||
|
||
config = mkIf (config.services.icingaweb2.enable && cfg.enable) {
|
||
environment.etc = { "icingaweb2/enabledModules/monitoring" = { source = "${pkgs.icingaweb2}/modules/monitoring"; }; }
|
||
// optionalAttrs (!cfg.generalConfig.mutable) { "icingaweb2/modules/monitoring/config.ini".text = configIni; }
|
||
// optionalAttrs (!cfg.mutableBackends) { "icingaweb2/modules/monitoring/backends.ini".text = backendsIni; }
|
||
// optionalAttrs (!cfg.mutableTransports) { "icingaweb2/modules/monitoring/commandtransports.ini".text = transportsIni; };
|
||
};
|
||
}
|