2022-10-10 05:16:25 +00:00
|
|
|
{ config, pkgs, lib, ... }:
|
|
|
|
let
|
|
|
|
cfg = config.services.karma;
|
|
|
|
yaml = pkgs.formats.yaml { };
|
|
|
|
in
|
|
|
|
{
|
|
|
|
options.services.karma = {
|
2024-08-29 22:46:58 +00:00
|
|
|
enable = lib.mkEnableOption "the Karma dashboard service";
|
2022-10-10 05:16:25 +00:00
|
|
|
|
2024-08-29 22:46:58 +00:00
|
|
|
package = lib.mkPackageOption pkgs "karma" { };
|
2022-10-10 05:16:25 +00:00
|
|
|
|
2024-08-29 22:46:58 +00:00
|
|
|
configFile = lib.mkOption {
|
|
|
|
type = lib.types.path;
|
2022-10-10 05:16:25 +00:00
|
|
|
default = yaml.generate "karma.yaml" cfg.settings;
|
|
|
|
defaultText = "A configuration file generated from the provided nix attributes settings option.";
|
|
|
|
description = ''
|
|
|
|
A YAML config file which can be used to configure karma instead of the nix-generated file.
|
|
|
|
'';
|
|
|
|
example = "/etc/karma/karma.conf";
|
|
|
|
};
|
|
|
|
|
2024-08-29 22:46:58 +00:00
|
|
|
environment = lib.mkOption {
|
|
|
|
type = with lib.types; attrsOf str;
|
2022-10-10 05:16:25 +00:00
|
|
|
default = {};
|
|
|
|
description = ''
|
|
|
|
Additional environment variables to provide to karma.
|
|
|
|
'';
|
|
|
|
example = {
|
|
|
|
ALERTMANAGER_URI = "https://alertmanager.example.com";
|
|
|
|
ALERTMANAGER_NAME= "single";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-08-29 22:46:58 +00:00
|
|
|
openFirewall = lib.mkOption {
|
|
|
|
type = lib.types.bool;
|
2022-10-10 05:16:25 +00:00
|
|
|
default = false;
|
|
|
|
description = ''
|
|
|
|
Whether to open ports in the firewall needed for karma to function.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-29 22:46:58 +00:00
|
|
|
extraOptions = lib.mkOption {
|
|
|
|
type = with lib.types; listOf str;
|
2022-10-10 05:16:25 +00:00
|
|
|
default = [];
|
|
|
|
description = ''
|
|
|
|
Extra command line options.
|
|
|
|
'';
|
|
|
|
example = [
|
|
|
|
"--alertmanager.timeout 10s"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2024-08-29 22:46:58 +00:00
|
|
|
settings = lib.mkOption {
|
|
|
|
type = lib.types.submodule {
|
2022-10-10 05:16:25 +00:00
|
|
|
freeformType = yaml.type;
|
|
|
|
|
|
|
|
options.listen = {
|
2024-08-29 22:46:58 +00:00
|
|
|
address = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
2022-10-10 05:16:25 +00:00
|
|
|
default = "127.0.0.1";
|
|
|
|
description = ''
|
|
|
|
Hostname or IP to listen on.
|
|
|
|
'';
|
|
|
|
example = "[::]";
|
|
|
|
};
|
|
|
|
|
2024-08-29 22:46:58 +00:00
|
|
|
port = lib.mkOption {
|
|
|
|
type = lib.types.port;
|
2022-10-10 05:16:25 +00:00
|
|
|
default = 8080;
|
|
|
|
description = ''
|
|
|
|
HTTP port to listen on.
|
|
|
|
'';
|
|
|
|
example = 8182;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
default = {
|
|
|
|
listen = {
|
|
|
|
address = "127.0.0.1";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
description = ''
|
|
|
|
Karma dashboard configuration as nix attributes.
|
|
|
|
|
|
|
|
Reference: <https://github.com/prymitive/karma/blob/main/docs/CONFIGURATION.md>
|
|
|
|
'';
|
|
|
|
example = {
|
|
|
|
listen = {
|
|
|
|
address = "192.168.1.4";
|
|
|
|
port = "8000";
|
|
|
|
prefix = "/dashboard";
|
|
|
|
};
|
|
|
|
alertmanager = {
|
|
|
|
interval = "15s";
|
|
|
|
servers = [
|
|
|
|
{
|
|
|
|
name = "prod";
|
|
|
|
uri = "http://alertmanager.example.com";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-08-29 22:46:58 +00:00
|
|
|
config = lib.mkIf cfg.enable {
|
2022-10-10 05:16:25 +00:00
|
|
|
systemd.services.karma = {
|
|
|
|
description = "Alert dashboard for Prometheus Alertmanager";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
environment = cfg.environment;
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "simple";
|
|
|
|
DynamicUser = true;
|
|
|
|
Restart = "on-failure";
|
2024-08-29 22:46:58 +00:00
|
|
|
ExecStart = "${pkgs.karma}/bin/karma --config.file ${cfg.configFile} ${lib.concatStringsSep " " cfg.extraOptions}";
|
2022-10-10 05:16:25 +00:00
|
|
|
};
|
|
|
|
};
|
2024-08-29 22:46:58 +00:00
|
|
|
networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ cfg.settings.listen.port ];
|
2022-10-10 05:16:25 +00:00
|
|
|
};
|
|
|
|
}
|