summary refs log tree commit diff
path: root/pkgs
diff options
context:
space:
mode:
authorMel <einebeere@gmail.com>2024-12-07 18:59:51 +0100
committerMel <einebeere@gmail.com>2024-12-07 18:59:51 +0100
commit934ab7978b824e1cd7a9e8d8284e9fc2cd325eb1 (patch)
tree0b05c7d7f4dc4e992d9d08460c33801fdc374e15 /pkgs
parentd1a88ffa2c8cf5d6dd690f9059c0da059e01b716 (diff)
downloadnetwork-934ab7978b824e1cd7a9e8d8284e9fc2cd325eb1.tar.zst
network-934ab7978b824e1cd7a9e8d8284e9fc2cd325eb1.zip
Allow global and tailnet ports in foundation
Signed-off-by: Mel <einebeere@gmail.com>
Diffstat (limited to 'pkgs')
-rw-r--r--pkgs/common.nix157
1 files changed, 106 insertions, 51 deletions
diff --git a/pkgs/common.nix b/pkgs/common.nix
index 5110335..7493f41 100644
--- a/pkgs/common.nix
+++ b/pkgs/common.nix
@@ -1,62 +1,117 @@
-{ dockerTools, system, ... }:
+{
+  lib,
+  dockerTools,
+  system,
+  ...
+}:
 
 let
   systemToArch = {
-    "x86_64-linux" = { short = "x86"; arch = "amd64"; };
-    "aarch64-linux" = { short = "arm"; arch = "arm64"; };
+    "x86_64-linux" = {
+      short = "x86";
+      arch = "amd64";
+    };
+    "aarch64-linux" = {
+      short = "arm";
+      arch = "arm64";
+    };
   };
 
