{ lib, config, pkgs, ... }: let listenIPs = (import ../../utils/getInternalIP.nix config).listenIPs; listenStatements = lib.concatStringsSep "\n" (builtins.map (ip: "listen ${ip}:443 http3;") listenIPs) + '' add_header Alt-Svc 'h3=":443"'; ''; clean-cache = pkgs.callPackage ../../packages/clean-s3-cache.nix { }; in { imports = [ ./postgres.nix ../../modules/hydra.nix ]; services.hydra = { enable = true; hydraURL = "https://hydra.chir.rs/"; notificationSender = "hydra@chir.rs"; useSubstitutes = true; extraConfig = '' darkkirb = #gitea_token# DarkKirb = Bearer #github_token# jobs = .* store_uri = s3://cache-chir-rs?scheme=https&endpoint=s3.us-west-000.backblazeb2.com&secret-key=${config.sops.secrets."services/hydra/cache-key".path}&multipart-upload=true&compression=zstd&compression-level=15 ''; giteaTokenFile = "/run/secrets/services/hydra/gitea_token"; githubTokenFile = "/run/secrets/services/hydra/github_token"; }; services.postgresql.ensureDatabases = [ "hydra" ]; services.postgresql.ensureUsers = [ { name = "hydra"; ensurePermissions = { "DATABASE hydra" = "ALL PRIVILEGES"; }; } ]; nix.settings.allowed-uris = [ "https://github.com/" "https://git.chir.rs/" "https://darkkirb.de/" "https://git.neo-layout.org/" "https://static.darkkirb.de/" ]; sops.secrets."services/hydra/gitea_token" = { }; sops.secrets."services/hydra/github_token" = { }; sops.secrets."services/hydra/cache-key" = { owner = "hydra-queue-runner"; }; services.nginx.virtualHosts."hydra.chir.rs" = { listenAddresses = listenIPs; sslCertificate = "/var/lib/acme/chir.rs/cert.pem"; sslCertificateKey = "/var/lib/acme/chir.rs/key.pem"; locations."/" = { proxyPass = "http://127.0.0.1:3000"; proxyWebsockets = true; }; extraConfig = listenStatements; }; services.nginx.virtualHosts."hydra.int.chir.rs" = { listenAddresses = listenIPs; sslCertificate = "/var/lib/acme/int.chir.rs/cert.pem"; sslCertificateKey = "/var/lib/acme/int.chir.rs/key.pem"; locations."/" = { proxyPass = "http://127.0.0.1:3000"; proxyWebsockets = true; }; extraConfig = listenStatements; }; systemd.services.clean-s3-cache = { enable = true; description = "Clean up S3 cache"; serviceConfig = { ExecStart = "${clean-cache}/bin/clean-s3-cache.py"; }; }; systemd.timers.clean-s3-cache = { enable = true; description = "Clean up S3 cache"; requires = [ "clean-s3-cache.service" ]; wantedBy = [ "multi-user.target" ]; timerConfig = { OnBootSec = 300; OnUnitActiveSec = 604800; }; }; sops.secrets."services/hydra/aws_credentials" = { owner = "hydra-queue-runner"; path = "/var/lib/hydra/queue-runner/.aws/credentials"; restartUnits = [ "hydra-queue-runner.service" ]; }; }