summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--machines/renard/default.nix1
-rw-r--r--services/soju.nix53
2 files changed, 54 insertions, 0 deletions
diff --git a/machines/renard/default.nix b/machines/renard/default.nix
index 8672da4..38a2c4d 100644
--- a/machines/renard/default.nix
+++ b/machines/renard/default.nix
@@ -11,6 +11,7 @@
     ../../modules/git.nix
   
     ../../services/cgit.nix
+    ../../services/soju.nix
   ];
 
   systemd.services."acme-renard.serval-moth.ts.net" =
diff --git a/services/soju.nix b/services/soju.nix
new file mode 100644
index 0000000..3fd64cf
--- /dev/null
+++ b/services/soju.nix
@@ -0,0 +1,53 @@
+{ pkgs, ... }:
+
+let
+  inherit (pkgs) dockerTools soju;
+
+  ircPort = "6667";
+  socketPort = "3030";
+  sojuDir = "/srv/soju";
+
+  # TODO: move this outside.
+  baseImage = dockerTools.pullImage {
+    imageName = "alpine";
+    imageDigest = "sha256:beefdbd8a1da6d2915566fde36db9db0b524eb737fc57cd1367effd16dc0d06d";
+    sha256 = "0fzqhqvvb0pzkwvjwyqjfv3rw2w8006xz4mhk0dk5clmyb08hqwc";
+    finalImageName = "alpine";
+    finalImageTag = "3.20.3";
+  };
+
+  sojuImage = dockerTools.buildLayeredImage {
+    name = soju.pname;
+    tag = soju.version;
+    fromImage = baseImage;
+
+    contents = [ soju ];
+
+    extraCommands = ''
+      mkdir -p ./run/soju
+    '';
+  };
+
+in
+{
+  virtualisation.oci-containers.containers = {
+    soju = {
+      imageFile = sojuImage;
+      image = "soju:${soju.version}";
+      ports = [
+        # TODO: take tailnet ip from `me`.
+        "100.75.17.75:${ircPort}:${ircPort}"
+        "100.75.17.75:${socketPort}:${socketPort}"
+      ];
+
+      volumes = [
+        "${sojuDir}/config.in:/etc/soju/config.in"
+        "${sojuDir}/soju.db:/var/lib/soju/soju.db"
+        "${sojuDir}/logs:/var/lib/soju/logs"
+      ];
+
+      entrypoint = "${soju}/bin/soju";
+      cmd = [ "-config" "/etc/soju/config.in" ];
+    };
+  };
+}