nixos-config/services/forgejo/default.nix

76 lines
1.9 KiB
Nix
Raw Normal View History

{
config,
pkgs,
lib,
...
}:
2025-01-17 13:34:14 +01:00
let
domain = "git.felschr.com";
sshPort = 2222;
cfg = config.services.forgejo;
2025-01-17 13:34:14 +01:00
in
{
2025-01-17 14:20:00 +01:00
imports = [ ./runner.nix ];
age.secrets.forgejo-admin-password = {
file = ../../secrets/forgejo/admin-password.age;
owner = cfg.user;
inherit (cfg) group;
};
2025-01-17 13:34:14 +01:00
services.forgejo = {
enable = true;
database.type = "postgres";
lfs.enable = true;
settings = {
server = {
DOMAIN = domain;
PROTOCOL = "http+unix";
ROOT_URL = "https://${domain}/";
START_SSH_SERVER = true;
SSH_PORT = sshPort;
SSH_LISTEN_PORT = sshPort;
};
service.DISABLE_REGISTRATION = true;
ui = {
DEFAULT_THEME = "forgejo-dark";
};
2025-01-17 14:20:00 +01:00
actions = {
ENABLED = true;
DEFAULT_ACTIONS_URL = "https://${domain}";
};
2025-01-17 13:34:14 +01:00
mailer = {
ENABLED = true;
PROTOCOL = "sendmail";
FROM = config.programs.msmtp.accounts.default.from;
SENDMAIL_PATH = "${pkgs.system-sendmail}/bin/sendmail";
SENDMAIL_ARGS = "--";
};
};
};
networking.firewall.allowedTCPPorts = [ sshPort ];
services.nginx.virtualHosts.${domain} = {
enableACME = true;
forceSSL = true;
extraConfig = ''
client_max_body_size 512M;
'';
locations."/".proxyPass = "http://unix:${cfg.settings.server.HTTP_ADDR}";
};
systemd.services.forgejo.preStart =
let
adminCmd = "${lib.getExe cfg.package} admin user";
passwordFile = config.age.secrets.forgejo-admin-password.path;
user = "felschr";
in
''
${adminCmd} create --admin --email "root@localhost" --username ${user} --password "$(tr -d '\n' < ${passwordFile})" || true
## uncomment this line to change an admin user which was already created
# ${adminCmd} change-password --username ${user} --password "$(tr -d '\n' < ${passwordFile})" || true
'';
2025-01-17 13:34:14 +01:00
}