2024-12-31 19:29:21 +04:00
|
|
|
{ config, lib, ... }:
|
|
|
|
with lib;
|
2024-12-31 19:31:15 +04:00
|
|
|
let cfg = config.void.server.services.forgejo;
|
2024-12-31 19:29:21 +04:00
|
|
|
in {
|
2025-01-04 19:54:51 +04:00
|
|
|
imports = [ ./runner.nix ];
|
2024-12-31 19:30:47 +04:00
|
|
|
options.void.server.services.forgejo = { enable = mkEnableOption false; };
|
2024-12-31 19:29:21 +04:00
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2025-01-01 15:03:30 +04:00
|
|
|
|
|
|
|
networking.firewall.allowedTCPPorts = [ 22 ];
|
|
|
|
|
2024-12-31 19:29:21 +04:00
|
|
|
services.forgejo = {
|
|
|
|
enable = true;
|
2025-01-01 14:44:26 +04:00
|
|
|
database.type = "postgres";
|
|
|
|
lfs.enable = true;
|
|
|
|
settings = {
|
|
|
|
DEFAULT = {
|
|
|
|
APP_NAME = "void-git";
|
|
|
|
APP_SLOGAN = "Now on NixOS!";
|
|
|
|
};
|
2024-12-31 22:44:37 +04:00
|
|
|
|
2025-01-01 14:44:26 +04:00
|
|
|
database = {
|
|
|
|
DB_TYPE = "postgres";
|
|
|
|
HOST = "/run/postgresql";
|
|
|
|
NAME = "forgejo";
|
|
|
|
USER = "forgejo";
|
|
|
|
PASSWD = "forgejo";
|
|
|
|
};
|
|
|
|
|
|
|
|
cache = {
|
|
|
|
ENABLED = true;
|
|
|
|
ADAPTER = "redis";
|
|
|
|
HOST = "redis://forgejo@localhost:6371";
|
|
|
|
};
|
|
|
|
"ui.meta" = {
|
|
|
|
AUTHOR = "sako!";
|
|
|
|
DESCRIPTION = "Something is happening...";
|
|
|
|
};
|
|
|
|
|
2025-01-01 14:45:19 +04:00
|
|
|
service.DISABLE_REGISTRATION = true;
|
2025-01-01 14:44:26 +04:00
|
|
|
|
|
|
|
server = {
|
|
|
|
ROOT_URL = "https://git.sako.lol";
|
|
|
|
DOMAIN = "git.sako.lol";
|
|
|
|
START_SSH_SERVER = true;
|
|
|
|
SSH_PORT = 22;
|
|
|
|
SSH_LISTEN_PORT = 22;
|
|
|
|
};
|
|
|
|
session = {
|
|
|
|
PROVIDER = "redis";
|
|
|
|
PROVIDER_CONFIG = "redis://:forgejo@localhost:6371";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
services.nginx.virtualHosts = {
|
|
|
|
"git.sako.lol" = {
|
|
|
|
forceSSL = true;
|
|
|
|
enableACME = true;
|
|
|
|
http3 = true;
|
|
|
|
locations."/" = { proxyPass = "http://localhost:3000"; };
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services.fail2ban.jails.forgejo = {
|
|
|
|
settings = {
|
|
|
|
filter = "forgejo";
|
2025-01-01 15:20:35 +04:00
|
|
|
action = "iptables-multiport";
|
2025-01-01 14:44:26 +04:00
|
|
|
mode = "aggressive";
|
|
|
|
maxretry = 5;
|
|
|
|
findtime = 3600;
|
|
|
|
bantime = 900;
|
|
|
|
};
|
|
|
|
};
|
2025-01-01 14:47:08 +04:00
|
|
|
security.acme.certs."git.sako.lol" = {
|
|
|
|
credentialsFile = "/srv/secrets/porkbun";
|
|
|
|
dnsProvider = "porkbun";
|
|
|
|
webroot = null;
|
|
|
|
};
|
2025-01-01 14:44:26 +04:00
|
|
|
environment.etc = {
|
|
|
|
"fail2ban/filter.d/forgejo.conf".text = ''
|
|
|
|
[Definition]
|
|
|
|
failregex = ^.*(Failed authentication attempt|invalid credentials|Attempted access of unknown user).* from <HOST>$
|
|
|
|
journalmatch = _SYSTEMD_UNIT=forgejo.service
|
|
|
|
'';
|
2024-12-31 19:29:21 +04:00
|
|
|
};
|
2025-01-02 14:38:42 +04:00
|
|
|
systemd.services.forgejo = {
|
|
|
|
after = [ "postgresql.service" "redis-forgejo.service" ];
|
|
|
|
serviceConfig = {
|
|
|
|
AmbientCapabilities = lib.mkForce [ "CAP_NET_BIND_SERVICE" ];
|
|
|
|
CapabilityBoundingSet = lib.mkForce [ "CAP_NET_BIND_SERVICE" ];
|
|
|
|
PrivateUsers = lib.mkForce false;
|
|
|
|
};
|
2025-01-01 14:50:47 +04:00
|
|
|
};
|
2024-12-31 19:29:21 +04:00
|
|
|
};
|
|
|
|
}
|