about summary refs log tree commit diff
path: root/ops/nixos/irccat.nix
diff options
context:
space:
mode:
authorVincent Ambo <mail@tazj.in>2021-04-11T20·50+0200
committertazjin <mail@tazj.in>2021-04-11T22·18+0000
commit90281c4eac4cd25045ed80c5f8f27c74898a02b3 (patch)
tree804425642af16b9e299d469ad6e21c6a23a400e9 /ops/nixos/irccat.nix
parent7deabb8c8d6f4c7e58e2b16548b8a1895795963b (diff)
refactor(ops): Split //ops/nixos into different locations r/2482
Splits //ops/nixos into:

* //ops/nixos.nix - utility functions for building systems
* //ops/machines - shared machine definitions (read by readTree)
* //ops/modules - shared NixOS modules (skipped by readTree)

This simplifies working with the configuration fixpoint in whitby, and
is overall a bit more in line with how NixOS systems in user folders
currently work.

Change-Id: I1322ec5cc76c0207c099c05d44828a3df0b3ffc1
Reviewed-on: https://cl.tvl.fyi/c/depot/+/2931
Tested-by: BuildkiteCI
Reviewed-by: sterni <sternenseemann@systemli.org>
Reviewed-by: glittershark <grfn@gws.fyi>
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 e4b30b7355..0000000000
--- 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";
-      };
-    };
-  };
-}