blob: d92e6f9782a207e03946ed4783a8fef8a4aa2e03 [file] [log] [blame]
{ config, pkgs, lib, ... }: {
sops.secrets.clicks_nextcloud_db_password = {
mode = lib.mkForce "0440";
group = lib.mkForce "nextcloud";
};
users.users.nextcloud = {
isSystemUser = true;
createHome = true;
home = "/var/lib/nextcloud";
group = config.users.groups.nextcloud.name;
shell = pkgs.bashInteractive;
};
users.groups.nextcloud = { };
services.nextcloud.enable = true;
services.nextcloud.https = true;
services.nextcloud.config.adminpassFile =
config.sops.secrets.nextcloud_admin_password.path;
services.nextcloud.hostName = "nextcloud.clicks.codes";
services.nginx.virtualHosts.${config.services.nextcloud.hostName} = {
enableACME = true;
forceSSL = true;
};
services.nextcloud.package = pkgs.nextcloud27;
services.nextcloud.poolSettings = {
pm = "dynamic";
"pm.max_children" = "32";
"pm.max_requests" = "500";
"pm.max_spare_servers" = "4";
"pm.min_spare_servers" = "2";
"pm.start_servers" = "2";
"listen.owner" = config.users.users.nextcloud.name;
"listen.group" = config.users.users.nextcloud.group;
};
services.nextcloud.config = {
dbtype = "pgsql";
dbport = config.services.postgresql.port;
dbpassFile = config.sops.secrets.clicks_nextcloud_db_password.path;
dbname = "nextcloud";
dbhost = "localhost";
extraTrustedDomains = [ "cloud.clicks.codes" "docs.clicks.codes" ];
};
services.nextcloud.extraOptions = { social_login_auto_redirect = true; };
services.nextcloud.extraApps = {
sociallogin = pkgs.fetchNextcloudApp {
url =
"https://github.com/zorn-v/nextcloud-social-login/releases/download/v5.5.3/release.tar.gz";
sha256 = "sha256-96/wtK7t23fXVRcntDONjgb5bYtZuaNZzbvQCa5Gsj4=";
};
richdocumentscode = pkgs.fetchNextcloudApp {
url = "redacted";
sha256 = "sha256-XYtjBZCIQ6+PL3BNLSZfJTgLLpOyphzR5HOAwI7bWx0=";
};
richdocuments = pkgs.fetchNextcloudApp {
url =
"https://github.com/nextcloud-releases/richdocuments/releases/download/v8.2.0/richdocuments-v8.2.0.tar.gz";
sha256 = "sha256-PKw7FXSWvden2+6XjnUDOvbTF71slgeTF/ktS/l2+Dk=";
};
calendar = pkgs.fetchNextcloudApp {
url =
"https://github.com/nextcloud-releases/calendar/releases/download/v4.5.2/calendar-v4.5.2.tar.gz";
sha256 = "sha256-n7GjgAyw2SLoZTEfakmI3IllWUk6o1MF89Zt3WGhR6A=";
};
contacts = pkgs.fetchNextcloudApp {
url =
"https://github.com/nextcloud-releases/contacts/releases/download/v5.4.2/contacts-v5.4.2.tar.gz";
sha256 = "sha256-IkKHJ3MY/UPZqa4H86WGOEOypffMIHyJ9WvMqkq/4t8=";
};
tasks = pkgs.fetchNextcloudApp {
url =
"https://github.com/nextcloud/tasks/releases/download/v0.15.0/tasks.tar.gz";
sha256 = "sha256-zMMqtEWiXmhB1C2IeWk8hgP7eacaXLkT7Tgi4NK6PCg=";
};
appointments = pkgs.fetchNextcloudApp {
url =
"https://github.com/SergeyMosin/Appointments/raw/v1.15.4/build/artifacts/appstore/appointments.tar.gz";
sha256 = "sha256-2Oo7MJBPiBUBf4kti4or5nX+QiXT1Tkw3KowUGCj67E=";
};
};
sops.secrets.nextcloud_admin_password = {
mode = "0600";
owner = config.users.users.nextcloud.name;
group = config.users.users.nextcloud.group;
sopsFile = ../secrets/nextcloud.json;
format = "json";
};
}