2024-05-23 13:39:48 +03:00
|
|
|
{ config, pkgs, ... }:
|
|
|
|
{
|
2024-06-02 16:18:19 +03:00
|
|
|
networking.firewall.allowedTCPPorts = [
|
|
|
|
80
|
|
|
|
443
|
|
|
|
];
|
2024-06-02 05:53:39 +03:00
|
|
|
networking.firewall.allowedUDPPorts = [ 443 ];
|
2024-05-23 13:39:48 +03:00
|
|
|
|
2024-06-02 05:53:39 +03:00
|
|
|
services.nextcloud = {
|
2024-11-26 18:30:56 +02:00
|
|
|
package = pkgs.nextcloud30;
|
2024-06-02 05:53:39 +03:00
|
|
|
enable = true;
|
|
|
|
hostName = "nextcloud.vsinerva.fi";
|
|
|
|
autoUpdateApps.enable = true;
|
|
|
|
https = true;
|
|
|
|
maxUploadSize = "10G";
|
|
|
|
config = {
|
|
|
|
adminpassFile = "/var/lib/nextcloud/adminpass";
|
|
|
|
};
|
|
|
|
settings = {
|
|
|
|
overwriteprotocol = "https";
|
|
|
|
};
|
|
|
|
};
|
2024-05-23 13:39:48 +03:00
|
|
|
|
2024-06-02 16:18:19 +03:00
|
|
|
services.nginx.virtualHosts = {
|
|
|
|
${config.services.nextcloud.hostName} = {
|
|
|
|
forceSSL = true;
|
|
|
|
kTLS = true;
|
|
|
|
sslCertificate = "/var/lib/nextcloud/nextcloud_fullchain.pem";
|
|
|
|
sslCertificateKey = "/var/lib/nextcloud/nextcloud_privkey.pem";
|
|
|
|
locations = {
|
|
|
|
"/".proxyWebsockets = true;
|
|
|
|
"~ ^\/nextcloud\/(?:index|remote|public|cron|core\/ajax\/update|status|ocs\/v[12]|updater\/.+|oc[ms]-provider\/.+|.+\/richdocumentscode\/proxy)\.php(?:$|\/)" =
|
|
|
|
{ };
|
2024-06-02 05:53:39 +03:00
|
|
|
};
|
|
|
|
};
|
2024-06-02 16:18:19 +03:00
|
|
|
};
|
|
|
|
}
|