summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorSoispha <soispha@vhack.eu>2023-06-17 21:09:22 +0200
committerSoispha <soispha@vhack.eu>2023-06-17 22:03:27 +0200
commit357f78ed275661f7196ce315b1a276c1a4f3acc9 (patch)
treee45c7556691633de80aac933a2d82eb46af8d51d
parentMerge branch 'keycloak' into develop (diff)
downloadnixos-server-357f78ed275661f7196ce315b1a276c1a4f3acc9.zip
Feat(system/services/git-sync): Add
-rw-r--r--system/services/default.nix1
-rw-r--r--system/services/git-sync/default.nix104
2 files changed, 105 insertions, 0 deletions
diff --git a/system/services/default.nix b/system/services/default.nix
index 99b8fb6..5c9b6bf 100644
--- a/system/services/default.nix
+++ b/system/services/default.nix
@@ -9,5 +9,6 @@
     ./opensshd
     ./rust-motd
     ./fail2ban
+    ./git-sync
   ];
 }
diff --git a/system/services/git-sync/default.nix b/system/services/git-sync/default.nix
new file mode 100644
index 0000000..776ca60
--- /dev/null
+++ b/system/services/git-sync/default.nix
@@ -0,0 +1,104 @@
+/*
+Taken from:
+https://github.com/nix-community/home-manager/blob/9ba7b3990eb1f4782ea3f5fe7ac4f3c88dd7a32c/modules/services/git-sync.nix
+*/
+{
+  config,
+  lib,
+  pkgs,
+  ...
+}: let
+  cfg = config.services.git-sync;
+
+  mkUnit = name: repo: {
+    Unit.Description = "Git Sync ${name}";
+
+    Install.WantedBy = ["default.target"];
+
+    Service = {
+      Environment = [
+        "PATH=${lib.makeBinPath (with pkgs; [openssh git])}"
+        "GIT_SYNC_DIRECTORY=${repo.path}"
+        "GIT_SYNC_COMMAND=${cfg.package}/bin/git-sync"
+        "GIT_SYNC_REPOSITORY=${repo.uri}"
+        "GIT_SYNC_INTERVAL=${toString repo.interval}"
+      ];
+      ExecStart = "${cfg.package}/bin/git-sync-on-inotify";
+      Restart = "on-abort";
+    };
+  };
+
+  services =
+    lib.mapAttrs' (name: repo: {
+      name = "git-sync-${name}";
+      value = mkUnit name repo;
+    })
+    cfg.repositories;
+
+  repositoryType = lib.types.submodule ({name, ...}: {
+    options = {
+      name = lib.mkOption {
+        internal = true;
+        default = name;
+        type = lib.types.str;
+        description = "The name that should be given to this unit.";
+      };
+
+      path = lib.mkOption {
+        type = lib.types.path;
+        description = "The path at which to sync the repository";
+      };
+
+      uri = lib.mkOption {
+        type = lib.types.str;
+        example = "git+ssh://user@example.com:/~[user]/path/to/repo.git";
+        description = ''
+          The URI of the remote to be synchronized. This is only used in the
+          event that the directory does not already exist. See
+          <link xlink:href="https://git-scm.com/docs/git-clone#_git_urls"/>
+          for the supported URIs.
+        '';
+      };
+
+      interval = lib.mkOption {
+        type = lib.types.int;
+        default = 500;
+        description = ''
+          The interval, specified in seconds, at which the synchronization will
+          be triggered even without filesystem changes.
+        '';
+      };
+    };
+  });
+in {
+  options = {
+    services.git-sync = {
+      enable = lib.mkEnableOption "git-sync services";
+
+      package = lib.mkOption {
+        type = lib.types.package;
+        default = pkgs.git-sync;
+        defaultText = lib.literalExpression "pkgs.git-sync";
+        description = ''
+          Package containing the <command>git-sync</command> program.
+        '';
+      };
+
+      repositories = lib.mkOption {
+        type = with lib.types; attrsOf repositoryType;
+        description = ''
+          The repositories that should be synchronized.
+        '';
+      };
+    };
+  };
+
+  config = lib.mkIf cfg.enable {
+    assertions = [
+      (lib.hm.assertions.assertPlatform "services.git-sync" pkgs
+        lib.platforms.linux)
+    ];
+
+    systemd.user.services = services;
+  };
+}