Created
July 4, 2020 02:56
-
-
Save jneplokh/62c4d8e79421a9bf8174c8c275163734 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{config, pkgs, ...}: | |
{ | |
# Enable Nginx | |
services.nginx = { | |
enable = true; | |
# Use recommended settings | |
recommendedGzipSettings = true; | |
recommendedOptimisation = true; | |
recommendedProxySettings = true; | |
recommendedTlsSettings = true; | |
# Only allow PFS-enabled ciphers with AES256 | |
sslCiphers = "AES256+EECDH:AES256+EDH:!aNULL"; | |
# Setup Nextcloud virtual host to listen on ports | |
virtualHosts = { | |
"nextcloud.jnep.xyz" = { | |
## Force HTTP redirect to HTTPS | |
forceSSL = true; | |
## LetsEncrypt | |
enableACME = true; | |
}; | |
}; | |
}; | |
# Actual Nextcloud Config | |
services.nextcloud = { | |
enable = true; | |
hostName = "nextcloud.example.com"; | |
# Enable built-in virtual host management | |
# Takes care of somewhat complicated setup | |
# See here: https://github.com/NixOS/nixpkgs/blob/master/nixos/modules/services/web-apps/nextcloud.nix#L529 | |
nginx.enable = true; | |
# Use HTTPS for links | |
https = true; | |
# Auto-update Nextcloud Apps | |
autoUpdateApps.enable = true; | |
# Set what time makes sense for you | |
autoUpdateApps.startAt = "05:00:00"; | |
config = { | |
# Further forces Nextcloud to use HTTPS | |
overwriteProtocol = "https"; | |
# Nextcloud PostegreSQL database configuration, recommended over using SQLite | |
dbtype = "pgsql"; | |
dbuser = "nextcloud"; | |
dbhost = "/run/postgresql"; # nextcloud will add /.s.PGSQL.5432 by itself | |
dbname = "nextcloud"; | |
dbpassFile = "/var/nextcloud-db-pass"; | |
adminpassFile = "/var/nextcloud-admin-pass"; | |
adminuser = "admin"; | |
}; | |
}; | |
# Enable PostgreSQL | |
services.postgresql = { | |
enable = true; | |
# Ensure the database, user, and permissions always exist | |
ensureDatabases = [ "nextcloud" ]; | |
ensureUsers = [ | |
{ name = "nextcloud"; | |
ensurePermissions."DATABASE nextcloud" = "ALL PRIVILEGES"; | |
} | |
]; | |
}; | |
# Ensure that postgres is running before running the setup | |
systemd.services."nextcloud-setup" = { | |
requires = ["postgresql.service"]; | |
after = ["postgresql.service"]; | |
}; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment