50 lines
1.3 KiB
Nix
50 lines
1.3 KiB
Nix
{ options, config, lib, pkgs, ... }:
|
|
with lib;
|
|
with lib.custom;
|
|
let
|
|
cfg = config.modules.services.gitea;
|
|
in {
|
|
options.modules.services.gitea = {
|
|
enable = mkBoolOpt false;
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
# Allows git@... clone addresses rather than gitea@...
|
|
users.users.git = {
|
|
useDefaultShell = true;
|
|
home = "/var/lib/gitea";
|
|
group = "gitea";
|
|
isSystemUser = true;
|
|
};
|
|
|
|
user.extraGroups = [ "gitea" ];
|
|
|
|
services.gitea = {
|
|
enable = true;
|
|
lfs.enable = true;
|
|
|
|
user = "git";
|
|
database.user = "git";
|
|
|
|
# We're assuming SSL-only connectivity
|
|
cookieSecure = true;
|
|
# Only log what's important, but Info is necessary for fail2ban to work
|
|
log.level = "Info";
|
|
settings = {
|
|
server.DISABLE_ROUTER_LOG = true;
|
|
database.LOG_SQL = false;
|
|
service.ENABLE_BASIC_AUTHENTICATION = false;
|
|
};
|
|
|
|
dump.interval = "daily";
|
|
};
|
|
|
|
services.fail2ban.jails.gitea = ''
|
|
enabled = true
|
|
filter = gitea
|
|
banaction = %(banaction_allports)s
|
|
maxretry = 5
|
|
'';
|
|
};
|
|
}
|