ae91cbe6cc
GitOrigin-RevId: 536fe36e23ab0fc8b7f35c24603422eee9fc17a2
81 lines
2 KiB
Nix
81 lines
2 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
let
|
|
inherit (lib) mkIf mkOption types;
|
|
|
|
cfg = config.hardware.sensor.hddtemp;
|
|
|
|
wrapper = pkgs.writeShellScript "hddtemp-wrapper" ''
|
|
set -eEuo pipefail
|
|
|
|
file=/var/lib/hddtemp/hddtemp.db
|
|
|
|
drives=(${toString (map (e: ''$(realpath ${lib.escapeShellArg e}) '') cfg.drives)})
|
|
|
|
cp ${pkgs.hddtemp}/share/hddtemp/hddtemp.db $file
|
|
${lib.concatMapStringsSep "\n" (e: "echo ${lib.escapeShellArg e} >> $file") cfg.dbEntries}
|
|
|
|
exec ${pkgs.hddtemp}/bin/hddtemp ${lib.escapeShellArgs cfg.extraArgs} \
|
|
--daemon \
|
|
--unit=${cfg.unit} \
|
|
--file=$file \
|
|
''${drives[@]}
|
|
'';
|
|
|
|
in
|
|
{
|
|
meta.maintainers = with lib.maintainers; [ peterhoeg ];
|
|
|
|
###### interface
|
|
|
|
options = {
|
|
hardware.sensor.hddtemp = {
|
|
enable = mkOption {
|
|
description = ''
|
|
Enable this option to support HDD/SSD temperature sensors.
|
|
'';
|
|
type = types.bool;
|
|
default = false;
|
|
};
|
|
|
|
drives = mkOption {
|
|
description = "List of drives to monitor. If you pass /dev/disk/by-path/* entries the symlinks will be resolved as hddtemp doesn't like names with colons.";
|
|
type = types.listOf types.str;
|
|
};
|
|
|
|
unit = mkOption {
|
|
description = "Celcius or Fahrenheit";
|
|
type = types.enum [ "C" "F" ];
|
|
default = "C";
|
|
};
|
|
|
|
dbEntries = mkOption {
|
|
description = "Additional DB entries";
|
|
type = types.listOf types.str;
|
|
default = [ ];
|
|
};
|
|
|
|
extraArgs = mkOption {
|
|
description = "Additional arguments passed to the daemon.";
|
|
type = types.listOf types.str;
|
|
default = [ ];
|
|
};
|
|
};
|
|
};
|
|
|
|
###### implementation
|
|
|
|
config = mkIf cfg.enable {
|
|
systemd.services.hddtemp = {
|
|
description = "HDD/SSD temperature";
|
|
wantedBy = [ "multi-user.target" ];
|
|
serviceConfig = {
|
|
Type = "forking";
|
|
ExecStart = wrapper;
|
|
StateDirectory = "hddtemp";
|
|
PrivateTmp = true;
|
|
ProtectHome = "tmpfs";
|
|
ProtectSystem = "strict";
|
|
};
|
|
};
|
|
};
|
|
}
|