nixpkgs/nixos/modules/services/networking/trickster.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

119 lines
3.2 KiB
Nix
Raw Normal View History

2019-11-01 09:57:29 +00:00
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.services.trickster;
in
{
2022-06-13 23:50:58 +01:00
imports = [
(mkRenamedOptionModule [ "services" "trickster" "origin" ] [ "services" "trickster" "origin-url" ])
];
2019-11-01 09:57:29 +00:00
options = {
services.trickster = {
enable = mkOption {
type = types.bool;
default = false;
description = lib.mdDoc ''
Enable Trickster.
'';
};
package = mkPackageOption pkgs "trickster" { };
2019-11-01 09:57:29 +00:00
configFile = mkOption {
type = types.nullOr types.path;
default = null;
description = lib.mdDoc ''
Path to configuration file.
'';
};
instance-id = mkOption {
type = types.nullOr types.int;
default = null;
description = lib.mdDoc ''
Instance ID for when running multiple processes (default null).
'';
};
log-level = mkOption {
type = types.str;
default = "info";
description = lib.mdDoc ''
Level of Logging to use (debug, info, warn, error) (default "info").
'';
};
metrics-port = mkOption {
type = types.port;
default = 8082;
description = lib.mdDoc ''
Port that the /metrics endpoint will listen on.
'';
};
2022-06-13 23:50:58 +01:00
origin-type = mkOption {
type = types.enum [ "prometheus" "influxdb" ];
default = "prometheus";
description = lib.mdDoc ''
Type of origin (prometheus, influxdb)
'';
};
origin-url = mkOption {
2019-11-01 09:57:29 +00:00
type = types.str;
default = "http://prometheus:9090";
description = lib.mdDoc ''
2022-06-13 23:50:58 +01:00
URL to the Origin. Enter it like you would in grafana, e.g., http://prometheus:9090 (default http://prometheus:9090).
2019-11-01 09:57:29 +00:00
'';
};
profiler-port = mkOption {
type = types.nullOr types.port;
default = null;
description = lib.mdDoc ''
Port that the /debug/pprof endpoint will listen on.
'';
};
proxy-port = mkOption {
type = types.port;
default = 9090;
description = lib.mdDoc ''
Port that the Proxy server will listen on.
'';
};
};
};
config = mkIf cfg.enable {
systemd.services.trickster = {
2022-06-13 23:50:58 +01:00
description = "Reverse proxy cache and time series dashboard accelerator";
2019-11-01 09:57:29 +00:00
after = [ "network.target" ];
wantedBy = [ "multi-user.target" ];
serviceConfig = {
DynamicUser = true;
ExecStart = ''
${cfg.package}/bin/trickster \
-log-level ${cfg.log-level} \
-metrics-port ${toString cfg.metrics-port} \
2022-06-13 23:50:58 +01:00
-origin-type ${cfg.origin-type} \
-origin-url ${cfg.origin-url} \
2019-11-01 09:57:29 +00:00
-proxy-port ${toString cfg.proxy-port} \
${optionalString (cfg.configFile != null) "-config ${cfg.configFile}"} \
${optionalString (cfg.profiler-port != null) "-profiler-port ${cfg.profiler-port}"} \
${optionalString (cfg.instance-id != null) "-instance-id ${cfg.instance-id}"}
'';
ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID";
Restart = "always";
};
};
};
2020-07-29 11:57:20 +01:00
meta.maintainers = with maintainers; [ _1000101 ];
2019-11-01 09:57:29 +00:00
}