about summary refs log tree commit diff
path: root/modules/services/gitea/default.nix
diff options
context:
space:
mode:
Diffstat (limited to 'modules/services/gitea/default.nix')
-rw-r--r--modules/services/gitea/default.nix52
1 files changed, 52 insertions, 0 deletions
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" ];
+      };
+    };
+  };
+}