mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-21 20:34:06 +00:00
ef176dcf7e
conversions were done using https://github.com/pennae/nix-doc-munge using (probably) rev f34e145 running nix-doc-munge nixos/**/*.nix nix-doc-munge --import nixos/**/*.nix the tool ensures that only changes that could affect the generated manual *but don't* are committed, other changes require manual review and are discarded.
91 lines
2.7 KiB
Nix
91 lines
2.7 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
cfg = config.services.telegraf;
|
|
|
|
settingsFormat = pkgs.formats.toml {};
|
|
configFile = settingsFormat.generate "config.toml" cfg.extraConfig;
|
|
in {
|
|
###### interface
|
|
options = {
|
|
services.telegraf = {
|
|
enable = mkEnableOption (lib.mdDoc "telegraf server");
|
|
|
|
package = mkOption {
|
|
default = pkgs.telegraf;
|
|
defaultText = literalExpression "pkgs.telegraf";
|
|
description = lib.mdDoc "Which telegraf derivation to use";
|
|
type = types.package;
|
|
};
|
|
|
|
environmentFiles = mkOption {
|
|
type = types.listOf types.path;
|
|
default = [];
|
|
example = [ "/run/keys/telegraf.env" ];
|
|
description = lib.mdDoc ''
|
|
File to load as environment file. Environment variables from this file
|
|
will be interpolated into the config file using envsubst with this
|
|
syntax: `$ENVIRONMENT` or `''${VARIABLE}`.
|
|
This is useful to avoid putting secrets into the nix store.
|
|
'';
|
|
};
|
|
|
|
extraConfig = mkOption {
|
|
default = {};
|
|
description = lib.mdDoc "Extra configuration options for telegraf";
|
|
type = settingsFormat.type;
|
|
example = {
|
|
outputs.influxdb = {
|
|
urls = ["http://localhost:8086"];
|
|
database = "telegraf";
|
|
};
|
|
inputs.statsd = {
|
|
service_address = ":8125";
|
|
delete_timings = true;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
|
|
###### implementation
|
|
config = mkIf config.services.telegraf.enable {
|
|
systemd.services.telegraf = let
|
|
finalConfigFile = if config.services.telegraf.environmentFiles == []
|
|
then configFile
|
|
else "/var/run/telegraf/config.toml";
|
|
in {
|
|
description = "Telegraf Agent";
|
|
wantedBy = [ "multi-user.target" ];
|
|
after = [ "network-online.target" ];
|
|
serviceConfig = {
|
|
EnvironmentFile = config.services.telegraf.environmentFiles;
|
|
ExecStartPre = lib.optional (config.services.telegraf.environmentFiles != [])
|
|
(pkgs.writeShellScript "pre-start" ''
|
|
umask 077
|
|
${pkgs.envsubst}/bin/envsubst -i "${configFile}" > /var/run/telegraf/config.toml
|
|
'');
|
|
ExecStart="${cfg.package}/bin/telegraf -config ${finalConfigFile}";
|
|
ExecReload="${pkgs.coreutils}/bin/kill -HUP $MAINPID";
|
|
RuntimeDirectory = "telegraf";
|
|
User = "telegraf";
|
|
Group = "telegraf";
|
|
Restart = "on-failure";
|
|
# for ping probes
|
|
AmbientCapabilities = [ "CAP_NET_RAW" ];
|
|
};
|
|
};
|
|
|
|
users.users.telegraf = {
|
|
uid = config.ids.uids.telegraf;
|
|
group = "telegraf";
|
|
description = "telegraf daemon user";
|
|
};
|
|
|
|
users.groups.telegraf = {};
|
|
};
|
|
}
|