-  mkImage = { name, tag, digest, ... }@inputs:
-  let
-    arch = systemToArch.${system};
-  
-    image = dockerTools.pullImage {
-      imageName = name;
-      imageDigest = digest;
-      finalImageName = name;
-      finalImageTag = tag;
-      os = "linux";
-      inherit (inputs.${arch.short}) sha256;
-      inherit (arch) arch;
+  mkImage =
+    {
+      name,
+      tag,
+      digest,
+      ...
+    }@inputs:
+    let
+      arch = systemToArch.${system};
+
+      image = dockerTools.pullImage {
+        imageName = name;
+        imageDigest = digest;
+        finalImageName = name;
+        finalImageTag = tag;
+        os = "linux";
+        inherit (inputs.${arch.short}) sha256;
+        inherit (arch) arch;
+      };
+    in
+    {
+      image = "${name}:${tag}";
+      imageFile = image;
+      base = image;
     };
-  in
-  {
-    image = "${name}:${tag}";
-    imageFile = image;
-    base = image;
-  };
 
-in
-{
-  alpine = mkImage {
-    name = "alpine";
-    tag = "3.20.3";
-    digest = "sha256:1e42bbe2508154c9126d48c2b8a75420c3544343bf86fd041fb7527e017a4b4a";
-    x86.sha256 = "02fr1isg8s2h7j8n5rda7avswnh7vpfhrix3rmvqsjp8cx3qbkz3";
-    arm.sha256 = "06c0q5kk60i89y1d83a28wk282ymp806xjcsmlca4cwwqp590j0q";
-  };
-  
-  postgres13 = mkImage {
-    name = "postgres";
-    tag = "13-alpine";
-    digest = "sha256:857aa00fc7e8541e3e5818b7bb8596182cb5c1b3ad964e4184e90682d5ca0d57";
-    x86.sha256 = "1yc0576kdfsz55ybjaykki2mhr6w9yrby7wslx8pfmn7xkykzq9w";
-    arm.sha256 = "0kjxk2sd03445mgf54x1ir9w2zmjn41zgmyns2h3k3cd7qazhkrx";
-  };
+  images = {
+    alpine = mkImage {
+      name = "alpine";
+      tag = "3.20.3";
+      digest = "sha256:1e42bbe2508154c9126d48c2b8a75420c3544343bf86fd041fb7527e017a4b4a";
+      x86.sha256 = "02fr1isg8s2h7j8n5rda7avswnh7vpfhrix3rmvqsjp8cx3qbkz3";
+      arm.sha256 = "06c0q5kk60i89y1d83a28wk282ymp806xjcsmlca4cwwqp590j0q";
+    };
+
+    postgres13 = mkImage {
+      name = "postgres";
+      tag = "13-alpine";
+      digest = "sha256:857aa00fc7e8541e3e5818b7bb8596182cb5c1b3ad964e4184e90682d5ca0d57";
+      x86.sha256 = "1yc0576kdfsz55ybjaykki2mhr6w9yrby7wslx8pfmn7xkykzq9w";
+      arm.sha256 = "0kjxk2sd03445mgf54x1ir9w2zmjn41zgmyns2h3k3cd7qazhkrx";
+    };
+
+    postgres14 = mkImage {
+      name = "postgres";
+      tag = "14-alpine";
+      digest = "sha256:3f5fc44eeb8e8b42448e218f05299105761a2c33b54a89d9fd06c87cd5f7b043";
+      x86.sha256 = "1zpiv9d6mj9d3n2xhgz0wn8q7a4gzjrk0hp8vpm706wwh72q8nir";
+      arm.sha256 = "1gh6f4frfilr5mp6smp1k00aijd9vh1kv711a64044yl9kqr2nci";
+    };
 
-  postgres14 = mkImage {
-    name = "postgres";
-    tag = "14-alpine";
-    digest = "sha256:3f5fc44eeb8e8b42448e218f05299105761a2c33b54a89d9fd06c87cd5f7b043";
-    x86.sha256 = "1zpiv9d6mj9d3n2xhgz0wn8q7a4gzjrk0hp8vpm706wwh72q8nir";
-    arm.sha256 = "1gh6f4frfilr5mp6smp1k00aijd9vh1kv711a64044yl9kqr2nci";
+    postgres15 = mkImage {
+      name = "postgres";
+      tag = "15-alpine";
+      digest = "sha256:8b963ea3038c3b32182ee7f592ccde21242fa7c5fd9d1b72aa333c27f1bfc809";
+      x86.sha256 = "0cfmp4v1a4b2m21ljsc3f3kn23rl9nki6z37ks9jclzxh9hy629n";
+      arm.sha256 = "0wydmscp4znjdflycvjqwjfry9crizhav0wc2hnajbyvk4ql32h8";
+    };
   };
 
-  postgres15 = mkImage {
-    name = "postgres";
-    tag = "15-alpine";
-    digest = "sha256:8b963ea3038c3b32182ee7f592ccde21242fa7c5fd9d1b72aa333c27f1bfc809";
-    x86.sha256 = "0cfmp4v1a4b2m21ljsc3f3kn23rl9nki6z37ks9jclzxh9hy629n";
-    arm.sha256 = "0wydmscp4znjdflycvjqwjfry9crizhav0wc2hnajbyvk4ql32h8";
+  soloOrDuoPort =
+    p:
+    with builtins;
+    if isList p then
+      assert length p == 2;
+      {
+        host = elemAt p 0;
+        container = elemAt p 1;
+      }
+    else if isInt p then
+      {
+        host = p;
+        container = p;
+      }
+    else
+      throw "unknown port type given";
+
+  ports = {
+    globalPort =
+      p:
+      let
+        ports = soloOrDuoPort p;
+        host = toString ports.host;
+        container = toString ports.container;
+      in
+      "0.0.0.0:${host}:${container}";
+
+    tailnetPort =
+      me: p:
+      let
+        ports = soloOrDuoPort p;
+        host = toString ports.host;
+        container = toString ports.container;
+      in
+      "${me.tailscale.ip}:${host}:${container}";
   };
-}
+in
+images // ports