mirror of
https://github.com/itme-brain/nixos.git
synced 2026-03-23 16:29:42 -04:00
121 lines
3.4 KiB
Nix
121 lines
3.4 KiB
Nix
{ pkgs, lib, config, ... }:
|
|
|
|
with lib;
|
|
let
|
|
cfg = config.modules.system.frigate;
|
|
nginx = config.modules.system.nginx;
|
|
domain = "ramos.codes";
|
|
|
|
in
|
|
{
|
|
options.modules.system.frigate = {
|
|
enable = mkEnableOption "Enable Frigate NVR";
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
services.go2rtc = {
|
|
enable = true;
|
|
settings = {
|
|
rtsp.listen = ":8554";
|
|
webrtc.listen = ":8555";
|
|
streams = {
|
|
doorbell = "rtsp://admin:ocu?u3Su@192.168.1.167/cam/realmonitor?channel=1&subtype=0";
|
|
living_room = "rtsp://admin:ocu?u3Su@192.168.1.147/cam/realmonitor?channel=1&subtype=0";
|
|
kitchen = "rtsp://admin:ocu?u3Su@192.168.1.147/cam/realmonitor?channel=2&subtype=0";
|
|
parking_lot = "rtsp://admin:ocu?u3Su@192.168.1.194/cam/realmonitor?channel=1&subtype=0";
|
|
porch = "rtsp://admin:ocu?u3Su@192.168.0.43/cam/realmonitor?channel=1&subtype=0";
|
|
};
|
|
};
|
|
};
|
|
|
|
services.frigate = {
|
|
enable = true;
|
|
hostname = "frigate.${domain}";
|
|
# vaapiDriver = "i965"; # Haswell only supports H.264, not HEVC
|
|
settings = {
|
|
mqtt.enabled = false;
|
|
# ffmpeg.hwaccel_args = "preset-vaapi"; # Disabled - camera uses HEVC which Haswell can't decode
|
|
|
|
record = {
|
|
enabled = true;
|
|
# 24/7 recording - needs better hardware
|
|
# retain = {
|
|
# days = 14;
|
|
# mode = "all";
|
|
# };
|
|
};
|
|
cameras = {
|
|
doorbell = {
|
|
enabled = true;
|
|
detect.enabled = false;
|
|
ffmpeg.inputs = [{
|
|
path = "rtsp://127.0.0.1:8554/doorbell";
|
|
roles = [ "record" ];
|
|
}];
|
|
};
|
|
living_room = {
|
|
enabled = false;
|
|
detect.enabled = false;
|
|
ffmpeg.inputs = [{
|
|
path = "rtsp://127.0.0.1:8554/living_room";
|
|
roles = [ "record" ];
|
|
}];
|
|
};
|
|
kitchen = {
|
|
enabled = false;
|
|
detect.enabled = false;
|
|
ffmpeg.inputs = [{
|
|
path = "rtsp://127.0.0.1:8554/kitchen";
|
|
roles = [ "record" ];
|
|
}];
|
|
};
|
|
parking_lot = {
|
|
enabled = true;
|
|
detect.enabled = false;
|
|
ffmpeg.inputs = [{
|
|
path = "rtsp://127.0.0.1:8554/parking_lot";
|
|
roles = [ "record" ];
|
|
}];
|
|
};
|
|
porch = {
|
|
enabled = false;
|
|
detect.enabled = false;
|
|
ffmpeg.inputs = [{
|
|
path = "rtsp://127.0.0.1:8554/porch";
|
|
roles = [ "record" ];
|
|
}];
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
# Add SSL to frigate's nginx virtualHost
|
|
services.nginx.virtualHosts."frigate.${domain}" = mkIf nginx.enable {
|
|
useACMEHost = domain;
|
|
forceSSL = true;
|
|
};
|
|
|
|
# Bind mount caches into the 3TB frigate LVM volume
|
|
systemd.tmpfiles.rules = [
|
|
"d /var/lib/frigate/cache 0750 frigate frigate -"
|
|
"d /var/lib/frigate/nginx-cache 0750 nginx nginx -"
|
|
];
|
|
|
|
fileSystems."/var/cache/frigate" = {
|
|
device = "/var/lib/frigate/cache";
|
|
options = [ "bind" ];
|
|
};
|
|
|
|
fileSystems."/var/cache/nginx/frigate" = {
|
|
device = "/var/lib/frigate/nginx-cache";
|
|
options = [ "bind" ];
|
|
};
|
|
|
|
# Backup recordings/database, exclude caches
|
|
modules.system.backup = {
|
|
paths = [ "/var/lib/frigate" ];
|
|
exclude = [ "*/cache" "*/nginx-cache" ];
|
|
};
|
|
|
|
};
|
|
}
|