about summary refs log tree commit diff
path: root/nixos/modules/services/hardware
diff options
context:
space:
mode:
authorLuke Granger-Brown <git@lukegb.com>2024-01-30 04:01:11 +0000
committerGitHub <noreply@github.com>2024-01-30 04:01:11 +0000
commita12b828a26dc12db12ddec20f94801d07758530a (patch)
tree4e8f69e978a520e84b56396adf73fd94bb706881 /nixos/modules/services/hardware
parent630cc6b1cae6876cc894a5527e8acc2d58e31112 (diff)
parentb960a217bd351378b01a27f37df9d4b0028570b0 (diff)
downloadnixlib-a12b828a26dc12db12ddec20f94801d07758530a.tar
nixlib-a12b828a26dc12db12ddec20f94801d07758530a.tar.gz
nixlib-a12b828a26dc12db12ddec20f94801d07758530a.tar.bz2
nixlib-a12b828a26dc12db12ddec20f94801d07758530a.tar.lz
nixlib-a12b828a26dc12db12ddec20f94801d07758530a.tar.xz
nixlib-a12b828a26dc12db12ddec20f94801d07758530a.tar.zst
nixlib-a12b828a26dc12db12ddec20f94801d07758530a.zip
Merge pull request #277661 from appsforartists/handheld-daemon
handheld-daemon: init at 1.1.0
Diffstat (limited to 'nixos/modules/services/hardware')
-rw-r--r--nixos/modules/services/hardware/handheld-daemon.nix44
1 files changed, 44 insertions, 0 deletions
diff --git a/nixos/modules/services/hardware/handheld-daemon.nix b/nixos/modules/services/hardware/handheld-daemon.nix
new file mode 100644
index 000000000000..e8a7a39f441d
--- /dev/null
+++ b/nixos/modules/services/hardware/handheld-daemon.nix
@@ -0,0 +1,44 @@
+{ config
+, lib
+, pkgs
+, ...
+}:
+with lib; let
+  cfg = config.services.handheld-daemon;
+in
+{
+  options.services.handheld-daemon = {
+    enable = mkEnableOption "Enable Handheld Daemon";
+    package = mkPackageOption pkgs "handheld-daemon" { };
+
+    user = mkOption {
+      type = types.str;
+      description = lib.mdDoc ''
+        The user to run Handheld Daemon with.
+      '';
+    };
+  };
+
+  config = mkIf cfg.enable {
+    environment.systemPackages = [ cfg.package ];
+    services.udev.packages = [ cfg.package ];
+    systemd.packages = [ cfg.package ];
+
+    systemd.services.handheld-daemon = {
+      description = "Handheld Daemon";
+
+      wantedBy = [ "multi-user.target" ];
+
+      restartIfChanged = true;
+
+      serviceConfig = {
+        ExecStart = "${ lib.getExe cfg.package } --user ${ cfg.user }";
+        Nice = "-12";
+        Restart = "on-failure";
+        RestartSec = "10";
+      };
+    };
+  };
+
+  meta.maintainers = [ maintainers.appsforartists ];
+}