2023-02-25 13:45:21 +00:00
|
|
|
{
|
2023-11-11 00:06:36 +00:00
|
|
|
flake,
|
2023-02-25 13:45:21 +00:00
|
|
|
pkgs,
|
|
|
|
config,
|
|
|
|
lib,
|
|
|
|
...
|
|
|
|
}: let
|
|
|
|
notifyPushPort = 7867;
|
|
|
|
in {
|
|
|
|
imports = [
|
|
|
|
./nextcloud-apps.nix
|
2023-10-01 20:07:32 +00:00
|
|
|
./nextcloud-collabora.nix
|
2023-02-25 13:45:21 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
age.secrets.nextcloud_db_pass = {
|
|
|
|
owner = "nextcloud";
|
|
|
|
group = "nextcloud";
|
2023-11-11 00:06:36 +00:00
|
|
|
file = "${flake.self}/secrets/chonk_nextcloud_db_pass.age";
|
2023-02-25 13:45:21 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
age.secrets.nextcloud_admin_pass = {
|
|
|
|
owner = "nextcloud";
|
|
|
|
group = "nextcloud";
|
2023-11-11 00:06:36 +00:00
|
|
|
file = "${flake.self}/secrets/chonk_nextcloud_admin_pass.age";
|
2023-02-25 13:45:21 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
# HTTP
|
|
|
|
services.nginx = {
|
|
|
|
enable = true;
|
|
|
|
recommendedGzipSettings = true;
|
|
|
|
recommendedOptimisation = true;
|
|
|
|
recommendedProxySettings = true;
|
|
|
|
recommendedTlsSettings = true;
|
|
|
|
sslCiphers = "AES256+EECDH:AES256+EDH:!aNULL";
|
|
|
|
virtualHosts."data.gssws.de" = {
|
|
|
|
enableACME = true;
|
|
|
|
forceSSL = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# DATABASES
|
|
|
|
services.postgresql = {
|
|
|
|
enable = true;
|
|
|
|
package = pkgs.postgresql_11;
|
|
|
|
|
|
|
|
settings = {
|
|
|
|
max_connections = "200";
|
|
|
|
};
|
|
|
|
|
|
|
|
ensureDatabases = ["nextcloud"];
|
|
|
|
ensureUsers = [
|
|
|
|
{
|
|
|
|
name = "nextcloud";
|
|
|
|
ensurePermissions."DATABASE nextcloud" = "ALL PRIVILEGES";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2023-10-01 20:07:32 +00:00
|
|
|
# NOTIFY PUSH
|
|
|
|
services.nextcloud.notify_push.enable = true;
|
2023-02-25 13:45:21 +00:00
|
|
|
|
2023-10-01 20:07:32 +00:00
|
|
|
# REDIS
|
|
|
|
services.redis.servers."nextcloud".enable = true;
|
2023-02-25 13:45:21 +00:00
|
|
|
users.groups."redis-nextcloud".members = ["nextcloud"];
|
|
|
|
|
|
|
|
# NEXTCLOUD
|
|
|
|
systemd.services."nextcloud-setup" = {
|
|
|
|
requires = ["postgresql.service"];
|
|
|
|
after = ["postgresql.service"];
|
|
|
|
};
|
2023-10-01 20:07:32 +00:00
|
|
|
|
2023-02-25 13:45:21 +00:00
|
|
|
services.nextcloud = {
|
|
|
|
enable = true;
|
2023-10-01 20:07:32 +00:00
|
|
|
package = pkgs.nextcloud27;
|
|
|
|
enableBrokenCiphersForSSE = false;
|
2023-02-25 13:45:21 +00:00
|
|
|
hostName = "data.gssws.de";
|
|
|
|
https = true;
|
|
|
|
datadir = "/mnt/internal/nextcloud";
|
|
|
|
|
|
|
|
caching.apcu = true;
|
|
|
|
caching.redis = true;
|
|
|
|
|
2023-10-01 20:07:32 +00:00
|
|
|
phpPackage = lib.mkForce pkgs.php82;
|
2023-02-25 13:45:21 +00:00
|
|
|
|
|
|
|
poolSettings = {
|
|
|
|
"pm" = "dynamic";
|
|
|
|
"pm.max_children" = "128";
|
|
|
|
"pm.start_servers" = "64";
|
|
|
|
"pm.min_spare_servers" = "32";
|
|
|
|
"pm.max_spare_servers" = "76";
|
|
|
|
"pm.max_requests" = "500";
|
|
|
|
};
|
|
|
|
|
|
|
|
phpOptions = {
|
|
|
|
short_open_tag = "Off";
|
|
|
|
expose_php = "Off";
|
|
|
|
error_reporting = "E_ALL & ~E_DEPRECATED & ~E_STRICT";
|
|
|
|
display_errors = "stderr";
|
|
|
|
"opcache.enable_cli" = "1";
|
|
|
|
"opcache.interned_strings_buffer" = "32";
|
|
|
|
"opcache.max_accelerated_files" = "100000";
|
|
|
|
"opcache.memory_consumption" = "256";
|
|
|
|
"opcache.revalidate_freq" = "1";
|
|
|
|
"opcache.fast_shutdown" = "1";
|
|
|
|
"openssl.cafile" = "/etc/ssl/certs/ca-certificates.crt";
|
|
|
|
catch_workers_output = "yes";
|
|
|
|
};
|
|
|
|
|
|
|
|
config = {
|
|
|
|
overwriteProtocol = "https";
|
|
|
|
|
|
|
|
dbtype = "pgsql";
|
|
|
|
dbuser = "nextcloud";
|
2023-10-01 20:07:32 +00:00
|
|
|
dbhost = "127.0.0.1:5432";
|
2023-02-25 13:45:21 +00:00
|
|
|
dbname = "nextcloud";
|
|
|
|
dbpassFile = "/run/agenix/nextcloud_db_pass";
|
|
|
|
adminpassFile = "/run/agenix/nextcloud_admin_pass";
|
|
|
|
adminuser = "admin";
|
|
|
|
|
|
|
|
trustedProxies = ["80.244.242.2"];
|
|
|
|
defaultPhoneRegion = "DE";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|