mirror of
https://github.com/phfroidmont/self-hosting.git
synced 2025-12-25 13:46:59 +01:00
84 lines
2.1 KiB
Nix
84 lines
2.1 KiB
Nix
{
|
|
pkgs,
|
|
config,
|
|
lib,
|
|
...
|
|
}:
|
|
let
|
|
cfg = config.custom.services.stb;
|
|
uploadWordpressConfig = pkgs.writeText "upload.ini" ''
|
|
file_uploads = On
|
|
memory_limit = 64M
|
|
upload_max_filesize = 64M
|
|
post_max_size = 64M
|
|
max_execution_time = 600
|
|
'';
|
|
in
|
|
{
|
|
options.custom.services.stb = {
|
|
enable = lib.mkEnableOption "stb";
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
virtualisation.podman.defaultNetwork.settings = {
|
|
dns_enabled = true;
|
|
};
|
|
systemd.services.init-stb-network = {
|
|
description = "Create the network bridge stb-br for wordpress.";
|
|
after = [ "network.target" ];
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
serviceConfig.Type = "oneshot";
|
|
script =
|
|
let
|
|
podmancli = "${pkgs.podman}/bin/podman";
|
|
in
|
|
''
|
|
# Put a true at the end to prevent getting non-zero return code, which will
|
|
# crash the whole service.
|
|
check=$(${podmancli} pod ps | grep "stb" || true)
|
|
if [ -z "$check" ]; then
|
|
${podmancli} pod create --publish 8180:80 stb
|
|
else
|
|
echo "stb pod already exists"
|
|
fi
|
|
'';
|
|
};
|
|
|
|
virtualisation.oci-containers.containers = {
|
|
"stb-mariadb" = {
|
|
image = "mariadb:10.7";
|
|
environment = {
|
|
"MYSQL_ROOT_PASSWORD" = "root";
|
|
"MYSQL_USER" = "stb";
|
|
"MYSQL_PASSWORD" = "stb";
|
|
"MYSQL_DATABASE" = "stb";
|
|
};
|
|
volumes = [ "/var/lib/mariadb/stb:/var/lib/mysql" ];
|
|
extraOptions = [ "--pod=stb" ];
|
|
autoStart = true;
|
|
};
|
|
|
|
"stb-wordpress" = {
|
|
image = "wordpress:5.8-php7.4-apache";
|
|
volumes = [
|
|
"/nix/var/data/stb-wordpress:/var/www/html"
|
|
"${uploadWordpressConfig}:/usr/local/etc/php/conf.d/uploads.ini"
|
|
];
|
|
extraOptions = [ "--pod=stb" ];
|
|
autoStart = true;
|
|
};
|
|
};
|
|
|
|
services.nginx.virtualHosts."www.societe-de-tir-bertrix.com" = {
|
|
serverAliases = [ "societe-de-tir-bertrix.com" ];
|
|
forceSSL = true;
|
|
enableACME = true;
|
|
|
|
locations."/" = {
|
|
proxyPass = "http://127.0.0.1:8180";
|
|
};
|
|
};
|
|
};
|
|
}
|