added ytptube podman service. web interface for youtube-dl

This commit is contained in:
Tigor Hutasuhut 2024-06-17 21:49:20 +07:00
parent d69819ebb7
commit 714cdcea1c
4 changed files with 98 additions and 2 deletions

View file

@ -5,5 +5,6 @@
caddy.enable = lib.mkEnableOption "caddy podman"; caddy.enable = lib.mkEnableOption "caddy podman";
pihole.enable = lib.mkEnableOption "pihole podman"; pihole.enable = lib.mkEnableOption "pihole podman";
suwayomi.enable = lib.mkEnableOption "suwayomi podman"; suwayomi.enable = lib.mkEnableOption "suwayomi podman";
ytptube.enable = lib.mkEnableOption "metube podman";
}; };
} }

View file

@ -27,6 +27,7 @@
enable = true; enable = true;
pihole.enable = true; pihole.enable = true;
suwayomi.enable = true; suwayomi.enable = true;
ytptube.enable = true;
}; };
docker = { docker = {

View file

@ -10,7 +10,6 @@ in
environment.systemPackages = with pkgs; [ environment.systemPackages = with pkgs; [
dive # look into docker image layers dive # look into docker image layers
podman-tui # status of containers in the terminal podman-tui # status of containers in the terminal
podman-compose # start group of containers for dev
]; ];
systemd.timers."podman-auto-update".enable = true; systemd.timers."podman-auto-update".enable = true;
@ -33,12 +32,13 @@ in
# Taken IP-Range Subnets # Taken IP-Range Subnets
# #
# 10.1.1.0-4 -> Pihole # 10.1.1.0-4 -> Pihole
# 10.1.1.4-8 -> # 10.1.1.4-8 -> ytptube
# 10.1.1.8-12 -> Suwayomi # 10.1.1.8-12 -> Suwayomi
# 10.1.1.12-16 -> Suwayomi # 10.1.1.12-16 -> Suwayomi
imports = [ imports = [
./caddy.nix ./caddy.nix
./pihole.nix ./pihole.nix
./suwayomi.nix ./suwayomi.nix
./ytptube.nix
]; ];
} }

94
system/podman/ytptube.nix Normal file
View file

@ -0,0 +1,94 @@
{ config, lib, pkgs, ... }:
let
name = "ytptube";
podman = config.profile.podman;
inherit (lib) mkIf;
gateway = "10.1.1.5";
subnet = "10.1.1.4/30";
ip = "10.1.1.6";
ip-range = "10.1.1.6/30";
image = "ghcr.io/arabcoders/${name}:latest";
volume = "/nas/mediaserver/${name}";
domain = "${name}.tigor.web.id";
user = config.profile.user;
uid = toString user.uid;
gid = toString user.gid;
in
{
config = mkIf (podman.enable && podman.${name}.enable) {
services.caddy.virtualHosts.${domain}.extraConfig = ''
reverse_proxy ${ip}:8081
'';
systemd.services."create-${name}-network" = {
serviceConfig = {
Type = "oneshot";
RemainAfterExit = true;
};
wantedBy = [ "podman-${name}.service" ];
script = ''${pkgs.podman}/bin/podman network exists ${name} || ${pkgs.podman}/bin/podman network create --gateway=${gateway} --subnet=${subnet} --ip-range=${ip-range} ${name}'';
};
system.activationScripts."podman-${name}" = ''
mkdir -p ${volume}
chown -R ${uid}:${gid} /nas/mediaserver
'';
environment.etc."podman/${name}/ytdlp.json" = {
# https://github.com/arabcoders/ytptube?tab=readme-ov-file#ytdlpjson-file
source = (pkgs.formats.json { }).generate "config.json" {
windowsfilenames = true;
writesubtitles = true;
writeinfojson = true;
writethumbnail = true;
writeautomaticsub = false;
merge_output_format = "mkv";
live_from_start = true;
format_sort = [ "codec:abc:m4a" ];
subtitleslangs = [ "en" ];
postprocessors = [
# this processor convert the downloaded thumbnail to jpg.
{
key = "FFmpegThumbnailsConvertor";
format = "jpg";
}
# This processor convert subtitles to srt format.
{
key = "FFmpegSubtitlesConvertor";
format = "srt";
}
# This processor embed metadata & info.json file into the final mkv file.
{
key = "FFmpegMetadata";
add_infojson = true;
add_metadata = true;
}
# This process embed subtitles into the final file if it doesn't have subtitles embedded
{
key = "FFmpegEmbedSubtitle";
already_have_subtitle = false;
}
];
};
mode = "0444";
};
virtualisation.oci-containers.containers.${name} = {
inherit image;
autoStart = true;
user = "${uid}:${gid}";
environment = {
TZ = "Asia/Jakarta";
};
volumes = [
"${volume}:/downloads"
"/etc/podman/${name}/ytdlp.json:/config/ytdlp.json"
];
extraOptions = [
"--ip=${ip}"
"--network=${name}"
];
};
};
}