2022-03-29 11:25:34 +02:00
|
|
|
{ ... }:
|
2022-01-15 13:22:32 +01:00
|
|
|
let
|
|
|
|
|
port = "8000";
|
2022-09-24 19:19:00 +02:00
|
|
|
db = "ihatemoney";
|
2022-10-30 15:51:48 +01:00
|
|
|
domain = "geld.mc-fucker.cool";
|
2022-01-15 13:22:32 +01:00
|
|
|
in
|
|
|
|
|
{
|
2022-03-29 11:25:34 +02:00
|
|
|
services.nginx.enable = true;
|
2022-10-30 15:51:48 +01:00
|
|
|
services.nginx.virtualHosts."${domain}" = {
|
2022-01-15 13:22:32 +01:00
|
|
|
forceSSL = true;
|
|
|
|
|
enableACME = true;
|
|
|
|
|
locations."/" = {
|
|
|
|
|
proxyPass = "http://localhost:${port}";
|
|
|
|
|
};
|
2022-10-30 15:51:48 +01:00
|
|
|
extraConfig = ''
|
|
|
|
|
access_log /var/log/nginx/${domain}_access.log;
|
|
|
|
|
error_log /var/log/nginx/${domain}_error.log;
|
|
|
|
|
'';
|
2022-01-15 13:22:32 +01:00
|
|
|
};
|
2022-03-29 11:25:34 +02:00
|
|
|
|
|
|
|
|
security.acme = {
|
|
|
|
|
acceptTerms = true;
|
|
|
|
|
defaults.email = "dev@mc-fucker.cool";
|
|
|
|
|
};
|
|
|
|
|
|
2022-09-24 19:19:00 +02:00
|
|
|
virtualisation.oci-containers.containers.ihatemoney = {
|
2022-10-30 15:51:48 +01:00
|
|
|
image = "e867068a7f61";
|
2022-09-24 19:19:00 +02:00
|
|
|
environment = {
|
|
|
|
|
ACTIVATE_ADMIN_DASHBOARD = "True";
|
|
|
|
|
ACTIVATE_DEMO_PROJECT = "False";
|
|
|
|
|
ALLOW_PUBLIC_PROJECT_CREATION = "False";
|
|
|
|
|
MAIL_DEFAULT_SENDER = "Budget manager <ihatemoney@mc-fucker.cool>";
|
|
|
|
|
MAIL_SERVER = "mc1.mc-fucker.vpn.mc-fucker.cool";
|
|
|
|
|
MAIL_USE_TLS = "True";
|
|
|
|
|
DEBUG = "False";
|
|
|
|
|
};
|
|
|
|
|
ports = [ "${port}:8000" ];
|
|
|
|
|
environmentFiles = [ /etc/nixos/keys/ihatemoney-env ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
services.postgresql = {
|
|
|
|
|
ensureDatabases = [ db ];
|
|
|
|
|
ensureUsers = [
|
|
|
|
|
{
|
|
|
|
|
name = db;
|
|
|
|
|
ensurePermissions = {
|
|
|
|
|
"DATABASE ${db}" = "ALL PRIVILEGES";
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
authentication = "host ${db} ${db} 10.88.0.0/16 md5";
|
|
|
|
|
};
|
|
|
|
|
|
2022-03-29 11:25:34 +02:00
|
|
|
networking.firewall.allowedTCPPorts = [ 80 443 ];
|
|
|
|
|
|
2022-07-19 12:26:25 +02:00
|
|
|
services.postgresqlBackup.databases = [ "ihatemoney" ];
|
|
|
|
|
|
2022-01-15 13:22:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# vim: set et ts=2 sw=2 ai:
|