Tristan Daniël Maat
517f4f0080
Podman pods make this obsolete; though we need to explicitly set slirp4netns, otherwise podman will not create private network namespaces for the pods.
52 lines
1.3 KiB
Nix
52 lines
1.3 KiB
Nix
{ config, ... }:
|
|
|
|
{
|
|
virtualisation.pods.nextcloud = {
|
|
hostname = "nextcloud.tlater.net";
|
|
publish = [ "3001:80" ];
|
|
network = "slirp4netns";
|
|
|
|
containers = {
|
|
nextcloud = {
|
|
image = "nextcloud:fpm-alpine";
|
|
dependsOn = [ "postgres" ];
|
|
volumes = [
|
|
"nextcloud-apps:/var/www/html/custom_apps"
|
|
"nextcloud-config:/var/www/html/config"
|
|
"nextcloud-data:/var/www/html/data"
|
|
];
|
|
environment = {
|
|
POSTGRES_DB = "nextcloud";
|
|
POSTGRES_USER = "nextcloud";
|
|
POSTGRES_HOST = "nextcloud-postgres";
|
|
OVERWRITEPROTOCOL = "https";
|
|
};
|
|
};
|
|
|
|
cron = {
|
|
image = "nextcloud:fpm-alpine";
|
|
entrypoint = "/cron.sh";
|
|
dependsOn = [ "postgres" "nextcloud" ];
|
|
extraOptions = [ "--volumes-from=nextcloud-nextcloud" ];
|
|
};
|
|
|
|
nginx = {
|
|
image = "nginx:alpine";
|
|
dependsOn = [ "nextcloud" ];
|
|
volumes =
|
|
[ "${./configs/nginx-nextcloud.conf}:/etc/nginx/nginx.conf:ro" ];
|
|
extraOptions = [ "--volumes-from=nextcloud-nextcloud" ];
|
|
};
|
|
|
|
postgres = {
|
|
image = "postgres:alpine";
|
|
environment = {
|
|
POSTGRES_DB = "nextcloud";
|
|
POSTGRES_USER = "nextcloud";
|
|
};
|
|
volumes = [ "nextcloud-db-data:/var/lib/postgresql/data" ];
|
|
};
|
|
};
|
|
};
|
|
}
|