Add radarr, sonarr

Signed-off-by: Nikolaos Karaolidis <nick@karaolidis.com>
This commit is contained in:
2025-07-09 21:36:43 +01:00
parent cb187f3518
commit 384f1b222f
22 changed files with 750 additions and 298 deletions

View File

@@ -35,10 +35,12 @@
inherit pkgs;
};
docker-prowlarr = import ./docker/prowlarr { inherit pkgs; };
docker-radarr = import ./docker/radarr { inherit pkgs; };
docker-redis = import ./docker/redis { inherit pkgs; };
docker-shlink = import ./docker/shlink { inherit pkgs inputs system; };
docker-shlink-web-client = import ./docker/shlink-web-client { inherit pkgs inputs system; };
docker-sish = import ./docker/sish { inherit pkgs; };
docker-sonarr = import ./docker/sonarr { inherit pkgs; };
docker-traefik = import ./docker/traefik { inherit pkgs; };
docker-transmission-protonvpn = import ./docker/transmission-protonvpn { inherit pkgs; };
docker-whoami = import ./docker/whoami { inherit pkgs; };

View File

@@ -21,7 +21,7 @@ fi
Prowlarr -data=/var/lib/prowlarr -nobrowser "$@" &
PID=$!
PROWLARR_HOST="http://localhost:9696${PROWLARR_URL_BASE}"
PROWLARR_HOST="http://localhost:9696${PROWLARR_URL_BASE:-}"
if [ ! -f /var/lib/prowlarr/init ]; then
curl -sf --retry 10 --retry-connrefused \

View File

@@ -0,0 +1,43 @@
{ pkgs, ... }:
let
entrypoint = pkgs.writeTextFile {
name = "entrypoint";
executable = true;
destination = "/bin/entrypoint";
text = builtins.readFile ./entrypoint.sh;
};
in
pkgs.dockerTools.buildImage {
name = "radarr";
fromImage = import ../base { inherit pkgs; };
copyToRoot = pkgs.buildEnv {
name = "root";
paths = with pkgs; [
entrypoint
radarr
xmlstarlet
curl
jq
];
pathsToLink = [
"/bin"
"/lib"
];
};
runAsRoot = ''
${pkgs.dockerTools.shadowSetup}
'';
config = {
Entrypoint = [ "entrypoint" ];
ExposedPorts = {
"7878/tcp" = { };
};
WorkingDir = "/var/lib/radarr";
Volumes = {
"/var/lib/radarr" = { };
};
};
}

View File

@@ -0,0 +1,41 @@
#!/usr/bin/env sh
set -o errexit
set -o nounset
if [ ! -f /var/lib/radarr/init ]; then
echo '<Config/>' > /var/lib/radarr/config.xml
xmlstarlet ed -L \
-s /Config -t elem -n LaunchBrowser -v "False" \
-s /Config -t elem -n ApiKey -v "$RADARR_API_KEY" \
-s /Config -t elem -n AuthenticationMethod -v "External" \
-s /Config -t elem -n AuthenticationRequired -v "DisabledForLocalAddresses" \
-s /Config -t elem -n LogLevel -v "info" \
-s /Config -t elem -n UrlBase -v "${RADARR_URL_BASE:-}" \
-s /Config -t elem -n InstanceName -v "${RADARR_INSTANCE_NAME:-radarr}" \
-s /Config -t elem -n AnalyticsEnabled -v "False" \
/var/lib/radarr/config.xml
fi
Radarr -data=/var/lib/radarr -nobrowser "$@" &
PID=$!
RADARR_HOST="http://localhost:7878${RADARR_URL_BASE:-}"
if [ ! -f /var/lib/radarr/init ]; then
curl -sf --retry 10 --retry-connrefused \
-H "X-Api-Key: $RADARR_API_KEY" \
"$RADARR_HOST/api/v1/health"
if [ -f /etc/radarr/setup.sh ]; then
# shellcheck disable=SC1091
. /etc/radarr/setup.sh
fi
touch /var/lib/radarr/init
fi
trap 'kill -INT "$PID"' INT TERM
wait "$PID"
exit $?

View File

@@ -0,0 +1,43 @@
{ pkgs, ... }:
let
entrypoint = pkgs.writeTextFile {
name = "entrypoint";
executable = true;
destination = "/bin/entrypoint";
text = builtins.readFile ./entrypoint.sh;
};
in
pkgs.dockerTools.buildImage {
name = "sonarr";
fromImage = import ../base { inherit pkgs; };
copyToRoot = pkgs.buildEnv {
name = "root";
paths = with pkgs; [
entrypoint
sonarr
xmlstarlet
curl
jq
];
pathsToLink = [
"/bin"
"/lib"
];
};
runAsRoot = ''
${pkgs.dockerTools.shadowSetup}
'';
config = {
Entrypoint = [ "entrypoint" ];
ExposedPorts = {
"8989/tcp" = { };
};
WorkingDir = "/var/lib/sonarr";
Volumes = {
"/var/lib/sonarr" = { };
};
};
}

View File

@@ -0,0 +1,41 @@
#!/usr/bin/env sh
set -o errexit
set -o nounset
if [ ! -f /var/lib/sonarr/init ]; then
echo '<Config/>' > /var/lib/sonarr/config.xml
xmlstarlet ed -L \
-s /Config -t elem -n LaunchBrowser -v "False" \
-s /Config -t elem -n ApiKey -v "$SONARR_API_KEY" \
-s /Config -t elem -n AuthenticationMethod -v "External" \
-s /Config -t elem -n AuthenticationRequired -v "DisabledForLocalAddresses" \
-s /Config -t elem -n LogLevel -v "info" \
-s /Config -t elem -n UrlBase -v "${SONARR_URL_BASE:-}" \
-s /Config -t elem -n InstanceName -v "${SONARR_INSTANCE_NAME:-sonarr}" \
-s /Config -t elem -n AnalyticsEnabled -v "False" \
/var/lib/sonarr/config.xml
fi
Sonarr -data=/var/lib/sonarr -nobrowser "$@" &
PID=$!
SONARR_HOST="http://localhost:8989${SONARR_URL_BASE:-}"
if [ ! -f /var/lib/sonarr/init ]; then
curl -sf --retry 10 --retry-connrefused \
-H "X-Api-Key: $SONARR_API_KEY" \
"$SONARR_HOST/api/v1/health"
if [ -f /etc/sonarr/setup.sh ]; then
# shellcheck disable=SC1091
. /etc/sonarr/setup.sh
fi
touch /var/lib/sonarr/init
fi
trap 'kill -INT "$PID"' INT TERM
wait "$PID"
exit $?