mirror of
https://forgejo.altau.su/lego/lego-monitoring.git
synced 2026-03-10 04:41:10 +00:00
124 lines
3.9 KiB
Nix
124 lines
3.9 KiB
Nix
{
|
|
lib,
|
|
...
|
|
}:
|
|
|
|
let
|
|
tempSensorOptions = (import ./suboptions/tempSensorOptions.nix) { inherit lib; };
|
|
vulnixWhitelistRule = (import ./suboptions/vulnixWhitelistRule.nix) { inherit lib; };
|
|
in
|
|
{
|
|
options.services.lego-monitoring = {
|
|
enable = lib.mkEnableOption "lego-monitoring service";
|
|
|
|
logLevel = lib.mkOption {
|
|
type = lib.types.enum [
|
|
"CRITICAL"
|
|
"ERROR"
|
|
"WARNING"
|
|
"INFO"
|
|
"DEBUG"
|
|
];
|
|
default = "INFO";
|
|
description = "Level of logging. INFO generates a log message with every check.";
|
|
};
|
|
|
|
enabledCheckSets = lib.mkOption {
|
|
type = lib.types.listOf (lib.types.enum [
|
|
"start"
|
|
"stop"
|
|
"remind"
|
|
|
|
"cpu"
|
|
"ram"
|
|
"temp"
|
|
|
|
"vulnix"
|
|
]);
|
|
default = [ ];
|
|
description = "List of enabled check sets. Each check set is a module which checks something and generates alerts based on check results.";
|
|
};
|
|
|
|
telegram = {
|
|
credsSecretPath = lib.mkOption {
|
|
type = lib.types.str;
|
|
description = "Path to a file containing Telegram api_id, api_hash, and bot token, separated by the `,` character.";
|
|
};
|
|
roomId = lib.mkOption {
|
|
type = lib.types.int;
|
|
description = "ID of chat where to send alerts.";
|
|
};
|
|
};
|
|
|
|
checks = {
|
|
temp = {
|
|
sensors = lib.mkOption {
|
|
type = lib.types.attrsOf (lib.types.submodule tempSensorOptions);
|
|
default = { };
|
|
description = ''
|
|
Temp sensor override definitions. Sensors not defined here, or missing options in definitions, will be read with default parameters.
|
|
|
|
To get list of sensors and their default configurations, run `lego-monitoring --print-temp`.'';
|
|
example = lib.literalExpression ''
|
|
{
|
|
amdgpu.readings.edge.label = "Integrated GPU";
|
|
k10temp.readings = {
|
|
Tctl = {
|
|
label = "AMD CPU";
|
|
criticalTemp = 95.0;
|
|
};
|
|
Tccd1.enabled = false;
|
|
Tccd2.enabled = false;
|
|
};
|
|
nvme.readings = {
|
|
"Sensor 1".enabled = false;
|
|
"Sensor 2".enabled = false;
|
|
};
|
|
}'';
|
|
};
|
|
};
|
|
|
|
vulnix = {
|
|
whitelist = lib.mkOption {
|
|
type = lib.types.attrsOf (lib.types.submodule vulnixWhitelistRule);
|
|
default = { };
|
|
description = "Whitelist rules for vulnix. Attr name is package with version, package name, or `*`.";
|
|
example = lib.literalExpression ''
|
|
{
|
|
"ffmpeg-3.4.2" = {
|
|
cve = [ "CVE-2018-6912" "CVE-2018-7557" ];
|
|
until = "2018-05-01";
|
|
issueUrl = "https://issues.example.com/29952";
|
|
};
|
|
}'';
|
|
};
|
|
};
|
|
|
|
cpu = {
|
|
warningPercentage = lib.mkOption {
|
|
type = lib.types.nullOr lib.types.float;
|
|
default = 80.0;
|
|
description = "CPU load percentage for a warning alert to be sent. Null means never generate a CPU warning alert.";
|
|
};
|
|
criticalPercentage = lib.mkOption {
|
|
type = lib.types.nullOr lib.types.float;
|
|
default = 90.0;
|
|
description = "CPU load percentage for a critical alert to be sent. Null means never generate a CPU critical alert.";
|
|
};
|
|
};
|
|
|
|
ram = {
|
|
warningPercentage = lib.mkOption {
|
|
type = lib.types.nullOr lib.types.float;
|
|
default = 80.0;
|
|
description = "RAM usage percentage for a warning alert to be sent. Null means never generate a RAM warning alert.";
|
|
};
|
|
criticalPercentage = lib.mkOption {
|
|
type = lib.types.nullOr lib.types.float;
|
|
default = 90.0;
|
|
description = "RAM usage percentage for a critical alert to be sent. Null means never generate a RAM critical alert.";
|
|
};
|
|
};
|
|
};
|
|
};
|
|
}
|