mirror of
https://github.com/nmasur/dotfiles
synced 2024-11-23 02:15:38 +00:00
81 lines
2.1 KiB
Nix
81 lines
2.1 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" ];
|
|
};
|
|
}
|