summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Hoang <Enzime@users.noreply.github.com>2024-10-04 09:44:43 +1000
committerGitHub <noreply@github.com>2024-10-04 09:44:43 +1000
commitc266b57bbea24083de4aaedd0921da1e46b2bd9f (patch)
treef8cd427346216ac4735b3cd1f555e6535ed0d7bd
parentf61d5f2051a387a15817007220e9fb3bbead57b3 (diff)
parent239d802869a30bb45d4403e8f63a57a61f6910d9 (diff)
Merge pull request #1077 from rsrohitsingh682/add-netadata
feat: add netdata service
-rw-r--r--modules/module-list.nix1
-rw-r--r--modules/services/monitoring/netdata.nix55
-rw-r--r--release.nix1
-rw-r--r--tests/services-netdata.nix19
4 files changed, 76 insertions, 0 deletions
diff --git a/modules/module-list.nix b/modules/module-list.nix
index 48880f0..3280682 100644
--- a/modules/module-list.nix
+++ b/modules/module-list.nix
@@ -70,6 +70,7 @@
./services/mail/offlineimap.nix
./services/mopidy.nix
./services/monitoring/telegraf.nix
+ ./services/monitoring/netdata.nix
./services/netbird.nix
./services/nix-daemon.nix
./services/nix-gc
diff --git a/modules/services/monitoring/netdata.nix b/modules/services/monitoring/netdata.nix
new file mode 100644
index 0000000..da0809c
--- /dev/null
+++ b/modules/services/monitoring/netdata.nix
@@ -0,0 +1,55 @@
+{ config, lib, pkgs, ... }:
+with lib;
+let
+ cfg = config.services.netdata;
+
+in {
+ meta.maintainers = [ lib.maintainers.rsrohitsingh682 or "rsrohitsingh682" ];
+
+ options = {
+ services.netdata = {
+ enable = mkEnableOption "Netdata daemon";
+
+ package = lib.mkPackageOption pkgs "netdata" {};
+
+ config = mkOption {
+ type = types.lines;
+ default = "";
+ description = "Custom configuration for Netdata";
+ };
+
+ workDir = mkOption {
+ type = types.path;
+ default = "/var/lib/netdata";
+ description = "Working directory for Netdata";
+ };
+
+ logDir = mkOption {
+ type = types.path;
+ default = "/var/log/netdata";
+ description = "Log directory for Netdata";
+ };
+ };
+ };
+
+ config = mkIf cfg.enable {
+ environment.systemPackages = [ cfg.package ];
+
+ launchd.daemons.netdata = {
+ serviceConfig = {
+ Label = "netdata";
+ KeepAlive = true;
+ WorkingDirectory = cfg.workDir;
+ StandardErrorPath = "${cfg.logDir}/netdata.log";
+ StandardOutPath = "${cfg.logDir}/netdata.log";
+ };
+ command = lib.getExe cfg.package;
+ };
+
+ environment.etc."netdata/netdata.conf".text = cfg.config;
+
+ system.activationScripts.preActivation.text = ''
+ mkdir -p ${cfg.workDir}
+ '';
+ };
+}
diff --git a/release.nix b/release.nix
index c3a9dde..ac0e31a 100644
--- a/release.nix
+++ b/release.nix
@@ -134,6 +134,7 @@ let
tests.services-nix-gc = makeTest ./tests/services-nix-gc.nix;
tests.services-nix-optimise = makeTest ./tests/services-nix-optimise.nix;
tests.services-nextdns = makeTest ./tests/services-nextdns.nix;
+ tests.services-netdata = makeTest ./tests/services-netdata.nix;
tests.services-ofborg = makeTest ./tests/services-ofborg.nix;
tests.services-offlineimap = makeTest ./tests/services-offlineimap.nix;
tests.services-privoxy = makeTest ./tests/services-privoxy.nix;
diff --git a/tests/services-netdata.nix b/tests/services-netdata.nix
new file mode 100644
index 0000000..6759677
--- /dev/null
+++ b/tests/services-netdata.nix
@@ -0,0 +1,19 @@
+{ config, lib, pkgs, ... }:
+
+with lib;
+
+let
+ netdata = pkgs.runCommand "netdata-0.0.0" {} "mkdir $out";
+in
+{
+ services.netdata = {
+ enable = true;
+ package = netdata;
+ };
+
+ test = ''
+ echo >&2 "checking netdata service in launchd daemons"
+ grep "netdata" ${config.out}/Library/LaunchDaemons/netdata.plist
+ grep "${netdata}/bin/netdata" ${config.out}/Library/LaunchDaemons/netdata.plist
+ '';
+}