{ pkgs, config, lib, ... }: let cfg = config.modules.services.; ids = ; in { options.modules.services. = { enable = lib.mkEnableOption "enables "; # extra options # mode = lib.mkOption { # type = lib.types.enum [ "server" "client" ]; # default = "client"; # description = "whether syncthing should run as a client (user) or server (system-wide)."; # }; }; config = lib.mkIf cfg.enable { # declare group users.groups. = { gid = ids; }; # declare user users.users. = { description = " media server user"; uid = ids; isSystemUser = true; home = "/var/lib/"; createHome = true; group = ""; extraGroups = [ "media" "video" "render" ]; }; # enable the service services. = { enable = true; openFirewall = true; # Opens 8096/8920 automatically user = ""; # Default: group = ""; # Default: dataDir = "/var/lib/"; # Config + metadata storage }; # override umask to make permissions work out systemd.services..serviceConfig = { UMask = lib.mkForce "0007"; }; # open firewall #networking.firewall.allowedTCPPorts = [ 8096 ]; # reverse proxy entryo services.nginx.virtualHosts."media.blakedheld.xyz" = { enableACME = false; forceSSL = true; sslCertificate = config.sops.secrets."ssl_blakedheld_crt".path; sslCertificateKey = config.sops.secrets."ssl_blakedheld_key".path; locations."/" = { proxyPass = "http://127.0.0.1:8096"; }; }; }; }