{ config, ... }: { imports = [ ./module.nix ]; services.nextcloud-claude-bot = { enable = true; nextcloudUrl = "https://nc.hoyer.xyz"; botSecretFile = config.sops.secrets."nextcloud-claude-bot/secret".path; allowedUsers = []; # Allow all registered users # Optional extra instructions (base prompt is hardcoded in bot.py) # systemPrompt = "Additional custom instructions here"; }; sops.secrets."nextcloud-claude-bot/secret" = { sopsFile = ../../../../.secrets/hetzner/nextcloud-claude-bot.yaml; restartUnits = [ "nextcloud-claude-bot.service" ]; owner = "claude-bot"; }; # Nginx location for Nextcloud to send webhooks to the bot services.nginx.virtualHosts."nc.hoyer.xyz".locations."/_claude-bot/" = { proxyPass = "http://127.0.0.1:8085/"; extraConfig = '' proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; # Only allow from localhost (Nextcloud on same server) allow 127.0.0.1; deny all; ''; }; }