infrastructure/machines/compute01/nextcloud.nix

83 lines
1.7 KiB
Nix
Raw Normal View History

{ config, pkgs, ... }:
2023-09-11 11:17:30 +02:00
let host = "cloud.dgnum.eu";
2023-09-11 11:17:30 +02:00
in {
services.nextcloud = {
enable = true;
hostName = host;
package = pkgs.nextcloud27;
https = true;
config = {
overwriteProtocol = "https";
dbtype = "pgsql";
adminpassFile = config.age.secrets."nextcloud-adminpass_file".path;
adminuser = "thubrecht";
defaultPhoneRegion = "FR";
trustedProxies = [ "::1" ];
objectstore.s3 = {
enable = true;
hostname = "s3.dgnum.eu";
region = "garage";
usePathStyle = true;
port = 443;
bucket = "nextcloud-dgnum";
key = "GKda5367c73ca607c349d83c35";
autocreate = false;
secretFile = config.age.secrets."nextcloud-s3_secret_file".path;
};
2023-09-11 11:17:30 +02:00
};
poolSettings = {
pm = "dynamic";
"pm.max_children" = 64;
"pm.max_requests" = "500";
"pm.max_spare_servers" = "8";
"pm.min_spare_servers" = "4";
"pm.start_servers" = "6";
};
2023-09-11 11:17:30 +02:00
notify_push = { enable = true; };
database.createLocally = true;
configureRedis = true;
autoUpdateApps.enable = true;
enableBrokenCiphersForSSE = false;
extraOptions = {
overwritehost = host;
"overwrite.cli.url" = "https://${host}";
updatechecker = false;
allow_local_remote_servers = true;
"opcache.interned_strings_buffer" = 32;
2023-09-11 11:17:30 +02:00
};
};
services.nginx.virtualHosts.${host} = {
enableACME = true;
forceSSL = true;
};
environment.systemPackages = with pkgs; [
ffmpeg_6-headless
jpegoptim
exif
perl
perlPackages.ImageExifTool
];
dgn-secrets.matches."^nextcloud-.*$" = { owner = "nextcloud"; };
2023-09-11 11:17:30 +02:00
}