blob: 9605bfc9dfe52d28638a25127e1dacc0d9ddff97 [file] [log] [blame]
Skyler Grey09c5cda2023-10-09 07:10:10 +00001{config, pkgs, lib, ...}: {
2 sops.secrets.clicks_nextcloud_db_password = {
3 mode = lib.mkForce "0440";
4 group = lib.mkForce "nextcloud";
5 };
6
7 users.users.nextcloud = {
8 isSystemUser = true;
9 createHome = true;
10 home = "/var/lib/nextcloud";
11 group = config.users.groups.nextcloud.name;
12 shell = pkgs.bashInteractive;
13 };
14 users.groups.nextcloud = {};
15
16
17 services.nextcloud.enable = true;
18 services.nextcloud.config.adminpassFile = config.sops.secrets.nextcloud_admin_password.path;
19 services.nextcloud.hostName = "cloud.clicks.codes";
20 services.nextcloud.package = pkgs.nextcloud27;
21 services.nextcloud.poolSettings = {
22 pm = "dynamic";
23 "pm.max_children" = "32";
24 "pm.max_requests" = "500";
25 "pm.max_spare_servers" = "4";
26 "pm.min_spare_servers" = "2";
27 "pm.start_servers" = "2";
28 "listen.owner" = config.users.users.nextcloud.name;
29 "listen.group" = config.users.users.nextcloud.group;
30 };
31
32 services.nextcloud.config = {
33 dbtype = "pgsql";
34 dbport = config.services.postgresql.port;
35 dbpassFile = config.sops.secrets.clicks_nextcloud_db_password.path;
36 dbname = "nextcloud";
37 dbhost = "localhost";
38 extraTrustedDomains = [ "nextcloud.clicks.codes" "docs.clicks.codes" ];
39 };
40
41 sops.secrets.nextcloud_admin_password = {
42 mode = "0600";
43 owner = config.users.users.nextcloud.name;
44 group = config.users.users.nextcloud.group;
45 sopsFile = ../secrets/nextcloud.json;
46 format = "json";
47 };
48}