about summary refs log tree commit diff
path: root/ops/nixos/irccat.nix
diff options
context:
space:
mode:
Diffstat (limited to 'ops/nixos/irccat.nix')
-rw-r--r--ops/nixos/irccat.nix49
1 files changed, 0 insertions, 49 deletions
diff --git a/ops/nixos/irccat.nix b/ops/nixos/irccat.nix
deleted file mode 100644
index e4b30b73553e..000000000000
--- a/ops/nixos/irccat.nix
+++ /dev/null
@@ -1,49 +0,0 @@
-{ depot, config, lib, pkgs, ... }:
-
-let
-  cfg = config.services.depot.irccat;
-  description = "irccat - forward messages to IRC";
-
-  # irccat expects to read its configuration from the *current
-  # directory*, and its configuration contains secrets.
-  #
-  # To make this work we construct the JSON configuration file and
-  # then recursively merge it with an on-disk secret using jq on
-  # service launch.
-  configJson = pkgs.writeText "irccat.json" (builtins.toJSON cfg.config);
-  configMerge = pkgs.writeShellScript "merge-irccat-config" ''
-    if [ ! -f "/etc/secrets/irccat.json" ]; then
-      echo "irccat secrets file is missing"
-      exit 1
-    fi
-
-    # jq's * is the recursive merge operator
-    ${pkgs.jq}/bin/jq -s '.[0] * .[1]' ${configJson} /etc/secrets/irccat.json \
-      > /var/lib/irccat/irccat.json
-  '';
-in {
-  options.services.depot.irccat = {
-    enable = lib.mkEnableOption description;
-
-    config = lib.mkOption {
-      type = lib.types.attrs; # varying value types
-      description = "Configuration structure (unchecked!)";
-    };
-  };
-
-  config = lib.mkIf cfg.enable {
-    systemd.services.irccat = {
-      inherit description;
-      preStart = "${configMerge}";
-      script = "${depot.third_party.irccat}/bin/irccat";
-      wantedBy = [ "multi-user.target" ];
-
-      serviceConfig = {
-        DynamicUser = true;
-        StateDirectory = "irccat";
-        WorkingDirectory = "/var/lib/irccat";
-        Restart = "always";
-      };
-    };
-  };
-}