158 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			5.0 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; };
 | 
						||
  };
 | 
						||
}
 |