From 7241f54c9fa18da72e4063ff70eb077481826a7c Mon Sep 17 00:00:00 2001 From: Ryan Horiguchi Date: Fri, 6 Dec 2024 21:31:55 +0100 Subject: [PATCH 1/2] nixos/librenms: use db socket when set --- .../modules/services/monitoring/librenms.nix | 27 ++++++++++++++----- 1 file changed, 20 insertions(+), 7 deletions(-) diff --git a/nixos/modules/services/monitoring/librenms.nix b/nixos/modules/services/monitoring/librenms.nix index 918c01ebaf22c..1d4eb1e593337 100644 --- a/nixos/modules/services/monitoring/librenms.nix +++ b/nixos/modules/services/monitoring/librenms.nix @@ -526,13 +526,25 @@ in User = cfg.user; Group = cfg.group; ExecStartPre = lib.mkIf cfg.database.createLocally [ - "!${pkgs.writeShellScript "librenms-db-init" '' - DB_PASSWORD=$(cat ${cfg.database.passwordFile} | tr -d '\n') - echo "ALTER USER '${cfg.database.username}'@'localhost' IDENTIFIED BY '$DB_PASSWORD';" | ${pkgs.mariadb}/bin/mysql - ${lib.optionalString cfg.useDistributedPollers '' - echo "ALTER USER '${cfg.database.username}'@'%' IDENTIFIED BY '$DB_PASSWORD';" | ${pkgs.mariadb}/bin/mysql - ''} - ''}" + "!${ + pkgs.writeShellScript "librenms-db-init" ( + if !isNull cfg.database.socket then + '' + echo "ALTER USER '${cfg.database.username}'@'localhost' IDENTIFIED VIA unix_socket;" | ${pkgs.mariadb}/bin/mysql --socket='${cfg.database.socket}' + ${lib.optionalString cfg.useDistributedPollers '' + echo "ALTER USER '${cfg.database.username}'@'%' IDENTIFIED VIA unix_socket;" | ${pkgs.mariadb}/bin/mysql --socket='${cfg.database.socket}' + ''} + '' + else + '' + DB_PASSWORD=$(cat ${cfg.database.passwordFile} | tr -d '\n') + echo "ALTER USER '${cfg.database.username}'@'localhost' IDENTIFIED BY '$DB_PASSWORD';" | ${pkgs.mariadb}/bin/mysql + ${lib.optionalString cfg.useDistributedPollers '' + echo "ALTER USER '${cfg.database.username}'@'%' IDENTIFIED BY '$DB_PASSWORD';" | ${pkgs.mariadb}/bin/mysql + ''} + '' + ) + }" ]; }; script = '' @@ -567,6 +579,7 @@ in then '' # use socket connection echo "DB_SOCKET=${cfg.database.socket}" >> ${cfg.dataDir}/.env + echo "DB_PASSWORD=null" >> ${cfg.dataDir}/.env '' else '' # use TCP connection From d512e0733898c63e491a7d562d717431ece4c328 Mon Sep 17 00:00:00 2001 From: Ryan Horiguchi Date: Tue, 10 Dec 2024 17:43:18 +0100 Subject: [PATCH 2/2] nixos/librenms: add package option and expose package --- nixos/modules/services/monitoring/librenms.nix | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/nixos/modules/services/monitoring/librenms.nix b/nixos/modules/services/monitoring/librenms.nix index 1d4eb1e593337..5275d61ecbdf6 100644 --- a/nixos/modules/services/monitoring/librenms.nix +++ b/nixos/modules/services/monitoring/librenms.nix @@ -5,7 +5,7 @@ let settingsFormat = pkgs.formats.json { }; configJson = settingsFormat.generate "librenms-config.json" cfg.settings; - package = pkgs.librenms.override { + package = cfg.package.override { logDir = cfg.logDir; dataDir = cfg.dataDir; }; @@ -60,6 +60,18 @@ in options.services.librenms = with lib; { enable = mkEnableOption "LibreNMS network monitoring system"; + package = lib.mkPackageOption pkgs "librenms" { }; + + finalPackage = lib.mkOption { + type = lib.types.package; + readOnly = true; + default = package; + defaultText = lib.literalExpression "package"; + description = '' + The final package used by the module. This is the package that has all overrides. + ''; + }; + user = mkOption { type = types.str; default = "librenms";