Skip to content

Commit

Permalink
chore: impersonate KGO RBACs with make run
Browse files Browse the repository at this point in the history
Signed-off-by: Mattia Lavacca <[email protected]>
  • Loading branch information
mlavacca committed Oct 17, 2024
1 parent 95cdf3a commit 74209ec
Showing 1 changed file with 24 additions and 7 deletions.
31 changes: 24 additions & 7 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -497,20 +497,32 @@ webhook-certs-dir:
_ensure-kong-system-namespace:
@kubectl create ns kong-system 2>/dev/null || true

TMP_DIR := $(shell mktemp -d)
KUBECONFIG ?= $(HOME)/.kube/config
TMP_KUBECONFIG := $(TMP_DIR)/kubeconfig

.PHONY: impersonate-kgo
impersonate-kgo:
mkdir -p $(TMP_DIR)
cp $(KUBECONFIG) $(TMP_KUBECONFIG)
KUBECONFIG=$(TMP_KUBECONFIG) kubectl config set-credentials kgo --token=$(shell kubectl create token --namespace=kong-system controller-manager)
KUBECONFIG=$(TMP_KUBECONFIG) kubectl config set-context kgo --cluster=$(shell kubectl config get-contexts | grep '^\*' | tr -s ' ' | cut -d ' ' -f 3) --user=kgo --namespace=kong-system
KUBECONFIG=$(TMP_KUBECONFIG) kubectl config use-context kgo



# Run a controller from your host.
# TODO: In order not to rely on 'main' version of Gateway API CRDs address but
# on the tag that is used in code (defined in go.mod) address this by solving
# https://github.com/Kong/gateway-operator/pull/480.
.PHONY: run
run: webhook-certs-dir manifests generate install.all _ensure-kong-system-namespace
@$(MAKE) _run
run: webhook-certs-dir manifests generate install.all _ensure-kong-system-namespace install.rbacs
$(MAKE) _run

# Run the operator without checking any preconditions, installing CRDs etc.
# This is mostly useful when 'run' was run at least once on a server and CRDs, RBACs
# etc didn't change in between the runs.
# The operator will use a temporary kubeconfig file and impersonate the real RBACs.
.PHONY: _run
_run:
GATEWAY_OPERATOR_DEVELOPMENT_MODE=true go run ./cmd/main.go \
_run: impersonate-kgo
KUBECONFIG=$(TMP_KUBECONFIG) GATEWAY_OPERATOR_DEVELOPMENT_MODE=true go run ./cmd/main.go \
--no-leader-election \
-cluster-ca-secret-namespace kong-system \
-enable-controller-kongplugininstallation \
Expand Down Expand Up @@ -569,6 +581,11 @@ KUBERNETES_CONFIGURATION_CRDS_CRDS_LOCAL_PATH = $(shell go env GOPATH)/pkg/mod/$
install.kubernetes-configuration-crds: kustomize
$(KUSTOMIZE) build $(KUBERNETES_CONFIGURATION_CRDS_CRDS_LOCAL_PATH) | kubectl apply -f -

# Install RBACs from config/rbac into the K8s cluster specified in ~/.kube/config.
.PHONY: install.rbacs
install.rbacs: kustomize
$(KUSTOMIZE) build config/rbac | kubectl apply -f -

# Install standard and experimental CRDs into the K8s cluster specified in ~/.kube/config.
.PHONY: install.all
install.all: manifests kustomize install-gateway-api-crds install.kubernetes-configuration-crds
Expand Down

0 comments on commit 74209ec

Please sign in to comment.