diff options
Diffstat (limited to 'modules')
-rw-r--r-- | modules/services/default.nix | 2 | ||||
-rw-r--r-- | modules/services/gitea/default.nix | 52 |
2 files changed, 54 insertions, 0 deletions
diff --git a/modules/services/default.nix b/modules/services/default.nix index 97a326a..94250d2 100644 --- a/modules/services/default.nix +++ b/modules/services/default.nix @@ -3,6 +3,8 @@ { imports = [ ./fwupd + ./gitea + ./grafana ./navidrome ./prometheus ./samba diff --git a/modules/services/gitea/default.nix b/modules/services/gitea/default.nix new file mode 100644 index 0000000..3551069 --- /dev/null +++ b/modules/services/gitea/default.nix @@ -0,0 +1,52 @@ +{ config, pkgs, lib, ... }: +let cfg = config.my.services.gitea; +in { + options.my.services.gitea = with lib; { + enable = mkEnableOption "gitea git server"; + stateDir = mkOption { + type = types.str; + example = "/var/lib/gitea"; + description = "gitea base directory"; + }; + }; + + config = lib.mkIf cfg.enable { + users.users.git = { + description = "Gitea Service"; + home = cfg.stateDir; + useDefaultShell = true; + group = "git"; + isSystemUser = true; + }; + users.groups.git = { }; + + services.gitea = { + enable = true; + user = "git"; + domain = "git.fcuny.net"; + appName = "${cfg.domain}"; + rootUrl = "https://${cfg.domain}/"; + httpAddress = "127.0.0.1"; + httpPort = 8002; + log.level = "Error"; + settings = { other.SHOW_FOOTER_VERSION = false; }; + dump.enable = false; + database = { + type = "sqlite3"; + user = cfg.user; + }; + }; + + services.restic.backups = { + gitea = { + paths = [ cfg.stateDir ]; + repository = "/data/slow/backups/systems"; + passwordFile = config.age.secrets.restic-repo-systems.path; + timerConfig = { OnCalendar = "00:15"; }; + initialize = true; + extraBackupArgs = [ "--tag gitea" ]; + pruneOpts = [ "--keep-daily 7" "--keep-weekly 4 --keep-monthly 6" ]; + }; + }; + }; +} |