2023-06-22 21:22:34 -07:00
|
|
|
{ config, pkgs, lib, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.shb.nextcloud;
|
2023-07-15 15:09:54 -07:00
|
|
|
|
|
|
|
fqdn = "${cfg.subdomain}.${cfg.domain}";
|
2023-06-22 21:22:34 -07:00
|
|
|
in
|
|
|
|
{
|
|
|
|
options.shb.nextcloud = {
|
|
|
|
enable = lib.mkEnableOption "selfhostblocks.nextcloud-server";
|
|
|
|
|
2023-07-15 15:09:54 -07:00
|
|
|
subdomain = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
description = "Subdomain under which home-assistant will be served.";
|
|
|
|
example = "nextcloud";
|
|
|
|
};
|
|
|
|
|
|
|
|
domain = lib.mkOption {
|
|
|
|
description = lib.mdDoc "Domain to serve sites under.";
|
2023-06-22 21:22:34 -07:00
|
|
|
type = lib.types.str;
|
2023-07-15 15:09:54 -07:00
|
|
|
example = "domain.com";
|
2023-06-22 21:22:34 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
sopsFile = lib.mkOption {
|
|
|
|
type = lib.types.path;
|
|
|
|
description = "Sops file location";
|
|
|
|
example = "secrets/nextcloud.yaml";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
users.users = {
|
|
|
|
nextcloud = {
|
|
|
|
name = "nextcloud";
|
|
|
|
group = "nextcloud";
|
|
|
|
isSystemUser = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
users.groups = {
|
|
|
|
nextcloud = {
|
|
|
|
members = [ "backup" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services.nextcloud = {
|
|
|
|
enable = true;
|
|
|
|
package = pkgs.nextcloud26;
|
|
|
|
|
|
|
|
# Enable php-fpm and nginx which will be behind the shb haproxy instance.
|
2023-07-15 15:09:54 -07:00
|
|
|
hostName = fqdn;
|
2023-06-22 21:22:34 -07:00
|
|
|
|
|
|
|
config = {
|
|
|
|
dbtype = "pgsql";
|
|
|
|
adminuser = "root";
|
|
|
|
adminpassFile = "/run/secrets/nextcloud/adminpass";
|
|
|
|
# Not using dbpassFile as we're using socket authentication.
|
|
|
|
defaultPhoneRegion = "US";
|
|
|
|
trustedProxies = [ "127.0.0.1" ];
|
|
|
|
};
|
|
|
|
database.createLocally = true;
|
|
|
|
|
|
|
|
# Enable caching using redis https://nixos.wiki/wiki/Nextcloud#Caching.
|
|
|
|
configureRedis = true;
|
|
|
|
caching.apcu = false;
|
|
|
|
# https://docs.nextcloud.com/server/26/admin_manual/configuration_server/caching_configuration.html
|
|
|
|
caching.redis = true;
|
|
|
|
|
|
|
|
# Adds appropriate nginx rewrite rules.
|
|
|
|
webfinger = true;
|
|
|
|
|
|
|
|
extraOptions = {
|
2023-07-15 15:09:54 -07:00
|
|
|
"overwrite.cli.url" = "https://" + fqdn;
|
|
|
|
"overwritehost" = fqdn;
|
2023-06-22 21:22:34 -07:00
|
|
|
"overwriteprotocol" = "https";
|
|
|
|
"overwritecondaddr" = "^127\\.0\\.0\\.1$";
|
|
|
|
};
|
|
|
|
|
|
|
|
phpOptions = {
|
|
|
|
# The OPcache interned strings buffer is nearly full with 8, bump to 16.
|
2023-07-29 22:13:09 -07:00
|
|
|
catch_workers_output = "yes";
|
|
|
|
display_errors = "stderr";
|
|
|
|
error_reporting = "E_ALL & ~E_DEPRECATED & ~E_STRICT";
|
|
|
|
expose_php = "Off";
|
|
|
|
"opcache.enable_cli" = "1";
|
|
|
|
"opcache.fast_shutdown" = "1";
|
2023-06-22 21:22:34 -07:00
|
|
|
"opcache.interned_strings_buffer" = "16";
|
2023-07-29 22:13:09 -07:00
|
|
|
"opcache.max_accelerated_files" = "10000";
|
|
|
|
"opcache.memory_consumption" = "128";
|
|
|
|
"opcache.revalidate_freq" = "1";
|
|
|
|
"openssl.cafile" = "/etc/ssl/certs/ca-certificates.crt";
|
|
|
|
short_open_tag = "Off";
|
|
|
|
|
|
|
|
# Needed to avoid corruption per https://docs.nextcloud.com/server/21/admin_manual/configuration_server/caching_configuration.html#id2
|
|
|
|
"redis.session.locking_enabled" = "1";
|
|
|
|
"redis.session.lock_retries" = "-1";
|
|
|
|
"redis.session.lock_wait_time" = "10000";
|
2023-06-22 21:22:34 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# Secret needed for services.nextcloud.config.adminpassFile.
|
|
|
|
sops.secrets."nextcloud/adminpass" = {
|
|
|
|
inherit (cfg) sopsFile;
|
|
|
|
mode = "0440";
|
|
|
|
owner = "nextcloud";
|
|
|
|
group = "nextcloud";
|
|
|
|
};
|
|
|
|
|
2023-07-15 15:09:54 -07:00
|
|
|
services.nginx.virtualHosts.${fqdn} = {
|
|
|
|
# listen = [ { addr = "0.0.0.0"; port = 443; } ];
|
|
|
|
sslCertificate = "/var/lib/acme/${cfg.domain}/cert.pem";
|
|
|
|
sslCertificateKey = "/var/lib/acme/${cfg.domain}/key.pem";
|
|
|
|
addSSL = true;
|
2023-06-22 21:22:34 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
systemd.services.phpfpm-nextcloud.serviceConfig = {
|
|
|
|
# Setup permissions needed for backups, as the backup user is member of the jellyfin group.
|
|
|
|
UMask = lib.mkForce "0027";
|
|
|
|
};
|
|
|
|
|
|
|
|
# Sets up backup for Nextcloud.
|
|
|
|
shb.backup.instances.nextcloud = {
|
|
|
|
sourceDirectories = [
|
|
|
|
config.services.nextcloud.datadir
|
|
|
|
];
|
2023-07-22 09:54:19 -07:00
|
|
|
excludePatterns = [".rnd"];
|
2023-06-22 21:22:34 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|