nextcloud-container/nextcloud-container.nix

141 lines
4.4 KiB
Nix
Raw Normal View History

2023-08-31 14:48:31 -07:00
{ config, lib, pkgs, ... }@toplevel:
with lib;
let
cfg = config.services.nextcloudContainer;
hostname = config.instance.hostname;
2023-08-31 15:16:38 -07:00
hostSecrets = config.fudo.secrets.host-secrets."${hostname}";
2023-08-31 14:48:31 -07:00
mkEnvFile = envVars:
let
envLines =
mapAttrsToList (var: val: ''${var}="${toString val}"'') envVars;
in pkgs.writeText "envFile" (concatStringsSep "\n" envLines);
postgresPasswdFile =
pkgs.lib.passwd.stablerandom-passwd-file "nextcloud-postgres-passwd"
config.instance.build-seed;
in {
options.services.nextcloudContainer = with types; {
enable = mkEnableOption "Enable Nextcloud running in an Arion container.";
state-directory = mkOption {
type = str;
description = "Directory at which to store server state data.";
};
2023-09-04 10:44:01 -07:00
hostname = mkOption {
type = str;
description = "Hostname at which the server is available.";
};
package = mkOption {
type = package;
description = "NextCloud package to use.";
};
extra-apps = mkOption {
type = attrsOf package;
2023-09-04 10:44:01 -07:00
description = "List of other apps to enable.";
default = { };
2023-08-31 14:48:31 -07:00
};
port = mkOption {
type = port;
description = "Intenal port on which to listen for requests.";
default = 6093;
};
timezone = mkOption {
type = str;
default = "America/Winnipeg";
};
};
config = mkIf cfg.enable {
fudo.secrets.host-secrets."${hostname}" = {
2023-09-04 10:44:01 -07:00
nextcloudAdminPasswd = {
source-file =
pkgs.lib.passwd.stablerandom-passwd-file "nextcloud-admin-passwd"
config.instance.build-seed;
target-file = "/run/nextcloud/admin.passwd";
2023-08-31 14:48:31 -07:00
};
};
2023-08-31 14:53:44 -07:00
virtualisation.arion.projects.nextcloud.settings = let
2023-08-31 14:48:31 -07:00
image = { ... }: {
project.name = "nextcloud";
services = {
2023-09-04 10:44:01 -07:00
nextcloud = { pkgs, lib, ... }: {
2023-08-31 14:48:31 -07:00
nixos = {
useSystemd = true;
configuration = {
boot.tmpOnTmpfs = true;
2023-08-31 15:24:24 -07:00
system.nssModules = lib.mkForce [ ];
environment.etc."nextcloud/admin.passwd" = {
source = "/run/nextcloud/admin.passwd";
mode = "0400";
user = "nextcloud";
};
systemd.tmpfiles.rules = [
"d /var/lib/nextcloud/data 0700 nextcloud root - -"
2023-09-06 11:51:17 -07:00
"d /var/lib/nextcloud/data/config 700 nextcloud root - -"
"d /var/lib/nextcloud/home 0755 nextcloud root - -"
];
2023-09-02 10:22:08 -07:00
services = {
nscd.enable = false;
2023-09-04 10:44:01 -07:00
postgresql.enable = true;
nextcloud = {
2023-09-02 10:22:08 -07:00
enable = true;
2023-09-04 10:44:01 -07:00
package = cfg.package;
hostName = cfg.hostname;
home = "/var/lib/nextcloud/home";
datadir = "/var/lib/nextcloud/data";
webfinger = true;
2023-09-04 10:44:01 -07:00
configureRedis = true;
extraAppsEnable = true;
extraApps = cfg.extra-apps;
autoUpdateApps.enable = true;
appstoreEnable = false;
2023-09-04 10:44:01 -07:00
enableBrokenCiphersForSSE = false;
enableImageMagick = true;
2023-09-04 10:44:01 -07:00
database.createLocally = true;
nginx.recommendedHttpHeaders = true;
maxUploadSize = "4G";
https = true;
2023-09-04 10:44:01 -07:00
config = {
dbtype = "pgsql";
adminpassFile = "/etc/nextcloud/admin.passwd";
overwriteProtocol = "https";
extraTrustedDomains = [ "nextcloud.fudo.org" ];
defaultPhoneRegion = "CA";
2023-08-31 14:48:31 -07:00
};
};
};
};
};
service = {
2023-09-04 10:44:01 -07:00
restart = "always";
volumes = [
2023-09-04 22:38:19 -07:00
"nextcloud-home:/var/lib/nextcloud/home"
"nextcloud-data:/var/lib/nextcloud/data"
2023-09-04 10:44:01 -07:00
"${hostSecrets.nextcloudAdminPasswd.target-file}:/run/nextcloud/admin.passwd:ro,Z"
2023-09-04 22:38:19 -07:00
"postgres-data:/var/lib/postgresql"
2023-09-04 10:44:01 -07:00
];
2023-09-04 18:21:44 -07:00
ports = [ "${toString cfg.port}:80" ];
2023-08-31 14:48:31 -07:00
};
};
};
docker-compose.volumes = {
2023-09-04 22:38:19 -07:00
postgres-data = { };
nextcloud-data = { };
nextcloud-home = { };
};
2023-08-31 14:48:31 -07:00
};
in { imports = [ image ]; };
};
}