puter/hosts/headless/abacus/forgejo.nix

89 lines
1.9 KiB
Nix
Raw Permalink Normal View History

2024-12-21 16:31:10 +00:00
{
config,
lib,
2025-04-08 21:27:00 +00:00
pkgs,
2024-12-21 16:31:10 +00:00
...
}: let
2025-04-02 15:35:50 +00:00
virtualHostName = "forgejo.helveticanonstandard.net";
2024-12-21 16:31:10 +00:00
in {
age.secrets = lib.mkSecrets {
forgejo-mailer = {
mode = "400";
owner = "forgejo";
};
forgejo-admin = {
mode = "400";
owner = "forgejo";
};
};
services.forgejo = {
enable = true;
database.type = "postgres";
lfs.enable = true;
settings = {
server = {
DOMAIN = virtualHostName;
ROOT_URL = "https://${virtualHostName}/";
HTTP_ADDR = "127.0.0.1";
HTTP_PORT = 8060;
};
service = {
DISABLE_REGISTRATION = true;
ENABLE_NOTIFY_MAIL = true;
};
2024-12-21 22:15:11 +00:00
# TODO: Enable
2024-12-21 16:31:10 +00:00
federation = {
2024-12-21 22:15:11 +00:00
ENABLED = false;
SHARE_USER_STATISTICS = false;
2024-12-21 16:31:10 +00:00
};
mailer = {
ENABLED = true;
SMTP_ADDR = "smtp.fastmail.com";
2025-03-23 21:48:46 +00:00
FROM = "tea@wrz.one";
USER = "lukas@wrz.one";
2024-12-21 16:31:10 +00:00
};
};
2025-04-02 15:35:50 +00:00
2024-12-21 16:31:10 +00:00
secrets.mailer.PASSWD = config.age.secrets.forgejo-mailer.path;
};
2025-04-08 21:27:00 +00:00
systemd.services.forgejo.preStart = lib.getExe pkgs.writeShellApplication {
name = "forgejo-init-admin";
runtimeInputs = [
config.services.forgejo.package
];
text = let
passwordFile = config.age.secrets.forgejo-admin.path;
in ''
admins=$(admin user list --admin)
admins=$((admins - 1))
if ((admins < 1)); then
gitea admin user create \
--admin \
--email helvetica@helveticanonstandard.net \
--username helvetica \
--password "$(cat -- ${passwordFile})"
fi
'';
};
2024-12-21 16:31:10 +00:00
services.nginx.virtualHosts.${virtualHostName} = {
enableACME = true;
forceSSL = true;
extraConfig = ''
client_max_body_size 512M;
'';
locations."/".proxyPass = let
2025-03-23 21:48:46 +00:00
host = config.services.forgejo.settings.server.HTTP_ADDR;
port = builtins.toString config.services.forgejo.settings.server.HTTP_PORT;
in "http://${host}:${port}";
2024-12-21 16:31:10 +00:00
};
}