mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-06-23 17:56:53 +03:00

After final improvements to the official formatter implementation,
this commit now performs the first treewide reformat of Nix files using it.
This is part of the implementation of RFC 166.
Only "inactive" files are reformatted, meaning only files that
aren't being touched by any PR with activity in the past 2 months.
This is to avoid conflicts for PRs that might soon be merged.
Later we can do a full treewide reformat to get the rest,
which should not cause as many conflicts.
A CI check has already been running for some time to ensure that new and
already-formatted files are formatted, so the files being reformatted here
should also stay formatted.
This commit was automatically created and can be verified using
nix-build https://github.com/infinisil/treewide-nixpkgs-reformat-script/archive/a08b3a4d199c6124ac5b36a889d9099b4383463f.tar.gz \
--argstr baseRev b32a094368
result/bin/apply-formatting $NIXPKGS_PATH
168 lines
4.7 KiB
Nix
168 lines
4.7 KiB
Nix
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}:
|
|
|
|
let
|
|
inherit (lib)
|
|
attrValues
|
|
literalExpression
|
|
mkEnableOption
|
|
mkPackageOption
|
|
mkIf
|
|
mkOption
|
|
types
|
|
;
|
|
cfg = config.services.metricbeat;
|
|
|
|
settingsFormat = pkgs.formats.yaml { };
|
|
|
|
in
|
|
{
|
|
options = {
|
|
|
|
services.metricbeat = {
|
|
|
|
enable = mkEnableOption "metricbeat";
|
|
|
|
package = mkPackageOption pkgs "metricbeat" {
|
|
example = "metricbeat7";
|
|
};
|
|
|
|
modules = mkOption {
|
|
description = ''
|
|
Metricbeat modules are responsible for reading metrics from the various sources.
|
|
|
|
This is like `services.metricbeat.settings.metricbeat.modules`,
|
|
but structured as an attribute set. This has the benefit that multiple
|
|
NixOS modules can contribute settings to a single metricbeat module.
|
|
|
|
A module can be specified multiple times by choosing a different `<name>`
|
|
for each, but setting [](#opt-services.metricbeat.modules._name_.module) to the same value.
|
|
|
|
See <https://www.elastic.co/guide/en/beats/metricbeat/current/metricbeat-modules.html>.
|
|
'';
|
|
default = { };
|
|
type = types.attrsOf (
|
|
types.submodule (
|
|
{ name, ... }:
|
|
{
|
|
freeformType = settingsFormat.type;
|
|
options = {
|
|
module = mkOption {
|
|
type = types.str;
|
|
default = name;
|
|
description = ''
|
|
The name of the module.
|
|
|
|
Look for the value after `module:` on the individual
|
|
module pages linked from <https://www.elastic.co/guide/en/beats/metricbeat/current/metricbeat-modules.html>.
|
|
'';
|
|
};
|
|
};
|
|
}
|
|
)
|
|
);
|
|
example = {
|
|
system = {
|
|
metricsets = [
|
|
"cpu"
|
|
"load"
|
|
"memory"
|
|
"network"
|
|
"process"
|
|
"process_summary"
|
|
"uptime"
|
|
"socket_summary"
|
|
];
|
|
enabled = true;
|
|
period = "10s";
|
|
processes = [ ".*" ];
|
|
cpu.metrics = [
|
|
"percentages"
|
|
"normalized_percentages"
|
|
];
|
|
core.metrics = [ "percentages" ];
|
|
};
|
|
};
|
|
};
|
|
|
|
settings = mkOption {
|
|
type = types.submodule {
|
|
freeformType = settingsFormat.type;
|
|
options = {
|
|
|
|
name = mkOption {
|
|
type = types.str;
|
|
default = "";
|
|
description = ''
|
|
Name of the beat. Defaults to the hostname.
|
|
See <https://www.elastic.co/guide/en/beats/metricbeat/current/configuration-general-options.html#_name>.
|
|
'';
|
|
};
|
|
|
|
tags = mkOption {
|
|
type = types.listOf types.str;
|
|
default = [ ];
|
|
description = ''
|
|
Tags to place on the shipped metrics.
|
|
See <https://www.elastic.co/guide/en/beats/metricbeat/current/configuration-general-options.html#_tags_2>.
|
|
'';
|
|
};
|
|
|
|
metricbeat.modules = mkOption {
|
|
type = types.listOf settingsFormat.type;
|
|
default = [ ];
|
|
internal = true;
|
|
description = ''
|
|
The metric collecting modules. Use [](#opt-services.metricbeat.modules) instead.
|
|
|
|
See <https://www.elastic.co/guide/en/beats/metricbeat/current/metricbeat-modules.html>.
|
|
'';
|
|
};
|
|
};
|
|
};
|
|
default = { };
|
|
description = ''
|
|
Configuration for metricbeat. See <https://www.elastic.co/guide/en/beats/metricbeat/current/configuring-howto-metricbeat.html> for supported values.
|
|
'';
|
|
};
|
|
|
|
};
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
assertions = [
|
|
{
|
|
# empty modules would cause a failure at runtime
|
|
assertion = cfg.settings.metricbeat.modules != [ ];
|
|
message = "services.metricbeat: You must configure one or more modules.";
|
|
}
|
|
];
|
|
|
|
services.metricbeat.settings.metricbeat.modules = attrValues cfg.modules;
|
|
|
|
systemd.services.metricbeat = {
|
|
description = "metricbeat metrics shipper";
|
|
wantedBy = [ "multi-user.target" ];
|
|
serviceConfig = {
|
|
ExecStart = ''
|
|
${cfg.package}/bin/metricbeat \
|
|
-c ${settingsFormat.generate "metricbeat.yml" cfg.settings} \
|
|
--path.data $STATE_DIRECTORY \
|
|
--path.logs $LOGS_DIRECTORY \
|
|
;
|
|
'';
|
|
Restart = "always";
|
|
DynamicUser = true;
|
|
ProtectSystem = "strict";
|
|
ProtectHome = "tmpfs";
|
|
StateDirectory = "metricbeat";
|
|
LogsDirectory = "metricbeat";
|
|
};
|
|
};
|
|
};
|
|
}
|