diff options
author | Ethel Morgan <eth@ethulhu.co.uk> | 2020-06-29 23:06:50 +0100 |
---|---|---|
committer | Ethel Morgan <eth@ethulhu.co.uk> | 2020-06-29 23:06:50 +0100 |
commit | 031b9e1b0cada730333e9dd1d0eb26cc975630f5 (patch) | |
tree | 99d1bafeb528716be68e6cfb32a732ef885014c7 /nixos/modules/services/catbus-actuator-lgtv.nix | |
parent | f55410f566369f83f6a1c7fd4c03f435d893eca7 (diff) |
refactor eth.services.catbus-lgtv
Diffstat (limited to '')
-rw-r--r-- | nixos/modules/services/catbus-lgtv.nix (renamed from nixos/modules/services/catbus-actuator-lgtv.nix) | 28 |
1 files changed, 24 insertions, 4 deletions
diff --git a/nixos/modules/services/catbus-actuator-lgtv.nix b/nixos/modules/services/catbus-lgtv.nix index 051da5b..8011004 100644 --- a/nixos/modules/services/catbus-actuator-lgtv.nix +++ b/nixos/modules/services/catbus-lgtv.nix @@ -3,7 +3,7 @@ with lib; let - cfg = config.eth.services.catbus-actuator-lgtv; + cfg = config.eth.services.catbus-lgtv; configJSON = pkgs.writeText "config.json" (builtins.toJSON { mqttBroker = "tcp://${cfg.mqttBroker.host}:${toString cfg.mqttBroker.port}"; @@ -19,9 +19,9 @@ let in { - options.eth.services.catbus-actuator-lgtv = { + options.eth.services.catbus-lgtv = { - enable = mkEnableOption "Whether to enable the Catbus WebOS LGTV actuator"; + enable = mkEnableOption "Whether to enable the Catbus WebOS LGTV daemons."; mqttBroker = { host = mkOption { @@ -83,7 +83,7 @@ in { config = mkIf cfg.enable { - systemd.services.catbus-actuator-lgtv = { + systemd.services.catbus-lgtv-actuator = { enable = true; description = "Control a WebOS LGTV via Catbus"; wants = [ "network.target" ]; @@ -102,6 +102,26 @@ in { RestrictNamespaces = true; }; }; + + systemd.services.catbus-lgtv-observer = { + enable = true; + description = "Observe a WebOS LGTV via Catbus"; + wants = [ "network.target" ]; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + DynamicUser = true; + + ExecStart = "${pkgs.eth.catbus-lgtv}/bin/catbus-observer-lgtv --config-path ${configJSON}"; + + NoNewPrivileges = true; + ProtectKernelTunables = true; + ProtectControlGroups = true; + ProtectKernelModules = true; + RestrictAddressFamilies = "AF_INET AF_INET6"; + RestrictNamespaces = true; + }; + }; }; } |