summaryrefslogtreecommitdiffstats
path: root/nixos/modules/services/video
diff options
context:
space:
mode:
authorSandro <sandro.jaeckel@gmail.com>2024-03-24 22:05:36 +0100
committerGitHub <noreply@github.com>2024-03-24 22:05:36 +0100
commit0e1cac923d7c9287106e76d565c0d0d7218371f1 (patch)
tree077edc2ff0587c26bc903dd3f4cce69786444ea1 /nixos/modules/services/video
parent83a2696de8a93dea32b8d5ba63602f8e3b2edf28 (diff)
parentea7101783c474ba072fa565e3ecc0e5c530ef61b (diff)
Merge pull request #286685 from max-niederman/photonvision
photonvision: init at 2024.2.3
Diffstat (limited to 'nixos/modules/services/video')
-rw-r--r--nixos/modules/services/video/photonvision.nix64
1 files changed, 64 insertions, 0 deletions
diff --git a/nixos/modules/services/video/photonvision.nix b/nixos/modules/services/video/photonvision.nix
new file mode 100644
index 000000000000..fdbe9da3999d
--- /dev/null
+++ b/nixos/modules/services/video/photonvision.nix
@@ -0,0 +1,64 @@
+{ config, pkgs, lib, ... }:
+
+let
+ cfg = config.services.photonvision;
+in
+{
+ options = {
+ services.photonvision = {
+ enable = lib.mkEnableOption (lib.mdDoc "Enable PhotonVision");
+
+ package = lib.mkPackageOption pkgs "photonvision" {};
+
+ openFirewall = lib.mkOption {
+ description = lib.mdDoc ''
+ Whether to open the required ports in the firewall.
+ '';
+ default = false;
+ type = lib.types.bool;
+ };
+ };
+ };
+
+ config = lib.mkIf cfg.enable {
+ systemd.services.photonvision = {
+ description = "PhotonVision, the free, fast, and easy-to-use computer vision solution for the FIRST Robotics Competition";
+
+ wantedBy = [ "multi-user.target" ];
+ after = [ "network.target" ];
+
+ serviceConfig = {
+ ExecStart = lib.getExe cfg.package;
+
+ # ephemeral root directory
+ RuntimeDirectory = "photonvision";
+ RootDirectory = "/run/photonvision";
+
+ # setup persistent state and logs directories
+ StateDirectory = "photonvision";
+ LogsDirectory = "photonvision";
+
+ BindReadOnlyPaths = [
+ # mount the nix store read-only
+ "/nix/store"
+
+ # the JRE reads the user.home property from /etc/passwd
+ "/etc/passwd"
+ ];
+ BindPaths = [
+ # mount the configuration and logs directories to the host
+ "/var/lib/photonvision:/photonvision_config"
+ "/var/log/photonvision:/photonvision_config/logs"
+ ];
+
+ # for PhotonVision's dynamic libraries, which it writes to /tmp
+ PrivateTmp = true;
+ };
+ };
+
+ networking.firewall = lib.mkIf cfg.openFirewall {
+ allowedTCPPorts = [ 5800 ];
+ allowedTCPPortRanges = [{ from = 1180; to = 1190; }];
+ };
+ };
+}