tdarr
This commit is contained in:
@@ -22,7 +22,7 @@ let
|
|||||||
];
|
];
|
||||||
enableDisplayManager = false;
|
enableDisplayManager = false;
|
||||||
# adding a flag cause nixos cant figure itself out and broke shit that cant be fixed
|
# adding a flag cause nixos cant figure itself out and broke shit that cant be fixed
|
||||||
enableUps = true;
|
enableUps = false;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
@@ -82,6 +82,8 @@ in
|
|||||||
|
|
||||||
swag.enable = true;
|
swag.enable = true;
|
||||||
|
|
||||||
|
tdarr.enable = true;
|
||||||
|
|
||||||
vscode.enable = true;
|
vscode.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -363,9 +365,9 @@ in
|
|||||||
|
|
||||||
# Configure environment
|
# Configure environment
|
||||||
environment = {
|
environment = {
|
||||||
etc."nut/upsd.conf".source = /home/matt/upsd.conf;
|
# etc."nut/upsd.conf".source = /home/matt/upsd.conf;
|
||||||
etc."nut/upsd.users".source = /home/matt/upsd.users;
|
# etc."nut/upsd.users".source = /home/matt/upsd.users;
|
||||||
etc."nut/upsmon.conf".source = /home/matt/upsmon.conf;
|
# etc."nut/upsmon.conf".source = /home/matt/upsmon.conf;
|
||||||
# List packages installed in system profile. To search, run:
|
# List packages installed in system profile. To search, run:
|
||||||
# $ nix search wget
|
# $ nix search wget
|
||||||
|
|
||||||
@@ -425,18 +427,18 @@ in
|
|||||||
monitor = "nasups@localhost 1 upsuser BogieDudie1 primary";
|
monitor = "nasups@localhost 1 upsuser BogieDudie1 primary";
|
||||||
};
|
};
|
||||||
upsd = {
|
upsd = {
|
||||||
enable = true;
|
enable = enableUps;
|
||||||
listen = {
|
listen = {
|
||||||
address = 0.0 0.0 0.0;
|
address = 0.0 0.0 0.0;
|
||||||
port = 3493;
|
port = 3493;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
users = {
|
# users = {
|
||||||
actions = [ "SET" ];
|
# actions = [ "SET" ];
|
||||||
instcmds = [ "ALL" ];
|
# instcmds = [ "ALL" ];
|
||||||
upsmon = "primary";
|
##* upsmon = "primary";
|
||||||
passwordFile = "/home/matt/ups.conf";
|
# passwordFile = "/home/matt/ups.conf";
|
||||||
};
|
# };
|
||||||
};
|
};
|
||||||
|
|
||||||
# Add UPS monitoring service
|
# Add UPS monitoring service
|
||||||
|
|||||||
44
modules/apps/tdarr/default.nix
Normal file
44
modules/apps/tdarr/default.nix
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
{
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
with lib;
|
||||||
|
let
|
||||||
|
cfg = config.nas-apps.tdarr;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
imports = [ ./options.nix ];
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
|
||||||
|
virtualisation.oci-containers.containers.${cfg.name} = {
|
||||||
|
autoStart = true;
|
||||||
|
image = cfg.image;
|
||||||
|
extraOptions = [ "--device=nvidia.com/gpu=0" ];
|
||||||
|
volumes = [
|
||||||
|
"${cfg.configPath}:/app/configs"
|
||||||
|
"${cfg.serverPath}:/app/server"
|
||||||
|
"${cfg.logPath}:/app/logs"
|
||||||
|
"${cfg.transcodePath}:/temp"
|
||||||
|
"${cfg.moviesPath}:/data/movies"
|
||||||
|
"${cfg.tvPath}:/data/tv"
|
||||||
|
];
|
||||||
|
ports = [ "${cfg.serverPort}:8266" "${cfg.webUIPort}:8265" ];
|
||||||
|
environment = {
|
||||||
|
serverPort = "8266";
|
||||||
|
webUIPort = "8265";
|
||||||
|
internalNode = "true";
|
||||||
|
inContainer = "true";
|
||||||
|
ffmpegVersion = "6";
|
||||||
|
nodeName = "tdarr node";
|
||||||
|
NVIDIA_VISIBLE_DEVICES = "all";
|
||||||
|
NVIDIA_DRIVER_CAPABILITIES = "all";
|
||||||
|
PUID = cfg.puid;
|
||||||
|
PGID = cfg.pgid;
|
||||||
|
TZ = cfg.timeZone;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
77
modules/apps/tdarr/options.nix
Normal file
77
modules/apps/tdarr/options.nix
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
{ lib, ... }:
|
||||||
|
with lib;
|
||||||
|
{
|
||||||
|
options.nas-apps.tdarr = {
|
||||||
|
enable = mkEnableOption "tdarr docker service";
|
||||||
|
|
||||||
|
autoStart = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
serverPort = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "8266";
|
||||||
|
};
|
||||||
|
|
||||||
|
webUIPort = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "8265";
|
||||||
|
};
|
||||||
|
|
||||||
|
name = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "tdarr";
|
||||||
|
};
|
||||||
|
|
||||||
|
image = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "ghcr.io/haveagitgat/tdarr";
|
||||||
|
};
|
||||||
|
|
||||||
|
configPath = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "/home/admin/ssd/nix-app-data/tdarr/config";
|
||||||
|
};
|
||||||
|
|
||||||
|
serverPath = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "/home/admin/ssd/nix-app-data/tdarr/server";
|
||||||
|
};
|
||||||
|
|
||||||
|
logPath = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "/home/admin/ssd/nix-app-data/tdarr/logs";
|
||||||
|
};
|
||||||
|
|
||||||
|
transcodePath = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "/home/admin/ssd/nix-app-data/tdarr/transcode";
|
||||||
|
};
|
||||||
|
|
||||||
|
moviesPath = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "/home/admin/mainpool/Movies";
|
||||||
|
};
|
||||||
|
|
||||||
|
tvPath = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "/home/admin/mainpool/TV";
|
||||||
|
};
|
||||||
|
|
||||||
|
puid = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "911";
|
||||||
|
};
|
||||||
|
|
||||||
|
pgid = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "1000";
|
||||||
|
};
|
||||||
|
|
||||||
|
timeZone = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "America/Chicago";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -20,6 +20,7 @@
|
|||||||
./apps/sabnzbd
|
./apps/sabnzbd
|
||||||
./apps/sonarr
|
./apps/sonarr
|
||||||
./apps/swag
|
./apps/swag
|
||||||
|
./apps/tdarr
|
||||||
./apps/vscode
|
./apps/vscode
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user