about summary refs log tree commit diff
path: root/modules/services
diff options
context:
space:
mode:
authorFranck Cuny <franck@fcuny.net>2022-04-06 12:39:26 -0700
committerFranck Cuny <franck@fcuny.net>2022-04-06 12:39:26 -0700
commitcf16fe85f3ac340b03f90e2f7f3ad85e4c621ce9 (patch)
treef06f3f9f5b6ea0d607648aa45e927bc248995ac4 /modules/services
parentprometheus: proper name for the option (diff)
downloadworld-cf16fe85f3ac340b03f90e2f7f3ad85e4c621ce9.tar.gz
refactor gitea as a module
Diffstat (limited to 'modules/services')
-rw-r--r--modules/services/default.nix2
-rw-r--r--modules/services/gitea/default.nix52
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" ];
+      };
+    };
+  };
+}