From e0b3fc15a0b9eccb18b6a932ab195538e194b814 Mon Sep 17 00:00:00 2001 From: phm07 <22707808+phm07@users.noreply.github.com> Date: Wed, 3 Jul 2024 12:39:48 +0200 Subject: [PATCH] feat: add launchd support for macOS See #18 --- .terraform.lock.hcl | 6 +++++ cleanup.sh | 13 ++++++++++ example/.terraform.lock.hcl | 6 +++++ example/Makefile | 1 + main-setup.tf | 6 +++++ registry-port-forward.sh | 50 +++++++++++++++++++++++++++++++++++-- 6 files changed, 80 insertions(+), 2 deletions(-) create mode 100755 cleanup.sh diff --git a/.terraform.lock.hcl b/.terraform.lock.hcl index 6d22d49..7469955 100644 --- a/.terraform.lock.hcl +++ b/.terraform.lock.hcl @@ -5,6 +5,7 @@ provider "registry.opentofu.org/hashicorp/helm" { version = "2.14.0" constraints = "2.14.0" hashes = [ + "h1:K1yXsEeNhW/7YVSvsv55UaFSx4hHeKB1giPuQUKmFfQ=", "h1:ibK3MM61pVjBwBcrro56OLTHwUhhNglvGG9CloLvliI=", "zh:1c84ca8c274564c46497e89055139c7af64c9e1a8dd4f1cd4c68503ac1322fb8", "zh:211a763173934d30c2e49c0cc828b1e34a528b0fdec8bf48d2bb3afadd4f9095", @@ -23,6 +24,7 @@ provider "registry.opentofu.org/hashicorp/kubernetes" { version = "2.31.0" constraints = "2.31.0" hashes = [ + "h1:MLk6rnv1ExXguVTT/lMa9VPubPYS6VF9sKBjzaVUASE=", "h1:z2qlqn6WbrjbezwQo4vvlwAgVUGz59klzDU4rlYhYi8=", "zh:0dd25babf78a88a61dd329b8c18538a295ea63630f1b69575e7898c89307da39", "zh:3138753e4b2ce6e9ffa5d65d73e9236169ff077c10089c7dc71031a0a139ff6d", @@ -41,6 +43,7 @@ provider "registry.opentofu.org/hashicorp/local" { version = "2.5.1" constraints = "2.5.1" hashes = [ + "h1:87L+rpGao062xifb1VuG9YVFwp9vbDP6G2fgfYxUkQs=", "h1:GgW5qncKu4KnXLE1ZYv5iwmhSYtTNzsOvJAOQIyFR7E=", "zh:031c2c2070672b7e78e0aa15560839278dc57fe7cf1e58a617ac13c67b31d5fb", "zh:1ef64ea4f8382cd538a76f3d319f405d18130dc3280f1c16d6aaa52a188ecaa4", @@ -59,6 +62,7 @@ provider "registry.opentofu.org/hashicorp/null" { version = "3.2.2" constraints = "3.2.2" hashes = [ + "h1:sU0t6ANQ4IfEwZbbBmcNeOCg2CDCViVb7L7QVfIHrCs=", "h1:xN1tSeF/rUBfaddk/AVqk4i65z/MMM9uVZWd2cWCCH0=", "zh:00e5877d19fb1c1d8c4b3536334a46a5c86f57146fd115c7b7b4b5d2bf2de86d", "zh:1755c2999e73e4d73f9de670c145c9a0dc5a373802799dff06a0e9c161354163", @@ -77,6 +81,7 @@ provider "registry.opentofu.org/hashicorp/tls" { version = "4.0.5" constraints = "4.0.5" hashes = [ + "h1:LWGTWAUrC+/iTsNq0vxANvGOp+7Jnl4wAnSOW2Shqjc=", "h1:zEH0OgSkeXDqNWzmOUWDczrUwyyujAHvnbW79qdxVMI=", "zh:05a7dc3ac92005485714f87541ad6d0d478988b478c5774227a7d39b01660050", "zh:547e0def44080456169bf77c21037aa6dc9e7f3e644a8f6a2c5fc3e6c15cf560", @@ -95,6 +100,7 @@ provider "registry.opentofu.org/hetznercloud/hcloud" { version = "1.47.0" constraints = "1.47.0" hashes = [ + "h1:KQbtq1sXF4deoc0DKgjyyJMdIuHfhfhAPkVV0DlTMRI=", "h1:aqEPcSpaWhKqbMs7c7Pf5ot6Tye7ntRitWsuNGPRPfk=", "zh:0759f0c23d0e59baab3382320eef4eb314e0c5967b6ef67ff07135da07a97b34", "zh:0e9ca84c4059d6d7e2c9f13d3c2b1cd91f7d9a47bedcb4b80c7c77d536eff887", diff --git a/cleanup.sh b/cleanup.sh new file mode 100755 index 0000000..8caf21d --- /dev/null +++ b/cleanup.sh @@ -0,0 +1,13 @@ +#!/usr/bin/env bash + +set -ue -o pipefail + +run_launchd() { + FILEPATH="$HOME/Library/LaunchAgents/com.hetzner.cloud.k8sdev.registry-port-forward.plist" + launchctl unload "$FILEPATH" 2> /dev/null || true + rm -f "$FILEPATH" +} + +if which launchctl > /dev/null; then + run_launchd +fi diff --git a/example/.terraform.lock.hcl b/example/.terraform.lock.hcl index 6d22d49..7469955 100644 --- a/example/.terraform.lock.hcl +++ b/example/.terraform.lock.hcl @@ -5,6 +5,7 @@ provider "registry.opentofu.org/hashicorp/helm" { version = "2.14.0" constraints = "2.14.0" hashes = [ + "h1:K1yXsEeNhW/7YVSvsv55UaFSx4hHeKB1giPuQUKmFfQ=", "h1:ibK3MM61pVjBwBcrro56OLTHwUhhNglvGG9CloLvliI=", "zh:1c84ca8c274564c46497e89055139c7af64c9e1a8dd4f1cd4c68503ac1322fb8", "zh:211a763173934d30c2e49c0cc828b1e34a528b0fdec8bf48d2bb3afadd4f9095", @@ -23,6 +24,7 @@ provider "registry.opentofu.org/hashicorp/kubernetes" { version = "2.31.0" constraints = "2.31.0" hashes = [ + "h1:MLk6rnv1ExXguVTT/lMa9VPubPYS6VF9sKBjzaVUASE=", "h1:z2qlqn6WbrjbezwQo4vvlwAgVUGz59klzDU4rlYhYi8=", "zh:0dd25babf78a88a61dd329b8c18538a295ea63630f1b69575e7898c89307da39", "zh:3138753e4b2ce6e9ffa5d65d73e9236169ff077c10089c7dc71031a0a139ff6d", @@ -41,6 +43,7 @@ provider "registry.opentofu.org/hashicorp/local" { version = "2.5.1" constraints = "2.5.1" hashes = [ + "h1:87L+rpGao062xifb1VuG9YVFwp9vbDP6G2fgfYxUkQs=", "h1:GgW5qncKu4KnXLE1ZYv5iwmhSYtTNzsOvJAOQIyFR7E=", "zh:031c2c2070672b7e78e0aa15560839278dc57fe7cf1e58a617ac13c67b31d5fb", "zh:1ef64ea4f8382cd538a76f3d319f405d18130dc3280f1c16d6aaa52a188ecaa4", @@ -59,6 +62,7 @@ provider "registry.opentofu.org/hashicorp/null" { version = "3.2.2" constraints = "3.2.2" hashes = [ + "h1:sU0t6ANQ4IfEwZbbBmcNeOCg2CDCViVb7L7QVfIHrCs=", "h1:xN1tSeF/rUBfaddk/AVqk4i65z/MMM9uVZWd2cWCCH0=", "zh:00e5877d19fb1c1d8c4b3536334a46a5c86f57146fd115c7b7b4b5d2bf2de86d", "zh:1755c2999e73e4d73f9de670c145c9a0dc5a373802799dff06a0e9c161354163", @@ -77,6 +81,7 @@ provider "registry.opentofu.org/hashicorp/tls" { version = "4.0.5" constraints = "4.0.5" hashes = [ + "h1:LWGTWAUrC+/iTsNq0vxANvGOp+7Jnl4wAnSOW2Shqjc=", "h1:zEH0OgSkeXDqNWzmOUWDczrUwyyujAHvnbW79qdxVMI=", "zh:05a7dc3ac92005485714f87541ad6d0d478988b478c5774227a7d39b01660050", "zh:547e0def44080456169bf77c21037aa6dc9e7f3e644a8f6a2c5fc3e6c15cf560", @@ -95,6 +100,7 @@ provider "registry.opentofu.org/hetznercloud/hcloud" { version = "1.47.0" constraints = "1.47.0" hashes = [ + "h1:KQbtq1sXF4deoc0DKgjyyJMdIuHfhfhAPkVV0DlTMRI=", "h1:aqEPcSpaWhKqbMs7c7Pf5ot6Tye7ntRitWsuNGPRPfk=", "zh:0759f0c23d0e59baab3382320eef4eb314e0c5967b6ef67ff07135da07a97b34", "zh:0e9ca84c4059d6d7e2c9f13d3c2b1cd91f7d9a47bedcb4b80c7c77d536eff887", diff --git a/example/Makefile b/example/Makefile index 0621e75..ad6e56e 100644 --- a/example/Makefile +++ b/example/Makefile @@ -21,6 +21,7 @@ up: .terraform env.auto.tfvars down: .terraform env.auto.tfvars tofu destroy -auto-approve + bash files/cleanup.sh port-forward: source files/env.sh diff --git a/main-setup.tf b/main-setup.tf index ef357f5..ec11e9f 100644 --- a/main-setup.tf +++ b/main-setup.tf @@ -204,6 +204,12 @@ resource "local_file" "registry_port_forward" { file_permission = "0755" } +resource "local_file" "cleanup" { + source = "${path.module}/cleanup.sh" + filename = "${path.root}/files/cleanup.sh" + file_permission = "0755" +} + resource "local_file" "env" { content = <<-EOT #!/usr/bin/env bash diff --git a/registry-port-forward.sh b/registry-port-forward.sh index 863adeb..de86a69 100755 --- a/registry-port-forward.sh +++ b/registry-port-forward.sh @@ -2,7 +2,7 @@ set -ue -o pipefail -run() { +run_systemd() { unit="k8s-registry-port-forward.service" description="Port Forward for Container Registry of k8s dev environment" @@ -17,4 +17,50 @@ run() { kubectl port-forward -n kube-system svc/docker-registry 30666:5000 } -run +run_launchd() { + FILEPATH="$HOME/Library/LaunchAgents/com.hetzner.cloud.k8sdev.registry-port-forward.plist" + + cat > "$FILEPATH" < + + + + Label + com.hetzner.cloud.k8sdev.portforward.plist + Program + $(which kubectl) + ProgramArguments + + kubectl + port-forward + -n + kube-system + svc/docker-registry + 30666:5000 + + EnvironmentVariables + + KUBECONFIG + $KUBECONFIG + + WorkingDirectory + $PWD + RunAtLoad + + KeepAlive + + + +EOF + + launchctl load "$FILEPATH" +} + +if which systemctl > /dev/null; then + run_systemd +elif which launchctl > /dev/null; then + run_launchd +else + echo "No supported init system found" + exit 1 +fi