mirror of
https://github.com/nmasur/dotfiles
synced 2024-12-28 02:14:54 +00:00
67 lines
2.0 KiB
Nix
67 lines
2.0 KiB
Nix
# Jellyfin is a self-hosted video streaming service. This means I can play my
|
|
# server's videos from a webpage, mobile app, or TV client.
|
|
|
|
{ config, pkgs, lib, ... }: {
|
|
|
|
config = lib.mkIf config.services.jellyfin.enable {
|
|
|
|
services.jellyfin.group = "media";
|
|
users.users.jellyfin = { isSystemUser = true; };
|
|
|
|
caddy.routes = [
|
|
# Prevent public access to Prometheus metrics.
|
|
{
|
|
match = [{
|
|
host = [ config.hostnames.stream ];
|
|
path = [ "/metrics*" ];
|
|
}];
|
|
handle = [{
|
|
handler = "static_response";
|
|
status_code = "403";
|
|
}];
|
|
}
|
|
# Allow access to normal route.
|
|
{
|
|
match = [{ host = [ config.hostnames.stream ]; }];
|
|
handle = [{
|
|
handler = "reverse_proxy";
|
|
upstreams = [{ dial = "localhost:8096"; }];
|
|
}];
|
|
}
|
|
];
|
|
|
|
# Configure Cloudflare DNS to point to this machine
|
|
services.cloudflare-dyndns.domains = [ config.hostnames.stream ];
|
|
|
|
# Create videos directory, allow anyone in Jellyfin group to manage it
|
|
systemd.tmpfiles.rules = [
|
|
"d /var/lib/jellyfin 0775 jellyfin media"
|
|
"d /var/lib/jellyfin/library 0775 jellyfin media"
|
|
];
|
|
|
|
# Enable VA-API for hardware transcoding
|
|
hardware.opengl = {
|
|
enable = true;
|
|
driSupport = true;
|
|
extraPackages = [ pkgs.libva ];
|
|
};
|
|
environment.systemPackages = [ pkgs.libva-utils ];
|
|
environment.variables = {
|
|
# VAAPI and VDPAU config for accelerated video.
|
|
# See https://wiki.archlinux.org/index.php/Hardware_video_acceleration
|
|
"VDPAU_DRIVER" = "radeonsi";
|
|
"LIBVA_DRIVER_NAME" = "radeonsi";
|
|
};
|
|
users.users.jellyfin.extraGroups =
|
|
[ "render" "video" ]; # Access to /dev/dri
|
|
|
|
# Fix issue where Jellyfin-created directories don't allow access for media group
|
|
systemd.services.jellyfin.serviceConfig.UMask = lib.mkForce "0007";
|
|
|
|
# Requires MetricsEnable is true in /var/lib/jellyfin/config/system.xml
|
|
prometheus.scrapeTargets = [ "127.0.0.1:8096" ];
|
|
|
|
};
|
|
|
|
}
|