initial website configuration

This commit is contained in:
Rouven Seifert 2023-08-16 13:24:56 +02:00
parent ebe2834de6
commit f8684b8be9
Signed by: rouven.seifert
GPG key ID: B95E8FE6B11C4D09
2 changed files with 57 additions and 0 deletions

View file

@ -45,6 +45,7 @@
./modules/mautrix-telegram.nix ./modules/mautrix-telegram.nix
./modules/sogo.nix ./modules/sogo.nix
./modules/vaultwarden.nix ./modules/vaultwarden.nix
./modules/website.nix
./modules/zsh.nix ./modules/zsh.nix
./modules/course-management.nix ./modules/course-management.nix
./modules/gitea.nix ./modules/gitea.nix

56
modules/website.nix Normal file
View file

@ -0,0 +1,56 @@
{ config, pkgs, lib, ... }:
let
www-domain = "www.${config.fsr.domain}";
user = "fsr-web";
group = "fsr-web";
in
{
users.users.${user} = {
group = group;
isSystemUser = true;
};
users.groups.${group} = { };
services.phpfpm.pools.ifsrde = {
user = user;
group = group;
settings = {
"listen.owner" = config.services.nginx.user;
"pm" = "dynamic";
"pm.max_children" = 32;
"pm.max_requests" = 500;
"pm.start_servers" = 2;
"pm.min_spare_servers" = 2;
"pm.max_spare_servers" = 5;
"php_admin_value[error_log]" = "stderr";
"php_admin_flag[log_errors]" = true;
"catch_workers_output" = true;
};
phpEnv."PATH" = lib.makeBinPath [ pkgs.php ];
};
services.nginx = rec {
virtualHosts.${www-domain} = {
root = "/srv/web/ifsrde";
locations = {
"= /" = {
extraConfig = ''
rewrite ^ /index.php;
'';
};
"~ \.php$" = {
extraConfig = ''
try_files $uri =404;
fastcgi_pass unix:${config.services.phpfpm.pools.ifsrde.socket};
fastcgi_index index.php;
include ${pkgs.nginx}/conf/fastcgi_params;
include ${pkgs.nginx}/conf/fastcgi.conf;
'';
};
};
};
# ifsr.de without www
virtualHosts.${config.fsr.domain} = virtualHosts.${www-domain};
};
}