2015-10-28 21:31:07 +01:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
2016-02-14 16:43:44 +01:00
|
|
|
with config.krebs.lib;
|
2015-10-28 21:31:07 +01:00
|
|
|
let
|
2015-10-29 10:55:54 +01:00
|
|
|
sec = toString <secrets>;
|
2016-07-28 13:02:06 +02:00
|
|
|
ext-dom = "wiki.euer.krebsco.de";
|
|
|
|
acmepath = "/var/lib/acme/";
|
|
|
|
acmechall = acmepath + "/challenges/";
|
|
|
|
|
|
|
|
#ssl_cert = "${sec}/wildcard.krebsco.de.crt";
|
|
|
|
#ssl_key = "${sec}/wildcard.krebsco.de.key";
|
|
|
|
ssl_cert = "${acmepath}/${ext-dom}/fullchain.pem";
|
|
|
|
ssl_key = "${acmepath}/${ext-dom}/key.pem";
|
|
|
|
|
2015-10-28 21:31:07 +01:00
|
|
|
user = config.services.nginx.user;
|
|
|
|
group = config.services.nginx.group;
|
|
|
|
fpm-socket = "/var/run/php5-fpm.sock";
|
|
|
|
hostname = config.krebs.build.host.name;
|
|
|
|
tw-upload = pkgs.tw-upload-plugin;
|
|
|
|
base-dir = "/var/www/wiki.euer";
|
|
|
|
base-cfg = "${base-dir}/twconf.ini";
|
|
|
|
wiki-dir = "${base-dir}/store/";
|
|
|
|
backup-dir = "${base-dir}/backup/";
|
|
|
|
# contains:
|
|
|
|
# user1 = pass1
|
|
|
|
# userN = passN
|
2015-10-29 10:55:54 +01:00
|
|
|
tw-pass-file = "${sec}/tw-pass.ini";
|
2016-04-08 03:53:34 +02:00
|
|
|
external-ip = config.krebs.build.host.nets.internet.ip4.addr;
|
|
|
|
internal-ip = config.krebs.build.host.nets.retiolum.ip4.addr;
|
2015-10-28 21:31:07 +01:00
|
|
|
in {
|
|
|
|
services.phpfpm = {
|
|
|
|
# phpfpm does not have an enable option
|
|
|
|
poolConfigs = {
|
|
|
|
euer-wiki = ''
|
|
|
|
user = ${user}
|
|
|
|
group = ${group}
|
|
|
|
listen = ${fpm-socket}
|
|
|
|
listen.owner = ${user}
|
|
|
|
listen.group = ${group}
|
|
|
|
env[twconf] = ${base-cfg};
|
|
|
|
pm = dynamic
|
|
|
|
pm.max_children = 5
|
|
|
|
pm.start_servers = 2
|
|
|
|
pm.min_spare_servers = 1
|
|
|
|
pm.max_spare_servers = 3
|
|
|
|
chdir = /
|
|
|
|
# errors to journal
|
|
|
|
php_admin_value[error_log] = 'stderr'
|
|
|
|
php_admin_flag[log_errors] = on
|
|
|
|
catch_workers_output = yes
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.services.prepare-tw = {
|
|
|
|
wantedBy = [ "local-fs.target" ];
|
|
|
|
before = [ "phpfpm.service" ];
|
|
|
|
serviceConfig = {
|
|
|
|
ExecStart = pkgs.writeScript "prepare-tw-service" ''
|
|
|
|
#!/bin/sh
|
2015-11-05 12:31:09 +01:00
|
|
|
if ! test -d "${base-dir}" ;then
|
|
|
|
mkdir -p "${wiki-dir}" "${backup-dir}"
|
2015-10-28 21:31:07 +01:00
|
|
|
|
2015-11-05 12:31:09 +01:00
|
|
|
# write the base configuration
|
|
|
|
cat > "${base-cfg}" <<EOF
|
2015-10-28 21:31:07 +01:00
|
|
|
[users]
|
|
|
|
$(cat "${tw-pass-file}")
|
|
|
|
[directories]
|
|
|
|
backupdir = ${backup-dir}
|
|
|
|
savedir = ${wiki-dir}
|
|
|
|
EOF
|
2015-11-05 12:31:09 +01:00
|
|
|
|
|
|
|
chown -R ${user}:${group} "${base-dir}"
|
|
|
|
chmod 700 -R "${base-dir}"
|
|
|
|
fi
|
2015-10-28 21:31:07 +01:00
|
|
|
'';
|
|
|
|
Type = "oneshot";
|
|
|
|
RemainAfterExit = "yes";
|
|
|
|
TimeoutSec = "0";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
krebs.nginx = {
|
|
|
|
enable = mkDefault true;
|
|
|
|
servers = {
|
|
|
|
euer-wiki = {
|
|
|
|
listen = [ "${external-ip}:80" "${external-ip}:443 ssl"
|
|
|
|
"${internal-ip}:80" "${internal-ip}:443 ssl" ];
|
|
|
|
server-names = [
|
2016-07-28 13:02:06 +02:00
|
|
|
ext-dom
|
2015-10-28 21:31:07 +01:00
|
|
|
"wiki.makefu.retiolum"
|
|
|
|
"wiki.makefu"
|
|
|
|
];
|
2016-07-28 13:02:06 +02:00
|
|
|
ssl = {
|
|
|
|
enable = true;
|
|
|
|
# these certs will be needed if acme has not yet created certificates:
|
|
|
|
certificate = ssl_cert;
|
|
|
|
certificate_key = ssl_key;
|
|
|
|
force_encryption = true;
|
|
|
|
};
|
2015-10-28 21:31:07 +01:00
|
|
|
extraConfig = ''
|
|
|
|
gzip on;
|
|
|
|
gzip_buffers 4 32k;
|
|
|
|
gzip_types text/plain application/x-javascript text/css;
|
|
|
|
default_type text/plain;
|
|
|
|
|
|
|
|
'';
|
|
|
|
locations = [
|
|
|
|
(nameValuePair "/" ''
|
|
|
|
root ${wiki-dir};
|
|
|
|
expires -1;
|
|
|
|
autoindex on;
|
|
|
|
'')
|
|
|
|
(nameValuePair "/store.php" ''
|
|
|
|
root ${tw-upload};
|
|
|
|
client_max_body_size 200M;
|
|
|
|
fastcgi_split_path_info ^(.+\.php)(/.+)$;
|
|
|
|
fastcgi_pass unix:${fpm-socket};
|
|
|
|
include ${pkgs.nginx}/conf/fastcgi_params;
|
|
|
|
include ${pkgs.nginx}/conf/fastcgi.conf;
|
|
|
|
'')
|
2016-07-28 13:02:06 +02:00
|
|
|
(nameValuePair "/.well-known/acme-challenge" ''
|
|
|
|
root ${acmechall}/${ext-dom}/;
|
|
|
|
'')
|
|
|
|
|
2015-10-28 21:31:07 +01:00
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2016-07-28 13:02:06 +02:00
|
|
|
security.acme.certs."${ext-dom}" = {
|
|
|
|
email = "acme@syntax-fehler.de";
|
|
|
|
webroot = "${acmechall}/${ext-dom}/";
|
|
|
|
group = "nginx";
|
|
|
|
allowKeysForGroup = true;
|
|
|
|
postRun = "systemctl reload nginx.service";
|
|
|
|
extraDomains."${ext-dom}" = null ;
|
|
|
|
};
|
2015-10-28 21:31:07 +01:00
|
|
|
}
|