From f4d5a76a811df99d26706336dda940556c4491f5 Mon Sep 17 00:00:00 2001 From: zimbatm Date: Thu, 27 Apr 2023 10:30:29 +0200 Subject: netdata module: add automatic claim Allow machines to auto-register themselves by passing the claim token. --- nixos/modules/services/monitoring/netdata.nix | 29 ++++++++++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) (limited to 'nixos/modules/services/monitoring') diff --git a/nixos/modules/services/monitoring/netdata.nix b/nixos/modules/services/monitoring/netdata.nix index 92c870bb23f1d..60dfcb7693506 100644 --- a/nixos/modules/services/monitoring/netdata.nix +++ b/nixos/modules/services/monitoring/netdata.nix @@ -159,6 +159,15 @@ in { ''; }; + claim_token_file = mkOption { + type = types.nullOr types.path; + default = null; + description = lib.mdDoc '' + If set, automatically registers the agent using the given claim token + file. + ''; + }; + enableAnalyticsReporting = mkOption { type = types.bool; default = false; @@ -246,7 +255,25 @@ in { PrivateTmp = true; ProtectControlGroups = true; PrivateMounts = true; - }; + } // (lib.optionalAttrs (cfg.claim_token_file != null) { + LoadCredential = [ + "netdata_claim_token:${cfg.claim_token_file}" + ]; + + ExecStartPre = pkgs.writeShellScript "netdata-claim" '' + set -euo pipefail + + if [[ -f /var/lib/netdata/cloud.d/claimed_id ]]; then + # Already registered + exit + fi + + exec ${cfg.package}/bin/netdata-claim.sh \ + -token="$(< "$CREDENTIALS_DIRECTORY/netdata_claim_token")" \ + -url=https://app.netdata.cloud \ + -daemon-not-running + ''; + }); }; systemd.enableCgroupAccounting = true; -- cgit 1.4.1 From 14793fac6c173e111d9be6a21135d59bf805b1c4 Mon Sep 17 00:00:00 2001 From: Jonas Chevalier Date: Fri, 5 May 2023 18:41:51 +0200 Subject: Update nixos/modules/services/monitoring/netdata.nix Co-authored-by: Ryan Lahfa --- nixos/modules/services/monitoring/netdata.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'nixos/modules/services/monitoring') diff --git a/nixos/modules/services/monitoring/netdata.nix b/nixos/modules/services/monitoring/netdata.nix index 60dfcb7693506..b60ec85e7deb8 100644 --- a/nixos/modules/services/monitoring/netdata.nix +++ b/nixos/modules/services/monitoring/netdata.nix @@ -159,7 +159,7 @@ in { ''; }; - claim_token_file = mkOption { + claimTokenFile = mkOption { type = types.nullOr types.path; default = null; description = lib.mdDoc '' -- cgit 1.4.1 From db8b28dc5dcd75009953f97762d6d196b9e519c2 Mon Sep 17 00:00:00 2001 From: Jonas Chevalier Date: Fri, 5 May 2023 18:41:56 +0200 Subject: Update nixos/modules/services/monitoring/netdata.nix Co-authored-by: Ryan Lahfa --- nixos/modules/services/monitoring/netdata.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'nixos/modules/services/monitoring') diff --git a/nixos/modules/services/monitoring/netdata.nix b/nixos/modules/services/monitoring/netdata.nix index b60ec85e7deb8..0aa8acad10d9d 100644 --- a/nixos/modules/services/monitoring/netdata.nix +++ b/nixos/modules/services/monitoring/netdata.nix @@ -257,7 +257,7 @@ in { PrivateMounts = true; } // (lib.optionalAttrs (cfg.claim_token_file != null) { LoadCredential = [ - "netdata_claim_token:${cfg.claim_token_file}" + "netdata_claim_token:${cfg.claimTokenFile}" ]; ExecStartPre = pkgs.writeShellScript "netdata-claim" '' -- cgit 1.4.1