{config, ...}: let cfg = config.services.forgejo; srv = cfg.settings.server; in { services.nginx = { virtualHosts.${cfg.settings.server.DOMAIN} = { forceSSL = true; enableACME = true; extraConfig = '' client_max_body_size 512M; ''; locations."/".proxyPass = "http://localhost:${toString srv.HTTP_PORT}"; }; }; services.forgejo = { enable = true; database.type = "postgres"; # Enable support for Git Large File Storage lfs.enable = true; settings = { server = { DOMAIN = "192.168.1.252"; # You need to specify this to remove the port from URLs in the web UI. ROOT_URL = "http://${srv.DOMAIN}:${toString srv.HTTP_PORT}/"; HTTP_PORT = 3000; }; # You can temporarily allow registration to create an admin user. service.DISABLE_REGISTRATION = false; # Add support for actions, based on act: https://github.com/nektos/act actions = { ENABLED = true; DEFAULT_ACTIONS_URL = "github"; }; # Sending emails is completely optional # You can send a test email from the web UI at: # Profile Picture > Site Administration > Configuration > Mailer Configuration mailer = { ENABLED = true; SMTP_ADDR = "mail.example.com"; FROM = "noreply@${srv.DOMAIN}"; USER = "noreply@${srv.DOMAIN}"; PASSWD = "password"; # Locally hosted instance a.k.a. NO ONE CARES. }; default = { APP_NAME = "Amadajo"; APP_SLOGAN = "Fun little instance I just have on my config..."; }; }; }; systemd.user.tmpfiles.users.forgejo.rules = [ "L+ %h/data/home/.ssh - - - - %h/.ssh" ]; }