{ config, pkgs, self, lib, ... }: { services.nginx = { enable = true; recommendedTlsSettings = true; recommendedOptimisation = true; recommendedGzipSettings = true; recommendedProxySettings = true; virtualHosts = { "missing.ninja" = { serverAliases = [ "joens.zone" "joens.website" "joens.site" "joens.online" "joens.link" "joens.international" "joens.family" "joens.digital" "joens.blog" "net0loggy.net" #"clan-war.net" "net0loggy.de" "dtg-c.de" ]; enableACME = true; forceSSL = true; }; "webmail.missing.ninja" = { serverAliases = [ "joens.email" ]; }; "pad.missing.ninja" = { forceSSL = true; enableACME = true; locations."/".proxyPass = "http://localhost:3333"; locations."/socket.io/" = { proxyPass = "http://localhost:3333"; proxyWebsockets = true; extraConfig = "proxy_ssl_server_name on;"; }; }; "test.missing.ninja" = { forceSSL = true; enableACME = true; }; "search.missing.ninja" = { forceSSL = true; enableACME = true; locations."/".proxyPass = "http://localhost:8080"; }; "cache.missing.ninja" = { forceSSL = true; enableACME = true; locations."/".proxyPass = "http://${config.services.nix-serve.bindAddress}:${toString config.services.nix-serve.port}"; }; "nix.missing.ninja" = { forceSSL = true; enableACME = true; locations."/".root = self.inputs.nuschtos.packages.${pkgs.stdenv.system}.mkMultiSearch { scopes = [ { modules = [ self.inputs.disko.nixosModules.default ]; name = "disko"; specialArgs.modulesPath = pkgs.path + "/nixos/modules"; urlPrefix = "https://github.com/nix-community/disko/blob/master/"; } { modules = lib.attrValues self.inputs.nixos-hardware.nixosModules; name = "nixos-hardware"; specialArgs = { modulesPath = pkgs.path + "/nixos/modules"; inherit pkgs; }; urlPrefix = "https://github.com/NixOS/nixos-hardware/blob/master/"; } { modules = [ self.inputs.snm.nixosModules.default { mailserver = { fqdn = "mx.example.com"; domains = [ "example.com" ]; dmarcReporting = { organizationName = "Example Corp"; domain = "example.com"; }; }; } ]; name = "simple-nixos-mailserver"; urlPrefix = "https://gitlab.com/simple-nixos-mailserver/nixos-mailserver/-/blob/master/"; } { optionsJSON = (import "${self.inputs.nixpkgs}/nixos/release.nix" { }).options + /share/doc/nixos/options.json; name = "NixOS"; urlPrefix = "https://github.com/NixOS/nixpkgs/tree/master/"; } ]; }; }; "hetzner" = { forceSSL = false; enableACME = false; locations = { "/" = { proxyPass = "http://127.0.0.1:1242"; proxyWebsockets = true; extraConfig = '' proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Host $host:$server_port; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Forwarded-Server $host; proxy_set_header Connection "Upgrade"; proxy_set_header Upgrade $http_upgrade; ''; }; "/Api/NLog" = { proxyPass = "http://127.0.0.1:1242"; extraConfig = '' proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Host $host:$server_port; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Forwarded-Server $host; ''; }; }; }; }; }; services.hedgedoc = { enable = true; settings = { db = { dialect = "sqlite"; torage = "/var/lib/hedgedoc/db.hedgedoc.sqlite"; }; domain = "pad.missing.ninja"; port = 3333; useSSL = false; protocolUseSSL = true; }; }; services.nix-serve = { enable = true; secretKeyFile = "/var/cache-priv-key.pem"; }; services.wordpress.webserver = "nginx"; services.phpfpm.phpOptions = '' post_max_size = "64M" upload_max_filesize = "64M" max_execution_time = 300 max_input_time = 300 ''; services.searx = { enable = true; runInUwsgi = false; settings = { server.secret_key = "NotASecret"; }; uwsgiConfig = { socket = "/run/searx/searx.sock"; chmod-socket = "660"; }; }; }