1
0
mirror of https://github.com/kmein/niveum synced 2026-03-16 10:11:08 +01:00
Files
niveum/systems/makanek/nextcloud.nix

74 lines
1.7 KiB
Nix
Raw Normal View History

2022-03-10 21:52:12 +01:00
{
pkgs,
2022-05-22 11:47:59 +02:00
config,
2022-03-10 21:52:12 +01:00
lib,
...
}: let
passwordFile = path: toString (pkgs.writeText "password" (lib.strings.fileContents path));
2020-10-24 13:30:30 +02:00
inherit (import <niveum/lib>) localAddresses;
2022-03-10 21:52:12 +01:00
in {
2020-10-24 13:30:30 +02:00
services.nextcloud = {
enable = true;
2022-12-01 18:25:16 +01:00
package = pkgs.nextcloud25;
2020-10-31 20:51:25 +01:00
https = true;
2020-10-24 13:30:30 +02:00
autoUpdateApps = {
enable = true;
startAt = "05:00:00";
};
hostName = "cloud.xn--kiern-0qa.de";
2020-10-24 13:30:30 +02:00
config = {
2020-10-31 20:51:25 +01:00
overwriteProtocol = "https";
2020-10-24 13:30:30 +02:00
dbtype = "pgsql";
dbuser = "nextcloud";
dbhost = "/run/postgresql"; # nextcloud will add /.s.PGSQL.5432 by itself
dbname = "nextcloud";
dbpassFile = passwordFile <system-secrets/nextcloud/database>;
adminpassFile = passwordFile <system-secrets/nextcloud/admin>;
2020-10-24 13:30:30 +02:00
adminuser = "admin";
2020-10-31 20:51:25 +01:00
# extraTrustedDomains = [ "toum.r" ];
2022-12-01 13:37:46 +01:00
defaultPhoneRegion = "DE";
2020-10-24 13:30:30 +02:00
};
2022-12-01 13:37:46 +01:00
logLevel = 0;
# logType = "systemd";
# phpExtensions = all: [ all.php-systemd ];
# extraOptions = { };
2020-10-24 13:30:30 +02:00
};
2022-05-22 11:47:59 +02:00
niveum.passport.services = [
{
title = "Nextcloud";
link = "https://${config.services.nextcloud.hostName}";
description = "manages calendars, to-do lists, files, and recipes.";
}
];
2020-10-24 13:30:30 +02:00
services.postgresql = {
enable = true;
2022-03-10 21:52:12 +01:00
ensureDatabases = ["nextcloud"];
2020-10-24 13:30:30 +02:00
ensureUsers = [
{
name = "nextcloud";
ensurePermissions."DATABASE nextcloud" = "ALL PRIVILEGES";
}
];
};
services.nginx.virtualHosts."cloud.xn--kiern-0qa.de" = {
2020-10-31 20:51:25 +01:00
enableACME = true;
forceSSL = true;
2020-10-31 20:51:25 +01:00
};
2020-10-24 13:30:30 +02:00
# Ensure that postgres is running before running the setup
systemd.services."nextcloud-setup" = {
requires = ["postgresql.service"];
after = ["postgresql.service"];
};
}