Changed option namespace for better compatibility
This commit is contained in:
parent
fe8045ee55
commit
8b25f46384
26 changed files with 407 additions and 232 deletions
|
|
@ -5,10 +5,33 @@
|
|||
...
|
||||
}:
|
||||
let
|
||||
cfg = config.download-pod;
|
||||
cfg = config.my.services.download-pod;
|
||||
|
||||
containers = {
|
||||
webserver = {
|
||||
enable = true;
|
||||
image = "nginx";
|
||||
volumes = [
|
||||
"aaa:/config"
|
||||
"bbb:/data"
|
||||
];
|
||||
};
|
||||
|
||||
postgres = {
|
||||
enable = false;
|
||||
image = "postgres:13";
|
||||
};
|
||||
};
|
||||
|
||||
enabledContainers =
|
||||
containers:
|
||||
lib.mapAttrs (name: container: lib.removeAttrs container [ "enable" ]) (
|
||||
lib.filterAttrs (name: container: container.enable) containers
|
||||
);
|
||||
|
||||
in
|
||||
{
|
||||
options.download-pod = {
|
||||
options.my.services.download-pod = {
|
||||
enable = lib.mkEnableOption "Enable the download searcher stack";
|
||||
|
||||
proxy = {
|
||||
|
|
@ -36,93 +59,69 @@ in
|
|||
|
||||
config = lib.mkIf cfg.enable {
|
||||
|
||||
podman.enable = true;
|
||||
|
||||
systemd.services.pod-download = {
|
||||
description = "Start podman 'download' pod";
|
||||
wants = [ "network-online.target" ];
|
||||
after = [ "network-online.target" ];
|
||||
requiredBy = [
|
||||
"podman-jackett.service"
|
||||
"podman-radarr.service"
|
||||
"podman-sabnzbd.service"
|
||||
"podman-sonarr.service"
|
||||
];
|
||||
unitConfig = {
|
||||
RequiresMountsFor = "/run/containers";
|
||||
my.virtualisation.podmanPods = {
|
||||
mywebapp = {
|
||||
name = "mywebapp";
|
||||
ports = [
|
||||
"9090:80"
|
||||
"9443:443"
|
||||
];
|
||||
containers = enabledContainers containers;
|
||||
};
|
||||
serviceConfig = {
|
||||
Type = "oneshot";
|
||||
# - 7878: Radarr
|
||||
# - 8080: Sabnzbd
|
||||
# - 8989: Sonarr
|
||||
# - 9117: Jackett
|
||||
# - 9696: Prowlarr
|
||||
ExecStart = "-${pkgs.podman}/bin/podman pod create -p 9117:9117 -p 7878:7878 -p 8080:8080 -p 8989:8989 -p 9696:9696 download";
|
||||
};
|
||||
path = [ pkgs.podman ];
|
||||
};
|
||||
|
||||
virtualisation.oci-containers.containers = {
|
||||
virtualisation.oci-containers.containers = enabledContainers containers;
|
||||
|
||||
my-pod = {
|
||||
image = "k8s.gcr.io/pause:3.9";
|
||||
extraOptions = [
|
||||
"--pod=new:my-pod"
|
||||
"--publish=8081:80" # Expose port 80 in the pod as 8080 on the host
|
||||
"--publish=8082:82" # Expose port 82 in the pod as 8082 on the host
|
||||
"--publish=83:9117" # Expose port 9117 in the pod as 83 on the host
|
||||
];
|
||||
};
|
||||
# virtualisation.oci-containers.containers = {
|
||||
|
||||
jackett = {
|
||||
image = "linuxserver/jackett";
|
||||
autoStart = true;
|
||||
extraOptions = [ "--pod=my-pod" ];
|
||||
volumes = [
|
||||
"jackett_config:/config"
|
||||
"jackett_data:/data"
|
||||
];
|
||||
};
|
||||
# jackett = {
|
||||
# image = "linuxserver/jackett";
|
||||
# autoStart = true;
|
||||
# extraOptions = [ "--pod=my-pod" ];
|
||||
# volumes = [
|
||||
# "jackett_config:/config"
|
||||
# "jackett_data:/data"
|
||||
# ];
|
||||
# };
|
||||
|
||||
radarr = {
|
||||
image = "linuxserver/radarr";
|
||||
autoStart = true;
|
||||
extraOptions = [ "--pod=download" ];
|
||||
volumes = [
|
||||
"radarr_config:/config"
|
||||
"radarr_data:/data"
|
||||
];
|
||||
};
|
||||
# radarr = {
|
||||
# image = "linuxserver/radarr";
|
||||
# autoStart = true;
|
||||
# extraOptions = [ "--pod=download" ];
|
||||
# volumes = [
|
||||
# "radarr_config:/config"
|
||||
# "radarr_data:/data"
|
||||
# ];
|
||||
# };
|
||||
|
||||
sabnzbd = {
|
||||
image = "linuxserver/sabnzbd";
|
||||
autoStart = true;
|
||||
extraOptions = [ "--pod=download" ];
|
||||
volumes = [
|
||||
"sabnzbd_config:/config"
|
||||
"sabnzbd_data:/data"
|
||||
];
|
||||
};
|
||||
# sabnzbd = {
|
||||
# image = "linuxserver/sabnzbd";
|
||||
# autoStart = true;
|
||||
# extraOptions = [ "--pod=download" ];
|
||||
# volumes = [
|
||||
# "sabnzbd_config:/config"
|
||||
# "sabnzbd_data:/data"
|
||||
# ];
|
||||
# };
|
||||
|
||||
sonarr = {
|
||||
image = "linuxserver/sonarr";
|
||||
autoStart = true;
|
||||
extraOptions = [ "--pod=download" ];
|
||||
volumes = [
|
||||
"sonarr_config:/config"
|
||||
"sonarr_data:/data"
|
||||
];
|
||||
};
|
||||
# sonarr = {
|
||||
# image = "linuxserver/sonarr";
|
||||
# autoStart = true;
|
||||
# extraOptions = [ "--pod=download" ];
|
||||
# volumes = [
|
||||
# "sonarr_config:/config"
|
||||
# "sonarr_data:/data"
|
||||
# ];
|
||||
# };
|
||||
|
||||
prowlarr = {
|
||||
image = "linuxserver/prowlarr";
|
||||
autoStart = true;
|
||||
extraOptions = [ "--pod=download" ];
|
||||
volumes = [ "prowlarr_config:/config" ];
|
||||
};
|
||||
# prowlarr = {
|
||||
# image = "linuxserver/prowlarr";
|
||||
# autoStart = true;
|
||||
# extraOptions = [ "--pod=download" ];
|
||||
# volumes = [ "prowlarr_config:/config" ];
|
||||
# };
|
||||
|
||||
};
|
||||
# };
|
||||
|
||||
services.caddy = lib.mkIf cfg.proxy.enable {
|
||||
enable = true;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue