always gave an error and i dunno how solve it, just discovered the wiki is outdated and collabora is actually packaged so rip bozo
117 lines
3 KiB
Nix
Executable file
117 lines
3 KiB
Nix
Executable file
{ config, pkgs, ... }:
|
|
|
|
{
|
|
sops.secrets."nextcloud/adminpass" = {};
|
|
|
|
services.caddy.virtualHosts."nextcloud.wo2wz.fyi".extraConfig =
|
|
assert config.services.caddy.enable;
|
|
''
|
|
import default-settings
|
|
|
|
root ${config.services.nginx.virtualHosts."localhost:8002".root}
|
|
file_server
|
|
|
|
php_fastcgi unix/${config.services.phpfpm.pools.nextcloud.socket}
|
|
|
|
redir /.well-known/carddav /remote.php/dav 301
|
|
redir /.well-known/caldav /remote.php/dav 301
|
|
redir /.well-known/webfinger /index.php/webfinger 301
|
|
redir /.well-known/nodeinfo /index.php/nodeinfo 301
|
|
redir /.well-known/* /index.php{uri} 301
|
|
redir /remote/* /remote.php{uri} 301
|
|
|
|
@forbidden {
|
|
path /build/* /tests/* /config/* /lib/* /3rdparty/* /templates/* /data/*
|
|
path /.* /autotest* /occ* /issue* /indie* /db_* /console*
|
|
not path /.well-known/*
|
|
}
|
|
|
|
respond @forbidden 403
|
|
|
|
# make .mjs javascript work for the functionality of some buttons/apps
|
|
@mjs path *.mjs
|
|
header @mjs Content-Type application/javascript
|
|
'';
|
|
|
|
services.nginx.enable = false; # disable to use caddy instead
|
|
users.users.nginx = {
|
|
group = "nginx";
|
|
isSystemUser = true;
|
|
};
|
|
users.groups.nginx = {};
|
|
|
|
users.users.caddy.extraGroups = [ "nextcloud" ];
|
|
services.phpfpm.pools.nextcloud.settings = {
|
|
"listen.owner" = "caddy";
|
|
"listen.group" = "caddy";
|
|
};
|
|
|
|
services = {
|
|
nextcloud = {
|
|
enable = true;
|
|
package = pkgs.nextcloud32;
|
|
hostName = "localhost:8002";
|
|
configureRedis = true;
|
|
config = {
|
|
adminuser = "wo2w";
|
|
adminpassFile = config.sops.secrets."nextcloud/adminpass".path;
|
|
dbtype = "sqlite";
|
|
};
|
|
settings = {
|
|
trusted_domains = [ "nextcloud.wo2wz.fyi" ];
|
|
trusted_proxies = [ "127.0.0.1" "::1" ];
|
|
|
|
default_phone_region = "US";
|
|
maintenance_window_start = 2;
|
|
};
|
|
|
|
poolSettings = {
|
|
pm = "dynamic";
|
|
"pm.max_children" = "52";
|
|
"pm.start_servers" = "16";
|
|
"pm.min_spare_servers" = "8";
|
|
"pm.max_spare_servers" = "16";
|
|
};
|
|
|
|
extraApps = {
|
|
inherit (config.services.nextcloud.package.packages.apps)
|
|
calendar
|
|
deck
|
|
richdocuments
|
|
tasks
|
|
twofactor_webauthn
|
|
user_oidc;
|
|
};
|
|
|
|
maxUploadSize = "200G";
|
|
};
|
|
};
|
|
|
|
services.caddy.virtualHosts."collabora.wo2wz.fyi".extraConfig =
|
|
assert config.services.caddy.enable;
|
|
''
|
|
import default-settings
|
|
import cloudflare-tls
|
|
|
|
reverse_proxy localhost:${toString config.services.collabora-online.port}
|
|
'';
|
|
|
|
services.collabora-online = {
|
|
enable = true;
|
|
port = 8003;
|
|
settings = {
|
|
server_name = "collabora.wo2wz.fyi";
|
|
net = {
|
|
listen = "loopback";
|
|
post_allow.host = [ ''127\.0\.0\.1'' "::1" ];
|
|
};
|
|
ssl = {
|
|
enable = false;
|
|
termination = true;
|
|
};
|
|
|
|
allowed_languages = "en_US";
|
|
remote_font_config.url = "https://nextcloud.wo2wz.fyi/index.php/apps/richdocuments/settings/fonts.json";
|
|
};
|
|
};
|
|
}
|