diff options
| author | Mel <einebeere@gmail.com> | 2024-11-13 04:05:57 +0100 |
|---|---|---|
| committer | Mel <einebeere@gmail.com> | 2024-11-13 04:05:57 +0100 |
| commit | 164ca46735e350bea4dde63b7381262573e6507a (patch) | |
| tree | 3b666fb869f37e670bd5a7c1bb37196ea10e9f2c | |
| parent | 7dc9db6cbb45ed444f83c108106e7f0f09490903 (diff) | |
| download | network-164ca46735e350bea4dde63b7381262573e6507a.tar.zst network-164ca46735e350bea4dde63b7381262573e6507a.zip | |
Create soju IRC bouncer service
Signed-off-by: Mel <einebeere@gmail.com>
| -rw-r--r-- | machines/renard/default.nix | 1 | ||||
| -rw-r--r-- | services/soju.nix | 53 |
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" ]; + }; + }; +} |
