From 64726dd84b99e946f7f125d8652bc6a10e47229d Mon Sep 17 00:00:00 2001 From: Julien Vincent Date: Wed, 22 Nov 2023 09:39:18 +1100 Subject: [PATCH] Add support for host.docker.internal on linux --- README.md | 15 +++++-------- src/k16/kl/commands/network.clj | 38 +++++++++++++++++++++++++++------ 2 files changed, 36 insertions(+), 17 deletions(-) diff --git a/README.md b/README.md index 7ba9131..11ab3cd 100644 --- a/README.md +++ b/README.md @@ -208,18 +208,13 @@ Below are some common ways of addressing services running in different contexts: + `http://example:8080` + `http://:8080` + A process running on the host and bound to port `8080` could be addressed as - + On macos - `http://host.docker.internal:8080` + + On macos and linux* - `http://host.docker.internal:8080` + On linux - `http://172.17.0.1:8080` -Because of this host address discrepancy between linux and macos it is highly recommended for **linux based users** to add the following to their `/etc/hosts` file: - -```bash -172.17.0.1 host.docker.internal -``` - -**DO NOT** do this if you are on macos. - -This is an acceptable compromise to allow for a stable way of addressing the host in module configs that are intended to be consumed by developers on different operating systems. +> [!NOTE] +> By default docker does not configure the `host.docker.internal` domain on linux*. This is typically only available on macos when using something like Docker Desktop. +> +> To allow for a consistent way of addressing the host that works across all operating systems kl manually adds the `host.docker.internal:172.17.0.1` host to to the proxy container. If you don't want this behaviour you can disable it by running `kl network start --add-host "host.docker.internal:"`. ## Routes diff --git a/src/k16/kl/commands/network.clj b/src/k16/kl/commands/network.clj index 2999f5e..3248d41 100644 --- a/src/k16/kl/commands/network.clj +++ b/src/k16/kl/commands/network.clj @@ -31,8 +31,26 @@ module)) -(defn- start-network! [{:keys [host-dns host-dns-port]}] +(def ^:private os + (-> (System/getProperty "os.name") .toLowerCase)) + +(def ^:private default-hosts + (cond + (str/includes? os "linux") ["host.docker.internal:172.17.0.1"] + :else [])) + +(defn- start-network! [{:keys [host-dns host-dns-port add-host]}] (let [workdir (api.fs/from-config-dir ".kl/network") + + extra-hosts (->> (concat default-hosts add-host) + (reduce (fn [acc host] + (let [[host ip] (str/split host #":")] + (assoc acc host ip))) + {}) + (filter (fn [[_ ip]] + (and ip (not= "" ip)))) + (map (fn [[host ip]] (str host ":" ip)))) + module (cond-> (write-network-module) (not host-dns) (assoc-in [:containers :dnsmasq-external :enabled] @@ -40,7 +58,11 @@ host-dns-port (assoc-in [:containers :dnsmasq-external :ports] - [(str host-dns-port ":53/udp") (str host-dns-port ":53/tcp")]))] + [(str host-dns-port ":53/udp") (str host-dns-port ":53/tcp")]) + + (seq extra-hosts) + (assoc-in [:containers :proxy :extra_hosts] + extra-hosts))] (api.proxy/write-proxy-config! {:module-name "kl" :module module}) @@ -61,11 +83,10 @@ (api.fs/rm-dir! workdir))) (def ^:private default-port - (let [os (-> (System/getProperty "os.name") .toLowerCase)] - (cond - (str/includes? os "mac") "53" - (str/includes? os "linux") "5343" - :else "5343"))) + (cond + (str/includes? os "mac") "53" + (str/includes? os "linux") "5343" + :else "5343")) (def cmd {:command "network" @@ -79,6 +100,9 @@ :type :with-flag} {:option "host-dns-port" :default default-port + :type :string} + {:option "add-host" + :multiple true :type :string}] :runs start-network!}