Overhaul services config on laptop server & fully setup jellyfin + caddy
This commit is contained in:
parent
ef017dc3ed
commit
84e2cc3b80
9 changed files with 133 additions and 22 deletions
|
@ -1,7 +1,13 @@
|
|||
{ ... }:
|
||||
{
|
||||
boot.loader = {
|
||||
systemd-boot.enable = true;
|
||||
boot = {
|
||||
loader = {
|
||||
systemd-boot = {
|
||||
enable = true;
|
||||
};
|
||||
efi.canTouchEfiVariables = true;
|
||||
};
|
||||
|
||||
initrd.systemd.enable = true;
|
||||
};
|
||||
}
|
|
@ -3,13 +3,16 @@
|
|||
fileSystems."/mnt/hdd" = {
|
||||
device = "/dev/mapper/hdd";
|
||||
fsType = "btrfs";
|
||||
options = [ "compression=zstd:3" "autodefrag" "nofail" ];
|
||||
options = [ "compress=zstd:3" "autodefrag" "nofail" ];
|
||||
|
||||
encrypted = {
|
||||
enable = true;
|
||||
label = "hdd";
|
||||
blkDev = "/dev/disk/by-uuid/eab5e1d6-6956-46fd-b3ac-5fcf525e1df8";
|
||||
keyFile = "/mnt-root/root/hdd.key";
|
||||
keyFile = "/sysroot/root/hdd.key";
|
||||
};
|
||||
};
|
||||
|
||||
# Loading the uas kernel module early is needed to mount the above drive via USB-SATA adapter
|
||||
boot.initrd.kernelModules = [ "uas" ];
|
||||
}
|
36
hosts/laptop-server/config/services/caddy/Caddyfile
Normal file
36
hosts/laptop-server/config/services/caddy/Caddyfile
Normal file
|
@ -0,0 +1,36 @@
|
|||
# Global options
|
||||
{
|
||||
acme_dns porkbun {
|
||||
api_key {env.PORKBUN_API_KEY}
|
||||
api_secret_key {env.PORKBUN_API_SECRET_KEY}
|
||||
}
|
||||
email ty@myriation.xyz
|
||||
|
||||
storage file_system {
|
||||
root /var/lib/caddy
|
||||
}
|
||||
}
|
||||
|
||||
# Handle all routes handled by this server
|
||||
https://*.m.myriation.xyz {
|
||||
# Enforce always using HTTPS
|
||||
header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload"
|
||||
# Give an HTTP cat on any errors
|
||||
handle_errors {
|
||||
header Content-Type text/html
|
||||
respond "<!DOCTYPE html><html><head><title>Error :(</title></head><body><img src=\"https://http.cat/{http.error.status_code}\" alt=\"cat\"></body></html>" {http.error.status_code}
|
||||
}
|
||||
|
||||
# Configure all service matchers
|
||||
@jellyfin host jellyfin.m.myriation.xyz
|
||||
|
||||
# Handle all services
|
||||
handle @jellyfin {
|
||||
reverse_proxy jellyfin.containers:8096
|
||||
}
|
||||
|
||||
# Handle all unmatched requests as a 404
|
||||
handle {
|
||||
error "Not Found" 404
|
||||
}
|
||||
}
|
26
hosts/laptop-server/config/services/caddy/default.nix
Normal file
26
hosts/laptop-server/config/services/caddy/default.nix
Normal file
|
@ -0,0 +1,26 @@
|
|||
{ pkgs, secrets, ... }:
|
||||
{
|
||||
# TODO: Containerize once I setup a proper shared bridge network
|
||||
services.caddy = {
|
||||
enable = true;
|
||||
package = pkgs.caddy.withPlugins {
|
||||
plugins = [ "github.com/caddy-dns/porkbun@v0.2.1" ];
|
||||
hash = "sha256-oizWuPXI0M9ngBCt/iEXWt+/33wpKlCs1yBPKnzFhRY=";
|
||||
};
|
||||
# Use a custom config because doing Caddyfile in multiline nix strings
|
||||
# feels messy (and not syntax highlighted)
|
||||
configFile = ./Caddyfile;
|
||||
};
|
||||
|
||||
# Pass secrets through the systemd service's environment variables
|
||||
systemd.services.caddy.environment = {
|
||||
PORKBUN_API_KEY = secrets.programs.caddy.porkbun_api_key;
|
||||
PORKBUN_API_SECRET_KEY = secrets.programs.caddy.porkbun_secret_key;
|
||||
};
|
||||
|
||||
# Allow caddy through the firewall
|
||||
networking.firewall = {
|
||||
allowedTCPPorts = [ 80 443 ]; # HTTP/1-2
|
||||
allowedUDPPorts = [ 443 ]; # HTTP/3 w/ QUIC
|
||||
};
|
||||
}
|
|
@ -1,13 +1,9 @@
|
|||
{ ... }:
|
||||
{
|
||||
imports = [
|
||||
./jellyfin.nix
|
||||
./networking.nix
|
||||
# Individual services
|
||||
./caddy
|
||||
./jellyfin
|
||||
];
|
||||
|
||||
networking = {
|
||||
nat = {
|
||||
enable = true;
|
||||
externalInterface = "wlp2s0";
|
||||
};
|
||||
};
|
||||
}
|
|
@ -1,7 +1,7 @@
|
|||
{ ... }:
|
||||
{
|
||||
containers.jellyfin = {
|
||||
config = { pkgs, ...}: {
|
||||
config = { pkgs, ... }: {
|
||||
system.stateVersion = "25.05";
|
||||
|
||||
services.jellyfin = {
|
||||
|
@ -13,9 +13,13 @@
|
|||
networking.firewall.enable = false;
|
||||
};
|
||||
autoStart = true;
|
||||
privateNetwork = true;
|
||||
hostAddress = "172.30.1.2"; # TODO define in config option
|
||||
localAddress = "172.30.0.2";
|
||||
|
||||
bindMounts = {
|
||||
"/var/lib/jellyfin/libraries" = {
|
||||
hostPath = "/mnt/hdd/jellyfin";
|
||||
isReadOnly = false;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
networking = {
|
34
hosts/laptop-server/config/services/networking.nix
Normal file
34
hosts/laptop-server/config/services/networking.nix
Normal file
|
@ -0,0 +1,34 @@
|
|||
{ lib, ... }:
|
||||
let
|
||||
services = {
|
||||
jellyfin = {
|
||||
hostByte = 2;
|
||||
ports = [];
|
||||
};
|
||||
};
|
||||
in {
|
||||
config = lib.mkMerge ([{
|
||||
# Config always added
|
||||
networking = {
|
||||
nat = {
|
||||
enable = true;
|
||||
externalInterface = "wlp2s0";
|
||||
};
|
||||
};
|
||||
}] ++ builtins.map (serviceName: {
|
||||
# Config added per-service
|
||||
containers.${serviceName} = {
|
||||
privateNetwork = true;
|
||||
# Give it an address of 172.30.0.X on the host-side and 172.30.1.X inside the container
|
||||
# This appears to be necessary as both having addresses the same seems to cause issues
|
||||
hostAddress = "172.30.0.${builtins.toString services.${serviceName}.hostByte}";
|
||||
localAddress = "172.30.1.${builtins.toString services.${serviceName}.hostByte}";
|
||||
};
|
||||
|
||||
networking = {
|
||||
firewall.trustedInterfaces = [ "ve-${serviceName}" ];
|
||||
nat.internalInterfaces = [ "ve-${serviceName}" ];
|
||||
networkmanager.unmanaged = [ "interface-name:ve-${serviceName}" ];
|
||||
};
|
||||
}) (builtins.attrNames services));
|
||||
}
|
|
@ -19,6 +19,12 @@
|
|||
token = null;
|
||||
};
|
||||
};
|
||||
|
||||
caddy = {
|
||||
# The API key and secret key to use for provisioning HTTPS certificates
|
||||
porkbun_api_key = null;
|
||||
porkbun_secret_key = null;
|
||||
};
|
||||
};
|
||||
|
||||
passwords = {
|
||||
|
|
Loading…
Reference in a new issue