From 226a2768f175baf272f55fb5b04c277694457cf6 Mon Sep 17 00:00:00 2001 From: ostempel Date: Tue, 5 Nov 2024 16:53:44 +0100 Subject: [PATCH 01/32] Initial commit --- .gitignore | 9 + Dockerfile | 12 + Dockerfile.dev | 3 + LICENCE | 21 + Makefile | 104 + charts/charts.go | 13 + .../Chart.yaml | 5 + .../gardener-extension-csi-driver-lvm/doc.go | 4 + .../templates/_helpers.tpl | 27 + .../configmap-imagevector-overwrite.yaml | 12 + .../templates/configmap.yaml | 20 + .../templates/deployment.yaml | 105 + .../templates/poddisruptionbudget.yaml | 14 + .../templates/rbac.yaml | 122 + .../templates/service.yaml | 24 + .../templates/serviceaccount.yaml | 7 + .../values.yaml | 45 + charts/images.go | 7 + charts/images.yaml | 29 + charts/internal/csi-driver-lvm/Chart.yaml | 5 + .../csi-driver-lvm/templates/daemonset.yaml | 174 ++ .../csi-driver-lvm/templates/driver.yaml | 10 + .../csi-driver-lvm/templates/helpers.tpl | 32 + .../csi-driver-lvm/templates/rbac.yaml | 89 + .../templates/serviceaccount.yaml | 12 + .../csi-driver-lvm/templates/statefulset.yaml | 77 + .../templates/storageclasses.yaml | 66 + charts/internal/csi-driver-lvm/values.yaml | 85 + .../app/app.go | 37 + .../app/options.go | 172 ++ cmd/gardener-extension-csi-driver-lvm/main.go | 21 + example/00-componentconfig.yaml | 5 + example/controller-registration.yaml | 24 + example/kustomization.yaml | 8 + example/kustomize/patch-deployment.yaml | 9 + example/kustomize/patch-registration.yaml | 15 + example/shoot.yaml | 42 + go.mod | 143 ++ go.sum | 1993 +++++++++++++++++ hack/boilerplate.txt | 3 + hack/tools.go | 17 + hack/update-codegen.sh | 54 + hack/update-github-templates.sh | 3 + pkg/apis/config/doc.go | 4 + pkg/apis/config/register.go | 37 + pkg/apis/config/types.go | 20 + pkg/apis/config/v1alpha1/defaults.go | 9 + pkg/apis/config/v1alpha1/doc.go | 6 + pkg/apis/config/v1alpha1/register.go | 40 + pkg/apis/config/v1alpha1/types.go | 20 + .../v1alpha1/zz_generated.conversion.go | 64 + .../config/v1alpha1/zz_generated.deepcopy.go | 55 + .../config/v1alpha1/zz_generated.defaults.go | 21 + pkg/apis/config/zz_generated.deepcopy.go | 55 + pkg/apis/csidriverlvm/doc.go | 6 + pkg/apis/csidriverlvm/install/install.go | 29 + pkg/apis/csidriverlvm/register.go | 37 + pkg/apis/csidriverlvm/types.go | 12 + pkg/apis/csidriverlvm/v1alpha1/doc.go | 6 + pkg/apis/csidriverlvm/v1alpha1/register.go | 37 + pkg/apis/csidriverlvm/v1alpha1/types.go | 16 + .../v1alpha1/zz_generated.deepcopy.go | 39 + .../v1alpha1/zz_generated.defaults.go | 21 + .../csidriverlvm/zz_generated.deepcopy.go | 39 + pkg/cmd/config.go | 88 + pkg/cmd/options.go | 28 + pkg/controller/csi-driver-lvm/actuator.go | 726 ++++++ pkg/controller/csi-driver-lvm/add.go | 54 + pkg/controller/healthcheck/registration.go | 53 + pkg/imagevector/imagevector.go | 25 + pkg/kapiserver/ensurer.go | 110 + pkg/kapiserver/webhook.go | 58 + 72 files changed, 5394 insertions(+) create mode 100644 .gitignore create mode 100644 Dockerfile create mode 100644 Dockerfile.dev create mode 100644 LICENCE create mode 100644 Makefile create mode 100644 charts/charts.go create mode 100644 charts/gardener-extension-csi-driver-lvm/Chart.yaml create mode 100644 charts/gardener-extension-csi-driver-lvm/doc.go create mode 100644 charts/gardener-extension-csi-driver-lvm/templates/_helpers.tpl create mode 100644 charts/gardener-extension-csi-driver-lvm/templates/configmap-imagevector-overwrite.yaml create mode 100644 charts/gardener-extension-csi-driver-lvm/templates/configmap.yaml create mode 100644 charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml create mode 100644 charts/gardener-extension-csi-driver-lvm/templates/poddisruptionbudget.yaml create mode 100644 charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml create mode 100644 charts/gardener-extension-csi-driver-lvm/templates/service.yaml create mode 100644 charts/gardener-extension-csi-driver-lvm/templates/serviceaccount.yaml create mode 100644 charts/gardener-extension-csi-driver-lvm/values.yaml create mode 100644 charts/images.go create mode 100644 charts/images.yaml create mode 100644 charts/internal/csi-driver-lvm/Chart.yaml create mode 100644 charts/internal/csi-driver-lvm/templates/daemonset.yaml create mode 100644 charts/internal/csi-driver-lvm/templates/driver.yaml create mode 100644 charts/internal/csi-driver-lvm/templates/helpers.tpl create mode 100644 charts/internal/csi-driver-lvm/templates/rbac.yaml create mode 100644 charts/internal/csi-driver-lvm/templates/serviceaccount.yaml create mode 100644 charts/internal/csi-driver-lvm/templates/statefulset.yaml create mode 100644 charts/internal/csi-driver-lvm/templates/storageclasses.yaml create mode 100644 charts/internal/csi-driver-lvm/values.yaml create mode 100644 cmd/gardener-extension-csi-driver-lvm/app/app.go create mode 100644 cmd/gardener-extension-csi-driver-lvm/app/options.go create mode 100644 cmd/gardener-extension-csi-driver-lvm/main.go create mode 100644 example/00-componentconfig.yaml create mode 100644 example/controller-registration.yaml create mode 100644 example/kustomization.yaml create mode 100644 example/kustomize/patch-deployment.yaml create mode 100644 example/kustomize/patch-registration.yaml create mode 100644 example/shoot.yaml create mode 100644 go.mod create mode 100644 go.sum create mode 100644 hack/boilerplate.txt create mode 100644 hack/tools.go create mode 100755 hack/update-codegen.sh create mode 100755 hack/update-github-templates.sh create mode 100644 pkg/apis/config/doc.go create mode 100644 pkg/apis/config/register.go create mode 100644 pkg/apis/config/types.go create mode 100644 pkg/apis/config/v1alpha1/defaults.go create mode 100644 pkg/apis/config/v1alpha1/doc.go create mode 100644 pkg/apis/config/v1alpha1/register.go create mode 100644 pkg/apis/config/v1alpha1/types.go create mode 100644 pkg/apis/config/v1alpha1/zz_generated.conversion.go create mode 100644 pkg/apis/config/v1alpha1/zz_generated.deepcopy.go create mode 100644 pkg/apis/config/v1alpha1/zz_generated.defaults.go create mode 100644 pkg/apis/config/zz_generated.deepcopy.go create mode 100644 pkg/apis/csidriverlvm/doc.go create mode 100644 pkg/apis/csidriverlvm/install/install.go create mode 100644 pkg/apis/csidriverlvm/register.go create mode 100644 pkg/apis/csidriverlvm/types.go create mode 100644 pkg/apis/csidriverlvm/v1alpha1/doc.go create mode 100644 pkg/apis/csidriverlvm/v1alpha1/register.go create mode 100644 pkg/apis/csidriverlvm/v1alpha1/types.go create mode 100644 pkg/apis/csidriverlvm/v1alpha1/zz_generated.deepcopy.go create mode 100644 pkg/apis/csidriverlvm/v1alpha1/zz_generated.defaults.go create mode 100644 pkg/apis/csidriverlvm/zz_generated.deepcopy.go create mode 100644 pkg/cmd/config.go create mode 100644 pkg/cmd/options.go create mode 100644 pkg/controller/csi-driver-lvm/actuator.go create mode 100644 pkg/controller/csi-driver-lvm/add.go create mode 100644 pkg/controller/healthcheck/registration.go create mode 100644 pkg/imagevector/imagevector.go create mode 100644 pkg/kapiserver/ensurer.go create mode 100644 pkg/kapiserver/webhook.go diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..729e024 --- /dev/null +++ b/.gitignore @@ -0,0 +1,9 @@ +.idea/ +vendor +tools/vendor +VERSION +helm +.vscode +hack/tools/bin/* +bin +.ci/ \ No newline at end of file diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..51888cd --- /dev/null +++ b/Dockerfile @@ -0,0 +1,12 @@ +FROM golang:1.23 AS builder + +WORKDIR /go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm +COPY . . +RUN make install \ + && strip /go/bin/gardener-extension-csi-driver-lvm + +FROM alpine:3.20 +WORKDIR / +COPY charts /charts +COPY --from=builder /go/bin/gardener-extension-csi-driver-lvm /gardener-extension-csi-driver-lvm +CMD ["/gardener-extension-csi-driver-lvm"] diff --git a/Dockerfile.dev b/Dockerfile.dev new file mode 100644 index 0000000..0dfa6b1 --- /dev/null +++ b/Dockerfile.dev @@ -0,0 +1,3 @@ +FROM alpine:3.20 +COPY bin/gardener-extension-csi-driver-lvm /gardener-extension-csi-driver-lvm +CMD ["/gardener-extension-csi-driver-lvm"] diff --git a/LICENCE b/LICENCE new file mode 100644 index 0000000..7f3913d --- /dev/null +++ b/LICENCE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2020 by the metal-stack. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..8e0a98b --- /dev/null +++ b/Makefile @@ -0,0 +1,104 @@ +ENSURE_GARDENER_MOD := $(shell go get github.com/gardener/gardener@$$(go list -m -f "{{.Version}}" github.com/gardener/gardener)) +GARDENER_HACK_DIR := $(shell go list -m -f "{{.Dir}}" github.com/gardener/gardener)/hack +IMAGE_TAG := $(or ${GITHUB_TAG_NAME}, latest) +REGISTRY := ghcr.io/metal-stack +IMAGE_PREFIX := $(REGISTRY) +REPO_ROOT := $(shell dirname "$(realpath $(lastword $(MAKEFILE_LIST)))") +HACK_DIR := $(REPO_ROOT)/hack +HOSTNAME := $(shell hostname) +LD_FLAGS := "-w -X github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/version.Version=$(IMAGE_TAG)" +VERIFY := true +LEADER_ELECTION := false +IGNORE_OPERATION_ANNOTATION := false +WEBHOOK_CONFIG_URL := localhost + +GOLANGCI_LINT_VERSION := v1.61.0 +GO_VERSION := 1.23 + +ifeq ($(CI),true) + DOCKER_TTY_ARG="" +else + DOCKER_TTY_ARG=t +endif + +export GO111MODULE := on + +TOOLS_DIR := $(HACK_DIR)/tools +include $(GARDENER_HACK_DIR)/tools.mk + +################################################################# +# Rules related to binary build, Docker image build and release # +################################################################# + +.PHONY: tidy +tidy: + @GO111MODULE=on go mod tidy + @mkdir -p $(REPO_ROOT)/.ci/hack && cp $(GARDENER_HACK_DIR)/.ci/* $(REPO_ROOT)/.ci/hack/ && chmod +xw $(REPO_ROOT)/.ci/hack/* + +.PHONY: build +build: + go build -ldflags $(LD_FLAGS) -tags netgo -o bin/gardener-extension-csi-driver-lvm ./cmd/gardener-extension-csi-driver-lvm + +.PHONY: install +install: tidy $(HELM) + @LD_FLAGS="-w -X github.com/gardener/$(EXTENSION_PREFIX)-$(NAME)/pkg/version.Version=$(VERSION)" \ + bash $(GARDENER_HACK_DIR)/install.sh ./... + +.PHONY: docker-image +docker-image: + @docker build --no-cache \ + --build-arg VERIFY=$(VERIFY) \ + --tag $(IMAGE_PREFIX)/gardener-extension-csi-driver-lvm:$(IMAGE_TAG) \ + --file Dockerfile --memory 6g . + +.PHONY: docker-push +docker-push: + @docker push $(IMAGE_PREFIX)/gardener-extension-csi-driver-lvm:$(IMAGE_TAG) + +##################################################################### +# Rules for verification, formatting, linting, testing and cleaning # +##################################################################### + +.PHONY: revendor +revendor: + @GO111MODULE=on go mod vendor + @GO111MODULE=on go mod tidy + @chmod +x $(REPO_ROOT)/vendor/github.com/gardener/gardener/hack/* + @chmod +x $(REPO_ROOT)/vendor/github.com/gardener/gardener/hack/.ci/* + @$(REPO_ROOT)/hack/update-github-templates.sh + +.PHONY: clean +clean: + @$(shell find ./example -type f -name "controller-registration.yaml" -exec rm '{}' \;) + @bash $(GARDENER_HACK_DIR)/clean.sh ./cmd/... ./pkg/... + +.PHONY: check-generate +check-generate: + @$(REPO_ROOT)/vendor/github.com/gardener/gardener/hack/check-generate.sh $(REPO_ROOT) + +.PHONY: generate +generate: $(VGOPATH) $(HELM) $(YQ) + @REPO_ROOT=$(REPO_ROOT) VGOPATH=$(VGOPATH) GARDENER_HACK_DIR=$(GARDENER_HACK_DIR) bash $(GARDENER_HACK_DIR)/generate-sequential.sh ./charts/... ./cmd/... ./pkg/... + +.PHONY: generate-in-docker +generate-in-docker: tidy $(HELM) $(YQ) + # echo $(shell git describe --abbrev=0 --tags) > VERSION + docker run --rm -i$(DOCKER_TTY_ARG) -v $(PWD):/go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm golang:$(GO_VERSION) \ + sh -c "cd /go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm \ + && make generate \ + # && make install generate \ + && chown -R $(shell id -u):$(shell id -g) ." + +.PHONY: test +test: + go test -v ./... + +.PHONY: push-to-gardener-local +push-to-gardener-local: + CGO_ENABLED=1 go build \ + -ldflags "-extldflags '-static -s -w'" \ + -tags 'osusergo netgo static_build' \ + -o bin/gardener-extension-csi-driver-lvm \ + ./cmd/gardener-extension-csi-driver-lvm + docker build -f Dockerfile.dev -t ghcr.io/metal-stack/gardener-extension-csi-driver-lvm:latest . + kind --name gardener-local load docker-image ghcr.io/metal-stack/gardener-extension-csi-driver-lvm:latest diff --git a/charts/charts.go b/charts/charts.go new file mode 100644 index 0000000..4c9b07e --- /dev/null +++ b/charts/charts.go @@ -0,0 +1,13 @@ +package charts + +import ( + "embed" +) + +// InternalChart embeds the internal charts in embed.FS +// +//go:embed internal +var InternalChart embed.FS + +// InternalChartsPath is the path to the internal charts +const InternalChartsPath = "internal" diff --git a/charts/gardener-extension-csi-driver-lvm/Chart.yaml b/charts/gardener-extension-csi-driver-lvm/Chart.yaml new file mode 100644 index 0000000..73a6e37 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/Chart.yaml @@ -0,0 +1,5 @@ +apiVersion: v1 +appVersion: "1.0" +description: A Helm chart for the csi-driver-lvm extension +name: gardener-extension-csi-driver-lvm +version: 0.2.0 diff --git a/charts/gardener-extension-csi-driver-lvm/doc.go b/charts/gardener-extension-csi-driver-lvm/doc.go new file mode 100644 index 0000000..4776100 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/doc.go @@ -0,0 +1,4 @@ +//go:generate sh -c "bash $GARDENER_HACK_DIR/generate-controller-registration.sh csi-driver-lvm . $(cat ../../VERSION) ../../example/controller-registration.yaml Extension:csi-driver-lvm" + +// Package chart enables go:generate support for generating the correct controller registration. +package chart diff --git a/charts/gardener-extension-csi-driver-lvm/templates/_helpers.tpl b/charts/gardener-extension-csi-driver-lvm/templates/_helpers.tpl new file mode 100644 index 0000000..b25a762 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/templates/_helpers.tpl @@ -0,0 +1,27 @@ +{{- define "name" -}} +gardener-extension-csi-driver-lvm +{{- end -}} + +{{- define "labels.app.key" -}} +app.kubernetes.io/name +{{- end -}} +{{- define "labels.app.value" -}} +{{ include "name" . }} +{{- end -}} + +{{- define "labels" -}} +{{ include "labels.app.key" . }}: {{ include "labels.app.value" . }} +app.kubernetes.io/instance: {{ .Release.Name }} +{{- end -}} + +{{- define "image" -}} + {{- if hasPrefix "sha256:" .Values.image.tag }} + {{- printf "%s@%s" .Values.image.repository .Values.image.tag }} + {{- else }} + {{- printf "%s:%s" .Values.image.repository .Values.image.tag }} + {{- end }} +{{- end }} + +{{- define "deploymentversion" -}} +apps/v1 +{{- end -}} diff --git a/charts/gardener-extension-csi-driver-lvm/templates/configmap-imagevector-overwrite.yaml b/charts/gardener-extension-csi-driver-lvm/templates/configmap-imagevector-overwrite.yaml new file mode 100644 index 0000000..42499d8 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/templates/configmap-imagevector-overwrite.yaml @@ -0,0 +1,12 @@ +{{- if .Values.imageVectorOverwrite }} +apiVersion: v1 +kind: ConfigMap +metadata: + name: {{ include "name" . }}-imagevector-overwrite + namespace: {{ .Release.Namespace }} + labels: +{{ include "labels" . | indent 4 }} +data: + images_overwrite.yaml: | +{{ .Values.imageVectorOverwrite | indent 4 }} +{{- end }} diff --git a/charts/gardener-extension-csi-driver-lvm/templates/configmap.yaml b/charts/gardener-extension-csi-driver-lvm/templates/configmap.yaml new file mode 100644 index 0000000..ff796a7 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/templates/configmap.yaml @@ -0,0 +1,20 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: {{ include "name" . }}-configmap + namespace: {{ .Release.Namespace }} + labels: +{{ include "labels" . | indent 4 }} +data: + config.yaml: | + --- + apiVersion: csi-driver-lvm.metal.extensions.config.gardener.cloud/v1alpha1 + kind: ControllerConfiguration +{{- if .Values.config.clientConnection }} + clientConnection: + acceptContentTypes: {{ required ".Values.config.clientConnection.acceptContentTypes is required" .Values.config.clientConnection.acceptContentTypes }} + contentType: {{ required ".Values.config.clientConnection.contentType is required" .Values.config.clientConnection.contentType }} + qps: {{ required ".Values.config.clientConnection.qps is required" .Values.config.clientConnection.qps }} + burst: {{ required ".Values.config.clientConnection.burst is required" .Values.config.clientConnection.burst }} +{{- end }} + diff --git a/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml b/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml new file mode 100644 index 0000000..760077b --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml @@ -0,0 +1,105 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: {{ include "name" . }} + namespace: {{ .Release.Namespace }} + labels: +{{ include "labels" . | indent 4 }} +spec: + revisionHistoryLimit: 0 + replicas: {{ .Values.replicaCount }} + selector: + matchLabels: +{{ include "labels" . | indent 6 }} + template: + metadata: + annotations: + {{- if .Values.imageVectorOverwrite }} + checksum/configmap-csi-driver-lvm-imagevector-overwrite: {{ include (print $.Template.BasePath "/configmap-imagevector-overwrite.yaml") . | sha256sum }} + {{- end }} + checksum/configmap-{{ include "name" . }}-config: {{ include (print $.Template.BasePath "/configmap.yaml") . | sha256sum }} + labels: + networking.gardener.cloud/to-runtime-apiserver: allowed + networking.gardener.cloud/to-dns: allowed + networking.gardener.cloud/to-public-networks: allowed + networking.gardener.cloud/to-private-networks: allowed + networking.resources.gardener.cloud/to-all-shoots-kube-apiserver-tcp-443: allowed +{{ include "labels" . | indent 8 }} + spec: + containers: + - name: {{ include "name" . }} + image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}" + imagePullPolicy: {{ .Values.image.pullPolicy }} + command: + - /gardener-extension-csi-driver-lvm + - --config=/etc/{{ include "name" . }}/config/config.yaml + - --max-concurrent-reconciles={{ .Values.controllers.concurrentSyncs }} + - --healthcheck-max-concurrent-reconciles={{ .Values.controllers.healthcheck.concurrentSyncs }} + - --ignore-operation-annotation={{ .Values.controllers.ignoreOperationAnnotation }} + - --webhook-config-namespace={{ .Release.Namespace }} + - --webhook-config-server-port={{ .Values.webhookConfig.serverPort }} + - --disable-controllers={{ .Values.disableControllers | join "," }} + {{- if .Values.metricsPort }} + - --metrics-bind-address=:{{ .Values.metricsPort }} + {{- end }} + {{- if .Values.healthPort }} + - --health-bind-address=:{{ .Values.healthPort }} + {{- end }} + {{- if .Values.gardener.version }} + - --gardener-version={{ .Values.gardener.version }} + {{- end }} + - --log-level={{ .Values.logLevel | default "info" }} + - --log-format={{ .Values.logFormat | default "json" }} + env: + - name: BACKEND_SECRET_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + - name: BACKEND_SECRET_PREFIX + value: default-backend-secret- + - name: LEADER_ELECTION_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.imageVectorOverwrite }} + - name: IMAGEVECTOR_OVERWRITE + value: /charts_overwrite/images_overwrite.yaml + {{- end }} + ports: + - name: webhook-server + containerPort: {{ .Values.webhookConfig.serverPort }} + protocol: TCP +{{- if .Values.resources }} + resources: +{{ toYaml .Values.resources | nindent 10 }} +{{- end }} + volumeMounts: + - name: config + mountPath: /etc/{{ include "name" . }}/config + {{- if .Values.imageVectorOverwrite }} + - name: imagevector-overwrite + mountPath: /charts_overwrite/ + readOnly: true + {{- end }} + serviceAccountName: {{ include "name" . }} + # affinity: + # podAntiAffinity: + # requiredDuringSchedulingIgnoredDuringExecution: + # - labelSelector: + # matchExpressions: + # - key: {{ include "labels.app.key" . }} + # operator: In + # values: + # - {{ include "labels.app.value" . }} + # topologyKey: "kubernetes.io/hostname" + volumes: + - name: config + configMap: + name: {{ include "name" . }}-configmap + defaultMode: 420 + {{- if .Values.imageVectorOverwrite }} + - name: imagevector-overwrite + configMap: + name: {{ include "name" . }}-imagevector-overwrite + defaultMode: 420 + {{- end }} diff --git a/charts/gardener-extension-csi-driver-lvm/templates/poddisruptionbudget.yaml b/charts/gardener-extension-csi-driver-lvm/templates/poddisruptionbudget.yaml new file mode 100644 index 0000000..6a135cc --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/templates/poddisruptionbudget.yaml @@ -0,0 +1,14 @@ +{{- if gt (int .Values.replicaCount) 1 }} +apiVersion: policy/v1beta1 +kind: PodDisruptionBudget +metadata: + name: {{ include "name" . }} + namespace: {{ .Release.Namespace }} + labels: +{{ include "labels" . | indent 4 }} +spec: + maxUnavailable: {{ sub (int .Values.replicaCount) 1 }} + selector: + matchLabels: +{{ include "labels" . | indent 6 }} +{{- end }} diff --git a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml new file mode 100644 index 0000000..5549ce8 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml @@ -0,0 +1,122 @@ +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: {{ include "name" . }} + labels: +{{ include "labels" . | indent 4 }} +rules: +rules: +- apiGroups: + - extensions.gardener.cloud + resources: + - clusters + verbs: + - get + - list + - watch +- apiGroups: + - admissionregistration.k8s.io + resources: + - mutatingwebhookconfigurations + verbs: + - get + - list + - watch + - update + - create + - patch +- apiGroups: + - extensions.gardener.cloud + resources: + - extensions + - extensions/status + verbs: + - get + - list + - watch + - patch + - update +- apiGroups: + - resources.gardener.cloud + resources: + - managedresources + verbs: + - get + - list + - watch + - create + - update + - patch + - delete +- apiGroups: + - "" + resources: + - secrets + - configmaps + verbs: + - get + - list + - watch + - create + - update + - patch + - delete +- apiGroups: + - "" + resources: + - namespaces + verbs: + - get + - list + - watch +- apiGroups: + - "" + resources: + - events + verbs: + - create + - update + - patch +- apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: + - create + - list + - watch +- apiGroups: + - coordination.k8s.io + resources: + - leases + resourceNames: + - extension-csi-driver-lvm-leader-election + verbs: + - update + - get +# dns records seem to be a regression? +- apiGroups: + - extensions.gardener.cloud + resources: + - dnsrecords + - dnsrecords/status + verbs: + - get + - list + - watch +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: {{ include "name" . }} + labels: +{{ include "labels" . | indent 4 }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ include "name" . }} +subjects: +- kind: ServiceAccount + name: {{ include "name" . }} + namespace: {{ .Release.Namespace }} \ No newline at end of file diff --git a/charts/gardener-extension-csi-driver-lvm/templates/service.yaml b/charts/gardener-extension-csi-driver-lvm/templates/service.yaml new file mode 100644 index 0000000..6d5f676 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/templates/service.yaml @@ -0,0 +1,24 @@ +apiVersion: v1 +kind: Service +metadata: + name: {{ include "name" . }} + namespace: {{ .Release.Namespace }} + annotations: + networking.resources.gardener.cloud/from-world-to-ports: '[{"protocol":"TCP","port":{{ .Values.webhookConfig.serverPort }}}]' + networking.resources.gardener.cloud/from-all-seed-scrape-targets-allowed-ports: '[{"port":{{ .Values.metricsPort }},"protocol":"TCP"}]' + networking.resources.gardener.cloud/from-all-webhook-targets-allowed-ports: '[{"protocol":"TCP","port":{{ .Values.webhookConfig.serverPort }}}]' + networking.resources.gardener.cloud/namespace-selectors: '[{"matchLabels":{"kubernetes.io/metadata.name":"garden"}},{"matchLabels":{"gardener.cloud/role":"shoot"}}]' + networking.resources.gardener.cloud/pod-label-selector-namespace-alias: extensions + # TODO: This label approach is deprecated and no longer needed in the future. Remove them as soon as gardener/gardener@v1.75 has been released. + networking.resources.gardener.cloud/from-policy-pod-label-selector: all-seed-scrape-targets + networking.resources.gardener.cloud/from-policy-allowed-ports: '[{"port":{{ .Values.metricsPort }},"protocol":"TCP"}]' + labels: +{{ include "labels" . | indent 4 }} +spec: + type: ClusterIP + selector: +{{ include "labels" . | indent 6 }} + ports: + - port: 443 + protocol: TCP + targetPort: {{ .Values.webhookConfig.serverPort }} diff --git a/charts/gardener-extension-csi-driver-lvm/templates/serviceaccount.yaml b/charts/gardener-extension-csi-driver-lvm/templates/serviceaccount.yaml new file mode 100644 index 0000000..52458f7 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/templates/serviceaccount.yaml @@ -0,0 +1,7 @@ +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ include "name" . }} + namespace: {{ .Release.Namespace }} + labels: +{{ include "labels" . | indent 4 }} diff --git a/charts/gardener-extension-csi-driver-lvm/values.yaml b/charts/gardener-extension-csi-driver-lvm/values.yaml new file mode 100644 index 0000000..72ce9d1 --- /dev/null +++ b/charts/gardener-extension-csi-driver-lvm/values.yaml @@ -0,0 +1,45 @@ +image: + repository: ghcr.io/metal-stack/gardener-extension-csi-driver-lvm + tag: latest + pullPolicy: IfNotPresent + +replicaCount: 1 +resources: {} + +controllers: + concurrentSyncs: 5 + healthcheck: + concurrentSyncs: 5 + heartbeat: + renewIntervalSeconds: 30 + ignoreOperationAnnotation: false + +disableControllers: [] +disableWebhooks: [] + +# imageVectorOverwrite: | +# images: +# - name: pause-container +# sourceRepository: github.com/kubernetes/kubernetes/blob/master/build/pause/Dockerfile +# repository: gcr.io/google_containers/pause-amd64 +# tag: "3.0" +# version: 1.11.x +# - name: pause-container +# sourceRepository: github.com/kubernetes/kubernetes/blob/master/build/pause/Dockerfile +# repository: gcr.io/google_containers/pause-amd64 +# tag: "3.1" +# version: ">= 1.12" +# ... + +webhookConfig: + serverPort: 443 + +config: + clientConnection: + acceptContentTypes: application/json + contentType: application/json + qps: 100 + burst: 130 + +gardener: + version: "" diff --git a/charts/images.go b/charts/images.go new file mode 100644 index 0000000..db463fa --- /dev/null +++ b/charts/images.go @@ -0,0 +1,7 @@ +package charts + +import _ "embed" + +// ImagesYAML contains the content of the images.yaml file +//go:embed images.yaml +var ImagesYAML string diff --git a/charts/images.yaml b/charts/images.yaml new file mode 100644 index 0000000..13c0252 --- /dev/null +++ b/charts/images.yaml @@ -0,0 +1,29 @@ +images: +- name: csi-driver-lvm + sourceRepository: https://github.com/metal-stack/csi-driver-lvm + repository: ghcr.io/metal-stack/ + tag: "v0.6.0" +- name: csi-driver-lvm-provisioner + sourceRepository: https://github.com/metal-stack/csi-driver-lvm + repository: ghcr.io/metal-stack/ + tag: "v0.6.0" +- name: csi-attacher + sourceRepository: https://github.com/kubernetes-csi/external-attacher + repository: k8s.gcr.io/sig-storage/ + tag: "v3.5.0" +- name: livenessprobe + sourceRepository: https://github.com/kubernetes-csi/livenessprobe + repository: k8s.gcr.io/sig-storage/ + tag: "v2.7.0" +- name: csi-provisioner + sourceRepository: https://github.com/kubernetes-csi/external-provisioner + repository: k8s.gcr.io/sig-storage/ + tag: "v3.2.1" +- name: csi-node-driver-registrar + sourceRepository: https://github.com/kubernetes-csi/node-driver-registrar + repository: k8s.gcr.io/sig-storage/ + tag: "v2.5.1" +- name: csi-resizer + sourceRepository: https://github.com/kubernetes-csi/external-resizer + repository: k8s.gcr.io/sig-storage/ + tag: "v2.5.1" diff --git a/charts/internal/csi-driver-lvm/Chart.yaml b/charts/internal/csi-driver-lvm/Chart.yaml new file mode 100644 index 0000000..73a6e37 --- /dev/null +++ b/charts/internal/csi-driver-lvm/Chart.yaml @@ -0,0 +1,5 @@ +apiVersion: v1 +appVersion: "1.0" +description: A Helm chart for the csi-driver-lvm extension +name: gardener-extension-csi-driver-lvm +version: 0.2.0 diff --git a/charts/internal/csi-driver-lvm/templates/daemonset.yaml b/charts/internal/csi-driver-lvm/templates/daemonset.yaml new file mode 100644 index 0000000..b8e67c3 --- /dev/null +++ b/charts/internal/csi-driver-lvm/templates/daemonset.yaml @@ -0,0 +1,174 @@ +apiVersion: apps/v1 +kind: DaemonSet +metadata: + name: csi-driver-lvm-plugin + namespace: {{ .Release.Namespace }} +spec: + revisionHistoryLimit: 10 + selector: + matchLabels: + app: csi-driver-lvm-plugin + template: + metadata: + labels: + app: csi-driver-lvm-plugin + spec: + serviceAccountName: csi-driver-lvm-plugin +{{- if .Values.tolerations.plugin }} + tolerations: +{{ toYaml .Values.tolerations.plugin | indent 8 }} +{{- end }} +{{- if .Values.nodeSelector.plugin }} + nodeSelector: +{{ toYaml .Values.nodeSelector.plugin | indent 8 }} +{{- end }} + containers: + - name: node-driver-registrar + args: + - --v=5 + - --csi-address=/csi/csi.sock + - --kubelet-registration-path={{ .Values.kubernetes.kubeletPath }}/plugins/csi-driver-lvm/csi.sock + env: + - name: KUBE_NODE_NAME + valueFrom: + fieldRef: + apiVersion: v1 + fieldPath: spec.nodeName + image: {{ .Values.sidecarImages.registrar }} + imagePullPolicy: IfNotPresent + resources: {} + securityContext: + readOnlyRootFilesystem: true + terminationMessagePath: /dev/termination-log + terminationMessagePolicy: File + volumeMounts: + - mountPath: /csi + name: socket-dir + - mountPath: {{ .Values.kubernetes.kubeletPath }}/plugins/csi-driver-lvm + name: socket-dir + - mountPath: /registration + name: registration-dir + - name: csi-driver-lvm-plugin + args: + - --drivername=lvm.csi.metal-stack.io + - --endpoint=unix:///csi/csi.sock + - --hostwritepath={{ .Values.lvm.hostWritePath }} + - --devices={{ .Values.lvm.devicePattern }} + - --nodeid=$(KUBE_NODE_NAME) + - --vgname={{ .Values.lvm.vgName }} + - --namespace={{ .Release.Namespace }} + - --provisionerimage={{ index .Values.images "csi-driver-lvm-provisioner" }} + - --pullpolicy=IfNotPresent + env: + - name: KUBE_NODE_NAME + valueFrom: + fieldRef: + apiVersion: v1 + fieldPath: spec.nodeName + image: {{ index .Values.images "csi-driver-lvm-plugin" }} + imagePullPolicy: IfNotPresent + livenessProbe: + failureThreshold: 5 + httpGet: + path: /healthz + port: healthz + scheme: HTTP + initialDelaySeconds: 10 + periodSeconds: 2 + successThreshold: 1 + timeoutSeconds: 3 + ports: + - containerPort: 9898 + name: healthz + protocol: TCP + resources: {} + securityContext: + readOnlyRootFilesystem: true + privileged: true + terminationMessagePath: /termination.log + terminationMessagePolicy: File + volumeMounts: + - mountPath: /csi + name: socket-dir + - mountPath: {{ .Values.kubernetes.kubeletPath }}/pods + mountPropagation: Bidirectional + name: mountpoint-dir + - mountPath: {{ .Values.kubernetes.kubeletPath }}/plugins + mountPropagation: Bidirectional + name: plugins-dir + - mountPath: /dev + name: dev-dir + mountPropagation: Bidirectional + - mountPath: /lib/modules + name: mod-dir + - mountPath: /etc/lvm/backup + name: lvmbackup + mountPropagation: Bidirectional + - mountPath: /etc/lvm/cache + name: lvmcache + mountPropagation: Bidirectional + - mountPath: /etc/lvm/archive + name: lvmarchive + mountPropagation: Bidirectional + - mountPath: /run/lock/lvm + name: lvmlock + mountPropagation: Bidirectional + - name: liveness-probe + args: + - --csi-address=/csi/csi.sock + - --health-port=9898 + image: {{ .Values.sidecarImages.livenessprobe }} + imagePullPolicy: IfNotPresent + resources: {} + securityContext: + readOnlyRootFilesystem: true + terminationMessagePath: /dev/termination-log + terminationMessagePolicy: File + volumeMounts: + - mountPath: /csi + name: socket-dir + dnsPolicy: ClusterFirst + restartPolicy: Always + schedulerName: default-scheduler + securityContext: {} + terminationGracePeriodSeconds: 30 + volumes: + - hostPath: + path: {{ .Values.kubernetes.kubeletPath }}/plugins/csi-driver-lvm + type: DirectoryOrCreate + name: socket-dir + - hostPath: + path: {{ .Values.kubernetes.kubeletPath }}/pods + type: DirectoryOrCreate + name: mountpoint-dir + - hostPath: + path: {{ .Values.kubernetes.kubeletPath }}/plugins_registry + type: Directory + name: registration-dir + - hostPath: + path: {{ .Values.kubernetes.kubeletPath }}/plugins + type: Directory + name: plugins-dir + - hostPath: + path: /dev + type: Directory + name: dev-dir + - hostPath: + path: /lib/modules + name: mod-dir + - hostPath: + path: {{ .Values.lvm.hostWritePath }}/backup + type: DirectoryOrCreate + name: lvmbackup + - hostPath: + path: {{ .Values.lvm.hostWritePath }}/cache + type: DirectoryOrCreate + name: lvmcache + - hostPath: + path: {{ .Values.lvm.hostWritePath }}/archive + type: DirectoryOrCreate + name: lvmarchive + - hostPath: + path: {{ .Values.lvm.hostWritePath }}/lock + type: DirectoryOrCreate + name: lvmlock \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/driver.yaml b/charts/internal/csi-driver-lvm/templates/driver.yaml new file mode 100644 index 0000000..c45ac81 --- /dev/null +++ b/charts/internal/csi-driver-lvm/templates/driver.yaml @@ -0,0 +1,10 @@ +apiVersion: storage.k8s.io/v1 +kind: CSIDriver +metadata: + name: csi-driver-lvm +spec: + volumeLifecycleModes: + - Persistent + - Ephemeral + podInfoOnMount: true + attachRequired: false \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/helpers.tpl b/charts/internal/csi-driver-lvm/templates/helpers.tpl new file mode 100644 index 0000000..ff883ef --- /dev/null +++ b/charts/internal/csi-driver-lvm/templates/helpers.tpl @@ -0,0 +1,32 @@ +{{- define "name" -}} +gardener-extension-csi-driver-lvm +{{- end -}} + +{{- define "labels.app.key" -}} +app.kubernetes.io/name +{{- end -}} +{{- define "labels.app.value" -}} +{{ include "name" . }} +{{- end -}} + +{{- define "labels" -}} +{{ include "labels.app.key" . }}: {{ include "labels.app.value" . }} +app.kubernetes.io/instance: {{ .Release.Name }} +{{- end -}} + +{{- define "image" -}} + {{- if hasPrefix "sha256:" .Values.image.tag }} + {{- printf "%s@%s" .Values.image.repository .Values.image.tag }} + {{- else }} + {{- printf "%s:%s" .Values.image.repository .Values.image.tag }} + {{- end }} +{{- end }} + +{{- define "deploymentversion" -}} +apps/v1 +{{- end -}} + + +{{- define "storageclassversion" -}} +storage.k8s.io/v1 +{{- end -}} diff --git a/charts/internal/csi-driver-lvm/templates/rbac.yaml b/charts/internal/csi-driver-lvm/templates/rbac.yaml new file mode 100644 index 0000000..77ccd24 --- /dev/null +++ b/charts/internal/csi-driver-lvm/templates/rbac.yaml @@ -0,0 +1,89 @@ +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: csi-driver-lvm-controller +rules: + - apiGroups: [""] + resources: ["persistentvolumes"] + verbs: ["get", "list", "watch", "update", "patch", "create", "delete"] + - apiGroups: ["storage.k8s.io"] + resources: ["csinodes"] + verbs: ["get", "list", "watch"] + - apiGroups: ["storage.k8s.io"] + resources: ["volumeattachments"] + verbs: ["get", "list", "watch", "update", "patch"] + - apiGroups: [""] + resources: ["persistentvolumeclaims"] + verbs: ["get", "list", "watch", "update", "patch"] + - apiGroups: [""] + resources: ["persistentvolumeclaims/status"] + verbs: ["update", "patch"] + - apiGroups: ["storage.k8s.io"] + resources: ["storageclasses"] + verbs: ["get", "list", "watch"] + - apiGroups: [""] + resources: ["events"] + verbs: ["list", "watch", "create", "update", "patch"] + - apiGroups: ["storage.k8s.io"] + resources: ["csinodes"] + verbs: ["get", "list", "watch"] + - apiGroups: [""] + resources: ["nodes"] + verbs: ["get", "list", "watch"] + - apiGroups: ["storage.k8s.io"] + resources: ["volumeattachments/status"] + verbs: ["patch"] + - apiGroups: [""] + resources: ["pods"] + verbs: ["get", "list", "watch"] +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: csi-driver-lvm-controller +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: csi-driver-lvm-controller +subjects: +- kind: ServiceAccount + name: csi-driver-lvm-controller + namespace: {{ .Release.Namespace }} +--- +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-driver-lvm-plugin +rules: + - apiGroups: [""] + resources: ["persistentvolumes"] + verbs: ["get", "list", "watch", "update", "patch", "create", "delete"] + - apiGroups: [""] + resources: ["persistentvolumeclaims"] + verbs: ["get", "list", "watch"] + - apiGroups: [""] + resources: ["persistentvolumeclaims/status"] + verbs: ["update", "patch"] + - apiGroups: [""] + resources: ["events"] + verbs: ["list", "watch", "create", "update", "patch"] + - apiGroups: [""] + resources: ["pods"] + verbs: ["list", "get", "watch", "create", "delete"] + - apiGroups: [""] + resources: ["nodes"] + verbs: ["get", "list", "watch"] +--- +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-driver-lvm-plugin +subjects: + - kind: ServiceAccount + name: csi-driver-lvm-plugin + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: csi-driver-lvm-plugin + apiGroup: rbac.authorization.k8s.io \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/serviceaccount.yaml b/charts/internal/csi-driver-lvm/templates/serviceaccount.yaml new file mode 100644 index 0000000..b5a02a1 --- /dev/null +++ b/charts/internal/csi-driver-lvm/templates/serviceaccount.yaml @@ -0,0 +1,12 @@ +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: csi-driver-lvm-controller + namespace: {{ .Release.Namespace }} +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: csi-driver-lvm-plugin + namespace: {{ .Release.Namespace }} \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/statefulset.yaml b/charts/internal/csi-driver-lvm/templates/statefulset.yaml new file mode 100644 index 0000000..dfb957b --- /dev/null +++ b/charts/internal/csi-driver-lvm/templates/statefulset.yaml @@ -0,0 +1,77 @@ +kind: StatefulSet +apiVersion: apps/v1 +metadata: + name: csi-driver-lvm-controller +spec: + serviceName: csi-driver-lvm-controller + replicas: 1 + selector: + matchLabels: + app: csi-driver-lvm-controller + template: + metadata: + labels: + app: csi-driver-lvm-controller + spec: + affinity: + podAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app + operator: In + values: + - csi-driver-lvm-plugin + topologyKey: kubernetes.io/hostname +{{- if .Values.nodeSelector.provisioner }} + nodeSelector: +{{ toYaml .Values.nodeSelector.provisioner | indent 8 }} +{{- end }} +{{- if .Values.tolerations.provisioner }} + tolerations: +{{ toYaml .Values.tolerations.provisioner | indent 8 }} +{{- end }} + serviceAccountName: csi-driver-lvm-controller + containers: + - name: csi-attacher + image: {{ .Values.sidecarImages.attacher }} + imagePullPolicy: IfNotPresent + args: + - --v=5 + - --csi-address=/csi/csi.sock + securityContext: + readOnlyRootFilesystem: true + privileged: true + volumeMounts: + - mountPath: /csi + name: socket-dir + - name: csi-provisioner + image: {{ .Values.sidecarImages.provisioner }} + imagePullPolicy: IfNotPresent + args: + - -v=5 + - --csi-address=/csi/csi.sock + - --feature-gates=Topology=true + securityContext: + readOnlyRootFilesystem: true + privileged: true + volumeMounts: + - mountPath: /csi + name: socket-dir + - name: csi-resizer + image: {{ .Values.sidecarImages.resizer }} + imagePullPolicy: IfNotPresent + args: + - -v=5 + - -csi-address=/csi/csi.sock + securityContext: + readOnlyRootFilesystem: true + privileged: true + volumeMounts: + - mountPath: /csi + name: socket-dir + volumes: + - hostPath: + path: {{ .Values.kubernetes.kubeletPath }}/plugins/csi-driver-lvm + type: DirectoryOrCreate + name: socket-dir \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/storageclasses.yaml b/charts/internal/csi-driver-lvm/templates/storageclasses.yaml new file mode 100644 index 0000000..7af6704 --- /dev/null +++ b/charts/internal/csi-driver-lvm/templates/storageclasses.yaml @@ -0,0 +1,66 @@ +--- +{{- $storageClass := .Values.storageClasses.linear -}} +{{ if $storageClass.enabled }} +apiVersion: storage.k8s.io/v1 +kind: StorageClass +metadata: + name: csi-driver-lvm-linear +{{- if not (empty $storageClass.additionalAnnotations) }} + annotations: + {{- $storageClass.additionalAnnotations | toYaml | nindent 4 -}} +{{ end }} +provisioner: lvm.csi.metal-stack.io +reclaimPolicy: {{ $storageClass.reclaimPolicy }} +volumeBindingMode: WaitForFirstConsumer +allowVolumeExpansion: true +parameters: + type: "linear" +{{ end }} +--- +{{- $storageClass := .Values.storageClasses.mirror -}} +{{ if $storageClass.enabled }} +apiVersion: storage.k8s.io/v1 +kind: StorageClass +metadata: + name: csi-driver-lvm-mirror +{{- if not (empty $storageClass.additionalAnnotations) }} + annotations: + {{- $storageClass.additionalAnnotations | toYaml | nindent 4 -}} +{{ end }} +provisioner: lvm.csi.metal-stack.io +reclaimPolicy: {{ $storageClass.reclaimPolicy }} +volumeBindingMode: WaitForFirstConsumer +allowVolumeExpansion: true +parameters: + type: "mirror" +{{ end }} +--- +{{- $storageClass := .Values.storageClasses.striped -}} +{{ if $storageClass.enabled }} +apiVersion: storage.k8s.io/v1 +kind: StorageClass +metadata: + name: csi-driver-lvm-striped +{{- if not (empty $storageClass.additionalAnnotations) }} + annotations: + {{- $storageClass.additionalAnnotations | toYaml | nindent 4 -}} +{{ end }} +provisioner: lvm.csi-metal-stack.io +reclaimPolicy: {{ $storageClass.reclaimPolicy }} +volumeBindingMode: WaitForFirstConsumer +allowVolumeExpansion: true +parameters: + type: "striped" +{{ end }} +--- +{{- $storageClass := .Values.storageClasses.linear -}} +apiVersion: storage.k8s.io/v1 +kind: StorageClass +metadata: + name: csi-lvm +provisioner: lvm.csi.metal-stack.io +volumeBindingMode: WaitForFirstConsumer +reclaimPolicy: {{ $storageClass.reclaimPolicy }} +parameters: + type: "linear" +--- \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/values.yaml b/charts/internal/csi-driver-lvm/values.yaml new file mode 100644 index 0000000..8d1e158 --- /dev/null +++ b/charts/internal/csi-driver-lvm/values.yaml @@ -0,0 +1,85 @@ +--- +lvm: + # This one you should change + devicePattern: /dev/nvme[0-9]n[0-9] + + # You will want to change this for read-only filesystems + # For example, in Talos OS, set this to "/var/etc/lvm" + hostWritePath: /etc/lvm + +images: + csi-driver-lvm-plugin: image-repository:image-tag + csi-driver-lvm-provisioner: image-repository:image-tag + +sidecarImages: + attacher: k8s.gcr.io/sig-storage/csi-attacher:v3.5.0 + livenessprobe: k8s.gcr.io/sig-storage/livenessprobe:v2.7.0 + provisioner: k8s.gcr.io/sig-storage/csi-provisioner:v3.2.1 + registrar: k8s.gcr.io/sig-storage/csi-node-driver-registrar:v2.5.1 + resizer: k8s.gcr.io/sig-storage/csi-resizer:v1.6.0 + +kubernetes: + kubeletPath: /var/lib/kubelet + +storageClasses: + default: + reclaimPolicy: Delete + linear: + enabled: true + additionalAnnotations: [] + reclaimPolicy: Delete + striped: + enabled: true + additionalAnnotations: [] + reclaimPolicy: Delete + mirror: + enabled: true + additionalAnnotations: [] + reclaimPolicy: Delete + +nodeSelector: + # The plugin daemonset will run on all nodes if it has a toleration, + # so it is not necessary to set a nodeSelector for it + + # plugin: + # node-role.kubernetes.io/master: "" + # Key name may need to be updated to 'node-role.kubernetes.io/control-plane' + # in the future + + # The provisioner has an affinity for nodes with a plugin pod, + # but since that's a daemonset, we allow more fine-grained node selection + + provisioner: + # node-role.kubernetes.io/master: "" + # Key name may need to be updated to 'node-role.kubernetes.io/control-plane' + # in the future + +tolerations: + plugin: + # - key: node-role.kubernetes.io/master + # operator: Exists + # effect: NoSchedule + # - key: node-role.kubernetes.io/control-plane + # operator: Exists + # effect: NoSchedule + provisioner: + # - key: node-role.kubernetes.io/master + # operator: Exists + # effect: NoSchedule + # - key: node-role.kubernetes.io/control-plane + # operator: Exists + # effect: NoSchedule +--- + +# ! unused/unsure +isDefaultStorageClass: true + +# lvm: +# # these are primariliy for testing purposes +# vgName: csi-lvm +# driverName: lvm.csi.metal-stack.io +# storageClassStub: csi-driver-lvm + +rbac: + create: true + pspEnabled: true diff --git a/cmd/gardener-extension-csi-driver-lvm/app/app.go b/cmd/gardener-extension-csi-driver-lvm/app/app.go new file mode 100644 index 0000000..78362a0 --- /dev/null +++ b/cmd/gardener-extension-csi-driver-lvm/app/app.go @@ -0,0 +1,37 @@ +package app + +import ( + "context" + "fmt" + + "github.com/spf13/cobra" + runtimelog "sigs.k8s.io/controller-runtime/pkg/log" +) + +var log = runtimelog.Log.WithName("gardener-extension-csi-driver-lvm") + +func NewControllerManagerCommand(ctx context.Context) *cobra.Command { + options := NewOptions() + cmd := &cobra.Command{ + Use: "gardener-extension-csi-driver-lvm", + Short: "provides csi-driver-lvm for shoot cluster", + SilenceErrors: true, + RunE: func(cmd *cobra.Command, args []string) error { + err := options.optionAggregator.Complete() + if err != nil { + return fmt.Errorf("error completing options: %w", err) + } + if err := options.heartbeatOptions.Validate(); err != nil { + return err + } + + cmd.SilenceUsage = true + + return options.run(ctx) + }, + } + + options.optionAggregator.AddFlags(cmd.Flags()) + + return cmd +} diff --git a/cmd/gardener-extension-csi-driver-lvm/app/options.go b/cmd/gardener-extension-csi-driver-lvm/app/options.go new file mode 100644 index 0000000..2385d3d --- /dev/null +++ b/cmd/gardener-extension-csi-driver-lvm/app/options.go @@ -0,0 +1,172 @@ +package app + +import ( + "context" + "fmt" + "os" + + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/install" + + corev1 "k8s.io/api/core/v1" + + extensionscontroller "github.com/gardener/gardener/extensions/pkg/controller" + heartbeatcmd "github.com/gardener/gardener/extensions/pkg/controller/heartbeat/cmd" + webhookcmd "github.com/gardener/gardener/extensions/pkg/webhook/cmd" + csidriverlvmcmd "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/cmd" + + controllercmd "github.com/gardener/gardener/extensions/pkg/controller/cmd" + "github.com/gardener/gardener/extensions/pkg/util" + ghealth "github.com/gardener/gardener/pkg/healthz" + componentbaseconfig "k8s.io/component-base/config" + "sigs.k8s.io/controller-runtime/pkg/client" + "sigs.k8s.io/controller-runtime/pkg/healthz" + "sigs.k8s.io/controller-runtime/pkg/manager" +) + +// var log = runtimelog.Log.WithName("gardener-extension-csi-driver-lvm") + +const ExtensionName = "extension-csi-driver-lvm" + +type Options struct { + generalOptions *controllercmd.GeneralOptions + csidriverlvmOptions *csidriverlvmcmd.AuthOptions + restOptions *controllercmd.RESTOptions + managerOptions *controllercmd.ManagerOptions + controllerOptions *controllercmd.ControllerOptions + heartbeatOptions *heartbeatcmd.Options + healthOptions *controllercmd.ControllerOptions + webhookOptions *webhookcmd.AddToManagerOptions + controllerSwitches *controllercmd.SwitchOptions + reconcileOptions *controllercmd.ReconcilerOptions + optionAggregator controllercmd.OptionAggregator +} + +func NewOptions() *Options { + // options for the webhook server + webhookServerOptions := &webhookcmd.ServerOptions{ + Namespace: os.Getenv("WEBHOOK_CONFIG_NAMESPACE"), + } + + webhookSwitches := csidriverlvmcmd.WebhookSwitchOptions() + webhookOptions := webhookcmd.NewAddToManagerOptions( + "csi-driver-lvm", + "", + nil, + webhookServerOptions, + webhookSwitches, + ) + + options := &Options{ + generalOptions: &controllercmd.GeneralOptions{}, + csidriverlvmOptions: &csidriverlvmcmd.AuthOptions{}, + restOptions: &controllercmd.RESTOptions{}, + managerOptions: &controllercmd.ManagerOptions{ + LeaderElection: true, + LeaderElectionID: controllercmd.LeaderElectionNameID(ExtensionName), + LeaderElectionNamespace: os.Getenv("LEADER_ELECTION_NAMESPACE"), + MetricsBindAddress: ":8080", + HealthBindAddress: ":8081", + }, + + // options for the controlplane controller + controllerOptions: &controllercmd.ControllerOptions{ + MaxConcurrentReconciles: 5, + }, + + heartbeatOptions: &heartbeatcmd.Options{ + // This is a default value. + ExtensionName: ExtensionName, + RenewIntervalSeconds: 30, + Namespace: os.Getenv("LEADER_ELECTION_NAMESPACE"), + }, + healthOptions: &controllercmd.ControllerOptions{ + // This is a default value. + MaxConcurrentReconciles: 5, + }, + controllerSwitches: csidriverlvmcmd.ControllerSwitchOptions(), + reconcileOptions: &controllercmd.ReconcilerOptions{}, + webhookOptions: webhookOptions, + } + + options.optionAggregator = controllercmd.NewOptionAggregator( + options.generalOptions, + options.csidriverlvmOptions, + options.restOptions, + options.managerOptions, + options.controllerOptions, + controllercmd.PrefixOption("heartbeat-", options.heartbeatOptions), + controllercmd.PrefixOption("healthcheck-", options.healthOptions), + options.controllerSwitches, + options.reconcileOptions, + options.webhookOptions, + ) + + return options +} + +func (options *Options) run(ctx context.Context) error { + log.Info("starting " + ExtensionName) + + util.ApplyClientConnectionConfigurationToRESTConfig(&componentbaseconfig.ClientConnectionConfiguration{ + QPS: 100.0, + Burst: 130, + }, options.restOptions.Completed().Config) + + log.Info("applied rest config") + + mgrOpts := options.managerOptions.Completed().Options() + + log.Info("completed mgr-options") + + mgrOpts.Client = client.Options{ + Cache: &client.CacheOptions{ + DisableFor: []client.Object{ + &corev1.Secret{}, + &corev1.ConfigMap{}, + }, + }, + } + + //TODO check ALL options -> + + mgr, err := manager.New(options.restOptions.Completed().Config, mgrOpts) + if err != nil { + return fmt.Errorf("could not instantiate controller-manager: %w", err) + } + + log.Info("completed rest-options") + + err = extensionscontroller.AddToScheme(mgr.GetScheme()) + if err != nil { + return fmt.Errorf("could not add mgr-scheme to extension-controller: %w", err) + } + + log.Info("added mgr-scheme to extensionscontroller") + + err = install.AddToScheme(mgr.GetScheme()) + if err != nil { + return fmt.Errorf("could not add mgr-scheme to installation") + } + + log.Info("added mgr-schme to installation") + + if err := mgr.AddReadyzCheck("informer-sync", ghealth.NewCacheSyncHealthz(mgr.GetCache())); err != nil { + return fmt.Errorf("could not add ready check for informers: %w", err) + } + + log.Info("added readyzcheck") + + if err := mgr.AddHealthzCheck("ping", healthz.Ping); err != nil { + return fmt.Errorf("could not add health check to manager: %w", err) + } + + log.Info("added healthzcheck") + + if err := mgr.Start(ctx); err != nil { + return fmt.Errorf("error running manager: %w", err) + } + + log.Info("started successfully") + + return nil +} diff --git a/cmd/gardener-extension-csi-driver-lvm/main.go b/cmd/gardener-extension-csi-driver-lvm/main.go new file mode 100644 index 0000000..2e0472d --- /dev/null +++ b/cmd/gardener-extension-csi-driver-lvm/main.go @@ -0,0 +1,21 @@ +package main + +import ( + "os" + + logger "github.com/gardener/gardener/pkg/logger" + runtimelog "sigs.k8s.io/controller-runtime/pkg/log" + "sigs.k8s.io/controller-runtime/pkg/manager/signals" + + "github.com/metal-stack/gardener-extension-csi-driver-lvm/cmd/gardener-extension-csi-driver-lvm/app" +) + +func main() { + runtimelog.SetLogger(logger.MustNewZapLogger(logger.InfoLevel, logger.FormatJSON)) + cmd := app.NewControllerManagerCommand(signals.SetupSignalHandler()) + + if err := cmd.Execute(); err != nil { + runtimelog.Log.Error(err, "error executing the main controller command") + os.Exit(1) + } +} diff --git a/example/00-componentconfig.yaml b/example/00-componentconfig.yaml new file mode 100644 index 0000000..2567da4 --- /dev/null +++ b/example/00-componentconfig.yaml @@ -0,0 +1,5 @@ +--- +apiVersion: csi-driver-lvm.metal.extensions.config.gardener.cloud/v1alpha1 +kind: ControllerConfiguration +auth: + providerTenant: a-tenant diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml new file mode 100644 index 0000000..abb544b --- /dev/null +++ b/example/controller-registration.yaml @@ -0,0 +1,24 @@ +--- +apiVersion: core.gardener.cloud/v1 +kind: ControllerDeployment +metadata: + name: csi-driver-lvm +helm: + rawChart: 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 + values: + image: + tag: v0.0.1 +--- +apiVersion: core.gardener.cloud/v1beta1 +kind: ControllerRegistration +metadata: + name: csi-driver-lvm + annotations: + security.gardener.cloud/pod-security-enforce: baseline +spec: + deployment: + deploymentRefs: + - name: csi-driver-lvm + resources: + - kind: Extension + type: csi-driver-lvm diff --git a/example/kustomization.yaml b/example/kustomization.yaml new file mode 100644 index 0000000..01d7e12 --- /dev/null +++ b/example/kustomization.yaml @@ -0,0 +1,8 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization + +resources: +- controller-registration.yaml + +patchesStrategicMerge: +- kustomize/patch-deployment.yaml diff --git a/example/kustomize/patch-deployment.yaml b/example/kustomize/patch-deployment.yaml new file mode 100644 index 0000000..17ba9a0 --- /dev/null +++ b/example/kustomize/patch-deployment.yaml @@ -0,0 +1,9 @@ +apiVersion: core.gardener.cloud/v1 +kind: ControllerDeployment +metadata: + name: csi-driver-lvm +helm: + values: + image: + tag: latest + pullPolicy: IfNotPresent diff --git a/example/kustomize/patch-registration.yaml b/example/kustomize/patch-registration.yaml new file mode 100644 index 0000000..3867daa --- /dev/null +++ b/example/kustomize/patch-registration.yaml @@ -0,0 +1,15 @@ +apiVersion: core.gardener.cloud/v1beta1 +kind: ControllerRegistration +metadata: + name: csi-driver-lvm +spec: + deployment: + policy: Always + resources: + - kind: Extension + type: csi-driver-lvm + globallyEnabled: true + lifecycle: + delete: BeforeKubeAPIServer + migrate: BeforeKubeAPIServer + reconcile: BeforeKubeAPIServer diff --git a/example/shoot.yaml b/example/shoot.yaml new file mode 100644 index 0000000..b4437cf --- /dev/null +++ b/example/shoot.yaml @@ -0,0 +1,42 @@ +--- +apiVersion: core.gardener.cloud/v1beta1 +kind: Shoot +metadata: + name: local + namespace: garden-local + annotations: + shoot.gardener.cloud/infrastructure-cleanup-wait-period-seconds: "0" + shoot.gardener.cloud/cloud-config-execution-max-delay-seconds: "0" +spec: + seedName: local + cloudProfileName: local + secretBindingName: local # dummy, doesn't contain any credentials + region: local + extensions: + - type: csi-driver-lvm + providerConfig: + apiVersion: csi-driver-lvm.metal.extensions.gardener.cloud/v1alpha1 + kind: CsiDriverLvmConfig + networking: + type: calico + nodes: 10.10.0.0/16 + provider: + type: local + workers: + - name: local + machine: + type: local + cri: + name: containerd + minimum: 1 + maximum: 1 # currently, only single-node clusters are supported + maxSurge: 1 + maxUnavailable: 0 + kubernetes: + kubelet: + seccompDefault: true + serializeImagePulls: false + registryPullQPS: 10 + registryBurst: 20 + protectKernelDefaults: true + streamingConnectionIdleTimeout: 5m diff --git a/go.mod b/go.mod new file mode 100644 index 0000000..4aa941c --- /dev/null +++ b/go.mod @@ -0,0 +1,143 @@ +module github.com/metal-stack/gardener-extension-csi-driver-lvm + +go 1.23 + +require ( + github.com/ahmetb/gen-crd-api-reference-docs v0.3.0 + github.com/gardener/gardener v1.97.4 + github.com/go-logr/logr v1.4.2 + github.com/golang/mock v1.6.0 + github.com/metal-stack/metal-lib v0.18.4 + github.com/onsi/ginkgo v1.16.5 + github.com/spf13/cobra v1.8.1 + github.com/spf13/pflag v1.0.5 + k8s.io/api v0.31.1 + k8s.io/apimachinery v0.31.1 + k8s.io/code-generator v0.31.1 + k8s.io/component-base v0.31.1 + sigs.k8s.io/controller-runtime v0.17.5 +) + +require ( + github.com/BurntSushi/toml v1.3.2 // indirect + github.com/Masterminds/goutils v1.1.1 // indirect + github.com/Masterminds/semver/v3 v3.3.0 // indirect + github.com/Masterminds/sprig/v3 v3.2.3 // indirect + github.com/beorn7/perks v1.0.1 // indirect + github.com/blang/semver/v4 v4.0.0 // indirect + github.com/cespare/xxhash/v2 v2.3.0 // indirect + github.com/coreos/go-systemd/v22 v22.5.0 // indirect + github.com/cyphar/filepath-securejoin v0.2.4 // indirect + github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc // indirect + github.com/emicklei/go-restful/v3 v3.12.1 // indirect + github.com/evanphx/json-patch/v5 v5.8.0 // indirect + github.com/fatih/color v1.17.0 // indirect + github.com/fluent/fluent-operator/v2 v2.8.0 // indirect + github.com/fsnotify/fsnotify v1.7.0 // indirect + github.com/gardener/cert-management v0.15.0 // indirect + github.com/gardener/etcd-druid v0.22.0 // indirect + github.com/gardener/hvpa-controller/api v0.15.0 // indirect + github.com/gardener/machine-controller-manager v0.53.0 // indirect + github.com/go-logr/zapr v1.3.0 // indirect + github.com/go-openapi/errors v0.22.0 // indirect + github.com/go-openapi/jsonpointer v0.21.0 // indirect + github.com/go-openapi/jsonreference v0.21.0 // indirect + github.com/go-openapi/swag v0.23.0 // indirect + github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572 // indirect + github.com/go-task/slim-sprig/v3 v3.0.0 // indirect + github.com/gobuffalo/flect v1.0.2 // indirect + github.com/gobwas/glob v0.2.3 // indirect + github.com/gogo/protobuf v1.3.2 // indirect + github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect + github.com/golang/protobuf v1.5.4 // indirect + github.com/google/gnostic-models v0.6.9-0.20230804172637-c7be7c783f49 // indirect + github.com/google/go-cmp v0.6.0 // indirect + github.com/google/gofuzz v1.2.0 // indirect + github.com/google/pprof v0.0.0-20240525223248-4bfdf5a9a2af // indirect + github.com/google/uuid v1.6.0 // indirect + github.com/gorilla/websocket v1.5.0 // indirect + github.com/hashicorp/errwrap v1.1.0 // indirect + github.com/hashicorp/go-multierror v1.1.1 // indirect + github.com/huandu/xstrings v1.4.0 // indirect + github.com/imdario/mergo v0.3.16 // indirect + github.com/inconshreveable/mousetrap v1.1.0 // indirect + github.com/ironcore-dev/vgopath v0.1.4 // indirect + github.com/josharian/intern v1.0.0 // indirect + github.com/json-iterator/go v1.1.12 // indirect + github.com/kubernetes-csi/external-snapshotter/client/v4 v4.2.0 // indirect + github.com/mailru/easyjson v0.7.7 // indirect + github.com/mattn/go-colorable v0.1.13 // indirect + github.com/mattn/go-isatty v0.0.20 // indirect + github.com/mitchellh/copystructure v1.2.0 // indirect + github.com/mitchellh/hashstructure/v2 v2.0.2 // indirect + github.com/mitchellh/reflectwalk v1.0.2 // indirect + github.com/moby/spdystream v0.4.0 // indirect + github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect + github.com/modern-go/reflect2 v1.0.2 // indirect + github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect + github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f // indirect + github.com/nxadm/tail v1.4.8 // indirect + github.com/onsi/ginkgo/v2 v2.19.0 // indirect + github.com/pkg/errors v0.9.1 // indirect + github.com/prometheus-operator/prometheus-operator/pkg/apis/monitoring v0.74.0 // indirect + github.com/prometheus/client_golang v1.19.1 // indirect + github.com/prometheus/client_model v0.6.1 // indirect + github.com/prometheus/common v0.55.0 // indirect + github.com/prometheus/procfs v0.15.1 // indirect + github.com/russross/blackfriday/v2 v2.1.0 // indirect + github.com/shopspring/decimal v1.3.1 // indirect + github.com/spf13/afero v1.11.0 // indirect + github.com/spf13/cast v1.6.0 // indirect + github.com/xeipuuv/gojsonpointer v0.0.0-20190905194746-02993c407bfb // indirect + github.com/xeipuuv/gojsonreference v0.0.0-20180127040603-bd5ef7bd5415 // indirect + github.com/xeipuuv/gojsonschema v1.2.0 // indirect + go.uber.org/mock v0.4.0 // indirect + go.uber.org/multierr v1.11.0 // indirect + go.uber.org/zap v1.27.0 // indirect + golang.org/x/crypto v0.26.0 // indirect + golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 // indirect + golang.org/x/mod v0.20.0 // indirect + golang.org/x/net v0.28.0 // indirect + golang.org/x/oauth2 v0.23.0 // indirect + golang.org/x/sync v0.8.0 // indirect + golang.org/x/sys v0.23.0 // indirect + golang.org/x/term v0.23.0 // indirect + golang.org/x/text v0.17.0 // indirect + golang.org/x/time v0.6.0 // indirect + golang.org/x/tools v0.24.0 // indirect + gomodules.xyz/jsonpatch/v2 v2.4.0 // indirect + google.golang.org/genproto/googleapis/api v0.0.0-20240528184218-531527333157 // indirect + google.golang.org/protobuf v1.34.2 // indirect + gopkg.in/inf.v0 v0.9.1 // indirect + gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 // indirect + gopkg.in/yaml.v2 v2.4.0 // indirect + gopkg.in/yaml.v3 v3.0.1 // indirect + helm.sh/helm/v3 v3.14.4 // indirect + istio.io/api v1.22.1 // indirect + istio.io/client-go v1.22.0 // indirect + k8s.io/apiextensions-apiserver v0.29.5 // indirect + k8s.io/autoscaler/vertical-pod-autoscaler v1.1.2 // indirect + k8s.io/client-go v0.31.2 // indirect + k8s.io/gengo v0.0.0-20230829151522-9cce18d56c01 // indirect + k8s.io/klog v1.0.0 // indirect + k8s.io/klog/v2 v2.130.1 // indirect + k8s.io/kube-aggregator v0.29.5 // indirect + k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 // indirect + k8s.io/kubelet v0.29.5 // indirect + k8s.io/metrics v0.29.5 // indirect + k8s.io/utils v0.0.0-20240711033017-18e509b52bc8 // indirect + sigs.k8s.io/controller-runtime/tools/setup-envtest v0.0.0-20231015215740-bf15e44028f9 // indirect + sigs.k8s.io/controller-tools v0.14.0 // indirect + sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd // indirect + sigs.k8s.io/structured-merge-diff/v4 v4.4.1 // indirect + sigs.k8s.io/yaml v1.4.0 // indirect +) + +replace ( + k8s.io/api => k8s.io/api v0.29.5 + k8s.io/apimachinery => k8s.io/apimachinery v0.29.5 + k8s.io/client-go => k8s.io/client-go v0.29.5 + k8s.io/code-generator => k8s.io/code-generator v0.29.5 + k8s.io/component-base => k8s.io/component-base v0.29.5 + k8s.io/kube-openapi => k8s.io/kube-openapi v0.0.0-20231010175941-2dd684a91f00 +) diff --git a/go.sum b/go.sum new file mode 100644 index 0000000..886b4d1 --- /dev/null +++ b/go.sum @@ -0,0 +1,1993 @@ +cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= +cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= +cloud.google.com/go v0.38.0/go.mod h1:990N+gfupTy94rShfmMCWGDn0LpTmnzTp2qbd1dvSRU= +cloud.google.com/go v0.44.1/go.mod h1:iSa0KzasP4Uvy3f1mN/7PiObzGgflwredwwASm/v6AU= +cloud.google.com/go v0.44.2/go.mod h1:60680Gw3Yr4ikxnPRS/oxxkBccT6SA1yMk63TGekxKY= +cloud.google.com/go v0.44.3/go.mod h1:60680Gw3Yr4ikxnPRS/oxxkBccT6SA1yMk63TGekxKY= +cloud.google.com/go v0.45.1/go.mod h1:RpBamKRgapWJb87xiFSdk4g1CME7QZg3uwTez+TSTjc= +cloud.google.com/go v0.46.3/go.mod h1:a6bKKbmY7er1mI7TEI4lsAkts/mkhTSZK8w33B4RAg0= +cloud.google.com/go v0.50.0/go.mod h1:r9sluTvynVuxRIOHXQEHMFffphuXHOMZMycpNR5e6To= +cloud.google.com/go v0.52.0/go.mod h1:pXajvRH/6o3+F9jDHZWQ5PbGhn+o8w9qiu/CffaVdO4= +cloud.google.com/go v0.53.0/go.mod h1:fp/UouUEsRkN6ryDKNW/Upv/JBKnv6WDthjR6+vze6M= +cloud.google.com/go v0.54.0/go.mod h1:1rq2OEkV3YMf6n/9ZvGWI3GWw0VoqH/1x2nd8Is/bPc= +cloud.google.com/go v0.56.0/go.mod h1:jr7tqZxxKOVYizybht9+26Z/gUq7tiRzu+ACVAMbKVk= +cloud.google.com/go v0.57.0/go.mod h1:oXiQ6Rzq3RAkkY7N6t3TcE6jE+CIBBbA36lwQ1JyzZs= +cloud.google.com/go v0.62.0/go.mod h1:jmCYTdRCQuc1PHIIJ/maLInMho30T/Y0M4hTdTShOYc= +cloud.google.com/go v0.65.0/go.mod h1:O5N8zS7uWy9vkA9vayVHs65eM1ubvY4h553ofrNHObY= +cloud.google.com/go v0.72.0/go.mod h1:M+5Vjvlc2wnp6tjzE102Dw08nGShTscUx2nZMufOKPI= +cloud.google.com/go v0.74.0/go.mod h1:VV1xSbzvo+9QJOxLDaJfTjx5e+MePCpCWwvftOeQmWk= +cloud.google.com/go v0.75.0/go.mod h1:VGuuCn7PG0dwsd5XPVm2Mm3wlh3EL55/79EKB6hlPTY= +cloud.google.com/go v0.78.0/go.mod h1:QjdrLG0uq+YwhjoVOLsS1t7TW8fs36kLs4XO5R5ECHg= +cloud.google.com/go v0.79.0/go.mod h1:3bzgcEeQlzbuEAYu4mrWhKqWjmpprinYgKJLgKHnbb8= +cloud.google.com/go v0.81.0/go.mod h1:mk/AM35KwGk/Nm2YSeZbxXdrNK3KZOYHmLkOqC2V6E0= +cloud.google.com/go v0.83.0/go.mod h1:Z7MJUsANfY0pYPdw0lbnivPx4/vhy/e2FEkSkF7vAVY= +cloud.google.com/go v0.84.0/go.mod h1:RazrYuxIK6Kb7YrzzhPoLmCVzl7Sup4NrbKPg8KHSUM= +cloud.google.com/go v0.87.0/go.mod h1:TpDYlFy7vuLzZMMZ+B6iRiELaY7z/gJPaqbMx6mlWcY= +cloud.google.com/go v0.90.0/go.mod h1:kRX0mNRHe0e2rC6oNakvwQqzyDmg57xJ+SZU1eT2aDQ= +cloud.google.com/go v0.93.3/go.mod h1:8utlLll2EF5XMAV15woO4lSbWQlk8rer9aLOfLh7+YI= +cloud.google.com/go v0.94.1/go.mod h1:qAlAugsXlC+JWO+Bke5vCtc9ONxjQT3drlTTnAplMW4= +cloud.google.com/go v0.97.0/go.mod h1:GF7l59pYBVlXQIBLx3a761cZ41F9bBH3JUlihCt2Udc= +cloud.google.com/go v0.99.0/go.mod h1:w0Xx2nLzqWJPuozYQX+hFfCSI8WioryfRDzkoI/Y2ZA= +cloud.google.com/go v0.100.1/go.mod h1:fs4QogzfH5n2pBXBP9vRiU+eCny7lD2vmFZy79Iuw1U= +cloud.google.com/go v0.100.2/go.mod h1:4Xra9TjzAeYHrl5+oeLlzbM2k3mjVhZh4UqTZ//w99A= +cloud.google.com/go v0.102.0/go.mod h1:oWcCzKlqJ5zgHQt9YsaeTY9KzIvjyy0ArmiBUgpQ+nc= +cloud.google.com/go v0.102.1/go.mod h1:XZ77E9qnTEnrgEOvr4xzfdX5TRo7fB4T2F4O6+34hIU= +cloud.google.com/go v0.104.0/go.mod h1:OO6xxXdJyvuJPcEPBLN9BJPD+jep5G1+2U5B5gkRYtA= +cloud.google.com/go v0.105.0/go.mod h1:PrLgOJNe5nfE9UMxKxgXj4mD3voiP+YQ6gdt6KMFOKM= +cloud.google.com/go v0.107.0/go.mod h1:wpc2eNrD7hXUTy8EKS10jkxpZBjASrORK7goS+3YX2I= +cloud.google.com/go v0.110.0/go.mod h1:SJnCLqQ0FCFGSZMUNUf84MV3Aia54kn7pi8st7tMzaY= +cloud.google.com/go v0.110.2/go.mod h1:k04UEeEtb6ZBRTv3dZz4CeJC3jKGxyhl0sAiVVquxiw= +cloud.google.com/go/accessapproval v1.4.0/go.mod h1:zybIuC3KpDOvotz59lFe5qxRZx6C75OtwbisN56xYB4= +cloud.google.com/go/accessapproval v1.5.0/go.mod h1:HFy3tuiGvMdcd/u+Cu5b9NkO1pEICJ46IR82PoUdplw= +cloud.google.com/go/accessapproval v1.6.0/go.mod h1:R0EiYnwV5fsRFiKZkPHr6mwyk2wxUJ30nL4j2pcFY2E= +cloud.google.com/go/accesscontextmanager v1.3.0/go.mod h1:TgCBehyr5gNMz7ZaH9xubp+CE8dkrszb4oK9CWyvD4o= +cloud.google.com/go/accesscontextmanager v1.4.0/go.mod h1:/Kjh7BBu/Gh83sv+K60vN9QE5NJcd80sU33vIe2IFPE= +cloud.google.com/go/accesscontextmanager v1.6.0/go.mod h1:8XCvZWfYw3K/ji0iVnp+6pu7huxoQTLmxAbVjbloTtM= +cloud.google.com/go/accesscontextmanager v1.7.0/go.mod h1:CEGLewx8dwa33aDAZQujl7Dx+uYhS0eay198wB/VumQ= +cloud.google.com/go/aiplatform v1.22.0/go.mod h1:ig5Nct50bZlzV6NvKaTwmplLLddFx0YReh9WfTO5jKw= +cloud.google.com/go/aiplatform v1.24.0/go.mod h1:67UUvRBKG6GTayHKV8DBv2RtR1t93YRu5B1P3x99mYY= +cloud.google.com/go/aiplatform v1.27.0/go.mod h1:Bvxqtl40l0WImSb04d0hXFU7gDOiq9jQmorivIiWcKg= +cloud.google.com/go/aiplatform v1.35.0/go.mod h1:7MFT/vCaOyZT/4IIFfxH4ErVg/4ku6lKv3w0+tFTgXQ= +cloud.google.com/go/aiplatform v1.36.1/go.mod h1:WTm12vJRPARNvJ+v6P52RDHCNe4AhvjcIZ/9/RRHy/k= +cloud.google.com/go/aiplatform v1.37.0/go.mod h1:IU2Cv29Lv9oCn/9LkFiiuKfwrRTq+QQMbW+hPCxJGZw= +cloud.google.com/go/analytics v0.11.0/go.mod h1:DjEWCu41bVbYcKyvlws9Er60YE4a//bK6mnhWvQeFNI= +cloud.google.com/go/analytics v0.12.0/go.mod h1:gkfj9h6XRf9+TS4bmuhPEShsh3hH8PAZzm/41OOhQd4= +cloud.google.com/go/analytics v0.17.0/go.mod h1:WXFa3WSym4IZ+JiKmavYdJwGG/CvpqiqczmL59bTD9M= +cloud.google.com/go/analytics v0.18.0/go.mod h1:ZkeHGQlcIPkw0R/GW+boWHhCOR43xz9RN/jn7WcqfIE= +cloud.google.com/go/analytics v0.19.0/go.mod h1:k8liqf5/HCnOUkbawNtrWWc+UAzyDlW89doe8TtoDsE= +cloud.google.com/go/apigateway v1.3.0/go.mod h1:89Z8Bhpmxu6AmUxuVRg/ECRGReEdiP3vQtk4Z1J9rJk= +cloud.google.com/go/apigateway v1.4.0/go.mod h1:pHVY9MKGaH9PQ3pJ4YLzoj6U5FUDeDFBllIz7WmzJoc= +cloud.google.com/go/apigateway v1.5.0/go.mod h1:GpnZR3Q4rR7LVu5951qfXPJCHquZt02jf7xQx7kpqN8= +cloud.google.com/go/apigeeconnect v1.3.0/go.mod h1:G/AwXFAKo0gIXkPTVfZDd2qA1TxBXJ3MgMRBQkIi9jc= +cloud.google.com/go/apigeeconnect v1.4.0/go.mod h1:kV4NwOKqjvt2JYR0AoIWo2QGfoRtn/pkS3QlHp0Ni04= +cloud.google.com/go/apigeeconnect v1.5.0/go.mod h1:KFaCqvBRU6idyhSNyn3vlHXc8VMDJdRmwDF6JyFRqZ8= +cloud.google.com/go/apigeeregistry v0.4.0/go.mod h1:EUG4PGcsZvxOXAdyEghIdXwAEi/4MEaoqLMLDMIwKXY= +cloud.google.com/go/apigeeregistry v0.5.0/go.mod h1:YR5+s0BVNZfVOUkMa5pAR2xGd0A473vA5M7j247o1wM= +cloud.google.com/go/apigeeregistry v0.6.0/go.mod h1:BFNzW7yQVLZ3yj0TKcwzb8n25CFBri51GVGOEUcgQsc= +cloud.google.com/go/apikeys v0.4.0/go.mod h1:XATS/yqZbaBK0HOssf+ALHp8jAlNHUgyfprvNcBIszU= +cloud.google.com/go/apikeys v0.5.0/go.mod h1:5aQfwY4D+ewMMWScd3hm2en3hCj+BROlyrt3ytS7KLI= +cloud.google.com/go/apikeys v0.6.0/go.mod h1:kbpXu5upyiAlGkKrJgQl8A0rKNNJ7dQ377pdroRSSi8= +cloud.google.com/go/appengine v1.4.0/go.mod h1:CS2NhuBuDXM9f+qscZ6V86m1MIIqPj3WC/UoEuR1Sno= +cloud.google.com/go/appengine v1.5.0/go.mod h1:TfasSozdkFI0zeoxW3PTBLiNqRmzraodCWatWI9Dmak= +cloud.google.com/go/appengine v1.6.0/go.mod h1:hg6i0J/BD2cKmDJbaFSYHFyZkgBEfQrDg/X0V5fJn84= +cloud.google.com/go/appengine v1.7.0/go.mod h1:eZqpbHFCqRGa2aCdope7eC0SWLV1j0neb/QnMJVWx6A= +cloud.google.com/go/appengine v1.7.1/go.mod h1:IHLToyb/3fKutRysUlFO0BPt5j7RiQ45nrzEJmKTo6E= +cloud.google.com/go/area120 v0.5.0/go.mod h1:DE/n4mp+iqVyvxHN41Vf1CR602GiHQjFPusMFW6bGR4= +cloud.google.com/go/area120 v0.6.0/go.mod h1:39yFJqWVgm0UZqWTOdqkLhjoC7uFfgXRC8g/ZegeAh0= +cloud.google.com/go/area120 v0.7.0/go.mod h1:a3+8EUD1SX5RUcCs3MY5YasiO1z6yLiNLRiFrykbynY= +cloud.google.com/go/area120 v0.7.1/go.mod h1:j84i4E1RboTWjKtZVWXPqvK5VHQFJRF2c1Nm69pWm9k= +cloud.google.com/go/artifactregistry v1.6.0/go.mod h1:IYt0oBPSAGYj/kprzsBjZ/4LnG/zOcHyFHjWPCi6SAQ= +cloud.google.com/go/artifactregistry v1.7.0/go.mod h1:mqTOFOnGZx8EtSqK/ZWcsm/4U8B77rbcLP6ruDU2Ixk= +cloud.google.com/go/artifactregistry v1.8.0/go.mod h1:w3GQXkJX8hiKN0v+at4b0qotwijQbYUqF2GWkZzAhC0= +cloud.google.com/go/artifactregistry v1.9.0/go.mod h1:2K2RqvA2CYvAeARHRkLDhMDJ3OXy26h3XW+3/Jh2uYc= +cloud.google.com/go/artifactregistry v1.11.1/go.mod h1:lLYghw+Itq9SONbCa1YWBoWs1nOucMH0pwXN1rOBZFI= +cloud.google.com/go/artifactregistry v1.11.2/go.mod h1:nLZns771ZGAwVLzTX/7Al6R9ehma4WUEhZGWV6CeQNQ= +cloud.google.com/go/artifactregistry v1.12.0/go.mod h1:o6P3MIvtzTOnmvGagO9v/rOjjA0HmhJ+/6KAXrmYDCI= +cloud.google.com/go/artifactregistry v1.13.0/go.mod h1:uy/LNfoOIivepGhooAUpL1i30Hgee3Cu0l4VTWHUC08= +cloud.google.com/go/asset v1.5.0/go.mod h1:5mfs8UvcM5wHhqtSv8J1CtxxaQq3AdBxxQi2jGW/K4o= +cloud.google.com/go/asset v1.7.0/go.mod h1:YbENsRK4+xTiL+Ofoj5Ckf+O17kJtgp3Y3nn4uzZz5s= +cloud.google.com/go/asset v1.8.0/go.mod h1:mUNGKhiqIdbr8X7KNayoYvyc4HbbFO9URsjbytpUaW0= +cloud.google.com/go/asset v1.9.0/go.mod h1:83MOE6jEJBMqFKadM9NLRcs80Gdw76qGuHn8m3h8oHQ= +cloud.google.com/go/asset v1.10.0/go.mod h1:pLz7uokL80qKhzKr4xXGvBQXnzHn5evJAEAtZiIb0wY= +cloud.google.com/go/asset v1.11.1/go.mod h1:fSwLhbRvC9p9CXQHJ3BgFeQNM4c9x10lqlrdEUYXlJo= +cloud.google.com/go/asset v1.12.0/go.mod h1:h9/sFOa4eDIyKmH6QMpm4eUK3pDojWnUhTgJlk762Hg= +cloud.google.com/go/asset v1.13.0/go.mod h1:WQAMyYek/b7NBpYq/K4KJWcRqzoalEsxz/t/dTk4THw= +cloud.google.com/go/assuredworkloads v1.5.0/go.mod h1:n8HOZ6pff6re5KYfBXcFvSViQjDwxFkAkmUFffJRbbY= +cloud.google.com/go/assuredworkloads v1.6.0/go.mod h1:yo2YOk37Yc89Rsd5QMVECvjaMKymF9OP+QXWlKXUkXw= +cloud.google.com/go/assuredworkloads v1.7.0/go.mod h1:z/736/oNmtGAyU47reJgGN+KVoYoxeLBoj4XkKYscNI= +cloud.google.com/go/assuredworkloads v1.8.0/go.mod h1:AsX2cqyNCOvEQC8RMPnoc0yEarXQk6WEKkxYfL6kGIo= +cloud.google.com/go/assuredworkloads v1.9.0/go.mod h1:kFuI1P78bplYtT77Tb1hi0FMxM0vVpRC7VVoJC3ZoT0= +cloud.google.com/go/assuredworkloads v1.10.0/go.mod h1:kwdUQuXcedVdsIaKgKTp9t0UJkE5+PAVNhdQm4ZVq2E= +cloud.google.com/go/automl v1.5.0/go.mod h1:34EjfoFGMZ5sgJ9EoLsRtdPSNZLcfflJR39VbVNS2M0= +cloud.google.com/go/automl v1.6.0/go.mod h1:ugf8a6Fx+zP0D59WLhqgTDsQI9w07o64uf/Is3Nh5p8= +cloud.google.com/go/automl v1.7.0/go.mod h1:RL9MYCCsJEOmt0Wf3z9uzG0a7adTT1fe+aObgSpkCt8= +cloud.google.com/go/automl v1.8.0/go.mod h1:xWx7G/aPEe/NP+qzYXktoBSDfjO+vnKMGgsApGJJquM= +cloud.google.com/go/automl v1.12.0/go.mod h1:tWDcHDp86aMIuHmyvjuKeeHEGq76lD7ZqfGLN6B0NuU= +cloud.google.com/go/baremetalsolution v0.3.0/go.mod h1:XOrocE+pvK1xFfleEnShBlNAXf+j5blPPxrhjKgnIFc= +cloud.google.com/go/baremetalsolution v0.4.0/go.mod h1:BymplhAadOO/eBa7KewQ0Ppg4A4Wplbn+PsFKRLo0uI= +cloud.google.com/go/baremetalsolution v0.5.0/go.mod h1:dXGxEkmR9BMwxhzBhV0AioD0ULBmuLZI8CdwalUxuss= +cloud.google.com/go/batch v0.3.0/go.mod h1:TR18ZoAekj1GuirsUsR1ZTKN3FC/4UDnScjT8NXImFE= +cloud.google.com/go/batch v0.4.0/go.mod h1:WZkHnP43R/QCGQsZ+0JyG4i79ranE2u8xvjq/9+STPE= +cloud.google.com/go/batch v0.7.0/go.mod h1:vLZN95s6teRUqRQ4s3RLDsH8PvboqBK+rn1oevL159g= +cloud.google.com/go/beyondcorp v0.2.0/go.mod h1:TB7Bd+EEtcw9PCPQhCJtJGjk/7TC6ckmnSFS+xwTfm4= +cloud.google.com/go/beyondcorp v0.3.0/go.mod h1:E5U5lcrcXMsCuoDNyGrpyTm/hn7ne941Jz2vmksAxW8= +cloud.google.com/go/beyondcorp v0.4.0/go.mod h1:3ApA0mbhHx6YImmuubf5pyW8srKnCEPON32/5hj+RmM= +cloud.google.com/go/beyondcorp v0.5.0/go.mod h1:uFqj9X+dSfrheVp7ssLTaRHd2EHqSL4QZmH4e8WXGGU= +cloud.google.com/go/bigquery v1.0.1/go.mod h1:i/xbL2UlR5RvWAURpBYZTtm/cXjCha9lbfbpx4poX+o= +cloud.google.com/go/bigquery v1.3.0/go.mod h1:PjpwJnslEMmckchkHFfq+HTD2DmtT67aNFKH1/VBDHE= +cloud.google.com/go/bigquery v1.4.0/go.mod h1:S8dzgnTigyfTmLBfrtrhyYhwRxG72rYxvftPBK2Dvzc= +cloud.google.com/go/bigquery v1.5.0/go.mod h1:snEHRnqQbz117VIFhE8bmtwIDY80NLUZUMb4Nv6dBIg= +cloud.google.com/go/bigquery v1.7.0/go.mod h1://okPTzCYNXSlb24MZs83e2Do+h+VXtc4gLoIoXIAPc= +cloud.google.com/go/bigquery v1.8.0/go.mod h1:J5hqkt3O0uAFnINi6JXValWIb1v0goeZM77hZzJN/fQ= +cloud.google.com/go/bigquery v1.42.0/go.mod h1:8dRTJxhtG+vwBKzE5OseQn/hiydoQN3EedCaOdYmxRA= +cloud.google.com/go/bigquery v1.43.0/go.mod h1:ZMQcXHsl+xmU1z36G2jNGZmKp9zNY5BUua5wDgmNCfw= +cloud.google.com/go/bigquery v1.44.0/go.mod h1:0Y33VqXTEsbamHJvJHdFmtqHvMIY28aK1+dFsvaChGc= +cloud.google.com/go/bigquery v1.47.0/go.mod h1:sA9XOgy0A8vQK9+MWhEQTY6Tix87M/ZurWFIxmF9I/E= +cloud.google.com/go/bigquery v1.48.0/go.mod h1:QAwSz+ipNgfL5jxiaK7weyOhzdoAy1zFm0Nf1fysJac= +cloud.google.com/go/bigquery v1.49.0/go.mod h1:Sv8hMmTFFYBlt/ftw2uN6dFdQPzBlREY9yBh7Oy7/4Q= +cloud.google.com/go/bigquery v1.50.0/go.mod h1:YrleYEh2pSEbgTBZYMJ5SuSr0ML3ypjRB1zgf7pvQLU= +cloud.google.com/go/billing v1.4.0/go.mod h1:g9IdKBEFlItS8bTtlrZdVLWSSdSyFUZKXNS02zKMOZY= +cloud.google.com/go/billing v1.5.0/go.mod h1:mztb1tBc3QekhjSgmpf/CV4LzWXLzCArwpLmP2Gm88s= +cloud.google.com/go/billing v1.6.0/go.mod h1:WoXzguj+BeHXPbKfNWkqVtDdzORazmCjraY+vrxcyvI= +cloud.google.com/go/billing v1.7.0/go.mod h1:q457N3Hbj9lYwwRbnlD7vUpyjq6u5U1RAOArInEiD5Y= +cloud.google.com/go/billing v1.12.0/go.mod h1:yKrZio/eu+okO/2McZEbch17O5CB5NpZhhXG6Z766ss= +cloud.google.com/go/billing v1.13.0/go.mod h1:7kB2W9Xf98hP9Sr12KfECgfGclsH3CQR0R08tnRlRbc= +cloud.google.com/go/binaryauthorization v1.1.0/go.mod h1:xwnoWu3Y84jbuHa0zd526MJYmtnVXn0syOjaJgy4+dM= +cloud.google.com/go/binaryauthorization v1.2.0/go.mod h1:86WKkJHtRcv5ViNABtYMhhNWRrD1Vpi//uKEy7aYEfI= +cloud.google.com/go/binaryauthorization v1.3.0/go.mod h1:lRZbKgjDIIQvzYQS1p99A7/U1JqvqeZg0wiI5tp6tg0= +cloud.google.com/go/binaryauthorization v1.4.0/go.mod h1:tsSPQrBd77VLplV70GUhBf/Zm3FsKmgSqgm4UmiDItk= +cloud.google.com/go/binaryauthorization v1.5.0/go.mod h1:OSe4OU1nN/VswXKRBmciKpo9LulY41gch5c68htf3/Q= +cloud.google.com/go/certificatemanager v1.3.0/go.mod h1:n6twGDvcUBFu9uBgt4eYvvf3sQ6My8jADcOVwHmzadg= +cloud.google.com/go/certificatemanager v1.4.0/go.mod h1:vowpercVFyqs8ABSmrdV+GiFf2H/ch3KyudYQEMM590= +cloud.google.com/go/certificatemanager v1.6.0/go.mod h1:3Hh64rCKjRAX8dXgRAyOcY5vQ/fE1sh8o+Mdd6KPgY8= +cloud.google.com/go/channel v1.8.0/go.mod h1:W5SwCXDJsq/rg3tn3oG0LOxpAo6IMxNa09ngphpSlnk= +cloud.google.com/go/channel v1.9.0/go.mod h1:jcu05W0my9Vx4mt3/rEHpfxc9eKi9XwsdDL8yBMbKUk= +cloud.google.com/go/channel v1.11.0/go.mod h1:IdtI0uWGqhEeatSB62VOoJ8FSUhJ9/+iGkJVqp74CGE= +cloud.google.com/go/channel v1.12.0/go.mod h1:VkxCGKASi4Cq7TbXxlaBezonAYpp1GCnKMY6tnMQnLU= +cloud.google.com/go/cloudbuild v1.3.0/go.mod h1:WequR4ULxlqvMsjDEEEFnOG5ZSRSgWOywXYDb1vPE6U= +cloud.google.com/go/cloudbuild v1.4.0/go.mod h1:5Qwa40LHiOXmz3386FrjrYM93rM/hdRr7b53sySrTqA= +cloud.google.com/go/cloudbuild v1.6.0/go.mod h1:UIbc/w9QCbH12xX+ezUsgblrWv+Cv4Tw83GiSMHOn9M= +cloud.google.com/go/cloudbuild v1.7.0/go.mod h1:zb5tWh2XI6lR9zQmsm1VRA+7OCuve5d8S+zJUul8KTg= +cloud.google.com/go/cloudbuild v1.9.0/go.mod h1:qK1d7s4QlO0VwfYn5YuClDGg2hfmLZEb4wQGAbIgL1s= +cloud.google.com/go/clouddms v1.3.0/go.mod h1:oK6XsCDdW4Ib3jCCBugx+gVjevp2TMXFtgxvPSee3OM= +cloud.google.com/go/clouddms v1.4.0/go.mod h1:Eh7sUGCC+aKry14O1NRljhjyrr0NFC0G2cjwX0cByRk= +cloud.google.com/go/clouddms v1.5.0/go.mod h1:QSxQnhikCLUw13iAbffF2CZxAER3xDGNHjsTAkQJcQA= +cloud.google.com/go/cloudtasks v1.5.0/go.mod h1:fD92REy1x5woxkKEkLdvavGnPJGEn8Uic9nWuLzqCpY= +cloud.google.com/go/cloudtasks v1.6.0/go.mod h1:C6Io+sxuke9/KNRkbQpihnW93SWDU3uXt92nu85HkYI= +cloud.google.com/go/cloudtasks v1.7.0/go.mod h1:ImsfdYWwlWNJbdgPIIGJWC+gemEGTBK/SunNQQNCAb4= +cloud.google.com/go/cloudtasks v1.8.0/go.mod h1:gQXUIwCSOI4yPVK7DgTVFiiP0ZW/eQkydWzwVMdHxrI= +cloud.google.com/go/cloudtasks v1.9.0/go.mod h1:w+EyLsVkLWHcOaqNEyvcKAsWp9p29dL6uL9Nst1cI7Y= +cloud.google.com/go/cloudtasks v1.10.0/go.mod h1:NDSoTLkZ3+vExFEWu2UJV1arUyzVDAiZtdWcsUyNwBs= +cloud.google.com/go/compute v0.1.0/go.mod h1:GAesmwr110a34z04OlxYkATPBEfVhkymfTBXtfbBFow= +cloud.google.com/go/compute v1.3.0/go.mod h1:cCZiE1NHEtai4wiufUhW8I8S1JKkAnhnQJWM7YD99wM= +cloud.google.com/go/compute v1.5.0/go.mod h1:9SMHyhJlzhlkJqrPAc839t2BZFTSk6Jdj6mkzQJeu0M= +cloud.google.com/go/compute v1.6.0/go.mod h1:T29tfhtVbq1wvAPo0E3+7vhgmkOYeXjhFvz/FMzPu0s= +cloud.google.com/go/compute v1.6.1/go.mod h1:g85FgpzFvNULZ+S8AYq87axRKuf2Kh7deLqV/jJ3thU= +cloud.google.com/go/compute v1.7.0/go.mod h1:435lt8av5oL9P3fv1OEzSbSUe+ybHXGMPQHHZWZxy9U= +cloud.google.com/go/compute v1.10.0/go.mod h1:ER5CLbMxl90o2jtNbGSbtfOpQKR0t15FOtRsugnLrlU= +cloud.google.com/go/compute v1.12.0/go.mod h1:e8yNOBcBONZU1vJKCvCoDw/4JQsA0dpM4x/6PIIOocU= +cloud.google.com/go/compute v1.12.1/go.mod h1:e8yNOBcBONZU1vJKCvCoDw/4JQsA0dpM4x/6PIIOocU= +cloud.google.com/go/compute v1.13.0/go.mod h1:5aPTS0cUNMIc1CE546K+Th6weJUNQErARyZtRXDJ8GE= +cloud.google.com/go/compute v1.14.0/go.mod h1:YfLtxrj9sU4Yxv+sXzZkyPjEyPBZfXHUvjxega5vAdo= +cloud.google.com/go/compute v1.15.1/go.mod h1:bjjoF/NtFUrkD/urWfdHaKuOPDR5nWIs63rR+SXhcpA= +cloud.google.com/go/compute v1.18.0/go.mod h1:1X7yHxec2Ga+Ss6jPyjxRxpu2uu7PLgsOVXvgU0yacs= +cloud.google.com/go/compute v1.19.0/go.mod h1:rikpw2y+UMidAe9tISo04EHNOIf42RLYF/q8Bs93scU= +cloud.google.com/go/compute v1.19.3/go.mod h1:qxvISKp/gYnXkSAD1ppcSOveRAmzxicEv/JlizULFrI= +cloud.google.com/go/compute v1.20.1/go.mod h1:4tCnrn48xsqlwSAiLf1HXMQk8CONslYbdiEZc9FEIbM= +cloud.google.com/go/compute/metadata v0.1.0/go.mod h1:Z1VN+bulIf6bt4P/C37K4DyZYZEXYonfTBHHFPO/4UU= +cloud.google.com/go/compute/metadata v0.2.0/go.mod h1:zFmK7XCadkQkj6TtorcaGlCW1hT1fIilQDwofLpJ20k= +cloud.google.com/go/compute/metadata v0.2.1/go.mod h1:jgHgmJd2RKBGzXqF5LR2EZMGxBkeanZ9wwa75XHJgOM= +cloud.google.com/go/compute/metadata v0.2.3/go.mod h1:VAV5nSsACxMJvgaAuX6Pk2AawlZn8kiOGuCv6gTkwuA= +cloud.google.com/go/contactcenterinsights v1.3.0/go.mod h1:Eu2oemoePuEFc/xKFPjbTuPSj0fYJcPls9TFlPNnHHY= +cloud.google.com/go/contactcenterinsights v1.4.0/go.mod h1:L2YzkGbPsv+vMQMCADxJoT9YiTTnSEd6fEvCeHTYVck= +cloud.google.com/go/contactcenterinsights v1.6.0/go.mod h1:IIDlT6CLcDoyv79kDv8iWxMSTZhLxSCofVV5W6YFM/w= +cloud.google.com/go/container v1.6.0/go.mod h1:Xazp7GjJSeUYo688S+6J5V+n/t+G5sKBTFkKNudGRxg= +cloud.google.com/go/container v1.7.0/go.mod h1:Dp5AHtmothHGX3DwwIHPgq45Y8KmNsgN3amoYfxVkLo= +cloud.google.com/go/container v1.13.1/go.mod h1:6wgbMPeQRw9rSnKBCAJXnds3Pzj03C4JHamr8asWKy4= +cloud.google.com/go/container v1.14.0/go.mod h1:3AoJMPhHfLDxLvrlVWaK57IXzaPnLaZq63WX59aQBfM= +cloud.google.com/go/container v1.15.0/go.mod h1:ft+9S0WGjAyjDggg5S06DXj+fHJICWg8L7isCQe9pQA= +cloud.google.com/go/containeranalysis v0.5.1/go.mod h1:1D92jd8gRR/c0fGMlymRgxWD3Qw9C1ff6/T7mLgVL8I= +cloud.google.com/go/containeranalysis v0.6.0/go.mod h1:HEJoiEIu+lEXM+k7+qLCci0h33lX3ZqoYFdmPcoO7s4= +cloud.google.com/go/containeranalysis v0.7.0/go.mod h1:9aUL+/vZ55P2CXfuZjS4UjQ9AgXoSw8Ts6lemfmxBxI= +cloud.google.com/go/containeranalysis v0.9.0/go.mod h1:orbOANbwk5Ejoom+s+DUCTTJ7IBdBQJDcSylAx/on9s= +cloud.google.com/go/datacatalog v1.3.0/go.mod h1:g9svFY6tuR+j+hrTw3J2dNcmI0dzmSiyOzm8kpLq0a0= +cloud.google.com/go/datacatalog v1.5.0/go.mod h1:M7GPLNQeLfWqeIm3iuiruhPzkt65+Bx8dAKvScX8jvs= +cloud.google.com/go/datacatalog v1.6.0/go.mod h1:+aEyF8JKg+uXcIdAmmaMUmZ3q1b/lKLtXCmXdnc0lbc= +cloud.google.com/go/datacatalog v1.7.0/go.mod h1:9mEl4AuDYWw81UGc41HonIHH7/sn52H0/tc8f8ZbZIE= +cloud.google.com/go/datacatalog v1.8.0/go.mod h1:KYuoVOv9BM8EYz/4eMFxrr4DUKhGIOXxZoKYF5wdISM= +cloud.google.com/go/datacatalog v1.8.1/go.mod h1:RJ58z4rMp3gvETA465Vg+ag8BGgBdnRPEMMSTr5Uv+M= +cloud.google.com/go/datacatalog v1.12.0/go.mod h1:CWae8rFkfp6LzLumKOnmVh4+Zle4A3NXLzVJ1d1mRm0= +cloud.google.com/go/datacatalog v1.13.0/go.mod h1:E4Rj9a5ZtAxcQJlEBTLgMTphfP11/lNaAshpoBgemX8= +cloud.google.com/go/dataflow v0.6.0/go.mod h1:9QwV89cGoxjjSR9/r7eFDqqjtvbKxAK2BaYU6PVk9UM= +cloud.google.com/go/dataflow v0.7.0/go.mod h1:PX526vb4ijFMesO1o202EaUmouZKBpjHsTlCtB4parQ= +cloud.google.com/go/dataflow v0.8.0/go.mod h1:Rcf5YgTKPtQyYz8bLYhFoIV/vP39eL7fWNcSOyFfLJE= +cloud.google.com/go/dataform v0.3.0/go.mod h1:cj8uNliRlHpa6L3yVhDOBrUXH+BPAO1+KFMQQNSThKo= +cloud.google.com/go/dataform v0.4.0/go.mod h1:fwV6Y4Ty2yIFL89huYlEkwUPtS7YZinZbzzj5S9FzCE= +cloud.google.com/go/dataform v0.5.0/go.mod h1:GFUYRe8IBa2hcomWplodVmUx/iTL0FrsauObOM3Ipr0= +cloud.google.com/go/dataform v0.6.0/go.mod h1:QPflImQy33e29VuapFdf19oPbE4aYTJxr31OAPV+ulA= +cloud.google.com/go/dataform v0.7.0/go.mod h1:7NulqnVozfHvWUBpMDfKMUESr+85aJsC/2O0o3jWPDE= +cloud.google.com/go/datafusion v1.4.0/go.mod h1:1Zb6VN+W6ALo85cXnM1IKiPw+yQMKMhB9TsTSRDo/38= +cloud.google.com/go/datafusion v1.5.0/go.mod h1:Kz+l1FGHB0J+4XF2fud96WMmRiq/wj8N9u007vyXZ2w= +cloud.google.com/go/datafusion v1.6.0/go.mod h1:WBsMF8F1RhSXvVM8rCV3AeyWVxcC2xY6vith3iw3S+8= +cloud.google.com/go/datalabeling v0.5.0/go.mod h1:TGcJ0G2NzcsXSE/97yWjIZO0bXj0KbVlINXMG9ud42I= +cloud.google.com/go/datalabeling v0.6.0/go.mod h1:WqdISuk/+WIGeMkpw/1q7bK/tFEZxsrFJOJdY2bXvTQ= +cloud.google.com/go/datalabeling v0.7.0/go.mod h1:WPQb1y08RJbmpM3ww0CSUAGweL0SxByuW2E+FU+wXcM= +cloud.google.com/go/dataplex v1.3.0/go.mod h1:hQuRtDg+fCiFgC8j0zV222HvzFQdRd+SVX8gdmFcZzA= +cloud.google.com/go/dataplex v1.4.0/go.mod h1:X51GfLXEMVJ6UN47ESVqvlsRplbLhcsAt0kZCCKsU0A= +cloud.google.com/go/dataplex v1.5.2/go.mod h1:cVMgQHsmfRoI5KFYq4JtIBEUbYwc3c7tXmIDhRmNNVQ= +cloud.google.com/go/dataplex v1.6.0/go.mod h1:bMsomC/aEJOSpHXdFKFGQ1b0TDPIeL28nJObeO1ppRs= +cloud.google.com/go/dataproc v1.7.0/go.mod h1:CKAlMjII9H90RXaMpSxQ8EU6dQx6iAYNPcYPOkSbi8s= +cloud.google.com/go/dataproc v1.8.0/go.mod h1:5OW+zNAH0pMpw14JVrPONsxMQYMBqJuzORhIBfBn9uI= +cloud.google.com/go/dataproc v1.12.0/go.mod h1:zrF3aX0uV3ikkMz6z4uBbIKyhRITnxvr4i3IjKsKrw4= +cloud.google.com/go/dataqna v0.5.0/go.mod h1:90Hyk596ft3zUQ8NkFfvICSIfHFh1Bc7C4cK3vbhkeo= +cloud.google.com/go/dataqna v0.6.0/go.mod h1:1lqNpM7rqNLVgWBJyk5NF6Uen2PHym0jtVJonplVsDA= +cloud.google.com/go/dataqna v0.7.0/go.mod h1:Lx9OcIIeqCrw1a6KdO3/5KMP1wAmTc0slZWwP12Qq3c= +cloud.google.com/go/datastore v1.0.0/go.mod h1:LXYbyblFSglQ5pkeyhO+Qmw7ukd3C+pD7TKLgZqpHYE= +cloud.google.com/go/datastore v1.1.0/go.mod h1:umbIZjpQpHh4hmRpGhH4tLFup+FVzqBi1b3c64qFpCk= +cloud.google.com/go/datastore v1.10.0/go.mod h1:PC5UzAmDEkAmkfaknstTYbNpgE49HAgW2J1gcgUfmdM= +cloud.google.com/go/datastore v1.11.0/go.mod h1:TvGxBIHCS50u8jzG+AW/ppf87v1of8nwzFNgEZU1D3c= +cloud.google.com/go/datastream v1.2.0/go.mod h1:i/uTP8/fZwgATHS/XFu0TcNUhuA0twZxxQ3EyCUQMwo= +cloud.google.com/go/datastream v1.3.0/go.mod h1:cqlOX8xlyYF/uxhiKn6Hbv6WjwPPuI9W2M9SAXwaLLQ= +cloud.google.com/go/datastream v1.4.0/go.mod h1:h9dpzScPhDTs5noEMQVWP8Wx8AFBRyS0s8KWPx/9r0g= +cloud.google.com/go/datastream v1.5.0/go.mod h1:6TZMMNPwjUqZHBKPQ1wwXpb0d5VDVPl2/XoS5yi88q4= +cloud.google.com/go/datastream v1.6.0/go.mod h1:6LQSuswqLa7S4rPAOZFVjHIG3wJIjZcZrw8JDEDJuIs= +cloud.google.com/go/datastream v1.7.0/go.mod h1:uxVRMm2elUSPuh65IbZpzJNMbuzkcvu5CjMqVIUHrww= +cloud.google.com/go/deploy v1.4.0/go.mod h1:5Xghikd4VrmMLNaF6FiRFDlHb59VM59YoDQnOUdsH/c= +cloud.google.com/go/deploy v1.5.0/go.mod h1:ffgdD0B89tToyW/U/D2eL0jN2+IEV/3EMuXHA0l4r+s= +cloud.google.com/go/deploy v1.6.0/go.mod h1:f9PTHehG/DjCom3QH0cntOVRm93uGBDt2vKzAPwpXQI= +cloud.google.com/go/deploy v1.8.0/go.mod h1:z3myEJnA/2wnB4sgjqdMfgxCA0EqC3RBTNcVPs93mtQ= +cloud.google.com/go/dialogflow v1.15.0/go.mod h1:HbHDWs33WOGJgn6rfzBW1Kv807BE3O1+xGbn59zZWI4= +cloud.google.com/go/dialogflow v1.16.1/go.mod h1:po6LlzGfK+smoSmTBnbkIZY2w8ffjz/RcGSS+sh1el0= +cloud.google.com/go/dialogflow v1.17.0/go.mod h1:YNP09C/kXA1aZdBgC/VtXX74G/TKn7XVCcVumTflA+8= +cloud.google.com/go/dialogflow v1.18.0/go.mod h1:trO7Zu5YdyEuR+BhSNOqJezyFQ3aUzz0njv7sMx/iek= +cloud.google.com/go/dialogflow v1.19.0/go.mod h1:JVmlG1TwykZDtxtTXujec4tQ+D8SBFMoosgy+6Gn0s0= +cloud.google.com/go/dialogflow v1.29.0/go.mod h1:b+2bzMe+k1s9V+F2jbJwpHPzrnIyHihAdRFMtn2WXuM= +cloud.google.com/go/dialogflow v1.31.0/go.mod h1:cuoUccuL1Z+HADhyIA7dci3N5zUssgpBJmCzI6fNRB4= +cloud.google.com/go/dialogflow v1.32.0/go.mod h1:jG9TRJl8CKrDhMEcvfcfFkkpp8ZhgPz3sBGmAUYJ2qE= +cloud.google.com/go/dlp v1.6.0/go.mod h1:9eyB2xIhpU0sVwUixfBubDoRwP+GjeUoxxeueZmqvmM= +cloud.google.com/go/dlp v1.7.0/go.mod h1:68ak9vCiMBjbasxeVD17hVPxDEck+ExiHavX8kiHG+Q= +cloud.google.com/go/dlp v1.9.0/go.mod h1:qdgmqgTyReTz5/YNSSuueR8pl7hO0o9bQ39ZhtgkWp4= +cloud.google.com/go/documentai v1.7.0/go.mod h1:lJvftZB5NRiFSX4moiye1SMxHx0Bc3x1+p9e/RfXYiU= +cloud.google.com/go/documentai v1.8.0/go.mod h1:xGHNEB7CtsnySCNrCFdCyyMz44RhFEEX2Q7UD0c5IhU= +cloud.google.com/go/documentai v1.9.0/go.mod h1:FS5485S8R00U10GhgBC0aNGrJxBP8ZVpEeJ7PQDZd6k= +cloud.google.com/go/documentai v1.10.0/go.mod h1:vod47hKQIPeCfN2QS/jULIvQTugbmdc0ZvxxfQY1bg4= +cloud.google.com/go/documentai v1.16.0/go.mod h1:o0o0DLTEZ+YnJZ+J4wNfTxmDVyrkzFvttBXXtYRMHkM= +cloud.google.com/go/documentai v1.18.0/go.mod h1:F6CK6iUH8J81FehpskRmhLq/3VlwQvb7TvwOceQ2tbs= +cloud.google.com/go/domains v0.6.0/go.mod h1:T9Rz3GasrpYk6mEGHh4rymIhjlnIuB4ofT1wTxDeT4Y= +cloud.google.com/go/domains v0.7.0/go.mod h1:PtZeqS1xjnXuRPKE/88Iru/LdfoRyEHYA9nFQf4UKpg= +cloud.google.com/go/domains v0.8.0/go.mod h1:M9i3MMDzGFXsydri9/vW+EWz9sWb4I6WyHqdlAk0idE= +cloud.google.com/go/edgecontainer v0.1.0/go.mod h1:WgkZ9tp10bFxqO8BLPqv2LlfmQF1X8lZqwW4r1BTajk= +cloud.google.com/go/edgecontainer v0.2.0/go.mod h1:RTmLijy+lGpQ7BXuTDa4C4ssxyXT34NIuHIgKuP4s5w= +cloud.google.com/go/edgecontainer v0.3.0/go.mod h1:FLDpP4nykgwwIfcLt6zInhprzw0lEi2P1fjO6Ie0qbc= +cloud.google.com/go/edgecontainer v1.0.0/go.mod h1:cttArqZpBB2q58W/upSG++ooo6EsblxDIolxa3jSjbY= +cloud.google.com/go/errorreporting v0.3.0/go.mod h1:xsP2yaAp+OAW4OIm60An2bbLpqIhKXdWR/tawvl7QzU= +cloud.google.com/go/essentialcontacts v1.3.0/go.mod h1:r+OnHa5jfj90qIfZDO/VztSFqbQan7HV75p8sA+mdGI= +cloud.google.com/go/essentialcontacts v1.4.0/go.mod h1:8tRldvHYsmnBCHdFpvU+GL75oWiBKl80BiqlFh9tp+8= +cloud.google.com/go/essentialcontacts v1.5.0/go.mod h1:ay29Z4zODTuwliK7SnX8E86aUF2CTzdNtvv42niCX0M= +cloud.google.com/go/eventarc v1.7.0/go.mod h1:6ctpF3zTnaQCxUjHUdcfgcA1A2T309+omHZth7gDfmc= +cloud.google.com/go/eventarc v1.8.0/go.mod h1:imbzxkyAU4ubfsaKYdQg04WS1NvncblHEup4kvF+4gw= +cloud.google.com/go/eventarc v1.10.0/go.mod h1:u3R35tmZ9HvswGRBnF48IlYgYeBcPUCjkr4BTdem2Kw= +cloud.google.com/go/eventarc v1.11.0/go.mod h1:PyUjsUKPWoRBCHeOxZd/lbOOjahV41icXyUY5kSTvVY= +cloud.google.com/go/filestore v1.3.0/go.mod h1:+qbvHGvXU1HaKX2nD0WEPo92TP/8AQuCVEBXNY9z0+w= +cloud.google.com/go/filestore v1.4.0/go.mod h1:PaG5oDfo9r224f8OYXURtAsY+Fbyq/bLYoINEK8XQAI= +cloud.google.com/go/filestore v1.5.0/go.mod h1:FqBXDWBp4YLHqRnVGveOkHDf8svj9r5+mUDLupOWEDs= +cloud.google.com/go/filestore v1.6.0/go.mod h1:di5unNuss/qfZTw2U9nhFqo8/ZDSc466dre85Kydllg= +cloud.google.com/go/firestore v1.9.0/go.mod h1:HMkjKHNTtRyZNiMzu7YAsLr9K3X2udY2AMwDaMEQiiE= +cloud.google.com/go/functions v1.6.0/go.mod h1:3H1UA3qiIPRWD7PeZKLvHZ9SaQhR26XIJcC0A5GbvAk= +cloud.google.com/go/functions v1.7.0/go.mod h1:+d+QBcWM+RsrgZfV9xo6KfA1GlzJfxcfZcRPEhDDfzg= +cloud.google.com/go/functions v1.8.0/go.mod h1:RTZ4/HsQjIqIYP9a9YPbU+QFoQsAlYgrwOXJWHn1POY= +cloud.google.com/go/functions v1.9.0/go.mod h1:Y+Dz8yGguzO3PpIjhLTbnqV1CWmgQ5UwtlpzoyquQ08= +cloud.google.com/go/functions v1.10.0/go.mod h1:0D3hEOe3DbEvCXtYOZHQZmD+SzYsi1YbI7dGvHfldXw= +cloud.google.com/go/functions v1.12.0/go.mod h1:AXWGrF3e2C/5ehvwYo/GH6O5s09tOPksiKhz+hH8WkA= +cloud.google.com/go/functions v1.13.0/go.mod h1:EU4O007sQm6Ef/PwRsI8N2umygGqPBS/IZQKBQBcJ3c= +cloud.google.com/go/gaming v1.5.0/go.mod h1:ol7rGcxP/qHTRQE/RO4bxkXq+Fix0j6D4LFPzYTIrDM= +cloud.google.com/go/gaming v1.6.0/go.mod h1:YMU1GEvA39Qt3zWGyAVA9bpYz/yAhTvaQ1t2sK4KPUA= +cloud.google.com/go/gaming v1.7.0/go.mod h1:LrB8U7MHdGgFG851iHAfqUdLcKBdQ55hzXy9xBJz0+w= +cloud.google.com/go/gaming v1.8.0/go.mod h1:xAqjS8b7jAVW0KFYeRUxngo9My3f33kFmua++Pi+ggM= +cloud.google.com/go/gaming v1.9.0/go.mod h1:Fc7kEmCObylSWLO334NcO+O9QMDyz+TKC4v1D7X+Bc0= +cloud.google.com/go/gkebackup v0.2.0/go.mod h1:XKvv/4LfG829/B8B7xRkk8zRrOEbKtEam6yNfuQNH60= +cloud.google.com/go/gkebackup v0.3.0/go.mod h1:n/E671i1aOQvUxT541aTkCwExO/bTer2HDlj4TsBRAo= +cloud.google.com/go/gkebackup v0.4.0/go.mod h1:byAyBGUwYGEEww7xsbnUTBHIYcOPy/PgUWUtOeRm9Vg= +cloud.google.com/go/gkeconnect v0.5.0/go.mod h1:c5lsNAg5EwAy7fkqX/+goqFsU1Da/jQFqArp+wGNr/o= +cloud.google.com/go/gkeconnect v0.6.0/go.mod h1:Mln67KyU/sHJEBY8kFZ0xTeyPtzbq9StAVvEULYK16A= +cloud.google.com/go/gkeconnect v0.7.0/go.mod h1:SNfmVqPkaEi3bF/B3CNZOAYPYdg7sU+obZ+QTky2Myw= +cloud.google.com/go/gkehub v0.9.0/go.mod h1:WYHN6WG8w9bXU0hqNxt8rm5uxnk8IH+lPY9J2TV7BK0= +cloud.google.com/go/gkehub v0.10.0/go.mod h1:UIPwxI0DsrpsVoWpLB0stwKCP+WFVG9+y977wO+hBH0= +cloud.google.com/go/gkehub v0.11.0/go.mod h1:JOWHlmN+GHyIbuWQPl47/C2RFhnFKH38jH9Ascu3n0E= +cloud.google.com/go/gkehub v0.12.0/go.mod h1:djiIwwzTTBrF5NaXCGv3mf7klpEMcST17VBTVVDcuaw= +cloud.google.com/go/gkemulticloud v0.3.0/go.mod h1:7orzy7O0S+5kq95e4Hpn7RysVA7dPs8W/GgfUtsPbrA= +cloud.google.com/go/gkemulticloud v0.4.0/go.mod h1:E9gxVBnseLWCk24ch+P9+B2CoDFJZTyIgLKSalC7tuI= +cloud.google.com/go/gkemulticloud v0.5.0/go.mod h1:W0JDkiyi3Tqh0TJr//y19wyb1yf8llHVto2Htf2Ja3Y= +cloud.google.com/go/grafeas v0.2.0/go.mod h1:KhxgtF2hb0P191HlY5besjYm6MqTSTj3LSI+M+ByZHc= +cloud.google.com/go/gsuiteaddons v1.3.0/go.mod h1:EUNK/J1lZEZO8yPtykKxLXI6JSVN2rg9bN8SXOa0bgM= +cloud.google.com/go/gsuiteaddons v1.4.0/go.mod h1:rZK5I8hht7u7HxFQcFei0+AtfS9uSushomRlg+3ua1o= +cloud.google.com/go/gsuiteaddons v1.5.0/go.mod h1:TFCClYLd64Eaa12sFVmUyG62tk4mdIsI7pAnSXRkcFo= +cloud.google.com/go/iam v0.1.0/go.mod h1:vcUNEa0pEm0qRVpmWepWaFMIAI8/hjB9mO8rNCJtF6c= +cloud.google.com/go/iam v0.3.0/go.mod h1:XzJPvDayI+9zsASAFO68Hk07u3z+f+JrT2xXNdp4bnY= +cloud.google.com/go/iam v0.5.0/go.mod h1:wPU9Vt0P4UmCux7mqtRu6jcpPAb74cP1fh50J3QpkUc= +cloud.google.com/go/iam v0.6.0/go.mod h1:+1AH33ueBne5MzYccyMHtEKqLE4/kJOibtffMHDMFMc= +cloud.google.com/go/iam v0.7.0/go.mod h1:H5Br8wRaDGNc8XP3keLc4unfUUZeyH3Sfl9XpQEYOeg= +cloud.google.com/go/iam v0.8.0/go.mod h1:lga0/y3iH6CX7sYqypWJ33hf7kkfXJag67naqGESjkE= +cloud.google.com/go/iam v0.11.0/go.mod h1:9PiLDanza5D+oWFZiH1uG+RnRCfEGKoyl6yo4cgWZGY= +cloud.google.com/go/iam v0.12.0/go.mod h1:knyHGviacl11zrtZUoDuYpDgLjvr28sLQaG0YB2GYAY= +cloud.google.com/go/iam v0.13.0/go.mod h1:ljOg+rcNfzZ5d6f1nAUJ8ZIxOaZUVoS14bKCtaLZ/D0= +cloud.google.com/go/iap v1.4.0/go.mod h1:RGFwRJdihTINIe4wZ2iCP0zF/qu18ZwyKxrhMhygBEc= +cloud.google.com/go/iap v1.5.0/go.mod h1:UH/CGgKd4KyohZL5Pt0jSKE4m3FR51qg6FKQ/z/Ix9A= +cloud.google.com/go/iap v1.6.0/go.mod h1:NSuvI9C/j7UdjGjIde7t7HBz+QTwBcapPE07+sSRcLk= +cloud.google.com/go/iap v1.7.0/go.mod h1:beqQx56T9O1G1yNPph+spKpNibDlYIiIixiqsQXxLIo= +cloud.google.com/go/iap v1.7.1/go.mod h1:WapEwPc7ZxGt2jFGB/C/bm+hP0Y6NXzOYGjpPnmMS74= +cloud.google.com/go/ids v1.1.0/go.mod h1:WIuwCaYVOzHIj2OhN9HAwvW+DBdmUAdcWlFxRl+KubM= +cloud.google.com/go/ids v1.2.0/go.mod h1:5WXvp4n25S0rA/mQWAg1YEEBBq6/s+7ml1RDCW1IrcY= +cloud.google.com/go/ids v1.3.0/go.mod h1:JBdTYwANikFKaDP6LtW5JAi4gubs57SVNQjemdt6xV4= +cloud.google.com/go/iot v1.3.0/go.mod h1:r7RGh2B61+B8oz0AGE+J72AhA0G7tdXItODWsaA2oLs= +cloud.google.com/go/iot v1.4.0/go.mod h1:dIDxPOn0UvNDUMD8Ger7FIaTuvMkj+aGk94RPP0iV+g= +cloud.google.com/go/iot v1.5.0/go.mod h1:mpz5259PDl3XJthEmh9+ap0affn/MqNSP4My77Qql9o= +cloud.google.com/go/iot v1.6.0/go.mod h1:IqdAsmE2cTYYNO1Fvjfzo9po179rAtJeVGUvkLN3rLE= +cloud.google.com/go/kms v1.4.0/go.mod h1:fajBHndQ+6ubNw6Ss2sSd+SWvjL26RNo/dr7uxsnnOA= +cloud.google.com/go/kms v1.5.0/go.mod h1:QJS2YY0eJGBg3mnDfuaCyLauWwBJiHRboYxJ++1xJNg= +cloud.google.com/go/kms v1.6.0/go.mod h1:Jjy850yySiasBUDi6KFUwUv2n1+o7QZFyuUJg6OgjA0= +cloud.google.com/go/kms v1.8.0/go.mod h1:4xFEhYFqvW+4VMELtZyxomGSYtSQKzM178ylFW4jMAg= +cloud.google.com/go/kms v1.9.0/go.mod h1:qb1tPTgfF9RQP8e1wq4cLFErVuTJv7UsSC915J8dh3w= +cloud.google.com/go/kms v1.10.0/go.mod h1:ng3KTUtQQU9bPX3+QGLsflZIHlkbn8amFAMY63m8d24= +cloud.google.com/go/kms v1.10.1/go.mod h1:rIWk/TryCkR59GMC3YtHtXeLzd634lBbKenvyySAyYI= +cloud.google.com/go/language v1.4.0/go.mod h1:F9dRpNFQmJbkaop6g0JhSBXCNlO90e1KWx5iDdxbWic= +cloud.google.com/go/language v1.6.0/go.mod h1:6dJ8t3B+lUYfStgls25GusK04NLh3eDLQnWM3mdEbhI= +cloud.google.com/go/language v1.7.0/go.mod h1:DJ6dYN/W+SQOjF8e1hLQXMF21AkH2w9wiPzPCJa2MIE= +cloud.google.com/go/language v1.8.0/go.mod h1:qYPVHf7SPoNNiCL2Dr0FfEFNil1qi3pQEyygwpgVKB8= +cloud.google.com/go/language v1.9.0/go.mod h1:Ns15WooPM5Ad/5no/0n81yUetis74g3zrbeJBE+ptUY= +cloud.google.com/go/lifesciences v0.5.0/go.mod h1:3oIKy8ycWGPUyZDR/8RNnTOYevhaMLqh5vLUXs9zvT8= +cloud.google.com/go/lifesciences v0.6.0/go.mod h1:ddj6tSX/7BOnhxCSd3ZcETvtNr8NZ6t/iPhY2Tyfu08= +cloud.google.com/go/lifesciences v0.8.0/go.mod h1:lFxiEOMqII6XggGbOnKiyZ7IBwoIqA84ClvoezaA/bo= +cloud.google.com/go/logging v1.6.1/go.mod h1:5ZO0mHHbvm8gEmeEUHrmDlTDSu5imF6MUP9OfilNXBw= +cloud.google.com/go/logging v1.7.0/go.mod h1:3xjP2CjkM3ZkO73aj4ASA5wRPGGCRrPIAeNqVNkzY8M= +cloud.google.com/go/longrunning v0.1.1/go.mod h1:UUFxuDWkv22EuY93jjmDMFT5GPQKeFVJBIF6QlTqdsE= +cloud.google.com/go/longrunning v0.3.0/go.mod h1:qth9Y41RRSUE69rDcOn6DdK3HfQfsUI0YSmW3iIlLJc= +cloud.google.com/go/longrunning v0.4.1/go.mod h1:4iWDqhBZ70CvZ6BfETbvam3T8FMvLK+eFj0E6AaRQTo= +cloud.google.com/go/managedidentities v1.3.0/go.mod h1:UzlW3cBOiPrzucO5qWkNkh0w33KFtBJU281hacNvsdE= +cloud.google.com/go/managedidentities v1.4.0/go.mod h1:NWSBYbEMgqmbZsLIyKvxrYbtqOsxY1ZrGM+9RgDqInM= +cloud.google.com/go/managedidentities v1.5.0/go.mod h1:+dWcZ0JlUmpuxpIDfyP5pP5y0bLdRwOS4Lp7gMni/LA= +cloud.google.com/go/maps v0.1.0/go.mod h1:BQM97WGyfw9FWEmQMpZ5T6cpovXXSd1cGmFma94eubI= +cloud.google.com/go/maps v0.6.0/go.mod h1:o6DAMMfb+aINHz/p/jbcY+mYeXBoZoxTfdSQ8VAJaCw= +cloud.google.com/go/maps v0.7.0/go.mod h1:3GnvVl3cqeSvgMcpRlQidXsPYuDGQ8naBis7MVzpXsY= +cloud.google.com/go/mediatranslation v0.5.0/go.mod h1:jGPUhGTybqsPQn91pNXw0xVHfuJ3leR1wj37oU3y1f4= +cloud.google.com/go/mediatranslation v0.6.0/go.mod h1:hHdBCTYNigsBxshbznuIMFNe5QXEowAuNmmC7h8pu5w= +cloud.google.com/go/mediatranslation v0.7.0/go.mod h1:LCnB/gZr90ONOIQLgSXagp8XUW1ODs2UmUMvcgMfI2I= +cloud.google.com/go/memcache v1.4.0/go.mod h1:rTOfiGZtJX1AaFUrOgsMHX5kAzaTQ8azHiuDoTPzNsE= +cloud.google.com/go/memcache v1.5.0/go.mod h1:dk3fCK7dVo0cUU2c36jKb4VqKPS22BTkf81Xq617aWM= +cloud.google.com/go/memcache v1.6.0/go.mod h1:XS5xB0eQZdHtTuTF9Hf8eJkKtR3pVRCcvJwtm68T3rA= +cloud.google.com/go/memcache v1.7.0/go.mod h1:ywMKfjWhNtkQTxrWxCkCFkoPjLHPW6A7WOTVI8xy3LY= +cloud.google.com/go/memcache v1.9.0/go.mod h1:8oEyzXCu+zo9RzlEaEjHl4KkgjlNDaXbCQeQWlzNFJM= +cloud.google.com/go/metastore v1.5.0/go.mod h1:2ZNrDcQwghfdtCwJ33nM0+GrBGlVuh8rakL3vdPY3XY= +cloud.google.com/go/metastore v1.6.0/go.mod h1:6cyQTls8CWXzk45G55x57DVQ9gWg7RiH65+YgPsNh9s= +cloud.google.com/go/metastore v1.7.0/go.mod h1:s45D0B4IlsINu87/AsWiEVYbLaIMeUSoxlKKDqBGFS8= +cloud.google.com/go/metastore v1.8.0/go.mod h1:zHiMc4ZUpBiM7twCIFQmJ9JMEkDSyZS9U12uf7wHqSI= +cloud.google.com/go/metastore v1.10.0/go.mod h1:fPEnH3g4JJAk+gMRnrAnoqyv2lpUCqJPWOodSaf45Eo= +cloud.google.com/go/monitoring v1.7.0/go.mod h1:HpYse6kkGo//7p6sT0wsIC6IBDET0RhIsnmlA53dvEk= +cloud.google.com/go/monitoring v1.8.0/go.mod h1:E7PtoMJ1kQXWxPjB6mv2fhC5/15jInuulFdYYtlcvT4= +cloud.google.com/go/monitoring v1.12.0/go.mod h1:yx8Jj2fZNEkL/GYZyTLS4ZtZEZN8WtDEiEqG4kLK50w= +cloud.google.com/go/monitoring v1.13.0/go.mod h1:k2yMBAB1H9JT/QETjNkgdCGD9bPF712XiLTVr+cBrpw= +cloud.google.com/go/networkconnectivity v1.4.0/go.mod h1:nOl7YL8odKyAOtzNX73/M5/mGZgqqMeryi6UPZTk/rA= +cloud.google.com/go/networkconnectivity v1.5.0/go.mod h1:3GzqJx7uhtlM3kln0+x5wyFvuVH1pIBJjhCpjzSt75o= +cloud.google.com/go/networkconnectivity v1.6.0/go.mod h1:OJOoEXW+0LAxHh89nXd64uGG+FbQoeH8DtxCHVOMlaM= +cloud.google.com/go/networkconnectivity v1.7.0/go.mod h1:RMuSbkdbPwNMQjB5HBWD5MpTBnNm39iAVpC3TmsExt8= +cloud.google.com/go/networkconnectivity v1.10.0/go.mod h1:UP4O4sWXJG13AqrTdQCD9TnLGEbtNRqjuaaA7bNjF5E= +cloud.google.com/go/networkconnectivity v1.11.0/go.mod h1:iWmDD4QF16VCDLXUqvyspJjIEtBR/4zq5hwnY2X3scM= +cloud.google.com/go/networkmanagement v1.4.0/go.mod h1:Q9mdLLRn60AsOrPc8rs8iNV6OHXaGcDdsIQe1ohekq8= +cloud.google.com/go/networkmanagement v1.5.0/go.mod h1:ZnOeZ/evzUdUsnvRt792H0uYEnHQEMaz+REhhzJRcf4= +cloud.google.com/go/networkmanagement v1.6.0/go.mod h1:5pKPqyXjB/sgtvB5xqOemumoQNB7y95Q7S+4rjSOPYY= +cloud.google.com/go/networksecurity v0.5.0/go.mod h1:xS6fOCoqpVC5zx15Z/MqkfDwH4+m/61A3ODiDV1xmiQ= +cloud.google.com/go/networksecurity v0.6.0/go.mod h1:Q5fjhTr9WMI5mbpRYEbiexTzROf7ZbDzvzCrNl14nyU= +cloud.google.com/go/networksecurity v0.7.0/go.mod h1:mAnzoxx/8TBSyXEeESMy9OOYwo1v+gZ5eMRnsT5bC8k= +cloud.google.com/go/networksecurity v0.8.0/go.mod h1:B78DkqsxFG5zRSVuwYFRZ9Xz8IcQ5iECsNrPn74hKHU= +cloud.google.com/go/notebooks v1.2.0/go.mod h1:9+wtppMfVPUeJ8fIWPOq1UnATHISkGXGqTkxeieQ6UY= +cloud.google.com/go/notebooks v1.3.0/go.mod h1:bFR5lj07DtCPC7YAAJ//vHskFBxA5JzYlH68kXVdk34= +cloud.google.com/go/notebooks v1.4.0/go.mod h1:4QPMngcwmgb6uw7Po99B2xv5ufVoIQ7nOGDyL4P8AgA= +cloud.google.com/go/notebooks v1.5.0/go.mod h1:q8mwhnP9aR8Hpfnrc5iN5IBhrXUy8S2vuYs+kBJ/gu0= +cloud.google.com/go/notebooks v1.7.0/go.mod h1:PVlaDGfJgj1fl1S3dUwhFMXFgfYGhYQt2164xOMONmE= +cloud.google.com/go/notebooks v1.8.0/go.mod h1:Lq6dYKOYOWUCTvw5t2q1gp1lAp0zxAxRycayS0iJcqQ= +cloud.google.com/go/optimization v1.1.0/go.mod h1:5po+wfvX5AQlPznyVEZjGJTMr4+CAkJf2XSTQOOl9l4= +cloud.google.com/go/optimization v1.2.0/go.mod h1:Lr7SOHdRDENsh+WXVmQhQTrzdu9ybg0NecjHidBq6xs= +cloud.google.com/go/optimization v1.3.1/go.mod h1:IvUSefKiwd1a5p0RgHDbWCIbDFgKuEdB+fPPuP0IDLI= +cloud.google.com/go/orchestration v1.3.0/go.mod h1:Sj5tq/JpWiB//X/q3Ngwdl5K7B7Y0KZ7bfv0wL6fqVA= +cloud.google.com/go/orchestration v1.4.0/go.mod h1:6W5NLFWs2TlniBphAViZEVhrXRSMgUGDfW7vrWKvsBk= +cloud.google.com/go/orchestration v1.6.0/go.mod h1:M62Bevp7pkxStDfFfTuCOaXgaaqRAga1yKyoMtEoWPQ= +cloud.google.com/go/orgpolicy v1.4.0/go.mod h1:xrSLIV4RePWmP9P3tBl8S93lTmlAxjm06NSm2UTmKvE= +cloud.google.com/go/orgpolicy v1.5.0/go.mod h1:hZEc5q3wzwXJaKrsx5+Ewg0u1LxJ51nNFlext7Tanwc= +cloud.google.com/go/orgpolicy v1.10.0/go.mod h1:w1fo8b7rRqlXlIJbVhOMPrwVljyuW5mqssvBtU18ONc= +cloud.google.com/go/osconfig v1.7.0/go.mod h1:oVHeCeZELfJP7XLxcBGTMBvRO+1nQ5tFG9VQTmYS2Fs= +cloud.google.com/go/osconfig v1.8.0/go.mod h1:EQqZLu5w5XA7eKizepumcvWx+m8mJUhEwiPqWiZeEdg= +cloud.google.com/go/osconfig v1.9.0/go.mod h1:Yx+IeIZJ3bdWmzbQU4fxNl8xsZ4amB+dygAwFPlvnNo= +cloud.google.com/go/osconfig v1.10.0/go.mod h1:uMhCzqC5I8zfD9zDEAfvgVhDS8oIjySWh+l4WK6GnWw= +cloud.google.com/go/osconfig v1.11.0/go.mod h1:aDICxrur2ogRd9zY5ytBLV89KEgT2MKB2L/n6x1ooPw= +cloud.google.com/go/oslogin v1.4.0/go.mod h1:YdgMXWRaElXz/lDk1Na6Fh5orF7gvmJ0FGLIs9LId4E= +cloud.google.com/go/oslogin v1.5.0/go.mod h1:D260Qj11W2qx/HVF29zBg+0fd6YCSjSqLUkY/qEenQU= +cloud.google.com/go/oslogin v1.6.0/go.mod h1:zOJ1O3+dTU8WPlGEkFSh7qeHPPSoxrcMbbK1Nm2iX70= +cloud.google.com/go/oslogin v1.7.0/go.mod h1:e04SN0xO1UNJ1M5GP0vzVBFicIe4O53FOfcixIqTyXo= +cloud.google.com/go/oslogin v1.9.0/go.mod h1:HNavntnH8nzrn8JCTT5fj18FuJLFJc4NaZJtBnQtKFs= +cloud.google.com/go/phishingprotection v0.5.0/go.mod h1:Y3HZknsK9bc9dMi+oE8Bim0lczMU6hrX0UpADuMefr0= +cloud.google.com/go/phishingprotection v0.6.0/go.mod h1:9Y3LBLgy0kDTcYET8ZH3bq/7qni15yVUoAxiFxnlSUA= +cloud.google.com/go/phishingprotection v0.7.0/go.mod h1:8qJI4QKHoda/sb/7/YmMQ2omRLSLYSu9bU0EKCNI+Lk= +cloud.google.com/go/policytroubleshooter v1.3.0/go.mod h1:qy0+VwANja+kKrjlQuOzmlvscn4RNsAc0e15GGqfMxg= +cloud.google.com/go/policytroubleshooter v1.4.0/go.mod h1:DZT4BcRw3QoO8ota9xw/LKtPa8lKeCByYeKTIf/vxdE= +cloud.google.com/go/policytroubleshooter v1.5.0/go.mod h1:Rz1WfV+1oIpPdN2VvvuboLVRsB1Hclg3CKQ53j9l8vw= +cloud.google.com/go/policytroubleshooter v1.6.0/go.mod h1:zYqaPTsmfvpjm5ULxAyD/lINQxJ0DDsnWOP/GZ7xzBc= +cloud.google.com/go/privatecatalog v0.5.0/go.mod h1:XgosMUvvPyxDjAVNDYxJ7wBW8//hLDDYmnsNcMGq1K0= +cloud.google.com/go/privatecatalog v0.6.0/go.mod h1:i/fbkZR0hLN29eEWiiwue8Pb+GforiEIBnV9yrRUOKI= +cloud.google.com/go/privatecatalog v0.7.0/go.mod h1:2s5ssIFO69F5csTXcwBP7NPFTZvps26xGzvQ2PQaBYg= +cloud.google.com/go/privatecatalog v0.8.0/go.mod h1:nQ6pfaegeDAq/Q5lrfCQzQLhubPiZhSaNhIgfJlnIXs= +cloud.google.com/go/pubsub v1.0.1/go.mod h1:R0Gpsv3s54REJCy4fxDixWD93lHJMoZTyQ2kNxGRt3I= +cloud.google.com/go/pubsub v1.1.0/go.mod h1:EwwdRX2sKPjnvnqCa270oGRyludottCI76h+R3AArQw= +cloud.google.com/go/pubsub v1.2.0/go.mod h1:jhfEVHT8odbXTkndysNHCcx0awwzvfOlguIAii9o8iA= +cloud.google.com/go/pubsub v1.3.1/go.mod h1:i+ucay31+CNRpDW4Lu78I4xXG+O1r/MAHgjpRVR+TSU= +cloud.google.com/go/pubsub v1.26.0/go.mod h1:QgBH3U/jdJy/ftjPhTkyXNj543Tin1pRYcdcPRnFIRI= +cloud.google.com/go/pubsub v1.27.1/go.mod h1:hQN39ymbV9geqBnfQq6Xf63yNhUAhv9CZhzp5O6qsW0= +cloud.google.com/go/pubsub v1.28.0/go.mod h1:vuXFpwaVoIPQMGXqRyUQigu/AX1S3IWugR9xznmcXX8= +cloud.google.com/go/pubsub v1.30.0/go.mod h1:qWi1OPS0B+b5L+Sg6Gmc9zD1Y+HaM0MdUr7LsupY1P4= +cloud.google.com/go/pubsublite v1.5.0/go.mod h1:xapqNQ1CuLfGi23Yda/9l4bBCKz/wC3KIJ5gKcxveZg= +cloud.google.com/go/pubsublite v1.6.0/go.mod h1:1eFCS0U11xlOuMFV/0iBqw3zP12kddMeCbj/F3FSj9k= +cloud.google.com/go/pubsublite v1.7.0/go.mod h1:8hVMwRXfDfvGm3fahVbtDbiLePT3gpoiJYJY+vxWxVM= +cloud.google.com/go/recaptchaenterprise v1.3.1/go.mod h1:OdD+q+y4XGeAlxRaMn1Y7/GveP6zmq76byL6tjPE7d4= +cloud.google.com/go/recaptchaenterprise/v2 v2.1.0/go.mod h1:w9yVqajwroDNTfGuhmOjPDN//rZGySaf6PtFVcSCa7o= +cloud.google.com/go/recaptchaenterprise/v2 v2.2.0/go.mod h1:/Zu5jisWGeERrd5HnlS3EUGb/D335f9k51B/FVil0jk= +cloud.google.com/go/recaptchaenterprise/v2 v2.3.0/go.mod h1:O9LwGCjrhGHBQET5CA7dd5NwwNQUErSgEDit1DLNTdo= +cloud.google.com/go/recaptchaenterprise/v2 v2.4.0/go.mod h1:Am3LHfOuBstrLrNCBrlI5sbwx9LBg3te2N6hGvHn2mE= +cloud.google.com/go/recaptchaenterprise/v2 v2.5.0/go.mod h1:O8LzcHXN3rz0j+LBC91jrwI3R+1ZSZEWrfL7XHgNo9U= +cloud.google.com/go/recaptchaenterprise/v2 v2.6.0/go.mod h1:RPauz9jeLtB3JVzg6nCbe12qNoaa8pXc4d/YukAmcnA= +cloud.google.com/go/recaptchaenterprise/v2 v2.7.0/go.mod h1:19wVj/fs5RtYtynAPJdDTb69oW0vNHYDBTbB4NvMD9c= +cloud.google.com/go/recommendationengine v0.5.0/go.mod h1:E5756pJcVFeVgaQv3WNpImkFP8a+RptV6dDLGPILjvg= +cloud.google.com/go/recommendationengine v0.6.0/go.mod h1:08mq2umu9oIqc7tDy8sx+MNJdLG0fUi3vaSVbztHgJ4= +cloud.google.com/go/recommendationengine v0.7.0/go.mod h1:1reUcE3GIu6MeBz/h5xZJqNLuuVjNg1lmWMPyjatzac= +cloud.google.com/go/recommender v1.5.0/go.mod h1:jdoeiBIVrJe9gQjwd759ecLJbxCDED4A6p+mqoqDvTg= +cloud.google.com/go/recommender v1.6.0/go.mod h1:+yETpm25mcoiECKh9DEScGzIRyDKpZ0cEhWGo+8bo+c= +cloud.google.com/go/recommender v1.7.0/go.mod h1:XLHs/W+T8olwlGOgfQenXBTbIseGclClff6lhFVe9Bs= +cloud.google.com/go/recommender v1.8.0/go.mod h1:PkjXrTT05BFKwxaUxQmtIlrtj0kph108r02ZZQ5FE70= +cloud.google.com/go/recommender v1.9.0/go.mod h1:PnSsnZY7q+VL1uax2JWkt/UegHssxjUVVCrX52CuEmQ= +cloud.google.com/go/redis v1.7.0/go.mod h1:V3x5Jq1jzUcg+UNsRvdmsfuFnit1cfe3Z/PGyq/lm4Y= +cloud.google.com/go/redis v1.8.0/go.mod h1:Fm2szCDavWzBk2cDKxrkmWBqoCiL1+Ctwq7EyqBCA/A= +cloud.google.com/go/redis v1.9.0/go.mod h1:HMYQuajvb2D0LvMgZmLDZW8V5aOC/WxstZHiy4g8OiA= +cloud.google.com/go/redis v1.10.0/go.mod h1:ThJf3mMBQtW18JzGgh41/Wld6vnDDc/F/F35UolRZPM= +cloud.google.com/go/redis v1.11.0/go.mod h1:/X6eicana+BWcUda5PpwZC48o37SiFVTFSs0fWAJ7uQ= +cloud.google.com/go/resourcemanager v1.3.0/go.mod h1:bAtrTjZQFJkiWTPDb1WBjzvc6/kifjj4QBYuKCCoqKA= +cloud.google.com/go/resourcemanager v1.4.0/go.mod h1:MwxuzkumyTX7/a3n37gmsT3py7LIXwrShilPh3P1tR0= +cloud.google.com/go/resourcemanager v1.5.0/go.mod h1:eQoXNAiAvCf5PXxWxXjhKQoTMaUSNrEfg+6qdf/wots= +cloud.google.com/go/resourcemanager v1.6.0/go.mod h1:YcpXGRs8fDzcUl1Xw8uOVmI8JEadvhRIkoXXUNVYcVo= +cloud.google.com/go/resourcemanager v1.7.0/go.mod h1:HlD3m6+bwhzj9XCouqmeiGuni95NTrExfhoSrkC/3EI= +cloud.google.com/go/resourcesettings v1.3.0/go.mod h1:lzew8VfESA5DQ8gdlHwMrqZs1S9V87v3oCnKCWoOuQU= +cloud.google.com/go/resourcesettings v1.4.0/go.mod h1:ldiH9IJpcrlC3VSuCGvjR5of/ezRrOxFtpJoJo5SmXg= +cloud.google.com/go/resourcesettings v1.5.0/go.mod h1:+xJF7QSG6undsQDfsCJyqWXyBwUoJLhetkRMDRnIoXA= +cloud.google.com/go/retail v1.8.0/go.mod h1:QblKS8waDmNUhghY2TI9O3JLlFk8jybHeV4BF19FrE4= +cloud.google.com/go/retail v1.9.0/go.mod h1:g6jb6mKuCS1QKnH/dpu7isX253absFl6iE92nHwlBUY= +cloud.google.com/go/retail v1.10.0/go.mod h1:2gDk9HsL4HMS4oZwz6daui2/jmKvqShXKQuB2RZ+cCc= +cloud.google.com/go/retail v1.11.0/go.mod h1:MBLk1NaWPmh6iVFSz9MeKG/Psyd7TAgm6y/9L2B4x9Y= +cloud.google.com/go/retail v1.12.0/go.mod h1:UMkelN/0Z8XvKymXFbD4EhFJlYKRx1FGhQkVPU5kF14= +cloud.google.com/go/run v0.2.0/go.mod h1:CNtKsTA1sDcnqqIFR3Pb5Tq0usWxJJvsWOCPldRU3Do= +cloud.google.com/go/run v0.3.0/go.mod h1:TuyY1+taHxTjrD0ZFk2iAR+xyOXEA0ztb7U3UNA0zBo= +cloud.google.com/go/run v0.8.0/go.mod h1:VniEnuBwqjigv0A7ONfQUaEItaiCRVujlMqerPPiktM= +cloud.google.com/go/run v0.9.0/go.mod h1:Wwu+/vvg8Y+JUApMwEDfVfhetv30hCG4ZwDR/IXl2Qg= +cloud.google.com/go/scheduler v1.4.0/go.mod h1:drcJBmxF3aqZJRhmkHQ9b3uSSpQoltBPGPxGAWROx6s= +cloud.google.com/go/scheduler v1.5.0/go.mod h1:ri073ym49NW3AfT6DZi21vLZrG07GXr5p3H1KxN5QlI= +cloud.google.com/go/scheduler v1.6.0/go.mod h1:SgeKVM7MIwPn3BqtcBntpLyrIJftQISRrYB5ZtT+KOk= +cloud.google.com/go/scheduler v1.7.0/go.mod h1:jyCiBqWW956uBjjPMMuX09n3x37mtyPJegEWKxRsn44= +cloud.google.com/go/scheduler v1.8.0/go.mod h1:TCET+Y5Gp1YgHT8py4nlg2Sew8nUHMqcpousDgXJVQc= +cloud.google.com/go/scheduler v1.9.0/go.mod h1:yexg5t+KSmqu+njTIh3b7oYPheFtBWGcbVUYF1GGMIc= +cloud.google.com/go/secretmanager v1.6.0/go.mod h1:awVa/OXF6IiyaU1wQ34inzQNc4ISIDIrId8qE5QGgKA= +cloud.google.com/go/secretmanager v1.8.0/go.mod h1:hnVgi/bN5MYHd3Gt0SPuTPPp5ENina1/LxM+2W9U9J4= +cloud.google.com/go/secretmanager v1.9.0/go.mod h1:b71qH2l1yHmWQHt9LC80akm86mX8AL6X1MA01dW8ht4= +cloud.google.com/go/secretmanager v1.10.0/go.mod h1:MfnrdvKMPNra9aZtQFvBcvRU54hbPD8/HayQdlUgJpU= +cloud.google.com/go/security v1.5.0/go.mod h1:lgxGdyOKKjHL4YG3/YwIL2zLqMFCKs0UbQwgyZmfJl4= +cloud.google.com/go/security v1.7.0/go.mod h1:mZklORHl6Bg7CNnnjLH//0UlAlaXqiG7Lb9PsPXLfD0= +cloud.google.com/go/security v1.8.0/go.mod h1:hAQOwgmaHhztFhiQ41CjDODdWP0+AE1B3sX4OFlq+GU= +cloud.google.com/go/security v1.9.0/go.mod h1:6Ta1bO8LXI89nZnmnsZGp9lVoVWXqsVbIq/t9dzI+2Q= +cloud.google.com/go/security v1.10.0/go.mod h1:QtOMZByJVlibUT2h9afNDWRZ1G96gVywH8T5GUSb9IA= +cloud.google.com/go/security v1.12.0/go.mod h1:rV6EhrpbNHrrxqlvW0BWAIawFWq3X90SduMJdFwtLB8= +cloud.google.com/go/security v1.13.0/go.mod h1:Q1Nvxl1PAgmeW0y3HTt54JYIvUdtcpYKVfIB8AOMZ+0= +cloud.google.com/go/securitycenter v1.13.0/go.mod h1:cv5qNAqjY84FCN6Y9z28WlkKXyWsgLO832YiWwkCWcU= +cloud.google.com/go/securitycenter v1.14.0/go.mod h1:gZLAhtyKv85n52XYWt6RmeBdydyxfPeTrpToDPw4Auc= +cloud.google.com/go/securitycenter v1.15.0/go.mod h1:PeKJ0t8MoFmmXLXWm41JidyzI3PJjd8sXWaVqg43WWk= +cloud.google.com/go/securitycenter v1.16.0/go.mod h1:Q9GMaLQFUD+5ZTabrbujNWLtSLZIZF7SAR0wWECrjdk= +cloud.google.com/go/securitycenter v1.18.1/go.mod h1:0/25gAzCM/9OL9vVx4ChPeM/+DlfGQJDwBy/UC8AKK0= +cloud.google.com/go/securitycenter v1.19.0/go.mod h1:LVLmSg8ZkkyaNy4u7HCIshAngSQ8EcIRREP3xBnyfag= +cloud.google.com/go/servicecontrol v1.4.0/go.mod h1:o0hUSJ1TXJAmi/7fLJAedOovnujSEvjKCAFNXPQ1RaU= +cloud.google.com/go/servicecontrol v1.5.0/go.mod h1:qM0CnXHhyqKVuiZnGKrIurvVImCs8gmqWsDoqe9sU1s= +cloud.google.com/go/servicecontrol v1.10.0/go.mod h1:pQvyvSRh7YzUF2efw7H87V92mxU8FnFDawMClGCNuAA= +cloud.google.com/go/servicecontrol v1.11.0/go.mod h1:kFmTzYzTUIuZs0ycVqRHNaNhgR+UMUpw9n02l/pY+mc= +cloud.google.com/go/servicecontrol v1.11.1/go.mod h1:aSnNNlwEFBY+PWGQ2DoM0JJ/QUXqV5/ZD9DOLB7SnUk= +cloud.google.com/go/servicedirectory v1.4.0/go.mod h1:gH1MUaZCgtP7qQiI+F+A+OpeKF/HQWgtAddhTbhL2bs= +cloud.google.com/go/servicedirectory v1.5.0/go.mod h1:QMKFL0NUySbpZJ1UZs3oFAmdvVxhhxB6eJ/Vlp73dfg= +cloud.google.com/go/servicedirectory v1.6.0/go.mod h1:pUlbnWsLH9c13yGkxCmfumWEPjsRs1RlmJ4pqiNjVL4= +cloud.google.com/go/servicedirectory v1.7.0/go.mod h1:5p/U5oyvgYGYejufvxhgwjL8UVXjkuw7q5XcG10wx1U= +cloud.google.com/go/servicedirectory v1.8.0/go.mod h1:srXodfhY1GFIPvltunswqXpVxFPpZjf8nkKQT7XcXaY= +cloud.google.com/go/servicedirectory v1.9.0/go.mod h1:29je5JjiygNYlmsGz8k6o+OZ8vd4f//bQLtvzkPPT/s= +cloud.google.com/go/servicemanagement v1.4.0/go.mod h1:d8t8MDbezI7Z2R1O/wu8oTggo3BI2GKYbdG4y/SJTco= +cloud.google.com/go/servicemanagement v1.5.0/go.mod h1:XGaCRe57kfqu4+lRxaFEAuqmjzF0r+gWHjWqKqBvKFo= +cloud.google.com/go/servicemanagement v1.6.0/go.mod h1:aWns7EeeCOtGEX4OvZUWCCJONRZeFKiptqKf1D0l/Jc= +cloud.google.com/go/servicemanagement v1.8.0/go.mod h1:MSS2TDlIEQD/fzsSGfCdJItQveu9NXnUniTrq/L8LK4= +cloud.google.com/go/serviceusage v1.3.0/go.mod h1:Hya1cozXM4SeSKTAgGXgj97GlqUvF5JaoXacR1JTP/E= +cloud.google.com/go/serviceusage v1.4.0/go.mod h1:SB4yxXSaYVuUBYUml6qklyONXNLt83U0Rb+CXyhjEeU= +cloud.google.com/go/serviceusage v1.5.0/go.mod h1:w8U1JvqUqwJNPEOTQjrMHkw3IaIFLoLsPLvsE3xueec= +cloud.google.com/go/serviceusage v1.6.0/go.mod h1:R5wwQcbOWsyuOfbP9tGdAnCAc6B9DRwPG1xtWMDeuPA= +cloud.google.com/go/shell v1.3.0/go.mod h1:VZ9HmRjZBsjLGXusm7K5Q5lzzByZmJHf1d0IWHEN5X4= +cloud.google.com/go/shell v1.4.0/go.mod h1:HDxPzZf3GkDdhExzD/gs8Grqk+dmYcEjGShZgYa9URw= +cloud.google.com/go/shell v1.6.0/go.mod h1:oHO8QACS90luWgxP3N9iZVuEiSF84zNyLytb+qE2f9A= +cloud.google.com/go/spanner v1.41.0/go.mod h1:MLYDBJR/dY4Wt7ZaMIQ7rXOTLjYrmxLE/5ve9vFfWos= +cloud.google.com/go/spanner v1.44.0/go.mod h1:G8XIgYdOK+Fbcpbs7p2fiprDw4CaZX63whnSMLVBxjk= +cloud.google.com/go/spanner v1.45.0/go.mod h1:FIws5LowYz8YAE1J8fOS7DJup8ff7xJeetWEo5REA2M= +cloud.google.com/go/speech v1.6.0/go.mod h1:79tcr4FHCimOp56lwC01xnt/WPJZc4v3gzyT7FoBkCM= +cloud.google.com/go/speech v1.7.0/go.mod h1:KptqL+BAQIhMsj1kOP2la5DSEEerPDuOP/2mmkhHhZQ= +cloud.google.com/go/speech v1.8.0/go.mod h1:9bYIl1/tjsAnMgKGHKmBZzXKEkGgtU+MpdDPTE9f7y0= +cloud.google.com/go/speech v1.9.0/go.mod h1:xQ0jTcmnRFFM2RfX/U+rk6FQNUF6DQlydUSyoooSpco= +cloud.google.com/go/speech v1.14.1/go.mod h1:gEosVRPJ9waG7zqqnsHpYTOoAS4KouMRLDFMekpJ0J0= +cloud.google.com/go/speech v1.15.0/go.mod h1:y6oH7GhqCaZANH7+Oe0BhgIogsNInLlz542tg3VqeYI= +cloud.google.com/go/storage v1.0.0/go.mod h1:IhtSnM/ZTZV8YYJWCY8RULGVqBDmpoyjwiyrjsg+URw= +cloud.google.com/go/storage v1.5.0/go.mod h1:tpKbwo567HUNpVclU5sGELwQWBDZ8gh0ZeosJ0Rtdos= +cloud.google.com/go/storage v1.6.0/go.mod h1:N7U0C8pVQ/+NIKOBQyamJIeKQKkZ+mxpohlUTyfDhBk= +cloud.google.com/go/storage v1.8.0/go.mod h1:Wv1Oy7z6Yz3DshWRJFhqM/UCfaWIRTdp0RXyy7KQOVs= +cloud.google.com/go/storage v1.10.0/go.mod h1:FLPqc6j+Ki4BU591ie1oL6qBQGu2Bl/tZ9ullr3+Kg0= +cloud.google.com/go/storage v1.14.0/go.mod h1:GrKmX003DSIwi9o29oFT7YDnHYwZoctc3fOKtUw0Xmo= +cloud.google.com/go/storage v1.22.1/go.mod h1:S8N1cAStu7BOeFfE8KAQzmyyLkK8p/vmRq6kuBTW58Y= +cloud.google.com/go/storage v1.23.0/go.mod h1:vOEEDNFnciUMhBeT6hsJIn3ieU5cFRmzeLgDvXzfIXc= +cloud.google.com/go/storage v1.27.0/go.mod h1:x9DOL8TK/ygDUMieqwfhdpQryTeEkhGKMi80i/iqR2s= +cloud.google.com/go/storage v1.28.1/go.mod h1:Qnisd4CqDdo6BGs2AD5LLnEsmSQ80wQ5ogcBBKhU86Y= +cloud.google.com/go/storage v1.29.0/go.mod h1:4puEjyTKnku6gfKoTfNOU/W+a9JyuVNxjpS5GBrB8h4= +cloud.google.com/go/storagetransfer v1.5.0/go.mod h1:dxNzUopWy7RQevYFHewchb29POFv3/AaBgnhqzqiK0w= +cloud.google.com/go/storagetransfer v1.6.0/go.mod h1:y77xm4CQV/ZhFZH75PLEXY0ROiS7Gh6pSKrM8dJyg6I= +cloud.google.com/go/storagetransfer v1.7.0/go.mod h1:8Giuj1QNb1kfLAiWM1bN6dHzfdlDAVC9rv9abHot2W4= +cloud.google.com/go/storagetransfer v1.8.0/go.mod h1:JpegsHHU1eXg7lMHkvf+KE5XDJ7EQu0GwNJbbVGanEw= +cloud.google.com/go/talent v1.1.0/go.mod h1:Vl4pt9jiHKvOgF9KoZo6Kob9oV4lwd/ZD5Cto54zDRw= +cloud.google.com/go/talent v1.2.0/go.mod h1:MoNF9bhFQbiJ6eFD3uSsg0uBALw4n4gaCaEjBw9zo8g= +cloud.google.com/go/talent v1.3.0/go.mod h1:CmcxwJ/PKfRgd1pBjQgU6W3YBwiewmUzQYH5HHmSCmM= +cloud.google.com/go/talent v1.4.0/go.mod h1:ezFtAgVuRf8jRsvyE6EwmbTK5LKciD4KVnHuDEFmOOA= +cloud.google.com/go/talent v1.5.0/go.mod h1:G+ODMj9bsasAEJkQSzO2uHQWXHHXUomArjWQQYkqK6c= +cloud.google.com/go/texttospeech v1.4.0/go.mod h1:FX8HQHA6sEpJ7rCMSfXuzBcysDAuWusNNNvN9FELDd8= +cloud.google.com/go/texttospeech v1.5.0/go.mod h1:oKPLhR4n4ZdQqWKURdwxMy0uiTS1xU161C8W57Wkea4= +cloud.google.com/go/texttospeech v1.6.0/go.mod h1:YmwmFT8pj1aBblQOI3TfKmwibnsfvhIBzPXcW4EBovc= +cloud.google.com/go/tpu v1.3.0/go.mod h1:aJIManG0o20tfDQlRIej44FcwGGl/cD0oiRyMKG19IQ= +cloud.google.com/go/tpu v1.4.0/go.mod h1:mjZaX8p0VBgllCzF6wcU2ovUXN9TONFLd7iz227X2Xg= +cloud.google.com/go/tpu v1.5.0/go.mod h1:8zVo1rYDFuW2l4yZVY0R0fb/v44xLh3llq7RuV61fPM= +cloud.google.com/go/trace v1.3.0/go.mod h1:FFUE83d9Ca57C+K8rDl/Ih8LwOzWIV1krKgxg6N0G28= +cloud.google.com/go/trace v1.4.0/go.mod h1:UG0v8UBqzusp+z63o7FK74SdFE+AXpCLdFb1rshXG+Y= +cloud.google.com/go/trace v1.8.0/go.mod h1:zH7vcsbAhklH8hWFig58HvxcxyQbaIqMarMg9hn5ECA= +cloud.google.com/go/trace v1.9.0/go.mod h1:lOQqpE5IaWY0Ixg7/r2SjixMuc6lfTFeO4QGM4dQWOk= +cloud.google.com/go/translate v1.3.0/go.mod h1:gzMUwRjvOqj5i69y/LYLd8RrNQk+hOmIXTi9+nb3Djs= +cloud.google.com/go/translate v1.4.0/go.mod h1:06Dn/ppvLD6WvA5Rhdp029IX2Mi3Mn7fpMRLPvXT5Wg= +cloud.google.com/go/translate v1.5.0/go.mod h1:29YDSYveqqpA1CQFD7NQuP49xymq17RXNaUDdc0mNu0= +cloud.google.com/go/translate v1.6.0/go.mod h1:lMGRudH1pu7I3n3PETiOB2507gf3HnfLV8qlkHZEyos= +cloud.google.com/go/translate v1.7.0/go.mod h1:lMGRudH1pu7I3n3PETiOB2507gf3HnfLV8qlkHZEyos= +cloud.google.com/go/video v1.8.0/go.mod h1:sTzKFc0bUSByE8Yoh8X0mn8bMymItVGPfTuUBUyRgxk= +cloud.google.com/go/video v1.9.0/go.mod h1:0RhNKFRF5v92f8dQt0yhaHrEuH95m068JYOvLZYnJSw= +cloud.google.com/go/video v1.12.0/go.mod h1:MLQew95eTuaNDEGriQdcYn0dTwf9oWiA4uYebxM5kdg= +cloud.google.com/go/video v1.13.0/go.mod h1:ulzkYlYgCp15N2AokzKjy7MQ9ejuynOJdf1tR5lGthk= +cloud.google.com/go/video v1.14.0/go.mod h1:SkgaXwT+lIIAKqWAJfktHT/RbgjSuY6DobxEp0C5yTQ= +cloud.google.com/go/video v1.15.0/go.mod h1:SkgaXwT+lIIAKqWAJfktHT/RbgjSuY6DobxEp0C5yTQ= +cloud.google.com/go/videointelligence v1.6.0/go.mod h1:w0DIDlVRKtwPCn/C4iwZIJdvC69yInhW0cfi+p546uU= +cloud.google.com/go/videointelligence v1.7.0/go.mod h1:k8pI/1wAhjznARtVT9U1llUaFNPh7muw8QyOUpavru4= +cloud.google.com/go/videointelligence v1.8.0/go.mod h1:dIcCn4gVDdS7yte/w+koiXn5dWVplOZkE+xwG9FgK+M= +cloud.google.com/go/videointelligence v1.9.0/go.mod h1:29lVRMPDYHikk3v8EdPSaL8Ku+eMzDljjuvRs105XoU= +cloud.google.com/go/videointelligence v1.10.0/go.mod h1:LHZngX1liVtUhZvi2uNS0VQuOzNi2TkY1OakiuoUOjU= +cloud.google.com/go/vision v1.2.0/go.mod h1:SmNwgObm5DpFBme2xpyOyasvBc1aPdjvMk2bBk0tKD0= +cloud.google.com/go/vision/v2 v2.2.0/go.mod h1:uCdV4PpN1S0jyCyq8sIM42v2Y6zOLkZs+4R9LrGYwFo= +cloud.google.com/go/vision/v2 v2.3.0/go.mod h1:UO61abBx9QRMFkNBbf1D8B1LXdS2cGiiCRx0vSpZoUo= +cloud.google.com/go/vision/v2 v2.4.0/go.mod h1:VtI579ll9RpVTrdKdkMzckdnwMyX2JILb+MhPqRbPsY= +cloud.google.com/go/vision/v2 v2.5.0/go.mod h1:MmaezXOOE+IWa+cS7OhRRLK2cNv1ZL98zhqFFZaaH2E= +cloud.google.com/go/vision/v2 v2.6.0/go.mod h1:158Hes0MvOS9Z/bDMSFpjwsUrZ5fPrdwuyyvKSGAGMY= +cloud.google.com/go/vision/v2 v2.7.0/go.mod h1:H89VysHy21avemp6xcf9b9JvZHVehWbET0uT/bcuY/0= +cloud.google.com/go/vmmigration v1.2.0/go.mod h1:IRf0o7myyWFSmVR1ItrBSFLFD/rJkfDCUTO4vLlJvsE= +cloud.google.com/go/vmmigration v1.3.0/go.mod h1:oGJ6ZgGPQOFdjHuocGcLqX4lc98YQ7Ygq8YQwHh9A7g= +cloud.google.com/go/vmmigration v1.5.0/go.mod h1:E4YQ8q7/4W9gobHjQg4JJSgXXSgY21nA5r8swQV+Xxc= +cloud.google.com/go/vmmigration v1.6.0/go.mod h1:bopQ/g4z+8qXzichC7GW1w2MjbErL54rk3/C843CjfY= +cloud.google.com/go/vmwareengine v0.1.0/go.mod h1:RsdNEf/8UDvKllXhMz5J40XxDrNJNN4sagiox+OI208= +cloud.google.com/go/vmwareengine v0.2.2/go.mod h1:sKdctNJxb3KLZkE/6Oui94iw/xs9PRNC2wnNLXsHvH8= +cloud.google.com/go/vmwareengine v0.3.0/go.mod h1:wvoyMvNWdIzxMYSpH/R7y2h5h3WFkx6d+1TIsP39WGY= +cloud.google.com/go/vpcaccess v1.4.0/go.mod h1:aQHVbTWDYUR1EbTApSVvMq1EnT57ppDmQzZ3imqIk4w= +cloud.google.com/go/vpcaccess v1.5.0/go.mod h1:drmg4HLk9NkZpGfCmZ3Tz0Bwnm2+DKqViEpeEpOq0m8= +cloud.google.com/go/vpcaccess v1.6.0/go.mod h1:wX2ILaNhe7TlVa4vC5xce1bCnqE3AeH27RV31lnmZes= +cloud.google.com/go/webrisk v1.4.0/go.mod h1:Hn8X6Zr+ziE2aNd8SliSDWpEnSS1u4R9+xXZmFiHmGE= +cloud.google.com/go/webrisk v1.5.0/go.mod h1:iPG6fr52Tv7sGk0H6qUFzmL3HHZev1htXuWDEEsqMTg= +cloud.google.com/go/webrisk v1.6.0/go.mod h1:65sW9V9rOosnc9ZY7A7jsy1zoHS5W9IAXv6dGqhMQMc= +cloud.google.com/go/webrisk v1.7.0/go.mod h1:mVMHgEYH0r337nmt1JyLthzMr6YxwN1aAIEc2fTcq7A= +cloud.google.com/go/webrisk v1.8.0/go.mod h1:oJPDuamzHXgUc+b8SiHRcVInZQuybnvEW72PqTc7sSg= +cloud.google.com/go/websecurityscanner v1.3.0/go.mod h1:uImdKm2wyeXQevQJXeh8Uun/Ym1VqworNDlBXQevGMo= +cloud.google.com/go/websecurityscanner v1.4.0/go.mod h1:ebit/Fp0a+FWu5j4JOmJEV8S8CzdTkAS77oDsiSqYWQ= +cloud.google.com/go/websecurityscanner v1.5.0/go.mod h1:Y6xdCPy81yi0SQnDY1xdNTNpfY1oAgXUlcfN3B3eSng= +cloud.google.com/go/workflows v1.6.0/go.mod h1:6t9F5h/unJz41YqfBmqSASJSXccBLtD1Vwf+KmJENM0= +cloud.google.com/go/workflows v1.7.0/go.mod h1:JhSrZuVZWuiDfKEFxU0/F1PQjmpnpcoISEXH2bcHC3M= +cloud.google.com/go/workflows v1.8.0/go.mod h1:ysGhmEajwZxGn1OhGOGKsTXc5PyxOc0vfKf5Af+to4M= +cloud.google.com/go/workflows v1.9.0/go.mod h1:ZGkj1aFIOd9c8Gerkjjq7OW7I5+l6cSvT3ujaO/WwSA= +cloud.google.com/go/workflows v1.10.0/go.mod h1:fZ8LmRmZQWacon9UCX1r/g/DfAXx5VcPALq2CxzdePw= +dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU= +gioui.org v0.0.0-20210308172011-57750fc8a0a6/go.mod h1:RSH6KIUZ0p2xy5zHDxgAM4zumjgTw83q2ge/PI+yyw8= +git.sr.ht/~sbinet/gg v0.3.1/go.mod h1:KGYtlADtqsqANL9ueOFkWymvzUvLMQllU5Ixo+8v3pc= +github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= +github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8= +github.com/BurntSushi/toml v1.3.2/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ= +github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= +github.com/JohnCGriffin/overflow v0.0.0-20211019200055-46fa312c352c/go.mod h1:X0CRv0ky0k6m906ixxpzmDRLvX58TFUKS2eePweuyxk= +github.com/Masterminds/goutils v1.1.1 h1:5nUrii3FMTL5diU80unEVvNevw1nH4+ZV4DSLVJLSYI= +github.com/Masterminds/goutils v1.1.1/go.mod h1:8cTjp+g8YejhMuvIA5y2vz3BpJxksy863GQaJW2MFNU= +github.com/Masterminds/semver/v3 v3.2.0/go.mod h1:qvl/7zhW3nngYb5+80sSMF+FG2BjYrf8m9wsX0PNOMQ= +github.com/Masterminds/semver/v3 v3.3.0 h1:B8LGeaivUe71a5qox1ICM/JLl0NqZSW5CHyL+hmvYS0= +github.com/Masterminds/semver/v3 v3.3.0/go.mod h1:4V+yj/TJE1HU9XfppCwVMZq3I84lprf4nC11bSS5beM= +github.com/Masterminds/sprig/v3 v3.2.3 h1:eL2fZNezLomi0uOLqjQoN6BfsDD+fyLtgbJMAj9n6YA= +github.com/Masterminds/sprig/v3 v3.2.3/go.mod h1:rXcFaZ2zZbLRJv/xSysmlgIM1u11eBaRMhvYXJNkGuM= +github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb06e3pkSAbeQ52E9H9iFoQsEEwGN64994WTCIhntQ= +github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU= +github.com/ahmetb/gen-crd-api-reference-docs v0.3.0 h1:+XfOU14S4bGuwyvCijJwhhBIjYN+YXS18jrCY2EzJaY= +github.com/ahmetb/gen-crd-api-reference-docs v0.3.0/go.mod h1:TdjdkYhlOifCQWPs1UdTma97kQQMozf5h26hTuG70u8= +github.com/ajstarks/deck v0.0.0-20200831202436-30c9fc6549a9/go.mod h1:JynElWSGnm/4RlzPXRlREEwqTHAN3T56Bv2ITsFT3gY= +github.com/ajstarks/deck/generate v0.0.0-20210309230005-c3f852c02e19/go.mod h1:T13YZdzov6OU0A1+RfKZiZN9ca6VeKdBdyDV+BY97Tk= +github.com/ajstarks/svgo v0.0.0-20180226025133-644b8db467af/go.mod h1:K08gAheRH3/J6wwsYMMT4xOr94bZjxIelGM0+d/wbFw= +github.com/ajstarks/svgo v0.0.0-20211024235047-1546f124cd8b/go.mod h1:1KcenG0jGWcpt8ov532z81sp/kMMUG485J2InIOyADM= +github.com/andybalholm/brotli v1.0.4/go.mod h1:fO7iG3H7G2nSZ7m0zPUDn85XEX2GTukHGRSepvi9Eig= +github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY= +github.com/apache/arrow/go/v10 v10.0.1/go.mod h1:YvhnlEePVnBS4+0z3fhPfUy7W1Ikj0Ih0vcRo/gZ1M0= +github.com/apache/arrow/go/v11 v11.0.0/go.mod h1:Eg5OsL5H+e299f7u5ssuXsuHQVEGC4xei5aX110hRiI= +github.com/apache/thrift v0.16.0/go.mod h1:PHK3hniurgQaNMZYaCLEqXKsYK8upmhPbmdP2FXSqgU= +github.com/armon/go-socks5 v0.0.0-20160902184237-e75332964ef5 h1:0CwZNZbxp69SHPdPJAN/hZIm0C4OItdklCFmMRWYpio= +github.com/armon/go-socks5 v0.0.0-20160902184237-e75332964ef5/go.mod h1:wHh0iHkYZB8zMSxRWpUBQtwG5a7fFgvEO+odwuTv2gs= +github.com/asaskevich/govalidator v0.0.0-20190424111038-f61b66f89f4a/go.mod h1:lB+ZfQJz7igIIfQNfa7Ml4HSf2uFQQRzpGGRXenZAgY= +github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= +github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= +github.com/blang/semver/v4 v4.0.0 h1:1PFHFE6yCCTv8C1TeyNNarDzntLi7wMI5i/pzqYIsAM= +github.com/blang/semver/v4 v4.0.0/go.mod h1:IbckMUScFkM3pff0VJDNKRiT6TG/YpiHIM2yvyW5YoQ= +github.com/boombuler/barcode v1.0.0/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8= +github.com/boombuler/barcode v1.0.1/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8= +github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= +github.com/census-instrumentation/opencensus-proto v0.3.0/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= +github.com/census-instrumentation/opencensus-proto v0.4.1/go.mod h1:4T9NM4+4Vw91VeyqjLS6ao50K5bOcLKN6Q42XnYaRYw= +github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc= +github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= +github.com/cespare/xxhash/v2 v2.2.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= +github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UFvs= +github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= +github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI= +github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e/go.mod h1:nSuG5e5PlCu98SY8svDHJxuZscDgtXS6KTTbou5AhLI= +github.com/chzyer/test v0.0.0-20180213035817-a1ea475d72b1/go.mod h1:Q3SI9o4m/ZMnBNeIyt5eFwwo7qiLfzFZmjNmxjkiQlU= +github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= +github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= +github.com/cncf/udpa/go v0.0.0-20200629203442-efcf912fb354/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= +github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= +github.com/cncf/udpa/go v0.0.0-20210930031921-04548b0d99d4/go.mod h1:6pvJx4me5XPnfI9Z40ddWsdw2W/uZgQLFXToKeRcDiI= +github.com/cncf/udpa/go v0.0.0-20220112060539-c52dc94e7fbe/go.mod h1:6pvJx4me5XPnfI9Z40ddWsdw2W/uZgQLFXToKeRcDiI= +github.com/cncf/xds/go v0.0.0-20210312221358-fbca930ec8ed/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/cncf/xds/go v0.0.0-20210805033703-aa0b78936158/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/cncf/xds/go v0.0.0-20210922020428-25de7278fc84/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/cncf/xds/go v0.0.0-20211001041855-01bcc9b48dfe/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/cncf/xds/go v0.0.0-20211011173535-cb28da3451f1/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/cncf/xds/go v0.0.0-20220314180256-7f1daf1720fc/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/cncf/xds/go v0.0.0-20230105202645-06c439db220b/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/cncf/xds/go v0.0.0-20230310173818-32f1caf87195/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/coreos/go-systemd/v22 v22.5.0 h1:RrqgGjYQKalulkV8NGVIfkXQf6YYmOyiJKk8iXXhfZs= +github.com/coreos/go-systemd/v22 v22.5.0/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= +github.com/cpuguy83/go-md2man/v2 v2.0.4/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= +github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= +github.com/cyphar/filepath-securejoin v0.2.4 h1:Ugdm7cg7i6ZK6x3xDF1oEu1nfkyfH53EtKeQYTC3kyg= +github.com/cyphar/filepath-securejoin v0.2.4/go.mod h1:aPGpWjXOXUn2NCNjFvBE6aRxGGx79pTxQpKOJNYHHl4= +github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc h1:U9qPSI2PIWSS1VwoXQT9A3Wy9MM3WgvqSxFWenqJduM= +github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/docopt/docopt-go v0.0.0-20180111231733-ee0de3bc6815/go.mod h1:WwZ+bS3ebgob9U8Nd0kOddGdZWjyMGR8Wziv+TBNwSE= +github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= +github.com/emicklei/go-restful/v3 v3.8.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= +github.com/emicklei/go-restful/v3 v3.11.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= +github.com/emicklei/go-restful/v3 v3.12.1 h1:PJMDIM/ak7btuL8Ex0iYET9hxM3CI2sjZtzpL63nKAU= +github.com/emicklei/go-restful/v3 v3.12.1/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= +github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= +github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= +github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= +github.com/envoyproxy/go-control-plane v0.9.7/go.mod h1:cwu0lG7PUMfa9snN8LXBig5ynNVH9qI8YYLbd1fK2po= +github.com/envoyproxy/go-control-plane v0.9.9-0.20201210154907-fd9021fe5dad/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= +github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= +github.com/envoyproxy/go-control-plane v0.9.9-0.20210512163311-63b5d3c536b0/go.mod h1:hliV/p42l8fGbc6Y9bQ70uLwIvmJyVE5k4iMKlh8wCQ= +github.com/envoyproxy/go-control-plane v0.9.10-0.20210907150352-cf90f659a021/go.mod h1:AFq3mo9L8Lqqiid3OhADV3RfLJnjiw63cSpi+fDTRC0= +github.com/envoyproxy/go-control-plane v0.10.2-0.20220325020618-49ff273808a1/go.mod h1:KJwIaB5Mv44NWtYuAOFCVOjcI94vtpEz2JU/D2v6IjE= +github.com/envoyproxy/go-control-plane v0.10.3/go.mod h1:fJJn/j26vwOu972OllsvAgJJM//w9BV6Fxbg2LuVd34= +github.com/envoyproxy/go-control-plane v0.11.0/go.mod h1:VnHyVMpzcLvCFt9yUz1UnCwHLhwx1WguiVDV7pTG/tI= +github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= +github.com/envoyproxy/protoc-gen-validate v0.6.7/go.mod h1:dyJXwwfPK2VSqiB9Klm1J6romD608Ba7Hij42vrOBCo= +github.com/envoyproxy/protoc-gen-validate v0.9.1/go.mod h1:OKNgG7TCp5pF4d6XftA0++PMirau2/yoOwVac3AbF2w= +github.com/envoyproxy/protoc-gen-validate v0.10.0/go.mod h1:DRjgyB0I43LtJapqN6NiRwroiAU2PaFuvk/vjgh61ss= +github.com/evanphx/json-patch v4.12.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= +github.com/evanphx/json-patch v5.7.0+incompatible h1:vgGkfT/9f8zE6tvSCe74nfpAVDQ2tG6yudJd8LBksgI= +github.com/evanphx/json-patch v5.7.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= +github.com/evanphx/json-patch/v5 v5.8.0 h1:lRj6N9Nci7MvzrXuX6HFzU8XjmhPiXPlsKEy1u0KQro= +github.com/evanphx/json-patch/v5 v5.8.0/go.mod h1:VNkHZ/282BpEyt/tObQO8s5CMPmYYq14uClGH4abBuQ= +github.com/fatih/color v1.17.0 h1:GlRw1BRJxkpqUCBKzKOw098ed57fEsKeNjpTe3cSjK4= +github.com/fatih/color v1.17.0/go.mod h1:YZ7TlrGPkiz6ku9fK3TLD/pl3CpsiFyu8N92HLgmosI= +github.com/fluent/fluent-operator/v2 v2.8.0 h1:G6TB1Fq6wx+HflXmv2mc7bhj2MiDoT9OfAeq/XkPCgI= +github.com/fluent/fluent-operator/v2 v2.8.0/go.mod h1:nGKS5Iryq98Jqt+Ixc8YSMmOzM/yNxD8Xwtt76DhmTg= +github.com/fogleman/gg v1.2.1-0.20190220221249-0403632d5b90/go.mod h1:R/bRT+9gY/C5z7JzPU0zXsXHKM4/ayA+zqcVNZzPa1k= +github.com/fogleman/gg v1.3.0/go.mod h1:R/bRT+9gY/C5z7JzPU0zXsXHKM4/ayA+zqcVNZzPa1k= +github.com/frankban/quicktest v1.14.6 h1:7Xjx+VpznH+oBnejlPUj8oUpdxnVs4f8XU8WnHkI4W8= +github.com/frankban/quicktest v1.14.6/go.mod h1:4ptaffx2x8+WTWXmUCuVU6aPUX1/Mz7zb5vbUoiM6w0= +github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= +github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ= +github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA= +github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= +github.com/gardener/cert-management v0.15.0 h1:ohm1eWae2rQSkwFGWXTt+lBv4rLBhtJsJgqvaXJBs6o= +github.com/gardener/cert-management v0.15.0/go.mod h1:3BK2VEtGwv2ijf3bSziTLMCUvYnPzIQrQ/uPeZzL4m0= +github.com/gardener/etcd-druid v0.22.0 h1:DVe+Zjrb93r9vI1uUiCTMHBffIUoMAKhNzFZNC6hsQ8= +github.com/gardener/etcd-druid v0.22.0/go.mod h1:FROhfVKyWBo4krlPe3R6FIhJRmOmijEWBdEeUP0CJjE= +github.com/gardener/gardener v1.97.4 h1:pF6rhbsJwpvSy8tA9oBr5Z3J+hWTr9lrYntoeq6G7z4= +github.com/gardener/gardener v1.97.4/go.mod h1:Y9HPpdO039YcdrPE/o8+NixlEvrLv6d34ojIhBfy2Uw= +github.com/gardener/hvpa-controller/api v0.15.0 h1:igsalL5Z6kFMn1+Kv1Eq0cRjYW+4oBA1aEY/yDO2QtI= +github.com/gardener/hvpa-controller/api v0.15.0/go.mod h1:fqb4wNrQLESDKpm7ppXyCM2Gvx96wRlLL35aH0ge07U= +github.com/gardener/machine-controller-manager v0.53.0 h1:g2O0F7nEYZ9LjyPY6Gew8+q0n+rU88deexNq5k8CKks= +github.com/gardener/machine-controller-manager v0.53.0/go.mod h1:XWXHaTy32TU0qmLjWqOgtw8NncdB0HfFzXhUUrcpr7Y= +github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= +github.com/go-fonts/dejavu v0.1.0/go.mod h1:4Wt4I4OU2Nq9asgDCteaAaWZOV24E+0/Pwo0gppep4g= +github.com/go-fonts/latin-modern v0.2.0/go.mod h1:rQVLdDMK+mK1xscDwsqM5J8U2jrRa3T0ecnM9pNujks= +github.com/go-fonts/liberation v0.1.1/go.mod h1:K6qoJYypsmfVjWg8KOVDQhLc8UDgIK2HYqyqAO9z7GY= +github.com/go-fonts/liberation v0.2.0/go.mod h1:K6qoJYypsmfVjWg8KOVDQhLc8UDgIK2HYqyqAO9z7GY= +github.com/go-fonts/stix v0.1.0/go.mod h1:w/c1f0ldAUlJmLBvlbkvVXLAD+tAMqobIIQpmnUIzUY= +github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU= +github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= +github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= +github.com/go-latex/latex v0.0.0-20210118124228-b3d85cf34e07/go.mod h1:CO1AlKB2CSIqUrmQPqA0gdRIlnLEY0gK5JGjh37zN5U= +github.com/go-latex/latex v0.0.0-20210823091927-c0d11ff05a81/go.mod h1:SX0U8uGpxhq9o2S/CELCSUxEWWAuoCUcVCQWv7G2OCk= +github.com/go-logr/logr v0.1.0/go.mod h1:ixOQHD9gLJUVQQ2ZOR7zLEifBX6tGkNJF4QyIY7sIas= +github.com/go-logr/logr v0.2.0/go.mod h1:z6/tIYblkpsD+a4lm/fGIIU9mZ+XfAiaFtq7xTgseGU= +github.com/go-logr/logr v1.2.0/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/logr v1.2.3/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/logr v1.2.4/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/logr v1.3.0/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= +github.com/go-logr/logr v1.4.2 h1:6pFjapn8bFcIbiKo3XT4j/BhANplGihG6tvd+8rYgrY= +github.com/go-logr/logr v1.4.2/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= +github.com/go-logr/zapr v1.3.0 h1:XGdV8XW8zdwFiwOA2Dryh1gj2KRQyOOoNmBy4EplIcQ= +github.com/go-logr/zapr v1.3.0/go.mod h1:YKepepNBd1u/oyhd/yQmtjVXmm9uML4IXUgMOwR8/Gg= +github.com/go-openapi/errors v0.22.0 h1:c4xY/OLxUBSTiepAg3j/MHuAv5mJhnf53LLMWFB+u/w= +github.com/go-openapi/errors v0.22.0/go.mod h1:J3DmZScxCDufmIMsdOuDHxJbdOGC0xtUynjIx092vXE= +github.com/go-openapi/jsonpointer v0.19.6/go.mod h1:osyAmYz/mB/C3I+WsTTSgw1ONzaLJoLCyoi6/zppojs= +github.com/go-openapi/jsonpointer v0.21.0 h1:YgdVicSA9vH5RiHs9TZW5oyafXZFc6+2Vc1rr/O9oNQ= +github.com/go-openapi/jsonpointer v0.21.0/go.mod h1:IUyH9l/+uyhIYQ/PXVA41Rexl+kOkAPDdXEYns6fzUY= +github.com/go-openapi/jsonreference v0.20.1/go.mod h1:Bl1zwGIM8/wsvqjsOQLJ/SH+En5Ap4rVB5KVcIDZG2k= +github.com/go-openapi/jsonreference v0.20.2/go.mod h1:Bl1zwGIM8/wsvqjsOQLJ/SH+En5Ap4rVB5KVcIDZG2k= +github.com/go-openapi/jsonreference v0.21.0 h1:Rs+Y7hSXT83Jacb7kFyjn4ijOuVGSvOdF2+tg1TRrwQ= +github.com/go-openapi/jsonreference v0.21.0/go.mod h1:LmZmgsrTkVg9LG4EaHeY8cBDslNPMo06cago5JNLkm4= +github.com/go-openapi/swag v0.22.3/go.mod h1:UzaqsxGiab7freDnrUUra0MwWfN/q7tE4j+VcZ0yl14= +github.com/go-openapi/swag v0.23.0 h1:vsEVJDUo2hPJ2tu0/Xc+4noaxyEffXNIs3cOULZ+GrE= +github.com/go-openapi/swag v0.23.0/go.mod h1:esZ8ITTYEsH1V2trKHjAN8Ai7xHb8RV+YSZ577vPjgQ= +github.com/go-pdf/fpdf v0.5.0/go.mod h1:HzcnA+A23uwogo0tp9yU+l3V+KXhiESpt1PMayhOh5M= +github.com/go-pdf/fpdf v0.6.0/go.mod h1:HzcnA+A23uwogo0tp9yU+l3V+KXhiESpt1PMayhOh5M= +github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg7847qk6SyHyPtNmDHnmrv/HOrqktSC+C9fM+CJOE= +github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572 h1:tfuBGBXKqDEevZMzYi5KSi8KkcZtzBcTgAUUtapy0OI= +github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572/go.mod h1:9Pwr4B2jHnOSGXyyzV8ROjYa2ojvAY6HCGYYfMoC3Ls= +github.com/go-task/slim-sprig/v3 v3.0.0 h1:sUs3vkvUymDpBKi3qH1YSqBQk9+9D/8M2mN1vB6EwHI= +github.com/go-task/slim-sprig/v3 v3.0.0/go.mod h1:W848ghGpv3Qj3dhTPRyJypKRiqCdHZiAzKg9hl15HA8= +github.com/gobuffalo/flect v1.0.2 h1:eqjPGSo2WmjgY2XlpGwo2NXgL3RucAKo4k4qQMNA5sA= +github.com/gobuffalo/flect v1.0.2/go.mod h1:A5msMlrHtLqh9umBSnvabjsMrCcCpAyzglnDvkbYKHs= +github.com/gobwas/glob v0.2.3 h1:A4xDbljILXROh+kObIiy5kIaPYD8e96x1tgBhUI5J+Y= +github.com/gobwas/glob v0.2.3/go.mod h1:d3Ez4x06l9bZtSvzIay5+Yzi0fmZzPgnTbPcKjJAkT8= +github.com/goccy/go-json v0.9.11/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= +github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= +github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= +github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= +github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= +github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= +github.com/golang/glog v1.0.0/go.mod h1:EWib/APOK0SL3dFbYqvxE3UYd8E6s1ouQ7iEp/0LWV4= +github.com/golang/glog v1.1.0/go.mod h1:pfYeQZ3JWZoXTV5sFc986z3HTpwQs9At6P4ImfuP3NQ= +github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= +github.com/golang/groupcache v0.0.0-20191227052852-215e87163ea7/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= +github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= +github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da h1:oI5xCqsCo564l8iNU+DwB5epxmsaqB+rhGL0m5jtYqE= +github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= +github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= +github.com/golang/mock v1.2.0/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= +github.com/golang/mock v1.3.1/go.mod h1:sBzyDLLjw3U8JLTeZvSv8jJB+tU5PVekmnlKIyFUx0Y= +github.com/golang/mock v1.4.0/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= +github.com/golang/mock v1.4.1/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= +github.com/golang/mock v1.4.3/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= +github.com/golang/mock v1.4.4/go.mod h1:l3mdAwkq5BuhzHwde/uurv3sEJeZMXNpwsxVWU71h+4= +github.com/golang/mock v1.5.0/go.mod h1:CWnOUgYIOo4TcNZ0wHX3YZCqsaM1I1Jvs6v3mP3KVu8= +github.com/golang/mock v1.6.0 h1:ErTB+efbowRARo13NNdxyJji2egdxLGQhRaY+DUumQc= +github.com/golang/mock v1.6.0/go.mod h1:p6yTPP+5HYm5mzsMV8JkE6ZKdX+/wYM6Hr+LicevLPs= +github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= +github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= +github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= +github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw= +github.com/golang/protobuf v1.3.4/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw= +github.com/golang/protobuf v1.3.5/go.mod h1:6O5/vntMXwX2lRkT1hjjk0nAC1IDOTvTlVgjlRvqsdk= +github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8= +github.com/golang/protobuf v1.4.0-rc.1.0.20200221234624-67d41d38c208/go.mod h1:xKAWHe0F5eneWXFV3EuXVDTCmh+JuBKY0li0aMyXATA= +github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrUpVNzEA03Pprs= +github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:WU3c8KckQ9AFe+yFwt9sWVRKCVIyN9cPHBJSNnbL67w= +github.com/golang/protobuf v1.4.0/go.mod h1:jodUvKwWbYaEsadDk5Fwe5c77LiNKVO9IDvqG2KuDX0= +github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QDs8UjoX8= +github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= +github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= +github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= +github.com/golang/protobuf v1.5.1/go.mod h1:DopwsBzvsk0Fs44TXzsVbJyPhcCPeIwnvohx4u74HPM= +github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= +github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= +github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek= +github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps= +github.com/golang/snappy v0.0.3/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= +github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= +github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= +github.com/google/btree v1.0.0/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= +github.com/google/btree v1.0.1/go.mod h1:xXMiIv4Fb/0kKde4SpL7qlzvu5cMJDRkFDxJfI9uaxA= +github.com/google/flatbuffers v2.0.8+incompatible/go.mod h1:1AeVuKshWv4vARoZatz6mlQ0JxURH0Kv5+zNeJKJCa8= +github.com/google/gnostic-models v0.6.8/go.mod h1:5n7qKqH0f5wFt+aWF8CW6pZLLNOfYuF5OpfBSENuI8U= +github.com/google/gnostic-models v0.6.9-0.20230804172637-c7be7c783f49 h1:0VpGH+cDhbDtdcweoyCVsF3fhN8kejK6rFe/2FFX2nU= +github.com/google/gnostic-models v0.6.9-0.20230804172637-c7be7c783f49/go.mod h1:BkkQ4L1KS1xMt2aWSPStnn55ChGC0DPOn2FQYj+f25M= +github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M= +github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= +github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= +github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.4.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.3/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.6/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.7/go.mod h1:n+brtR0CgQNWTVd5ZUFpTBC8YFBDLK/h/bpaJ8/DtOE= +github.com/google/go-cmp v0.5.8/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= +github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= +github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= +github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= +github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= +github.com/google/gofuzz v1.1.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= +github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0= +github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= +github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs= +github.com/google/martian/v3 v3.0.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0= +github.com/google/martian/v3 v3.1.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0= +github.com/google/martian/v3 v3.2.1/go.mod h1:oBOf6HBosgwRXnUGWUB05QECsc6uvmMiJ3+6W4l/CUk= +github.com/google/martian/v3 v3.3.2/go.mod h1:oBOf6HBosgwRXnUGWUB05QECsc6uvmMiJ3+6W4l/CUk= +github.com/google/pprof v0.0.0-20181206194817-3ea8567a2e57/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc= +github.com/google/pprof v0.0.0-20190515194954-54271f7e092f/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc= +github.com/google/pprof v0.0.0-20191218002539-d4f498aebedc/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20200212024743-f11f1df84d12/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20200229191704-1ebb73c60ed3/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20200430221834-fc25d7d30c6d/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20200708004538-1a94d8640e99/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20201023163331-3e6fc7fc9c4c/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20201203190320-1bf35d6f28c2/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20201218002935-b9804c9f04c2/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20210122040257-d980be63207e/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20210226084205-cbba55b83ad5/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20210407192527-94a9f03dee38/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20210601050228-01bbb1931b22/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20210609004039-a478d1d731e9/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20240525223248-4bfdf5a9a2af h1:kmjWCqn2qkEml422C2Rrd27c3VGxi6a/6HNq8QmHRKM= +github.com/google/pprof v0.0.0-20240525223248-4bfdf5a9a2af/go.mod h1:K1liHPHnj73Fdn/EKuT8nrFqBihUSKXoLYU0BuatOYo= +github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= +github.com/google/s2a-go v0.1.0/go.mod h1:OJpEgntRZo8ugHpF9hkoLJbS5dSI20XZeXJ9JVywLlM= +github.com/google/s2a-go v0.1.3/go.mod h1:Ej+mSEMGRnqRzjc7VtF+jdBwYG5fuJfiZ8ELkjEwM0A= +github.com/google/s2a-go v0.1.4/go.mod h1:Ej+mSEMGRnqRzjc7VtF+jdBwYG5fuJfiZ8ELkjEwM0A= +github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/google/uuid v1.3.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= +github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/googleapis/enterprise-certificate-proxy v0.0.0-20220520183353-fd19c99a87aa/go.mod h1:17drOmN3MwGY7t0e+Ei9b45FFGA3fBs3x36SsCg1hq8= +github.com/googleapis/enterprise-certificate-proxy v0.1.0/go.mod h1:17drOmN3MwGY7t0e+Ei9b45FFGA3fBs3x36SsCg1hq8= +github.com/googleapis/enterprise-certificate-proxy v0.2.0/go.mod h1:8C0jb7/mgJe/9KK8Lm7X9ctZC2t60YyIpYEI16jx0Qg= +github.com/googleapis/enterprise-certificate-proxy v0.2.1/go.mod h1:AwSRAtLfXpU5Nm3pW+v7rGDHp09LsPtGY9MduiEsR9k= +github.com/googleapis/enterprise-certificate-proxy v0.2.3/go.mod h1:AwSRAtLfXpU5Nm3pW+v7rGDHp09LsPtGY9MduiEsR9k= +github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg= +github.com/googleapis/gax-go/v2 v2.0.5/go.mod h1:DWXyrwAJ9X0FpwwEdw+IPEYBICEFu5mhpdKc/us6bOk= +github.com/googleapis/gax-go/v2 v2.1.0/go.mod h1:Q3nei7sK6ybPYH7twZdmQpAd1MKb7pfu6SK+H1/DsU0= +github.com/googleapis/gax-go/v2 v2.1.1/go.mod h1:hddJymUZASv3XPyGkUpKj8pPO47Rmb0eJc8R6ouapiM= +github.com/googleapis/gax-go/v2 v2.2.0/go.mod h1:as02EH8zWkzwUoLbBaFeQ+arQaj/OthfcblKl4IGNaM= +github.com/googleapis/gax-go/v2 v2.3.0/go.mod h1:b8LNqSzNabLiUpXKkY7HAR5jr6bIT99EXz9pXxye9YM= +github.com/googleapis/gax-go/v2 v2.4.0/go.mod h1:XOTVJ59hdnfJLIP/dh8n5CGryZR2LxK9wbMD5+iXC6c= +github.com/googleapis/gax-go/v2 v2.5.1/go.mod h1:h6B0KMMFNtI2ddbGJn3T3ZbwkeT6yqEF02fYlzkUCyo= +github.com/googleapis/gax-go/v2 v2.6.0/go.mod h1:1mjbznJAPHFpesgE5ucqfYEscaz5kMdcIDwU/6+DDoY= +github.com/googleapis/gax-go/v2 v2.7.0/go.mod h1:TEop28CZZQ2y+c0VxMUmu1lV+fQx57QpBWsYpwqHJx8= +github.com/googleapis/gax-go/v2 v2.7.1/go.mod h1:4orTrqY6hXxxaUL4LHIPl6lGo8vAE38/qKbhSAKP6QI= +github.com/googleapis/gax-go/v2 v2.8.0/go.mod h1:4orTrqY6hXxxaUL4LHIPl6lGo8vAE38/qKbhSAKP6QI= +github.com/googleapis/gax-go/v2 v2.10.0/go.mod h1:4UOEnMCrxsSqQ940WnTiD6qJ63le2ev3xfyagutxiPw= +github.com/googleapis/gax-go/v2 v2.11.0/go.mod h1:DxmR61SGKkGLa2xigwuZIQpkCI2S5iydzRfb3peWZJI= +github.com/googleapis/go-type-adapters v1.0.0/go.mod h1:zHW75FOG2aur7gAO2B+MLby+cLsWGBF62rFAi7WjWO4= +github.com/googleapis/google-cloud-go-testing v0.0.0-20200911160855-bcd43fbb19e8/go.mod h1:dvDLG8qkwmyD9a/MJJN3XJcT3xFxOKAvTZGvuZmac9g= +github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= +github.com/gorilla/websocket v1.5.0 h1:PPwGk2jz7EePpoHN/+ClbZu8SPxiqlu12wZP/3sWmnc= +github.com/gorilla/websocket v1.5.0/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= +github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA= +github.com/grpc-ecosystem/grpc-gateway v1.16.0/go.mod h1:BDjrQk3hbvj6Nolgz8mAMFbcEtjT1g+wF4CSlocrBnw= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.7.0/go.mod h1:hgWBS7lorOAVIJEQMi4ZsPv9hVvWI6+ch50m39Pf2Ks= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.11.3/go.mod h1:o//XUCC/F+yRGJoPO/VU0GSB0f8Nhgmxx0VIRUvaC0w= +github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= +github.com/hashicorp/errwrap v1.1.0 h1:OxrOeh75EUXMY8TBjag2fzXGZ40LB6IKw45YeGUDY2I= +github.com/hashicorp/errwrap v1.1.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= +github.com/hashicorp/go-multierror v1.1.1 h1:H5DkEtf6CXdFp0N0Em5UCwQpXMWke8IA0+lD48awMYo= +github.com/hashicorp/go-multierror v1.1.1/go.mod h1:iw975J/qwKPdAO1clOe2L8331t/9/fmwbPZ6JB6eMoM= +github.com/hashicorp/golang-lru v0.5.0/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= +github.com/hashicorp/golang-lru v0.5.1/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= +github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= +github.com/huandu/xstrings v1.3.3/go.mod h1:y5/lhBue+AyNmUVz9RLU9xbLR0o4KIIExikq4ovT0aE= +github.com/huandu/xstrings v1.4.0 h1:D17IlohoQq4UcpqD7fDk80P7l+lwAmlFaBHgOipl2FU= +github.com/huandu/xstrings v1.4.0/go.mod h1:y5/lhBue+AyNmUVz9RLU9xbLR0o4KIIExikq4ovT0aE= +github.com/iancoleman/strcase v0.2.0/go.mod h1:iwCmte+B7n89clKwxIoIXy/HfoL7AsD47ZCWhYzw7ho= +github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= +github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= +github.com/imdario/mergo v0.3.6/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA= +github.com/imdario/mergo v0.3.11/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA= +github.com/imdario/mergo v0.3.16 h1:wwQJbIsHYGMUyLSPrEq1CT16AhnhNJQ51+4fdHUnCl4= +github.com/imdario/mergo v0.3.16/go.mod h1:WBLT9ZmE3lPoWsEzCh9LPo3TiwVN+ZKEjmz+hD27ysY= +github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= +github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= +github.com/ironcore-dev/vgopath v0.1.4 h1:hBMuv7+wnZp5JHkVfdg4mtP8hsIGvuv42+l+F2wmQxk= +github.com/ironcore-dev/vgopath v0.1.4/go.mod h1:PTGnX8xW/QDytFR7oU4kcXr1RPDLCgAJ0ZUa5Rp8vyI= +github.com/josharian/intern v1.0.0 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY= +github.com/josharian/intern v1.0.0/go.mod h1:5DoeVV0s6jJacbCEi61lwdGj/aVlrQvzHFFd8Hwg//Y= +github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= +github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= +github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU= +github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk= +github.com/jung-kurt/gofpdf v1.0.0/go.mod h1:7Id9E/uU8ce6rXgefFLlgrJj/GYY22cpxn+r32jIOes= +github.com/jung-kurt/gofpdf v1.0.3-0.20190309125859-24315acbbda5/go.mod h1:7Id9E/uU8ce6rXgefFLlgrJj/GYY22cpxn+r32jIOes= +github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8= +github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= +github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= +github.com/klauspost/asmfmt v1.3.2/go.mod h1:AG8TuvYojzulgDAMCnYn50l/5QV3Bs/tp6j0HLHbNSE= +github.com/klauspost/compress v1.15.9/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU= +github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= +github.com/kr/fs v0.1.0/go.mod h1:FFnZGqtBN9Gxj7eW1uZ42v5BccTP0vu6NEaFoC2HwRg= +github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= +github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= +github.com/kr/pretty v0.2.1/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= +github.com/kr/pretty v0.3.0/go.mod h1:640gp4NfQd8pI5XOwp5fnNeVWj67G7CFk/SaSQn7NBk= +github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= +github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= +github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= +github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= +github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= +github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= +github.com/kubernetes-csi/external-snapshotter/client/v4 v4.2.0 h1:nHHjmvjitIiyPlUHk/ofpgvBcNcawJLtf4PYHORLjAA= +github.com/kubernetes-csi/external-snapshotter/client/v4 v4.2.0/go.mod h1:YBCo4DoEeDndqvAn6eeu0vWM7QdXmHEeI9cFWplmBys= +github.com/lyft/protoc-gen-star v0.6.0/go.mod h1:TGAoBVkt8w7MPG72TrKIu85MIdXwDuzJYeZuUPFPNwA= +github.com/lyft/protoc-gen-star v0.6.1/go.mod h1:TGAoBVkt8w7MPG72TrKIu85MIdXwDuzJYeZuUPFPNwA= +github.com/lyft/protoc-gen-star/v2 v2.0.1/go.mod h1:RcCdONR2ScXaYnQC5tUzxzlpA3WVYF7/opLeUgcQs/o= +github.com/mailru/easyjson v0.7.7 h1:UGYAvKxe3sBsEDzO8ZeWOSlIQfWFlxbzLZe7hwFURr0= +github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc= +github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= +github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= +github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= +github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= +github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= +github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= +github.com/mattn/go-sqlite3 v1.14.14/go.mod h1:NyWgC/yNuGj7Q9rpYnZvas74GogHl5/Z4A/KQRfk6bU= +github.com/metal-stack/metal-lib v0.18.4 h1:7HnfSwSbrKNHU+i6i79YFk/eeuhBhwIEHWpGqS7pYCc= +github.com/metal-stack/metal-lib v0.18.4/go.mod h1:Ctyi6zaXFr2NVrQZLFsDLnFCzupKnYErTtgRFKAsnbw= +github.com/minio/asm2plan9s v0.0.0-20200509001527-cdd76441f9d8/go.mod h1:mC1jAcsrzbxHt8iiaC+zU4b1ylILSosueou12R++wfY= +github.com/minio/c2goasm v0.0.0-20190812172519-36a3d3bbc4f3/go.mod h1:RagcQ7I8IeTMnF8JTXieKnO4Z6JCsikNEzj0DwauVzE= +github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw= +github.com/mitchellh/copystructure v1.2.0 h1:vpKXTN4ewci03Vljg/q9QvCGUDttBOGBIa15WveJJGw= +github.com/mitchellh/copystructure v1.2.0/go.mod h1:qLl+cE2AmVv+CoeAwDPye/v+N2HKCj9FbZEVFJRxO9s= +github.com/mitchellh/hashstructure/v2 v2.0.2 h1:vGKWl0YJqUNxE8d+h8f6NJLcCJrgbhC4NcD46KavDd4= +github.com/mitchellh/hashstructure/v2 v2.0.2/go.mod h1:MG3aRVU/N29oo/V/IhBX8GR/zz4kQkprJgF2EVszyDE= +github.com/mitchellh/reflectwalk v1.0.0/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= +github.com/mitchellh/reflectwalk v1.0.2 h1:G2LzWKi524PWgd3mLHV8Y5k7s6XUvT0Gef6zxSIeXaQ= +github.com/mitchellh/reflectwalk v1.0.2/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= +github.com/moby/spdystream v0.2.0/go.mod h1:f7i0iNDQJ059oMTcWxx8MA/zKFIuD/lY+0GqbN2Wy8c= +github.com/moby/spdystream v0.4.0 h1:Vy79D6mHeJJjiPdFEL2yku1kl0chZpJfZcPpb16BRl8= +github.com/moby/spdystream v0.4.0/go.mod h1:xBAYlnt/ay+11ShkdFKNAG7LsyK/tmNBVvVOwrfMgdI= +github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= +github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= +github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= +github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M= +github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= +github.com/munnerz/goautoneg v0.0.0-20120707110453-a547fc61f48d/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= +github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 h1:C3w9PqII01/Oq1c1nUAm88MOHcQC9l5mIlSMApZMrHA= +github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= +github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f h1:y5//uYreIhSUg3J1GEMiLbxo1LJaP8RfCpH6pymGZus= +github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f/go.mod h1:ZdcZmHo+o7JKHSa8/e818NopupXU1YMK5fe1lsApnBw= +github.com/nxadm/tail v1.4.4/go.mod h1:kenIhsEOeOJmVchQTgglprH7qJGnHDVpk1VPCcaMI8A= +github.com/nxadm/tail v1.4.8 h1:nPr65rt6Y5JFSKQO7qToXr7pePgD6Gwiw05lkbyAQTE= +github.com/nxadm/tail v1.4.8/go.mod h1:+ncqLTQzXmGhMZNUePPaPqPvBxHAIsmXswZKocGu+AU= +github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= +github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= +github.com/onsi/ginkgo v1.16.4/go.mod h1:dX+/inL/fNMqNlz0e9LfyB9TswhZpCVdJM/Z6Vvnwo0= +github.com/onsi/ginkgo v1.16.5 h1:8xi0RTUf59SOSfEtZMvwTvXYMzG4gV23XVHOZiXNtnE= +github.com/onsi/ginkgo v1.16.5/go.mod h1:+E8gABHa3K6zRBolWtd+ROzc/U5bkGt0FwiG042wbpU= +github.com/onsi/ginkgo/v2 v2.1.3/go.mod h1:vw5CSIxN1JObi/U8gcbwft7ZxR2dgaR70JSE3/PpL4c= +github.com/onsi/ginkgo/v2 v2.1.4/go.mod h1:um6tUpWM/cxCK3/FK8BXqEiUMUwRgSM4JXG47RKZmLU= +github.com/onsi/ginkgo/v2 v2.1.6/go.mod h1:MEH45j8TBi6u9BMogfbp0stKC5cdGjumZj5Y7AG4VIk= +github.com/onsi/ginkgo/v2 v2.3.0/go.mod h1:Eew0uilEqZmIEZr8JrvYlvOM7Rr6xzTmMV8AyFNU9d0= +github.com/onsi/ginkgo/v2 v2.4.0/go.mod h1:iHkDK1fKGcBoEHT5W7YBq4RFWaQulw+caOMkAt4OrFo= +github.com/onsi/ginkgo/v2 v2.5.0/go.mod h1:Luc4sArBICYCS8THh8v3i3i5CuSZO+RaQRaJoeNwomw= +github.com/onsi/ginkgo/v2 v2.7.0/go.mod h1:yjiuMwPokqY1XauOgju45q3sJt6VzQ/Fict1LFVcsAo= +github.com/onsi/ginkgo/v2 v2.8.1/go.mod h1:N1/NbDngAFcSLdyZ+/aYTYGSlq9qMCS/cNKGJjy+csc= +github.com/onsi/ginkgo/v2 v2.9.0/go.mod h1:4xkjoL/tZv4SMWeww56BU5kAt19mVB47gTWxmrTcxyk= +github.com/onsi/ginkgo/v2 v2.9.1/go.mod h1:FEcmzVcCHl+4o9bQZVab+4dC9+j+91t2FHSzmGAPfuo= +github.com/onsi/ginkgo/v2 v2.9.2/go.mod h1:WHcJJG2dIlcCqVfBAwUCrJxSPFb6v4azBwgxeMeDuts= +github.com/onsi/ginkgo/v2 v2.9.5/go.mod h1:tvAoo1QUJwNEU2ITftXTpR7R1RbCzoZUOs3RonqW57k= +github.com/onsi/ginkgo/v2 v2.9.7/go.mod h1:cxrmXWykAwTwhQsJOPfdIDiJ+l2RYq7U8hFU+M/1uw0= +github.com/onsi/ginkgo/v2 v2.11.0/go.mod h1:ZhrRA5XmEE3x3rhlzamx/JJvujdZoJ2uvgI7kR0iZvM= +github.com/onsi/ginkgo/v2 v2.13.0/go.mod h1:TE309ZR8s5FsKKpuB1YAQYBzCaAfUgatB/xlT/ETL/o= +github.com/onsi/ginkgo/v2 v2.19.0 h1:9Cnnf7UHo57Hy3k6/m5k3dRfGTMXGvxhHFvkDTCTpvA= +github.com/onsi/ginkgo/v2 v2.19.0/go.mod h1:rlwLi9PilAFJ8jCg9UE1QP6VBpd6/xj3SRC0d6TU0To= +github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= +github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= +github.com/onsi/gomega v1.17.0/go.mod h1:HnhC7FXeEQY45zxNK3PPoIUhzk/80Xly9PcubAlGdZY= +github.com/onsi/gomega v1.19.0/go.mod h1:LY+I3pBVzYsTBU1AnDwOSxaYi9WoWiqgwooUqq9yPro= +github.com/onsi/gomega v1.20.1/go.mod h1:DtrZpjmvpn2mPm4YWQa0/ALMDj9v4YxLgojwPeREyVo= +github.com/onsi/gomega v1.21.1/go.mod h1:iYAIXgPSaDHak0LCMA+AWBpIKBr8WZicMxnE8luStNc= +github.com/onsi/gomega v1.22.1/go.mod h1:x6n7VNe4hw0vkyYUM4mjIXx3JbLiPaBPNgB7PRQ1tuM= +github.com/onsi/gomega v1.24.0/go.mod h1:Z/NWtiqwBrwUt4/2loMmHL63EDLnYHmVbuBpDr2vQAg= +github.com/onsi/gomega v1.24.1/go.mod h1:3AOiACssS3/MajrniINInwbfOOtfZvplPzuRSmvt1jM= +github.com/onsi/gomega v1.26.0/go.mod h1:r+zV744Re+DiYCIPRlYOTxn0YkOLcAnW8k1xXdMPGhM= +github.com/onsi/gomega v1.27.1/go.mod h1:aHX5xOykVYzWOV4WqQy0sy8BQptgukenXpCXfadcIAw= +github.com/onsi/gomega v1.27.3/go.mod h1:5vG284IBtfDAmDyrK+eGyZmUgUlmi+Wngqo557cZ6Gw= +github.com/onsi/gomega v1.27.4/go.mod h1:riYq/GJKh8hhoM01HN6Vmuy93AarCXCBGpvFDK3q3fQ= +github.com/onsi/gomega v1.27.6/go.mod h1:PIQNjfQwkP3aQAH7lf7j87O/5FiNr+ZR8+ipb+qQlhg= +github.com/onsi/gomega v1.27.7/go.mod h1:1p8OOlwo2iUUDsHnOrjE5UKYJ+e3W8eQ3qSlRahPmr4= +github.com/onsi/gomega v1.27.8/go.mod h1:2J8vzI/s+2shY9XHRApDkdgPo1TKT7P2u6fXeJKFnNQ= +github.com/onsi/gomega v1.27.10/go.mod h1:RsS8tutOdbdgzbPtzzATp12yT7kM5I5aElG3evPbQ0M= +github.com/onsi/gomega v1.29.0/go.mod h1:9sxs+SwGrKI0+PWe4Fxa9tFQQBG5xSsSbMXOI8PPpoQ= +github.com/onsi/gomega v1.33.1 h1:dsYjIxxSR755MDmKVsaFQTE22ChNBcuuTWgkUDSubOk= +github.com/onsi/gomega v1.33.1/go.mod h1:U4R44UsT+9eLIaYRB2a5qajjtQYn0hauxvRm16AVYg0= +github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU= +github.com/phpdave11/gofpdf v1.4.2/go.mod h1:zpO6xFn9yxo3YLyMvW8HcKWVdbNqgIfOOp2dXMnm1mY= +github.com/phpdave11/gofpdi v1.0.12/go.mod h1:vBmVV0Do6hSBHC8uKUQ71JGW+ZGQq74llk/7bXwjDoI= +github.com/phpdave11/gofpdi v1.0.13/go.mod h1:vBmVV0Do6hSBHC8uKUQ71JGW+ZGQq74llk/7bXwjDoI= +github.com/pierrec/lz4/v4 v4.1.15/go.mod h1:gZWDp/Ze/IJXGXf23ltt2EXimqmTUXEy0GFuRQyBid4= +github.com/pkg/diff v0.0.0-20210226163009-20ebb0f2a09e/go.mod h1:pJLUxLENpZxwdsKMEsNbx1VGcRFpLqf3715MtcvvzbA= +github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= +github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= +github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= +github.com/pkg/sftp v1.10.1/go.mod h1:lYOWFsE0bwd1+KfKJaKeuokY15vzFx25BLbzYYoAxZI= +github.com/pkg/sftp v1.13.1/go.mod h1:3HaPG6Dq1ILlpPZRO0HVMrsydcdLt6HRDccSgb87qRg= +github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 h1:Jamvg5psRIccs7FGNTlIRMkT8wgtp5eCXdBlqhYGL6U= +github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/prometheus-operator/prometheus-operator/pkg/apis/monitoring v0.74.0 h1:AHzMWDxNiAVscJL6+4wkvFRTpMnJqiaZFEKA/osaBXE= +github.com/prometheus-operator/prometheus-operator/pkg/apis/monitoring v0.74.0/go.mod h1:wAR5JopumPtAZnu0Cjv2PSqV4p4QB09LMhc6fZZTXuA= +github.com/prometheus/client_golang v1.19.1 h1:wZWJDwK+NameRJuPGDhlnFgx8e8HN3XHQeLaYJFJBOE= +github.com/prometheus/client_golang v1.19.1/go.mod h1:mP78NwGzrVks5S2H6ab8+ZZGJLZUq1hoULYBAYBw1Ho= +github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= +github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= +github.com/prometheus/client_model v0.3.0/go.mod h1:LDGWKZIo7rky3hgvBe+caln+Dr3dPggB5dvjtD7w9+w= +github.com/prometheus/client_model v0.6.1 h1:ZKSh/rekM+n3CeS952MLRAdFwIKqeY8b62p8ais2e9E= +github.com/prometheus/client_model v0.6.1/go.mod h1:OrxVMOVHjw3lKMa8+x6HeMGkHMQyHDk9E3jmP2AmGiY= +github.com/prometheus/common v0.55.0 h1:KEi6DK7lXW/m7Ig5i47x0vRzuBsHuvJdi5ee6Y3G1dc= +github.com/prometheus/common v0.55.0/go.mod h1:2SECS4xJG1kd8XF9IcM1gMX6510RAEL65zxzNImwdc8= +github.com/prometheus/procfs v0.15.1 h1:YagwOFzUgYfKKHX6Dr+sHT7km/hxC76UB0learggepc= +github.com/prometheus/procfs v0.15.1/go.mod h1:fB45yRUv8NstnjriLhBQLuOUt+WW4BsoGhij/e3PBqk= +github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo= +github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= +github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= +github.com/rogpeppe/go-internal v1.6.1/go.mod h1:xXDCJY+GAPziupqXw64V24skbSoqbTEfhy4qGm1nDQc= +github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs= +github.com/rogpeppe/go-internal v1.10.0/go.mod h1:UQnix2H7Ngw/k4C5ijL5+65zddjncjaFoBhdsK/akog= +github.com/rogpeppe/go-internal v1.11.0 h1:cWPaGQEPrBb5/AsnsZesgZZ9yb1OQ+GOISoDNXVBh4M= +github.com/rogpeppe/go-internal v1.11.0/go.mod h1:ddIwULY96R17DhadqLgMfk9H9tvdUzkipdSkR5nkCZA= +github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= +github.com/russross/blackfriday/v2 v2.1.0 h1:JIOH55/0cWyOuilr9/qlrm0BSXldqnqwMsf35Ld67mk= +github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= +github.com/ruudk/golang-pdf417 v0.0.0-20181029194003-1af4ab5afa58/go.mod h1:6lfFZQK844Gfx8o5WFuvpxWRwnSoipWe/p622j1v06w= +github.com/ruudk/golang-pdf417 v0.0.0-20201230142125-a7e3863a1245/go.mod h1:pQAZKsJ8yyVxGRWYNEm9oFB8ieLgKFnamEyDmSA0BRk= +github.com/shopspring/decimal v1.2.0/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o= +github.com/shopspring/decimal v1.3.1 h1:2Usl1nmF/WZucqkFZhnfFYxxxu8LG21F6nPQBE5gKV8= +github.com/shopspring/decimal v1.3.1/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o= +github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= +github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA= +github.com/spf13/afero v1.2.2/go.mod h1:9ZxEEn6pIJ8Rxe320qSDBk6AsU0r9pR7Q4OcevTdifk= +github.com/spf13/afero v1.3.3/go.mod h1:5KUK8ByomD5Ti5Artl0RtHeI5pTF7MIDuXL3yY520V4= +github.com/spf13/afero v1.6.0/go.mod h1:Ai8FlHk4v/PARR026UzYexafAt9roJ7LcLMAmO6Z93I= +github.com/spf13/afero v1.9.2/go.mod h1:iUV7ddyEEZPO5gA3zD4fJt6iStLlL+Lg4m2cihcDf8Y= +github.com/spf13/afero v1.11.0 h1:WJQKhtpdm3v2IzqG8VMqrr6Rf3UYpEF239Jy9wNepM8= +github.com/spf13/afero v1.11.0/go.mod h1:GH9Y3pIexgf1MTIWtNGyogA5MwRIDXGUr+hbWNoBjkY= +github.com/spf13/cast v1.3.1/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= +github.com/spf13/cast v1.6.0 h1:GEiTHELF+vaR5dhz3VqZfFSzZjYbgeKDpBxQVS4GYJ0= +github.com/spf13/cast v1.6.0/go.mod h1:ancEpBxwJDODSW/UG4rDrAqiKolqNNh2DX3mk86cAdo= +github.com/spf13/cobra v1.8.1 h1:e5/vxKd/rZsfSJMUX1agtjeTDf+qv1/JdBF8gg5k9ZM= +github.com/spf13/cobra v1.8.1/go.mod h1:wHxEcudfqmLYa8iTfL+OuZPbBZkmvliBWKIezN3kD9Y= +github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA= +github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= +github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= +github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= +github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= +github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= +github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= +github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4= +github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA= +github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= +github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= +github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= +github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= +github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= +github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= +github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= +github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= +github.com/xeipuuv/gojsonpointer v0.0.0-20180127040702-4e3ac2762d5f/go.mod h1:N2zxlSyiKSe5eX1tZViRH5QA0qijqEDrYZiPEAiq3wU= +github.com/xeipuuv/gojsonpointer v0.0.0-20190905194746-02993c407bfb h1:zGWFAtiMcyryUHoUjUJX0/lt1H2+i2Ka2n+D3DImSNo= +github.com/xeipuuv/gojsonpointer v0.0.0-20190905194746-02993c407bfb/go.mod h1:N2zxlSyiKSe5eX1tZViRH5QA0qijqEDrYZiPEAiq3wU= +github.com/xeipuuv/gojsonreference v0.0.0-20180127040603-bd5ef7bd5415 h1:EzJWgHovont7NscjpAxXsDA8S8BMYve8Y5+7cuRE7R0= +github.com/xeipuuv/gojsonreference v0.0.0-20180127040603-bd5ef7bd5415/go.mod h1:GwrjFmJcFw6At/Gs6z4yjiIwzuJ1/+UwLxMQDVQXShQ= +github.com/xeipuuv/gojsonschema v1.2.0 h1:LhYJRs+L4fBtjZUfuSZIKGeVu0QRy8e5Xi7D17UxZ74= +github.com/xeipuuv/gojsonschema v1.2.0/go.mod h1:anYRn/JVcOK2ZgGU+IjEV4nwlhoK5sQluxsYJ78Id3Y= +github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= +github.com/yuin/goldmark v1.4.1/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= +github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= +github.com/zeebo/assert v1.3.0/go.mod h1:Pq9JiuJQpG8JLJdtkwrJESF0Foym2/D9XMU5ciN/wJ0= +github.com/zeebo/xxh3 v1.0.2/go.mod h1:5NWz9Sef7zIDm2JHfFlcQvNekmcEl9ekUZQQKCYaDcA= +go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU= +go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8= +go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= +go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= +go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= +go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk= +go.opencensus.io v0.23.0/go.mod h1:XItmlyltB5F7CS4xOC1DcqMoFqwtC6OG2xF7mCv7P7E= +go.opencensus.io v0.24.0/go.mod h1:vNK8G9p7aAivkbmorf4v+7Hgx+Zs0yY+0fOtgBfjQKo= +go.opentelemetry.io/proto/otlp v0.7.0/go.mod h1:PqfVotwruBrMGOCsRd/89rSnXhoiJIqeYNgFYFoEGnI= +go.opentelemetry.io/proto/otlp v0.15.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= +go.opentelemetry.io/proto/otlp v0.19.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= +go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto= +go.uber.org/goleak v1.3.0/go.mod h1:CoHD4mav9JJNrW/WLlf7HGZPjdw8EucARQHekz1X6bE= +go.uber.org/mock v0.4.0 h1:VcM4ZOtdbR4f6VXfiOpwpVJDL6lCReaZ6mw31wqh7KU= +go.uber.org/mock v0.4.0/go.mod h1:a6FSlNadKUHUa9IP5Vyt1zh4fC7uAwxMutEAscFbkZc= +go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0= +go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y= +go.uber.org/zap v1.27.0 h1:aJMhYGrd5QSmlpLMr2MftRKl7t8J8PTZPA732ud/XR8= +go.uber.org/zap v1.27.0/go.mod h1:GB2qFLM7cTU87MWRP2mPIjqfIDnGu+VIO4V/SdhGo2E= +golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= +golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20190605123033-f99c8df09eb5/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20190820162420-60c769a6c586/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20210421170649-83a5a9bb288b/go.mod h1:T9bdIzuCu7OtxOm1hfPfRQxPLYneinmdGuTeoZ9dtd4= +golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= +golang.org/x/crypto v0.0.0-20211108221036-ceb1ce70b4fa/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= +golang.org/x/crypto v0.0.0-20220314234659-1baeb1ce4c0b/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= +golang.org/x/crypto v0.1.0/go.mod h1:RecgLatLF4+eUMCP1PoPZQb+cVrJcOPbHkTkbkB9sbw= +golang.org/x/crypto v0.3.0/go.mod h1:hebNnKkNXi2UzZN1eVRvBB7co0a+JxK6XbPiWVs/3J4= +golang.org/x/crypto v0.7.0/go.mod h1:pYwdfH91IfpZVANVyUOhSIPZaFoJGxTFbZhFTx+dXZU= +golang.org/x/crypto v0.9.0/go.mod h1:yrmDGqONDYtNj3tH8X9dzUun2m2lzPa9ngI6/RUPGR0= +golang.org/x/crypto v0.11.0/go.mod h1:xgJhtzW8F9jGdVFWZESrid1U1bjeNy4zgy5cRr/CIio= +golang.org/x/crypto v0.12.0/go.mod h1:NF0Gs7EO5K4qLn+Ylc+fih8BSTeIjAP05siRnAh98yw= +golang.org/x/crypto v0.13.0/go.mod h1:y6Z2r+Rw4iayiXXAIxJIDAJ1zMW4yaTpebo8fPOliYc= +golang.org/x/crypto v0.14.0/go.mod h1:MVFd36DqK4CsrnJYDkBA3VC4m2GkXAM0PvzMCn4JQf4= +golang.org/x/crypto v0.16.0/go.mod h1:gCAAfMLgwOJRpTjQ2zCCt2OcSfYMTeZVSRtQlPC7Nq4= +golang.org/x/crypto v0.19.0/go.mod h1:Iy9bg/ha4yyC70EfRS8jz+B6ybOBKMaSxLj6P6oBDfU= +golang.org/x/crypto v0.21.0/go.mod h1:0BP7YvVV9gBbVKyeTG0Gyn+gZm94bibOW5BjDEYAOMs= +golang.org/x/crypto v0.26.0 h1:RrRspgV4mU+YwB4FYnuBoKsUapNIL5cohGAmSH3azsw= +golang.org/x/crypto v0.26.0/go.mod h1:GY7jblb9wI+FOo5y8/S2oY4zWP07AkOJ4+jxCqdqn54= +golang.org/x/exp v0.0.0-20180321215751-8460e604b9de/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= +golang.org/x/exp v0.0.0-20180807140117-3d87b88a115f/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= +golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= +golang.org/x/exp v0.0.0-20190125153040-c74c464bbbf2/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= +golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= +golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= +golang.org/x/exp v0.0.0-20190829153037-c13cbed26979/go.mod h1:86+5VVa7VpoJ4kLfm080zCjGlMRFzhUhsZKEZO7MGek= +golang.org/x/exp v0.0.0-20191002040644-a1355ae1e2c3/go.mod h1:NOZ3BPKG0ec/BKJQgnvsSFpcKLM5xXVWnvZS97DWHgE= +golang.org/x/exp v0.0.0-20191030013958-a1ab85dbe136/go.mod h1:JXzH8nQsPlswgeRAPE3MuO9GYsAcnJvJ4vnMwN/5qkY= +golang.org/x/exp v0.0.0-20191129062945-2f5052295587/go.mod h1:2RIsYlXP63K8oxa1u096TMicItID8zy7Y6sNkU49FU4= +golang.org/x/exp v0.0.0-20191227195350-da58074b4299/go.mod h1:2RIsYlXP63K8oxa1u096TMicItID8zy7Y6sNkU49FU4= +golang.org/x/exp v0.0.0-20200119233911-0405dc783f0a/go.mod h1:2RIsYlXP63K8oxa1u096TMicItID8zy7Y6sNkU49FU4= +golang.org/x/exp v0.0.0-20200207192155-f17229e696bd/go.mod h1:J/WKrq2StrnmMY6+EHIKF9dgMWnmCNThgcyBT1FY9mM= +golang.org/x/exp v0.0.0-20200224162631-6cc2880d07d6/go.mod h1:3jZMyOhIsHpP37uCMkUooju7aAi5cS1Q23tOzKc+0MU= +golang.org/x/exp v0.0.0-20220827204233-334a2380cb91/go.mod h1:cyybsKvd6eL0RnXn6p/Grxp8F5bW7iYuBgsNCOHpMYE= +golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 h1:2dVuKD2vS7b0QIHQbpyTISPd0LeHDbnYEryqj5Q1ug8= +golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56/go.mod h1:M4RDyNAINzryxdtnbRXRL/OHtkFuWGRjvuhBJpk2IlY= +golang.org/x/image v0.0.0-20180708004352-c73c2afc3b81/go.mod h1:ux5Hcp/YLpHSI86hEcLt0YII63i6oz57MZXIpbrjZUs= +golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js= +golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= +golang.org/x/image v0.0.0-20190910094157-69e4b8554b2a/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= +golang.org/x/image v0.0.0-20200119044424-58c23975cae1/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= +golang.org/x/image v0.0.0-20200430140353-33d19683fad8/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= +golang.org/x/image v0.0.0-20200618115811-c13761719519/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= +golang.org/x/image v0.0.0-20201208152932-35266b937fa6/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= +golang.org/x/image v0.0.0-20210216034530-4410531fe030/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= +golang.org/x/image v0.0.0-20210607152325-775e3b0c77b9/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM= +golang.org/x/image v0.0.0-20210628002857-a66eb6448b8d/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM= +golang.org/x/image v0.0.0-20211028202545-6944b10bf410/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM= +golang.org/x/image v0.0.0-20220302094943-723b81ca9867/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM= +golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= +golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU= +golang.org/x/lint v0.0.0-20190301231843-5614ed5bae6f/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= +golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= +golang.org/x/lint v0.0.0-20190409202823-959b441ac422/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= +golang.org/x/lint v0.0.0-20190909230951-414d861bb4ac/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= +golang.org/x/lint v0.0.0-20190930215403-16217165b5de/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= +golang.org/x/lint v0.0.0-20191125180803-fdd1cda4f05f/go.mod h1:5qLYkcX4OjUUV8bRuDixDT3tpyyb+LUpUlRWLxfhWrs= +golang.org/x/lint v0.0.0-20200130185559-910be7a94367/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= +golang.org/x/lint v0.0.0-20200302205851-738671d3881b/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= +golang.org/x/lint v0.0.0-20201208152925-83fdc39ff7b5/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= +golang.org/x/lint v0.0.0-20210508222113-6edffad5e616/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= +golang.org/x/mobile v0.0.0-20190312151609-d3739f865fa6/go.mod h1:z+o9i4GpDbdi3rU15maQ/Ox0txvL9dWGYEHz965HBQE= +golang.org/x/mobile v0.0.0-20190719004257-d2bd2a29d028/go.mod h1:E/iHnbuqvinMTCcRqshq8CkpyQDoeVncDDYHnLhea+o= +golang.org/x/mod v0.0.0-20190513183733-4bf6d317e70e/go.mod h1:mXi4GBBbnImb6dmsKGUJ2LatrhH/nqhxcFungHvyanc= +golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY= +golang.org/x/mod v0.1.1-0.20191105210325-c90efee705ee/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg= +golang.org/x/mod v0.1.1-0.20191107180719-034126e5016b/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg= +golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.4.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.4.1/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.5.0/go.mod h1:5OXOZSfqPIIbmVBIIKWRFfZjPR0E5r58TLhUjH0a2Ro= +golang.org/x/mod v0.5.1/go.mod h1:5OXOZSfqPIIbmVBIIKWRFfZjPR0E5r58TLhUjH0a2Ro= +golang.org/x/mod v0.6.0-dev.0.20220106191415-9b9b3d81d5e3/go.mod h1:3p9vT2HGsQu2K1YbXdKPJLVgG5VJdoTa1poYQBtP1AY= +golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= +golang.org/x/mod v0.6.0/go.mod h1:4mET923SAdbXp2ki8ey+zGs1SLqsuM2Y0uvdZR/fUNI= +golang.org/x/mod v0.7.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.9.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.10.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.12.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.14.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/mod v0.20.0 h1:utOm6MM3R3dnawAiJgn0y+xvuYRsm1RKM/4giyfDgV0= +golang.org/x/mod v0.20.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= +golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= +golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= +golang.org/x/net v0.0.0-20190108225652-1e06a53dbb7e/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= +golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= +golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= +golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= +golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= +golang.org/x/net v0.0.0-20190503192946-f4e77d36d62c/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= +golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks= +golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20190628185345-da137c7871d7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20190724013045-ca1201d0de80/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20200114155413-6afb5195e5aa/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20200202094626-16171245cfb2/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20200222125558-5a598a2470a0/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20200301022130-244492dfa37a/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20200324143707-d3edc9973b7e/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200501053045-e0ff5e5a1de5/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200506145744-7e3656a0809f/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200513185701-a91f0712d120/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200520004742-59133d7f0dd7/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200520182314-0ba52f642ac2/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= +golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= +golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= +golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20201031054903-ff519b6c9102/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20201110031124-69a78807bb2b/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20201209123823-ac852fbbde11/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20201224014010-6772e930b67b/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210119194325-5f4716e94777/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210316092652-d523dce5a7f4/go.mod h1:RBQZq4jEuRlivfhVLdyRGr576XBO4/greRjx4P4O3yc= +golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= +golang.org/x/net v0.0.0-20210428140749-89ef3d95e781/go.mod h1:OJAsFXCWl8Ukc7SiCT/9KSuxbyM7479/AVlXFRxuMCk= +golang.org/x/net v0.0.0-20210503060351-7fd8e65b6420/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= +golang.org/x/net v0.0.0-20210813160813-60bc85c4be6d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= +golang.org/x/net v0.0.0-20211015210444-4f30a5c0130f/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= +golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= +golang.org/x/net v0.0.0-20220127200216-cd36cc0744dd/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= +golang.org/x/net v0.0.0-20220225172249-27dd8689420f/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= +golang.org/x/net v0.0.0-20220325170049-de3da57026de/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= +golang.org/x/net v0.0.0-20220412020605-290c469a71a5/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= +golang.org/x/net v0.0.0-20220425223048-2871e0cb64e4/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= +golang.org/x/net v0.0.0-20220607020251-c690dde0001d/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= +golang.org/x/net v0.0.0-20220617184016-355a448f1bc9/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= +golang.org/x/net v0.0.0-20220624214902-1bab6f366d9e/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= +golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= +golang.org/x/net v0.0.0-20220909164309-bea034e7d591/go.mod h1:YDH+HFinaLZZlnHAfSS6ZXJJ9M9t4Dl22yv3iI2vPwk= +golang.org/x/net v0.0.0-20221012135044-0b7e1fb9d458/go.mod h1:YDH+HFinaLZZlnHAfSS6ZXJJ9M9t4Dl22yv3iI2vPwk= +golang.org/x/net v0.0.0-20221014081412-f15817d10f9b/go.mod h1:YDH+HFinaLZZlnHAfSS6ZXJJ9M9t4Dl22yv3iI2vPwk= +golang.org/x/net v0.1.0/go.mod h1:Cx3nUiGt4eDBEyega/BKRp+/AlGL8hYe7U9odMt2Cco= +golang.org/x/net v0.2.0/go.mod h1:KqCZLdyyvdV855qA2rE3GC2aiw5xGR5TEjj8smXukLY= +golang.org/x/net v0.3.0/go.mod h1:MBQ8lrhLObU/6UmLb4fmbmk5OcyYmqtbGd/9yIeKjEE= +golang.org/x/net v0.4.0/go.mod h1:MBQ8lrhLObU/6UmLb4fmbmk5OcyYmqtbGd/9yIeKjEE= +golang.org/x/net v0.5.0/go.mod h1:DivGGAXEgPSlEBzxGzZI+ZLohi+xUj054jfeKui00ws= +golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= +golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= +golang.org/x/net v0.8.0/go.mod h1:QVkue5JL9kW//ek3r6jTKnTFis1tRmNAW2P1shuFdJc= +golang.org/x/net v0.9.0/go.mod h1:d48xBJpPfHeWQsugry2m+kC02ZBRGRgulfHnEXEuWns= +golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= +golang.org/x/net v0.12.0/go.mod h1:zEVYFnQC7m/vmpQFELhcD1EWkZlX69l4oqgmer6hfKA= +golang.org/x/net v0.14.0/go.mod h1:PpSgVXXLK0OxS0F31C1/tv6XNguvCrnXIDrFMspZIUI= +golang.org/x/net v0.15.0/go.mod h1:idbUs1IY1+zTqbi8yxTbhexhEEk5ur9LInksu6HrEpk= +golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE= +golang.org/x/net v0.19.0/go.mod h1:CfAk/cbD4CthTvqiEl8NpboMuiuOYsAr/7NOjZJtv1U= +golang.org/x/net v0.21.0/go.mod h1:bIjVDfnllIU7BJ2DNgfnXvpSvtn8VRwhlsaeUTyUS44= +golang.org/x/net v0.23.0/go.mod h1:JKghWKKOSdJwpW2GEx0Ja7fmaKnMsbu+MWVZTokSYmg= +golang.org/x/net v0.28.0 h1:a9JDOJc5GMUJ0+UDqmLT86WiEy7iWyIhz8gz8E4e5hE= +golang.org/x/net v0.28.0/go.mod h1:yqtgsTWOOnlGLG9GFRrK3++bGOUEkNBoHZc8MEDWPNg= +golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= +golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= +golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= +golang.org/x/oauth2 v0.0.0-20191202225959-858c2ad4c8b6/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= +golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= +golang.org/x/oauth2 v0.0.0-20200902213428-5d25da1a8d43/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20201109201403-9fd604954f58/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20201208152858-08078c50e5b5/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210218202405-ba52d332ba99/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210220000619-9bb904979d93/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210313182246-cd4f82c27b84/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210514164344-f6687ab2804c/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210628180205-a41e5a781914/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210805134026-6f1e6394065a/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210819190943-2bc19b11175f/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20211104180415-d3ed0bb246c8/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20220223155221-ee480838109b/go.mod h1:DAh4E804XQdzx2j+YRIaUnCqCV2RuMz24cGBJ5QYIrc= +golang.org/x/oauth2 v0.0.0-20220309155454-6242fa91716a/go.mod h1:DAh4E804XQdzx2j+YRIaUnCqCV2RuMz24cGBJ5QYIrc= +golang.org/x/oauth2 v0.0.0-20220411215720-9780585627b5/go.mod h1:DAh4E804XQdzx2j+YRIaUnCqCV2RuMz24cGBJ5QYIrc= +golang.org/x/oauth2 v0.0.0-20220608161450-d0670ef3b1eb/go.mod h1:jaDAt6Dkxork7LmZnYtzbRWj0W47D86a3TGe0YHBvmE= +golang.org/x/oauth2 v0.0.0-20220622183110-fd043fe589d2/go.mod h1:jaDAt6Dkxork7LmZnYtzbRWj0W47D86a3TGe0YHBvmE= +golang.org/x/oauth2 v0.0.0-20220822191816-0ebed06d0094/go.mod h1:h4gKUeWbJ4rQPri7E0u6Gs4e9Ri2zaLxzw5DI5XGrYg= +golang.org/x/oauth2 v0.0.0-20220909003341-f21342109be1/go.mod h1:h4gKUeWbJ4rQPri7E0u6Gs4e9Ri2zaLxzw5DI5XGrYg= +golang.org/x/oauth2 v0.0.0-20221006150949-b44042a4b9c1/go.mod h1:h4gKUeWbJ4rQPri7E0u6Gs4e9Ri2zaLxzw5DI5XGrYg= +golang.org/x/oauth2 v0.0.0-20221014153046-6fdb5e3db783/go.mod h1:h4gKUeWbJ4rQPri7E0u6Gs4e9Ri2zaLxzw5DI5XGrYg= +golang.org/x/oauth2 v0.4.0/go.mod h1:RznEsdpjGAINPTOF0UH/t+xJ75L18YO3Ho6Pyn+uRec= +golang.org/x/oauth2 v0.5.0/go.mod h1:9/XBHVqLaWO3/BRHs5jbpYCnOZVjj5V0ndyaAM7KB4I= +golang.org/x/oauth2 v0.6.0/go.mod h1:ycmewcwgD4Rpr3eZJLSB4Kyyljb3qDh40vJ8STE5HKw= +golang.org/x/oauth2 v0.7.0/go.mod h1:hPLQkd9LyjfXTiRohC/41GhcFqxisoUQ99sCUOHO9x4= +golang.org/x/oauth2 v0.8.0/go.mod h1:yr7u4HXZRm1R1kBWqr/xKNqewf0plRYoB7sla+BCIXE= +golang.org/x/oauth2 v0.10.0/go.mod h1:kTpgurOux7LqtuxjuyZa4Gj2gdezIt/jQtGnNFfypQI= +golang.org/x/oauth2 v0.23.0 h1:PbgcYx2W7i4LvjJWEbf0ngHV6qJYr86PkAV3bXdLEbs= +golang.org/x/oauth2 v0.23.0/go.mod h1:XYTD2NtWslqkgxebSiOHnXEap4TF09sJSc7H1sXbhtI= +golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20200317015054-43a5402ce75a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20220601150217-0de741cfad7f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20220819030929-7fc1605a5dde/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20220929204114-8fcdb60fdcc0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.2.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.3.0/go.mod h1:FU7BRWz2tNW+3quACPkgCx/L+uEAv1htQ0V83Z9Rj+Y= +golang.org/x/sync v0.5.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= +golang.org/x/sync v0.8.0 h1:3NFvSEYkUoMifnESzZl15y791HH1qU2xm6eCJU5ZPXQ= +golang.org/x/sync v0.8.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= +golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= +golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= +golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= +golang.org/x/sys v0.0.0-20190312061237-fead79001313/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20190502145724-3ef323f4f1fd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20190507160741-ecd444e8653b/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20190606165138-5da285871e9c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20190624142023-c5567b49c5d0/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20190726091711-fc99dfbffb4e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20190904154756-749cb33beabd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20191001151750-bb3f8db39f24/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20191120155948-bd437916bb0e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20191204072324-ce4227a45e2e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200113162924-86b910548bc1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200202164722-d101bd2416d5/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200212091648-12a6c2dcc1e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200302150141-5c8b2ff67527/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200331124033-c3d80250170d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200501052902-10377860bb8e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200511232937-7e40ca221e25/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200515095857-1151b9dac4a9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200523222454-059865788121/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200803210538-64077c9b5642/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200905004654-be1d3432aa8f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20201201145000-ef89a241ccb3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210104204734-6f8348627aad/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210112080510-489259a85091/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210119212857-b64e53b001e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210220050731-9a76102bfb43/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210225134936-a50acf3fe073/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210304124612-50617c2ba197/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210305230114-8fe3ee5dd75b/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210315160823-c6e025ad8005/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210320140829-1e4c9ba3b0c4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210423185535-09eb48e85fd7/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210514084401-e8d321eab015/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210603125802-9665404d3644/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210616094352-59db8d763f22/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210806184541-e5e7981a1069/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210816183151-1e6c022a8912/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210823070655-63515b42dcdf/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210908233432-aa78b53d3365/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20211007075335-d3039528d8ac/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20211019181941-9d821ace8654/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20211124211545-fe61309f8881/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20211210111614-af8b64212486/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220128215802-99c3d69c2c27/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220209214540-3681064d5158/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220227234510-4e6760a101f9/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220319134239-a9b59b0215f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220328115105-d36c6a25d886/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220412211240-33da011f77ad/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220422013727-9388b58f7150/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220502124256-b6088ccd6cba/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220503163025-988cb79eb6c6/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220610221304-9f5ed59c137d/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220615213510-4f61da869c0c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220624220833-87e55d714810/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220728004956-3c1f35247d10/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220829200755-d48e67d00261/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.1.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.2.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.3.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.4.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.7.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.9.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.10.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.15.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.17.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.23.0 h1:YfKFowiIMvtgl1UERQoTPPToxltDeZfbj4H7dVUCwmM= +golang.org/x/sys v0.23.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= +golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= +golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= +golang.org/x/term v0.2.0/go.mod h1:TVmDHMZPmdnySmBfhjOoOdhjzdE1h4u1VwSiw2l1Nuc= +golang.org/x/term v0.3.0/go.mod h1:q750SLmJuPmVoN1blW3UFBPREJfb1KmY3vwxfr+nFDA= +golang.org/x/term v0.4.0/go.mod h1:9P2UbLfCdcvo3p/nzKvsmas4TnlujnuoV9hGgYzW1lQ= +golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= +golang.org/x/term v0.6.0/go.mod h1:m6U89DPEgQRMq3DNkDClhWw02AUbt2daBVO4cn4Hv9U= +golang.org/x/term v0.7.0/go.mod h1:P32HKFT3hSsZrRxla30E9HqToFYAQPCMs/zFMBUFqPY= +golang.org/x/term v0.8.0/go.mod h1:xPskH00ivmX89bAKVGSKKtLOWNx2+17Eiy94tnKShWo= +golang.org/x/term v0.10.0/go.mod h1:lpqdcUyK/oCiQxvxVrppt5ggO2KCZ5QblwqPnfZ6d5o= +golang.org/x/term v0.11.0/go.mod h1:zC9APTIj3jG3FdV/Ons+XE1riIZXG4aZ4GTHiPZJPIU= +golang.org/x/term v0.12.0/go.mod h1:owVbMEjm3cBLCHdkQu9b1opXd4ETQWc3BhuQGKgXgvU= +golang.org/x/term v0.13.0/go.mod h1:LTmsnFJwVN6bCy1rVCoS+qHT1HhALEFxKncY3WNNh4U= +golang.org/x/term v0.15.0/go.mod h1:BDl952bC7+uMoWR75FIrCDx79TPU9oHkTZ9yRbYOrX0= +golang.org/x/term v0.17.0/go.mod h1:lLRBjIVuehSbZlaOtGMbcMncT+aqLLLmKrsjNrUguwk= +golang.org/x/term v0.18.0/go.mod h1:ILwASektA3OnRv7amZ1xhE/KTR+u50pbXfZ03+6Nx58= +golang.org/x/term v0.23.0 h1:F6D4vR+EHoL9/sWAWgAR1H2DcHr4PareCbAaCo1RpuU= +golang.org/x/term v0.23.0/go.mod h1:DgV24QBUrK6jhZXl+20l6UWznPlwAHm1Q1mGHtydmSk= +golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= +golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= +golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= +golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= +golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.4/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.5/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= +golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ= +golang.org/x/text v0.4.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= +golang.org/x/text v0.5.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= +golang.org/x/text v0.6.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= +golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= +golang.org/x/text v0.8.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8= +golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8= +golang.org/x/text v0.11.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= +golang.org/x/text v0.12.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= +golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= +golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= +golang.org/x/text v0.17.0 h1:XtiM5bkSOt+ewxlOE/aE/AKEHibwj/6gvWMl9Rsh0Qc= +golang.org/x/text v0.17.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= +golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.0.0-20220922220347-f3bd1da661af/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.1.0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.3.0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.6.0 h1:eTDhh4ZXt5Qf0augr54TN6suAUudPcawVZeIAPU7D4U= +golang.org/x/time v0.6.0/go.mod h1:3BpzKBy/shNhVucY/MWOyx10tF3SFh9QdLuxbVysPQM= +golang.org/x/tools v0.0.0-20180525024113-a5b4c53f6e8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= +golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= +golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= +golang.org/x/tools v0.0.0-20190206041539-40960b6deb8e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= +golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY= +golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= +golang.org/x/tools v0.0.0-20190312151545-0bb0c0a6e846/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= +golang.org/x/tools v0.0.0-20190312170243-e65039ee4138/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= +golang.org/x/tools v0.0.0-20190425150028-36563e24a262/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= +golang.org/x/tools v0.0.0-20190506145303-2d16b83fe98c/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= +golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= +golang.org/x/tools v0.0.0-20190606124116-d0a3d012864b/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= +golang.org/x/tools v0.0.0-20190621195816-6e04913cbbac/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= +golang.org/x/tools v0.0.0-20190628153133-6cdbf07be9d0/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= +golang.org/x/tools v0.0.0-20190816200558-6889da9d5479/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20190911174233-4f2ddba30aff/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20190927191325-030b2cf1153e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20191012152004-8de300cfc20a/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20191113191852-77e3bb0ad9e7/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20191115202509-3a792d9c32b2/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20191125144606-a911d9008d1f/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20191130070609-6e064ea0cf2d/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20191216173652-a0e659d51361/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20191227053925-7b8e75db28f4/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200117161641-43d50277825c/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200122220014-bf1340f18c4a/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200130002326-2f3ba24bd6e7/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200204074204-1cc6d1ef6c74/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200207183749-b753a1ba74fa/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200212150539-ea181f53ac56/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200224181240-023911ca70b2/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200227222343-706bc42d1f0d/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200304193943-95d2e580d8eb/go.mod h1:o4KQGtdN14AW+yjsvvwRTJJuXz8XRtIHtEnmAXLyFUw= +golang.org/x/tools v0.0.0-20200312045724-11d5b4c81c7d/go.mod h1:o4KQGtdN14AW+yjsvvwRTJJuXz8XRtIHtEnmAXLyFUw= +golang.org/x/tools v0.0.0-20200331025713-a30bf2db82d4/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8= +golang.org/x/tools v0.0.0-20200501065659-ab2804fb9c9d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200505023115-26f46d2f7ef8/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200512131952-2bc93b1c0c88/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200515010526-7d3b6ebf133d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200618134242-20370b0cb4b2/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200729194436-6467de6f59a7/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= +golang.org/x/tools v0.0.0-20200804011535-6c149bb5ef0d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= +golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= +golang.org/x/tools v0.0.0-20200904185747-39188db58858/go.mod h1:Cj7w3i3Rnn0Xh82ur9kSqwfTHTeVxaDqrfMjpcNT6bE= +golang.org/x/tools v0.0.0-20201110124207-079ba7bd75cd/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20201201161351-ac6f37ff4c2a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20201208233053-a543418bbed2/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20201224043029-2b0845dc783e/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20210105154028-b0ab187a4818/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20210108195828-e2f9c7f1fc8e/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.1.0/go.mod h1:xkSsbof2nBLbhDlRMhhhyNLN/zl3eTqcnHD5viDpcZ0= +golang.org/x/tools v0.1.1/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= +golang.org/x/tools v0.1.2/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= +golang.org/x/tools v0.1.3/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= +golang.org/x/tools v0.1.4/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= +golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= +golang.org/x/tools v0.1.9/go.mod h1:nABZi5QlRsZVlzPpHl034qft6wpY4eDcsTt5AaioBiU= +golang.org/x/tools v0.1.10/go.mod h1:Uh6Zz+xoGYZom868N8YTex3t7RhtHDBrE8Gzo9bV56E= +golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= +golang.org/x/tools v0.2.0/go.mod h1:y4OqIKeOV/fWJetJ8bXPU1sEVniLMIyDAZWeHdV+NTA= +golang.org/x/tools v0.3.0/go.mod h1:/rWhSS2+zyEVwoJf8YAX6L2f0ntZ7Kn/mGgAWcipA5k= +golang.org/x/tools v0.4.0/go.mod h1:UE5sM2OK9E/d67R0ANs2xJizIymRP5gJU295PvKXxjQ= +golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= +golang.org/x/tools v0.7.0/go.mod h1:4pg6aUX35JBAogB10C9AtvVL+qowtN4pT3CGSQex14s= +golang.org/x/tools v0.9.1/go.mod h1:owI94Op576fPu3cIGQeHs3joujW/2Oc6MtlxbF5dfNc= +golang.org/x/tools v0.9.3/go.mod h1:owI94Op576fPu3cIGQeHs3joujW/2Oc6MtlxbF5dfNc= +golang.org/x/tools v0.12.0/go.mod h1:Sc0INKfu04TlqNoRA1hgpFZbhYXHPr4V5DzpSBTPqQM= +golang.org/x/tools v0.13.0/go.mod h1:HvlwmtVNQAhOuCjW7xxvovg8wbNq7LwfXh/k7wXUl58= +golang.org/x/tools v0.16.1/go.mod h1:kYVVN6I1mBNoB1OX+noeBjbRk4IUEPa7JJ+TJMEooJ0= +golang.org/x/tools v0.24.0 h1:J1shsA93PJUEVaUSaay7UXAyE8aimq3GW0pjlolpa24= +golang.org/x/tools v0.24.0/go.mod h1:YhNqVBIfWHdzvTLs0d8LCuMhkKUgSUKldakyV7W/WDQ= +golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20220411194840-2f41105eb62f/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20220517211312-f3a8303e98df/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8= +golang.org/x/xerrors v0.0.0-20220609144429-65e65417b02f/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8= +golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8= +gomodules.xyz/jsonpatch/v2 v2.4.0 h1:Ci3iUJyx9UeRx7CeFN8ARgGbkESwJK+KB9lLcWxY/Zw= +gomodules.xyz/jsonpatch/v2 v2.4.0/go.mod h1:AH3dM2RI6uoBZxn3LVrfvJ3E0/9dG4cSrbuBJT4moAY= +gonum.org/v1/gonum v0.0.0-20180816165407-929014505bf4/go.mod h1:Y+Yx5eoAFn32cQvJDxZx5Dpnq+c3wtXuadVZAcxbbBo= +gonum.org/v1/gonum v0.8.2/go.mod h1:oe/vMfY3deqTw+1EZJhuvEW2iwGF1bW9wwu7XCu0+v0= +gonum.org/v1/gonum v0.9.3/go.mod h1:TZumC3NeyVQskjXqmyWt4S3bINhy7B4eYwW69EbyX+0= +gonum.org/v1/gonum v0.11.0/go.mod h1:fSG4YDCxxUZQJ7rKsQrj0gMOg00Il0Z96/qMA4bVQhA= +gonum.org/v1/netlib v0.0.0-20190313105609-8cb42192e0e0/go.mod h1:wa6Ws7BG/ESfp6dHfk7C6KdzKA7wR7u/rKwOGE66zvw= +gonum.org/v1/plot v0.0.0-20190515093506-e2840ee46a6b/go.mod h1:Wt8AAjI+ypCyYX3nZBvf6cAIx93T+c/OS2HFAYskSZc= +gonum.org/v1/plot v0.9.0/go.mod h1:3Pcqqmp6RHvJI72kgb8fThyUnav364FOsdDo2aGW5lY= +gonum.org/v1/plot v0.10.1/go.mod h1:VZW5OlhkL1mysU9vaqNHnsy86inf6Ot+jB3r+BczCEo= +google.golang.org/api v0.4.0/go.mod h1:8k5glujaEP+g9n7WNsDg8QP6cUVNI86fCNMcbazEtwE= +google.golang.org/api v0.7.0/go.mod h1:WtwebWUNSVBH/HAw79HIFXZNqEvBhG+Ra+ax0hx3E3M= +google.golang.org/api v0.8.0/go.mod h1:o4eAsZoiT+ibD93RtjEohWalFOjRDx6CVaqeizhEnKg= +google.golang.org/api v0.9.0/go.mod h1:o4eAsZoiT+ibD93RtjEohWalFOjRDx6CVaqeizhEnKg= +google.golang.org/api v0.13.0/go.mod h1:iLdEw5Ide6rF15KTC1Kkl0iskquN2gFfn9o9XIsbkAI= +google.golang.org/api v0.14.0/go.mod h1:iLdEw5Ide6rF15KTC1Kkl0iskquN2gFfn9o9XIsbkAI= +google.golang.org/api v0.15.0/go.mod h1:iLdEw5Ide6rF15KTC1Kkl0iskquN2gFfn9o9XIsbkAI= +google.golang.org/api v0.17.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= +google.golang.org/api v0.18.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= +google.golang.org/api v0.19.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= +google.golang.org/api v0.20.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= +google.golang.org/api v0.22.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= +google.golang.org/api v0.24.0/go.mod h1:lIXQywCXRcnZPGlsd8NbLnOjtAoL6em04bJ9+z0MncE= +google.golang.org/api v0.28.0/go.mod h1:lIXQywCXRcnZPGlsd8NbLnOjtAoL6em04bJ9+z0MncE= +google.golang.org/api v0.29.0/go.mod h1:Lcubydp8VUV7KeIHD9z2Bys/sm/vGKnG1UHuDBSrHWM= +google.golang.org/api v0.30.0/go.mod h1:QGmEvQ87FHZNiUVJkT14jQNYJ4ZJjdRF23ZXz5138Fc= +google.golang.org/api v0.35.0/go.mod h1:/XrVsuzM0rZmrsbjJutiuftIzeuTQcEeaYcSk/mQ1dg= +google.golang.org/api v0.36.0/go.mod h1:+z5ficQTmoYpPn8LCUNVpK5I7hwkpjbcgqA7I34qYtE= +google.golang.org/api v0.40.0/go.mod h1:fYKFpnQN0DsDSKRVRcQSDQNtqWPfM9i+zNPxepjRCQ8= +google.golang.org/api v0.41.0/go.mod h1:RkxM5lITDfTzmyKFPt+wGrCJbVfniCr2ool8kTBzRTU= +google.golang.org/api v0.43.0/go.mod h1:nQsDGjRXMo4lvh5hP0TKqF244gqhGcr/YSIykhUk/94= +google.golang.org/api v0.47.0/go.mod h1:Wbvgpq1HddcWVtzsVLyfLp8lDg6AA241LmgIL59tHXo= +google.golang.org/api v0.48.0/go.mod h1:71Pr1vy+TAZRPkPs/xlCf5SsU8WjuAWv1Pfjbtukyy4= +google.golang.org/api v0.50.0/go.mod h1:4bNT5pAuq5ji4SRZm+5QIkjny9JAyVD/3gaSihNefaw= +google.golang.org/api v0.51.0/go.mod h1:t4HdrdoNgyN5cbEfm7Lum0lcLDLiise1F8qDKX00sOU= +google.golang.org/api v0.54.0/go.mod h1:7C4bFFOvVDGXjfDTAsgGwDgAxRDeQ4X8NvUedIt6z3k= +google.golang.org/api v0.55.0/go.mod h1:38yMfeP1kfjsl8isn0tliTjIb1rJXcQi4UXlbqivdVE= +google.golang.org/api v0.56.0/go.mod h1:38yMfeP1kfjsl8isn0tliTjIb1rJXcQi4UXlbqivdVE= +google.golang.org/api v0.57.0/go.mod h1:dVPlbZyBo2/OjBpmvNdpn2GRm6rPy75jyU7bmhdrMgI= +google.golang.org/api v0.61.0/go.mod h1:xQRti5UdCmoCEqFxcz93fTl338AVqDgyaDRuOZ3hg9I= +google.golang.org/api v0.63.0/go.mod h1:gs4ij2ffTRXwuzzgJl/56BdwJaA194ijkfn++9tDuPo= +google.golang.org/api v0.67.0/go.mod h1:ShHKP8E60yPsKNw/w8w+VYaj9H6buA5UqDp8dhbQZ6g= +google.golang.org/api v0.70.0/go.mod h1:Bs4ZM2HGifEvXwd50TtW70ovgJffJYw2oRCOFU/SkfA= +google.golang.org/api v0.71.0/go.mod h1:4PyU6e6JogV1f9eA4voyrTY2batOLdgZ5qZ5HOCc4j8= +google.golang.org/api v0.74.0/go.mod h1:ZpfMZOVRMywNyvJFeqL9HRWBgAuRfSjJFpe9QtRRyDs= +google.golang.org/api v0.75.0/go.mod h1:pU9QmyHLnzlpar1Mjt4IbapUCy8J+6HD6GeELN69ljA= +google.golang.org/api v0.77.0/go.mod h1:pU9QmyHLnzlpar1Mjt4IbapUCy8J+6HD6GeELN69ljA= +google.golang.org/api v0.78.0/go.mod h1:1Sg78yoMLOhlQTeF+ARBoytAcH1NNyyl390YMy6rKmw= +google.golang.org/api v0.80.0/go.mod h1:xY3nI94gbvBrE0J6NHXhxOmW97HG7Khjkku6AFB3Hyg= +google.golang.org/api v0.84.0/go.mod h1:NTsGnUFJMYROtiquksZHBWtHfeMC7iYthki7Eq3pa8o= +google.golang.org/api v0.85.0/go.mod h1:AqZf8Ep9uZ2pyTvgL+x0D3Zt0eoT9b5E8fmzfu6FO2g= +google.golang.org/api v0.90.0/go.mod h1:+Sem1dnrKlrXMR/X0bPnMWyluQe4RsNoYfmNLhOIkzw= +google.golang.org/api v0.93.0/go.mod h1:+Sem1dnrKlrXMR/X0bPnMWyluQe4RsNoYfmNLhOIkzw= +google.golang.org/api v0.95.0/go.mod h1:eADj+UBuxkh5zlrSntJghuNeg8HwQ1w5lTKkuqaETEI= +google.golang.org/api v0.96.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ13s= +google.golang.org/api v0.97.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ13s= +google.golang.org/api v0.98.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ13s= +google.golang.org/api v0.99.0/go.mod h1:1YOf74vkVndF7pG6hIHuINsM7eWwpVTAfNMNiL91A08= +google.golang.org/api v0.100.0/go.mod h1:ZE3Z2+ZOr87Rx7dqFsdRQkRBk36kDtp/h+QpHbB7a70= +google.golang.org/api v0.102.0/go.mod h1:3VFl6/fzoA+qNuS1N1/VfXY4LjoXN/wzeIp7TweWwGo= +google.golang.org/api v0.103.0/go.mod h1:hGtW6nK1AC+d9si/UBhw8Xli+QMOf6xyNAyJw4qU9w0= +google.golang.org/api v0.106.0/go.mod h1:2Ts0XTHNVWxypznxWOYUeI4g3WdP9Pk2Qk58+a/O9MY= +google.golang.org/api v0.107.0/go.mod h1:2Ts0XTHNVWxypznxWOYUeI4g3WdP9Pk2Qk58+a/O9MY= +google.golang.org/api v0.108.0/go.mod h1:2Ts0XTHNVWxypznxWOYUeI4g3WdP9Pk2Qk58+a/O9MY= +google.golang.org/api v0.110.0/go.mod h1:7FC4Vvx1Mooxh8C5HWjzZHcavuS2f6pmJpZx60ca7iI= +google.golang.org/api v0.111.0/go.mod h1:qtFHvU9mhgTJegR31csQ+rwxyUTHOKFqCKWp1J0fdw0= +google.golang.org/api v0.114.0/go.mod h1:ifYI2ZsFK6/uGddGfAD5BMxlnkBqCmqHSDUVi45N5Yg= +google.golang.org/api v0.118.0/go.mod h1:76TtD3vkgmZ66zZzp72bUUklpmQmKlhh6sYtIjYK+5E= +google.golang.org/api v0.122.0/go.mod h1:gcitW0lvnyWjSp9nKxAbdHKIZ6vF4aajGueeslZOyms= +google.golang.org/api v0.124.0/go.mod h1:xu2HQurE5gi/3t1aFCvhPD781p0a3p11sdunTJ2BlP4= +google.golang.org/api v0.126.0/go.mod h1:mBwVAtz+87bEN6CbA1GtZPDOqY2R5ONPqJeIlvyo4Aw= +google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= +google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= +google.golang.org/appengine v1.5.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= +google.golang.org/appengine v1.6.1/go.mod h1:i06prIuMbXzDqacNJfV5OdTW448YApPu5ww/cMBSeb0= +google.golang.org/appengine v1.6.5/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= +google.golang.org/appengine v1.6.6/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= +google.golang.org/appengine v1.6.7/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= +google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc= +google.golang.org/genproto v0.0.0-20190307195333-5fe7a883aa19/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= +google.golang.org/genproto v0.0.0-20190418145605-e7d98fc518a7/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= +google.golang.org/genproto v0.0.0-20190425155659-357c62f0e4bb/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= +google.golang.org/genproto v0.0.0-20190502173448-54afdca5d873/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= +google.golang.org/genproto v0.0.0-20190801165951-fa694d86fc64/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= +google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= +google.golang.org/genproto v0.0.0-20190911173649-1774047e7e51/go.mod h1:IbNlFCBrqXvoKpeg0TB2l7cyZUmoaFKYIwrEpbDKLA8= +google.golang.org/genproto v0.0.0-20191108220845-16a3f7862a1a/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= +google.golang.org/genproto v0.0.0-20191115194625-c23dd37a84c9/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= +google.golang.org/genproto v0.0.0-20191216164720-4f79533eabd1/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= +google.golang.org/genproto v0.0.0-20191230161307-f3c370f40bfb/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= +google.golang.org/genproto v0.0.0-20200115191322-ca5a22157cba/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= +google.golang.org/genproto v0.0.0-20200122232147-0452cf42e150/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= +google.golang.org/genproto v0.0.0-20200204135345-fa8e72b47b90/go.mod h1:GmwEX6Z4W5gMy59cAlVYjN9JhxgbQH6Gn+gFDQe2lzA= +google.golang.org/genproto v0.0.0-20200212174721-66ed5ce911ce/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200224152610-e50cd9704f63/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200228133532-8c2c7df3a383/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200305110556-506484158171/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200312145019-da6875a35672/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200331122359-1ee6d9798940/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200430143042-b979b6f78d84/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200511104702-f5ebc3bea380/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200515170657-fc4c6c6a6587/go.mod h1:YsZOwe1myG/8QRHRsmBRE1LrgQY60beZKjly0O1fX9U= +google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo= +google.golang.org/genproto v0.0.0-20200618031413-b414f8b61790/go.mod h1:jDfRM7FcilCzHH/e9qn6dsT145K34l5v+OpcnNgKAAA= +google.golang.org/genproto v0.0.0-20200729003335-053ba62fc06f/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20200804131852-c06518451d9c/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20200825200019-8632dd797987/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20200904004341-0bd0a958aa1d/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201109203340-2640f1f9cdfb/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201201144952-b05cb90ed32e/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201210142538-e3217bee35cc/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201214200347-8c77b98c765d/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210108203827-ffc7fda8c3d7/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210222152913-aa3ee6e6a81c/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210226172003-ab064af71705/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210303154014-9728d6b83eeb/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210310155132-4ce2db91004e/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210319143718-93e7006c17a6/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210329143202-679c6ae281ee/go.mod h1:9lPAdzaEmUacj36I+k7YKbEc5CXzPIeORRgDAUOu28A= +google.golang.org/genproto v0.0.0-20210402141018-6c239bbf2bb1/go.mod h1:9lPAdzaEmUacj36I+k7YKbEc5CXzPIeORRgDAUOu28A= +google.golang.org/genproto v0.0.0-20210513213006-bf773b8c8384/go.mod h1:P3QM42oQyzQSnHPnZ/vqoCdDmzH28fzWByN9asMeM8A= +google.golang.org/genproto v0.0.0-20210602131652-f16073e35f0c/go.mod h1:UODoCrxHCcBojKKwX1terBiRUaqAsFqJiF615XL43r0= +google.golang.org/genproto v0.0.0-20210604141403-392c879c8b08/go.mod h1:UODoCrxHCcBojKKwX1terBiRUaqAsFqJiF615XL43r0= +google.golang.org/genproto v0.0.0-20210608205507-b6d2f5bf0d7d/go.mod h1:UODoCrxHCcBojKKwX1terBiRUaqAsFqJiF615XL43r0= +google.golang.org/genproto v0.0.0-20210624195500-8bfb893ecb84/go.mod h1:SzzZ/N+nwJDaO1kznhnlzqS8ocJICar6hYhVyhi++24= +google.golang.org/genproto v0.0.0-20210713002101-d411969a0d9a/go.mod h1:AxrInvYm1dci+enl5hChSFPOmmUF1+uAa/UsgNRWd7k= +google.golang.org/genproto v0.0.0-20210716133855-ce7ef5c701ea/go.mod h1:AxrInvYm1dci+enl5hChSFPOmmUF1+uAa/UsgNRWd7k= +google.golang.org/genproto v0.0.0-20210728212813-7823e685a01f/go.mod h1:ob2IJxKrgPT52GcgX759i1sleT07tiKowYBGbczaW48= +google.golang.org/genproto v0.0.0-20210805201207-89edb61ffb67/go.mod h1:ob2IJxKrgPT52GcgX759i1sleT07tiKowYBGbczaW48= +google.golang.org/genproto v0.0.0-20210813162853-db860fec028c/go.mod h1:cFeNkxwySK631ADgubI+/XFU/xp8FD5KIVV4rj8UC5w= +google.golang.org/genproto v0.0.0-20210821163610-241b8fcbd6c8/go.mod h1:eFjDcFEctNawg4eG61bRv87N7iHBWyVhJu7u1kqDUXY= +google.golang.org/genproto v0.0.0-20210828152312-66f60bf46e71/go.mod h1:eFjDcFEctNawg4eG61bRv87N7iHBWyVhJu7u1kqDUXY= +google.golang.org/genproto v0.0.0-20210831024726-fe130286e0e2/go.mod h1:eFjDcFEctNawg4eG61bRv87N7iHBWyVhJu7u1kqDUXY= +google.golang.org/genproto v0.0.0-20210903162649-d08c68adba83/go.mod h1:eFjDcFEctNawg4eG61bRv87N7iHBWyVhJu7u1kqDUXY= +google.golang.org/genproto v0.0.0-20210909211513-a8c4777a87af/go.mod h1:eFjDcFEctNawg4eG61bRv87N7iHBWyVhJu7u1kqDUXY= +google.golang.org/genproto v0.0.0-20210924002016-3dee208752a0/go.mod h1:5CzLGKJ67TSI2B9POpiiyGha0AjJvZIUgRMt1dSmuhc= +google.golang.org/genproto v0.0.0-20211118181313-81c1377c94b1/go.mod h1:5CzLGKJ67TSI2B9POpiiyGha0AjJvZIUgRMt1dSmuhc= +google.golang.org/genproto v0.0.0-20211206160659-862468c7d6e0/go.mod h1:5CzLGKJ67TSI2B9POpiiyGha0AjJvZIUgRMt1dSmuhc= +google.golang.org/genproto v0.0.0-20211208223120-3a66f561d7aa/go.mod h1:5CzLGKJ67TSI2B9POpiiyGha0AjJvZIUgRMt1dSmuhc= +google.golang.org/genproto v0.0.0-20211221195035-429b39de9b1c/go.mod h1:5CzLGKJ67TSI2B9POpiiyGha0AjJvZIUgRMt1dSmuhc= +google.golang.org/genproto v0.0.0-20220126215142-9970aeb2e350/go.mod h1:5CzLGKJ67TSI2B9POpiiyGha0AjJvZIUgRMt1dSmuhc= +google.golang.org/genproto v0.0.0-20220207164111-0872dc986b00/go.mod h1:5CzLGKJ67TSI2B9POpiiyGha0AjJvZIUgRMt1dSmuhc= +google.golang.org/genproto v0.0.0-20220218161850-94dd64e39d7c/go.mod h1:kGP+zUP2Ddo0ayMi4YuN7C3WZyJvGLZRh8Z5wnAqvEI= +google.golang.org/genproto v0.0.0-20220222213610-43724f9ea8cf/go.mod h1:kGP+zUP2Ddo0ayMi4YuN7C3WZyJvGLZRh8Z5wnAqvEI= +google.golang.org/genproto v0.0.0-20220304144024-325a89244dc8/go.mod h1:kGP+zUP2Ddo0ayMi4YuN7C3WZyJvGLZRh8Z5wnAqvEI= +google.golang.org/genproto v0.0.0-20220310185008-1973136f34c6/go.mod h1:kGP+zUP2Ddo0ayMi4YuN7C3WZyJvGLZRh8Z5wnAqvEI= +google.golang.org/genproto v0.0.0-20220324131243-acbaeb5b85eb/go.mod h1:hAL49I2IFola2sVEjAn7MEwsja0xp51I0tlGAf9hz4E= +google.golang.org/genproto v0.0.0-20220329172620-7be39ac1afc7/go.mod h1:8w6bsBMX6yCPbAVTeqQHvzxW0EIFigd5lZyahWgyfDo= +google.golang.org/genproto v0.0.0-20220407144326-9054f6ed7bac/go.mod h1:8w6bsBMX6yCPbAVTeqQHvzxW0EIFigd5lZyahWgyfDo= +google.golang.org/genproto v0.0.0-20220413183235-5e96e2839df9/go.mod h1:8w6bsBMX6yCPbAVTeqQHvzxW0EIFigd5lZyahWgyfDo= +google.golang.org/genproto v0.0.0-20220414192740-2d67ff6cf2b4/go.mod h1:8w6bsBMX6yCPbAVTeqQHvzxW0EIFigd5lZyahWgyfDo= +google.golang.org/genproto v0.0.0-20220421151946-72621c1f0bd3/go.mod h1:8w6bsBMX6yCPbAVTeqQHvzxW0EIFigd5lZyahWgyfDo= +google.golang.org/genproto v0.0.0-20220429170224-98d788798c3e/go.mod h1:8w6bsBMX6yCPbAVTeqQHvzxW0EIFigd5lZyahWgyfDo= +google.golang.org/genproto v0.0.0-20220502173005-c8bf987b8c21/go.mod h1:RAyBrSAP7Fh3Nc84ghnVLDPuV51xc9agzmm4Ph6i0Q4= +google.golang.org/genproto v0.0.0-20220505152158-f39f71e6c8f3/go.mod h1:RAyBrSAP7Fh3Nc84ghnVLDPuV51xc9agzmm4Ph6i0Q4= +google.golang.org/genproto v0.0.0-20220518221133-4f43b3371335/go.mod h1:RAyBrSAP7Fh3Nc84ghnVLDPuV51xc9agzmm4Ph6i0Q4= +google.golang.org/genproto v0.0.0-20220523171625-347a074981d8/go.mod h1:RAyBrSAP7Fh3Nc84ghnVLDPuV51xc9agzmm4Ph6i0Q4= +google.golang.org/genproto v0.0.0-20220608133413-ed9918b62aac/go.mod h1:KEWEmljWE5zPzLBa/oHl6DaEt9LmfH6WtH1OHIvleBA= +google.golang.org/genproto v0.0.0-20220616135557-88e70c0c3a90/go.mod h1:KEWEmljWE5zPzLBa/oHl6DaEt9LmfH6WtH1OHIvleBA= +google.golang.org/genproto v0.0.0-20220617124728-180714bec0ad/go.mod h1:KEWEmljWE5zPzLBa/oHl6DaEt9LmfH6WtH1OHIvleBA= +google.golang.org/genproto v0.0.0-20220624142145-8cd45d7dbd1f/go.mod h1:KEWEmljWE5zPzLBa/oHl6DaEt9LmfH6WtH1OHIvleBA= +google.golang.org/genproto v0.0.0-20220628213854-d9e0b6570c03/go.mod h1:KEWEmljWE5zPzLBa/oHl6DaEt9LmfH6WtH1OHIvleBA= +google.golang.org/genproto v0.0.0-20220722212130-b98a9ff5e252/go.mod h1:GkXuJDJ6aQ7lnJcRF+SJVgFdQhypqgl3LB1C9vabdRE= +google.golang.org/genproto v0.0.0-20220801145646-83ce21fca29f/go.mod h1:iHe1svFLAZg9VWz891+QbRMwUv9O/1Ww+/mngYeThbc= +google.golang.org/genproto v0.0.0-20220815135757-37a418bb8959/go.mod h1:dbqgFATTzChvnt+ujMdZwITVAJHFtfyN1qUhDqEiIlk= +google.golang.org/genproto v0.0.0-20220817144833-d7fd3f11b9b1/go.mod h1:dbqgFATTzChvnt+ujMdZwITVAJHFtfyN1qUhDqEiIlk= +google.golang.org/genproto v0.0.0-20220822174746-9e6da59bd2fc/go.mod h1:dbqgFATTzChvnt+ujMdZwITVAJHFtfyN1qUhDqEiIlk= +google.golang.org/genproto v0.0.0-20220829144015-23454907ede3/go.mod h1:dbqgFATTzChvnt+ujMdZwITVAJHFtfyN1qUhDqEiIlk= +google.golang.org/genproto v0.0.0-20220829175752-36a9c930ecbf/go.mod h1:dbqgFATTzChvnt+ujMdZwITVAJHFtfyN1qUhDqEiIlk= +google.golang.org/genproto v0.0.0-20220913154956-18f8339a66a5/go.mod h1:0Nb8Qy+Sk5eDzHnzlStwW3itdNaWoZA5XeSG+R3JHSo= +google.golang.org/genproto v0.0.0-20220914142337-ca0e39ece12f/go.mod h1:0Nb8Qy+Sk5eDzHnzlStwW3itdNaWoZA5XeSG+R3JHSo= +google.golang.org/genproto v0.0.0-20220915135415-7fd63a7952de/go.mod h1:0Nb8Qy+Sk5eDzHnzlStwW3itdNaWoZA5XeSG+R3JHSo= +google.golang.org/genproto v0.0.0-20220916172020-2692e8806bfa/go.mod h1:0Nb8Qy+Sk5eDzHnzlStwW3itdNaWoZA5XeSG+R3JHSo= +google.golang.org/genproto v0.0.0-20220919141832-68c03719ef51/go.mod h1:0Nb8Qy+Sk5eDzHnzlStwW3itdNaWoZA5XeSG+R3JHSo= +google.golang.org/genproto v0.0.0-20220920201722-2b89144ce006/go.mod h1:ht8XFiar2npT/g4vkk7O0WYS1sHOHbdujxbEp7CJWbw= +google.golang.org/genproto v0.0.0-20220926165614-551eb538f295/go.mod h1:woMGP53BroOrRY3xTxlbr8Y3eB/nzAvvFM83q7kG2OI= +google.golang.org/genproto v0.0.0-20220926220553-6981cbe3cfce/go.mod h1:woMGP53BroOrRY3xTxlbr8Y3eB/nzAvvFM83q7kG2OI= +google.golang.org/genproto v0.0.0-20221010155953-15ba04fc1c0e/go.mod h1:3526vdqwhZAwq4wsRUaVG555sVgsNmIjRtO7t/JH29U= +google.golang.org/genproto v0.0.0-20221014173430-6e2ab493f96b/go.mod h1:1vXfmgAz9N9Jx0QA82PqRVauvCz1SGSz739p0f183jM= +google.golang.org/genproto v0.0.0-20221014213838-99cd37c6964a/go.mod h1:1vXfmgAz9N9Jx0QA82PqRVauvCz1SGSz739p0f183jM= +google.golang.org/genproto v0.0.0-20221024153911-1573dae28c9c/go.mod h1:9qHF0xnpdSfF6knlcsnpzUu5y+rpwgbvsyGAZPBMg4s= +google.golang.org/genproto v0.0.0-20221024183307-1bc688fe9f3e/go.mod h1:9qHF0xnpdSfF6knlcsnpzUu5y+rpwgbvsyGAZPBMg4s= +google.golang.org/genproto v0.0.0-20221027153422-115e99e71e1c/go.mod h1:CGI5F/G+E5bKwmfYo09AXuVN4dD894kIKUFmVbP2/Fo= +google.golang.org/genproto v0.0.0-20221109142239-94d6d90a7d66/go.mod h1:rZS5c/ZVYMaOGBfO68GWtjOw/eLaZM1X6iVtgjZ+EWg= +google.golang.org/genproto v0.0.0-20221114212237-e4508ebdbee1/go.mod h1:rZS5c/ZVYMaOGBfO68GWtjOw/eLaZM1X6iVtgjZ+EWg= +google.golang.org/genproto v0.0.0-20221117204609-8f9c96812029/go.mod h1:rZS5c/ZVYMaOGBfO68GWtjOw/eLaZM1X6iVtgjZ+EWg= +google.golang.org/genproto v0.0.0-20221118155620-16455021b5e6/go.mod h1:rZS5c/ZVYMaOGBfO68GWtjOw/eLaZM1X6iVtgjZ+EWg= +google.golang.org/genproto v0.0.0-20221201164419-0e50fba7f41c/go.mod h1:rZS5c/ZVYMaOGBfO68GWtjOw/eLaZM1X6iVtgjZ+EWg= +google.golang.org/genproto v0.0.0-20221201204527-e3fa12d562f3/go.mod h1:rZS5c/ZVYMaOGBfO68GWtjOw/eLaZM1X6iVtgjZ+EWg= +google.golang.org/genproto v0.0.0-20221202195650-67e5cbc046fd/go.mod h1:cTsE614GARnxrLsqKREzmNYJACSWWpAWdNMwnD7c2BE= +google.golang.org/genproto v0.0.0-20221227171554-f9683d7f8bef/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230110181048-76db0878b65f/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230112194545-e10362b5ecf9/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230113154510-dbe35b8444a5/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230123190316-2c411cf9d197/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230124163310-31e0e69b6fc2/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230125152338-dcaf20b6aeaa/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230127162408-596548ed4efa/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230209215440-0dfe4f8abfcc/go.mod h1:RGgjbofJ8xD9Sq1VVhDM1Vok1vRONV+rg+CjzG4SZKM= +google.golang.org/genproto v0.0.0-20230216225411-c8e22ba71e44/go.mod h1:8B0gmkoRebU8ukX6HP+4wrVQUY1+6PkQ44BSyIlflHA= +google.golang.org/genproto v0.0.0-20230222225845-10f96fb3dbec/go.mod h1:3Dl5ZL0q0isWJt+FVcfpQyirqemEuLAK/iFvg1UP1Hw= +google.golang.org/genproto v0.0.0-20230223222841-637eb2293923/go.mod h1:3Dl5ZL0q0isWJt+FVcfpQyirqemEuLAK/iFvg1UP1Hw= +google.golang.org/genproto v0.0.0-20230303212802-e74f57abe488/go.mod h1:TvhZT5f700eVlTNwND1xoEZQeWTB2RY/65kplwl/bFA= +google.golang.org/genproto v0.0.0-20230306155012-7f2fa6fef1f4/go.mod h1:NWraEVixdDnqcqQ30jipen1STv2r/n24Wb7twVTGR4s= +google.golang.org/genproto v0.0.0-20230320184635-7606e756e683/go.mod h1:NWraEVixdDnqcqQ30jipen1STv2r/n24Wb7twVTGR4s= +google.golang.org/genproto v0.0.0-20230323212658-478b75c54725/go.mod h1:UUQDJDOlWu4KYeJZffbWgBkS1YFobzKbLVfK69pe0Ak= +google.golang.org/genproto v0.0.0-20230330154414-c0448cd141ea/go.mod h1:UUQDJDOlWu4KYeJZffbWgBkS1YFobzKbLVfK69pe0Ak= +google.golang.org/genproto v0.0.0-20230331144136-dcfb400f0633/go.mod h1:UUQDJDOlWu4KYeJZffbWgBkS1YFobzKbLVfK69pe0Ak= +google.golang.org/genproto v0.0.0-20230403163135-c38d8f061ccd/go.mod h1:UUQDJDOlWu4KYeJZffbWgBkS1YFobzKbLVfK69pe0Ak= +google.golang.org/genproto v0.0.0-20230410155749-daa745c078e1/go.mod h1:nKE/iIaLqn2bQwXBg8f1g2Ylh6r5MN5CmZvuzZCgsCU= +google.golang.org/genproto v0.0.0-20230525234025-438c736192d0/go.mod h1:9ExIQyXL5hZrHzQceCwuSYwZZ5QZBazOcprJ5rgs3lY= +google.golang.org/genproto v0.0.0-20230530153820-e85fd2cbaebc/go.mod h1:xZnkP7mREFX5MORlOPEzLMr+90PPZQ2QWzrVTWfAq64= +google.golang.org/genproto/googleapis/api v0.0.0-20230525234020-1aefcd67740a/go.mod h1:ts19tUU+Z0ZShN1y3aPyq2+O3d5FUNNgT6FtOzmrNn8= +google.golang.org/genproto/googleapis/api v0.0.0-20230525234035-dd9d682886f9/go.mod h1:vHYtlOoi6TsQ3Uk2yxR7NI5z8uoV+3pZtR4jmHIkRig= +google.golang.org/genproto/googleapis/api v0.0.0-20230526203410-71b5a4ffd15e/go.mod h1:vHYtlOoi6TsQ3Uk2yxR7NI5z8uoV+3pZtR4jmHIkRig= +google.golang.org/genproto/googleapis/api v0.0.0-20230530153820-e85fd2cbaebc/go.mod h1:vHYtlOoi6TsQ3Uk2yxR7NI5z8uoV+3pZtR4jmHIkRig= +google.golang.org/genproto/googleapis/api v0.0.0-20240528184218-531527333157 h1:7whR9kGa5LUwFtpLm2ArCEejtnxlGeLbAyjFY8sGNFw= +google.golang.org/genproto/googleapis/api v0.0.0-20240528184218-531527333157/go.mod h1:99sLkeliLXfdj2J75X3Ho+rrVCaJze0uwN7zDDkjPVU= +google.golang.org/genproto/googleapis/bytestream v0.0.0-20230530153820-e85fd2cbaebc/go.mod h1:ylj+BE99M198VPbBh6A8d9n3w8fChvyLK3wwBOjXBFA= +google.golang.org/genproto/googleapis/rpc v0.0.0-20230525234015-3fc162c6f38a/go.mod h1:xURIpW9ES5+/GZhnV6beoEtxQrnkRGIfP5VQG2tCBLc= +google.golang.org/genproto/googleapis/rpc v0.0.0-20230525234030-28d5490b6b19/go.mod h1:66JfowdXAEgad5O9NnYcsNPLCPZJD++2L9X0PCMODrA= +google.golang.org/genproto/googleapis/rpc v0.0.0-20230526203410-71b5a4ffd15e/go.mod h1:66JfowdXAEgad5O9NnYcsNPLCPZJD++2L9X0PCMODrA= +google.golang.org/genproto/googleapis/rpc v0.0.0-20230530153820-e85fd2cbaebc/go.mod h1:66JfowdXAEgad5O9NnYcsNPLCPZJD++2L9X0PCMODrA= +google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= +google.golang.org/grpc v1.20.1/go.mod h1:10oTOabMzJvdu6/UiuZezV6QK5dSlG84ov/aaiqXj38= +google.golang.org/grpc v1.21.1/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ijfRaM= +google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= +google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY= +google.golang.org/grpc v1.26.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= +google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= +google.golang.org/grpc v1.27.1/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= +google.golang.org/grpc v1.28.0/go.mod h1:rpkK4SK4GF4Ach/+MFLZUBavHOvF2JJB5uozKKal+60= +google.golang.org/grpc v1.29.1/go.mod h1:itym6AZVZYACWQqET3MqgPpjcuV5QH3BxFS3IjizoKk= +google.golang.org/grpc v1.30.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= +google.golang.org/grpc v1.31.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= +google.golang.org/grpc v1.31.1/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= +google.golang.org/grpc v1.33.1/go.mod h1:fr5YgcSWrqhRRxogOsw7RzIpsmvOZ6IcH4kBYTpR3n0= +google.golang.org/grpc v1.33.2/go.mod h1:JMHMWHQWaTccqQQlmk3MJZS+GWXOdAesneDmEnv2fbc= +google.golang.org/grpc v1.34.0/go.mod h1:WotjhfgOW/POjDeRt8vscBtXq+2VjORFy659qA51WJ8= +google.golang.org/grpc v1.35.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= +google.golang.org/grpc v1.36.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= +google.golang.org/grpc v1.36.1/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= +google.golang.org/grpc v1.37.0/go.mod h1:NREThFqKR1f3iQ6oBuvc5LadQuXVGo9rkm5ZGrQdJfM= +google.golang.org/grpc v1.37.1/go.mod h1:NREThFqKR1f3iQ6oBuvc5LadQuXVGo9rkm5ZGrQdJfM= +google.golang.org/grpc v1.38.0/go.mod h1:NREThFqKR1f3iQ6oBuvc5LadQuXVGo9rkm5ZGrQdJfM= +google.golang.org/grpc v1.39.0/go.mod h1:PImNr+rS9TWYb2O4/emRugxiyHZ5JyHW5F+RPnDzfrE= +google.golang.org/grpc v1.39.1/go.mod h1:PImNr+rS9TWYb2O4/emRugxiyHZ5JyHW5F+RPnDzfrE= +google.golang.org/grpc v1.40.0/go.mod h1:ogyxbiOoUXAkP+4+xa6PZSE9DZgIHtSpzjDTB9KAK34= +google.golang.org/grpc v1.40.1/go.mod h1:ogyxbiOoUXAkP+4+xa6PZSE9DZgIHtSpzjDTB9KAK34= +google.golang.org/grpc v1.42.0/go.mod h1:k+4IHHFw41K8+bbowsex27ge2rCb65oeWqe4jJ590SU= +google.golang.org/grpc v1.44.0/go.mod h1:k+4IHHFw41K8+bbowsex27ge2rCb65oeWqe4jJ590SU= +google.golang.org/grpc v1.45.0/go.mod h1:lN7owxKUQEqMfSyQikvvk5tf/6zMPsrK+ONuO11+0rQ= +google.golang.org/grpc v1.46.0/go.mod h1:vN9eftEi1UMyUsIF80+uQXhHjbXYbm0uXoFCACuMGWk= +google.golang.org/grpc v1.46.2/go.mod h1:vN9eftEi1UMyUsIF80+uQXhHjbXYbm0uXoFCACuMGWk= +google.golang.org/grpc v1.47.0/go.mod h1:vN9eftEi1UMyUsIF80+uQXhHjbXYbm0uXoFCACuMGWk= +google.golang.org/grpc v1.48.0/go.mod h1:vN9eftEi1UMyUsIF80+uQXhHjbXYbm0uXoFCACuMGWk= +google.golang.org/grpc v1.49.0/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI= +google.golang.org/grpc v1.50.0/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI= +google.golang.org/grpc v1.50.1/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI= +google.golang.org/grpc v1.51.0/go.mod h1:wgNDFcnuBGmxLKI/qn4T+m5BtEBYXJPvibbUPsAIPww= +google.golang.org/grpc v1.52.0/go.mod h1:pu6fVzoFb+NBYNAvQL08ic+lvB2IojljRYuun5vorUY= +google.golang.org/grpc v1.53.0/go.mod h1:OnIrk0ipVdj4N5d9IUoFUx72/VlD7+jUsHwZgwSMQpw= +google.golang.org/grpc v1.54.0/go.mod h1:PUSEXI6iWghWaB6lXM4knEgpJNu2qUcKfDtNci3EC2g= +google.golang.org/grpc v1.55.0/go.mod h1:iYEXKGkEBhg1PjZQvoYEVPTDkHo1/bjTnfwTeGONTY8= +google.golang.org/grpc/cmd/protoc-gen-go-grpc v1.1.0/go.mod h1:6Kw0yEErY5E/yWrBtf03jp27GLLJujG4z/JK95pnjjw= +google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= +google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0= +google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM= +google.golang.org/protobuf v1.20.1-0.20200309200217-e05f789c0967/go.mod h1:A+miEFZTKqfCUM6K7xSMQL9OKL/b6hQv+e19PK+JZNE= +google.golang.org/protobuf v1.21.0/go.mod h1:47Nbq4nVaFHyn7ilMalzfO3qCViNmqZ2kzikPIcrTAo= +google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= +google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= +google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= +google.golang.org/protobuf v1.24.0/go.mod h1:r/3tXBNzIEhYS9I1OUVjXDlt8tc493IdKGjtUeSXeh4= +google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c= +google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= +google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= +google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= +google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +google.golang.org/protobuf v1.29.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +google.golang.org/protobuf v1.30.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +google.golang.org/protobuf v1.31.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +google.golang.org/protobuf v1.33.0/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos= +google.golang.org/protobuf v1.34.2 h1:6xV6lTsCfpGD21XK49h7MhtcApnLqkfYgPcdHftf6hg= +google.golang.org/protobuf v1.34.2/go.mod h1:qYOHts0dSfpeUzUFpOMr/WGzszTmLH+DiWniOlNbLDw= +gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk= +gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q= +gopkg.in/errgo.v2 v2.1.0/go.mod h1:hNsd1EY+bozCKY1Ytp96fpM3vjJbqLJn88ws8XvfDNI= +gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys= +gopkg.in/inf.v0 v0.9.1 h1:73M5CoZyi3ZLMOyDlQh031Cx6N9NDJ2Vvfl76EDAgDc= +gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw= +gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ= +gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= +gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.2.3/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= +gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= +gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= +gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= +gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= +gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= +helm.sh/helm/v3 v3.14.4 h1:6FSpEfqyDalHq3kUr4gOMThhgY55kXUEjdQoyODYnrM= +helm.sh/helm/v3 v3.14.4/go.mod h1:Tje7LL4gprZpuBNTbG34d1Xn5NmRT3OWfBRwpOSer9I= +honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= +honnef.co/go/tools v0.0.0-20190106161140-3f1c8253044a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= +honnef.co/go/tools v0.0.0-20190418001031-e561f6794a2a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= +honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= +honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg= +honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= +honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= +honnef.co/go/tools v0.1.3/go.mod h1:NgwopIslSNH47DimFoV78dnkksY2EFtX0ajyb3K/las= +istio.io/api v1.22.1 h1:dzjmBYq6PEWAF7Kn7Dy5mI+RbJd49I41DEZLjYKfdZM= +istio.io/api v1.22.1/go.mod h1:S3l8LWqNYS9yT+d4bH+jqzH2lMencPkW7SKM1Cu9EyM= +istio.io/client-go v1.22.0 h1:TQ+Y7hqZVQHvaJXF99Q1jBqnVG7gYAHR9IvCK2nlwfE= +istio.io/client-go v1.22.0/go.mod h1:1lAPr0DOVBbnRQqLAQKxWbEaxFk6b1CJTm+ypnP7sMo= +k8s.io/api v0.29.5 h1:levS+umUigHCfI3riD36pMY1vQEbrzh4r1ivVWAhHaI= +k8s.io/api v0.29.5/go.mod h1:7b18TtPcJzdjk7w5zWyIHgoAtpGeRvGGASxlS7UZXdQ= +k8s.io/apiextensions-apiserver v0.29.5 h1:njDywexhE6n+1NEl3A4axT0TMQHREnndrk3/ztdWcNE= +k8s.io/apiextensions-apiserver v0.29.5/go.mod h1:pfIvij+MH9a8NQKtW7MD4EFnzvUjJ1ZQsDL8wuP8fnc= +k8s.io/apimachinery v0.29.5 h1:Hofa2BmPfpoT+IyDTlcPdCHSnHtEQMoJYGVoQpRTfv4= +k8s.io/apimachinery v0.29.5/go.mod h1:i3FJVwhvSp/6n8Fl4K97PJEP8C+MM+aoDq4+ZJBf70Y= +k8s.io/apiserver v0.29.5 h1:223C+JkRnGmudEU00GfpX6quDSrzwwP0DuXOYTyUYb0= +k8s.io/apiserver v0.29.5/go.mod h1:zN9xdatz5g7XwL1Xoz9hD4QQON1GN0c+1kV5e/NHejM= +k8s.io/autoscaler/vertical-pod-autoscaler v1.1.2 h1:ENxmnVXLt8+iXhDA0PNFhXb1sgvbvnAc66sC34UGrTw= +k8s.io/autoscaler/vertical-pod-autoscaler v1.1.2/go.mod h1:J2cNKnieE7r4bInjpQDBq93D50aD/CmspSi6xRUfKk4= +k8s.io/client-go v0.29.5 h1:nlASXmPQy190qTteaVP31g3c/wi2kycznkTP7Sv1zPc= +k8s.io/client-go v0.29.5/go.mod h1:aY5CnqUUvXYccJhm47XHoPcRyX6vouHdIBHaKZGTbK4= +k8s.io/code-generator v0.29.5 h1:WqSdBPVV1B3jsPnKtPS39U02zj6Q7+FsjhAj1EPBJec= +k8s.io/code-generator v0.29.5/go.mod h1:7TYnI0dYItL2cKuhhgPSuF3WED9uMdELgbVXFfn/joE= +k8s.io/component-base v0.29.5 h1:Ptj8AzG+p8c2a839XriHwxakDpZH9uvIgYz+o1agjg8= +k8s.io/component-base v0.29.5/go.mod h1:9nBUoPxW/yimISIgAG7sJDrUGJlu7t8HnDafIrOdU8Q= +k8s.io/gengo v0.0.0-20201203183100-97869a43a9d9/go.mod h1:FiNAH4ZV3gBg2Kwh89tzAEV2be7d5xI0vBa/VySYy3E= +k8s.io/gengo v0.0.0-20230829151522-9cce18d56c01 h1:pWEwq4Asjm4vjW7vcsmijwBhOr1/shsbSYiWXmNGlks= +k8s.io/gengo v0.0.0-20230829151522-9cce18d56c01/go.mod h1:FiNAH4ZV3gBg2Kwh89tzAEV2be7d5xI0vBa/VySYy3E= +k8s.io/klog v0.2.0/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= +k8s.io/klog v1.0.0 h1:Pt+yjF5aB1xDSVbau4VsWe+dQNzA0qv1LlXdC2dF6Q8= +k8s.io/klog v1.0.0/go.mod h1:4Bi6QPql/J/LkTDqv7R/cd3hPo4k2DG6Ptcz060Ez5I= +k8s.io/klog/v2 v2.0.0/go.mod h1:PBfzABfn139FHAV07az/IF9Wp1bkk3vpT2XSJ76fSDE= +k8s.io/klog/v2 v2.2.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y= +k8s.io/klog/v2 v2.80.1/go.mod h1:y1WjHnz7Dj687irZUWR/WLkLc5N1YHtjLdmgWjndZn0= +k8s.io/klog/v2 v2.110.1/go.mod h1:YGtd1984u+GgbuZ7e08/yBuAfKLSO0+uR1Fhi6ExXjo= +k8s.io/klog/v2 v2.130.1 h1:n9Xl7H1Xvksem4KFG4PYbdQCQxqc/tTUyrgXaOhHSzk= +k8s.io/klog/v2 v2.130.1/go.mod h1:3Jpz1GvMt720eyJH1ckRHK1EDfpxISzJ7I9OYgaDtPE= +k8s.io/kube-aggregator v0.29.5 h1:+ko7OE8HoXjPPxcQTXbo1ctkymYIohI/E0dYDnFM1vU= +k8s.io/kube-aggregator v0.29.5/go.mod h1:4MPs9uKrm5VgxXsoaSU0QJbgIuxvNCnVTYlCVz7VWzY= +k8s.io/kube-openapi v0.0.0-20231010175941-2dd684a91f00 h1:aVUu9fTY98ivBPKR9Y5w/AuzbMm96cd3YHRTU83I780= +k8s.io/kube-openapi v0.0.0-20231010175941-2dd684a91f00/go.mod h1:AsvuZPBlUDVuCdzJ87iajxtXuR9oktsTctW/R9wwouA= +k8s.io/kubelet v0.29.5 h1:tYYyc2JcrDt8jFYTsKpgcIpp+S5a/nm85CY4liosprw= +k8s.io/kubelet v0.29.5/go.mod h1:eWJR0OtRRkLwKEYjsQXcTyTZlSfgR3Py1xJVFa0ISTk= +k8s.io/metrics v0.29.5 h1:5AZBM4pMiq+SHi2/RP1OuL90In3f07BrL610zunKoxA= +k8s.io/metrics v0.29.5/go.mod h1:Cx7JPEEbjdDpEQ2A1QyXSBd6z5bxlwaSf9rgFJ/adfQ= +k8s.io/utils v0.0.0-20210802155522-efc7438f0176/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= +k8s.io/utils v0.0.0-20230726121419-3b25d923346b/go.mod h1:OLgZIPagt7ERELqWJFomSt595RzquPNLL48iOWgYOg0= +k8s.io/utils v0.0.0-20240711033017-18e509b52bc8 h1:pUdcCO1Lk/tbT5ztQWOBi5HBgbBP1J8+AsQnQCKsi8A= +k8s.io/utils v0.0.0-20240711033017-18e509b52bc8/go.mod h1:OLgZIPagt7ERELqWJFomSt595RzquPNLL48iOWgYOg0= +lukechampine.com/uint128 v1.1.1/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk= +lukechampine.com/uint128 v1.2.0/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk= +modernc.org/cc/v3 v3.36.0/go.mod h1:NFUHyPn4ekoC/JHeZFfZurN6ixxawE1BnVonP/oahEI= +modernc.org/cc/v3 v3.36.2/go.mod h1:NFUHyPn4ekoC/JHeZFfZurN6ixxawE1BnVonP/oahEI= +modernc.org/cc/v3 v3.36.3/go.mod h1:NFUHyPn4ekoC/JHeZFfZurN6ixxawE1BnVonP/oahEI= +modernc.org/ccgo/v3 v3.0.0-20220428102840-41399a37e894/go.mod h1:eI31LL8EwEBKPpNpA4bU1/i+sKOwOrQy8D87zWUcRZc= +modernc.org/ccgo/v3 v3.0.0-20220430103911-bc99d88307be/go.mod h1:bwdAnOoaIt8Ax9YdWGjxWsdkPcZyRPHqrOvJxaKAKGw= +modernc.org/ccgo/v3 v3.16.4/go.mod h1:tGtX0gE9Jn7hdZFeU88slbTh1UtCYKusWOoCJuvkWsQ= +modernc.org/ccgo/v3 v3.16.6/go.mod h1:tGtX0gE9Jn7hdZFeU88slbTh1UtCYKusWOoCJuvkWsQ= +modernc.org/ccgo/v3 v3.16.8/go.mod h1:zNjwkizS+fIFDrDjIAgBSCLkWbJuHF+ar3QRn+Z9aws= +modernc.org/ccgo/v3 v3.16.9/go.mod h1:zNMzC9A9xeNUepy6KuZBbugn3c0Mc9TeiJO4lgvkJDo= +modernc.org/ccorpus v1.11.6/go.mod h1:2gEUTrWqdpH2pXsmTM1ZkjeSrUWDpjMu2T6m29L/ErQ= +modernc.org/httpfs v1.0.6/go.mod h1:7dosgurJGp0sPaRanU53W4xZYKh14wfzX420oZADeHM= +modernc.org/libc v0.0.0-20220428101251-2d5f3daf273b/go.mod h1:p7Mg4+koNjc8jkqwcoFBJx7tXkpj00G77X7A72jXPXA= +modernc.org/libc v1.16.0/go.mod h1:N4LD6DBE9cf+Dzf9buBlzVJndKr/iJHG97vGLHYnb5A= +modernc.org/libc v1.16.1/go.mod h1:JjJE0eu4yeK7tab2n4S1w8tlWd9MxXLRzheaRnAKymU= +modernc.org/libc v1.16.17/go.mod h1:hYIV5VZczAmGZAnG15Vdngn5HSF5cSkbvfz2B7GRuVU= +modernc.org/libc v1.16.19/go.mod h1:p7Mg4+koNjc8jkqwcoFBJx7tXkpj00G77X7A72jXPXA= +modernc.org/libc v1.17.0/go.mod h1:XsgLldpP4aWlPlsjqKRdHPqCxCjISdHfM/yeWC5GyW0= +modernc.org/libc v1.17.1/go.mod h1:FZ23b+8LjxZs7XtFMbSzL/EhPxNbfZbErxEHc7cbD9s= +modernc.org/mathutil v1.2.2/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= +modernc.org/mathutil v1.4.1/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= +modernc.org/mathutil v1.5.0/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E= +modernc.org/memory v1.1.1/go.mod h1:/0wo5ibyrQiaoUoH7f9D8dnglAmILJ5/cxZlRECf+Nw= +modernc.org/memory v1.2.0/go.mod h1:/0wo5ibyrQiaoUoH7f9D8dnglAmILJ5/cxZlRECf+Nw= +modernc.org/memory v1.2.1/go.mod h1:PkUhL0Mugw21sHPeskwZW4D6VscE/GQJOnIpCnW6pSU= +modernc.org/opt v0.1.1/go.mod h1:WdSiB5evDcignE70guQKxYUl14mgWtbClRi5wmkkTX0= +modernc.org/opt v0.1.3/go.mod h1:WdSiB5evDcignE70guQKxYUl14mgWtbClRi5wmkkTX0= +modernc.org/sqlite v1.18.1/go.mod h1:6ho+Gow7oX5V+OiOQ6Tr4xeqbx13UZ6t+Fw9IRUG4d4= +modernc.org/strutil v1.1.1/go.mod h1:DE+MQQ/hjKBZS2zNInV5hhcipt5rLPWkmpbGeW5mmdw= +modernc.org/strutil v1.1.3/go.mod h1:MEHNA7PdEnEwLvspRMtWTNnp2nnyvMfkimT1NKNAGbw= +modernc.org/tcl v1.13.1/go.mod h1:XOLfOwzhkljL4itZkK6T72ckMgvj0BDsnKNdZVUOecw= +modernc.org/token v1.0.0/go.mod h1:UGzOrNV1mAFSEB63lOFHIpNRUVMvYTc6yu1SMY/XTDM= +modernc.org/z v1.5.1/go.mod h1:eWFB510QWW5Th9YGZT81s+LwvaAs3Q2yr4sP0rmLkv8= +rsc.io/binaryregexp v0.2.0/go.mod h1:qTv7/COck+e2FymRvadv62gMdZztPaShugOCi3I+8D8= +rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= +rsc.io/quote/v3 v3.1.0/go.mod h1:yEA65RcK8LyAZtP9Kv3t0HmxON59tX3rD+tICJqUlj0= +rsc.io/sampler v1.3.0/go.mod h1:T1hPZKmBbMNahiBKFy5HrXp6adAjACjK9JXDnKaTXpA= +sigs.k8s.io/controller-runtime v0.17.5 h1:1FI9Lm7NiOOmBsgTV36/s2XrEFXnO2C4sbg/Zme72Rw= +sigs.k8s.io/controller-runtime v0.17.5/go.mod h1:N0jpP5Lo7lMTF9aL56Z/B2oWBJjey6StQM0jRbKQXtY= +sigs.k8s.io/controller-runtime/tools/setup-envtest v0.0.0-20231015215740-bf15e44028f9 h1:O27fSMHw4u0h+Rj8bNzcZk5jY0iZCO0J8/mCpigpnbw= +sigs.k8s.io/controller-runtime/tools/setup-envtest v0.0.0-20231015215740-bf15e44028f9/go.mod h1:TF/lVLWS+JNNaVqJuDDictY2hZSXSsIHCx4FClMvqFg= +sigs.k8s.io/controller-tools v0.14.0 h1:rnNoCC5wSXlrNoBKKzL70LNJKIQKEzT6lloG6/LF73A= +sigs.k8s.io/controller-tools v0.14.0/go.mod h1:TV7uOtNNnnR72SpzhStvPkoS/U5ir0nMudrkrC4M9Sc= +sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd h1:EDPBXCAspyGV4jQlpZSudPeMmr1bNJefnuqLsRAsHZo= +sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd/go.mod h1:B8JuhiUyNFVKdsE8h686QcCxMaH6HrOAZj4vswFpcB0= +sigs.k8s.io/structured-merge-diff/v4 v4.2.3/go.mod h1:qjx8mGObPmV2aSZepjQjbmb2ihdVs8cGKBraizNC69E= +sigs.k8s.io/structured-merge-diff/v4 v4.4.1 h1:150L+0vs/8DA78h1u02ooW1/fFq/Lwr+sGiqlzvrtq4= +sigs.k8s.io/structured-merge-diff/v4 v4.4.1/go.mod h1:N8hJocpFajUSSeSJ9bOZ77VzejKZaXsTtZo4/u7Io08= +sigs.k8s.io/yaml v1.2.0/go.mod h1:yfXDCHCao9+ENCvLSE62v9VSji2MKu5jeNfTrofGhJc= +sigs.k8s.io/yaml v1.3.0/go.mod h1:GeOyir5tyXNByN85N/dRIT9es5UQNerPYEKK56eTBm8= +sigs.k8s.io/yaml v1.4.0 h1:Mk1wCc2gy/F0THH0TAp1QYyJNzRm2KCLy3o5ASXVI5E= +sigs.k8s.io/yaml v1.4.0/go.mod h1:Ejl7/uTz7PSA4eKMyQCUTnhZYNmLIl+5c2lQPGR2BPY= diff --git a/hack/boilerplate.txt b/hack/boilerplate.txt new file mode 100644 index 0000000..a2fceb0 --- /dev/null +++ b/hack/boilerplate.txt @@ -0,0 +1,3 @@ +/* +YEAR Copyright metal-stack Authors. +*/ diff --git a/hack/tools.go b/hack/tools.go new file mode 100644 index 0000000..7481f23 --- /dev/null +++ b/hack/tools.go @@ -0,0 +1,17 @@ +// +build tools + +// This package imports things required by build scripts, to force `go mod` to see them as dependencies +package tools + +import ( + _ "github.com/gardener/gardener/.github" + _ "github.com/gardener/gardener/.github/ISSUE_TEMPLATE" + _ "github.com/gardener/gardener/hack" + _ "github.com/gardener/gardener/hack/.ci" + _ "github.com/gardener/gardener/hack/api-reference/template" + + _ "github.com/ahmetb/gen-crd-api-reference-docs" + _ "github.com/golang/mock/mockgen" + _ "github.com/onsi/ginkgo/ginkgo" + _ "k8s.io/code-generator" +) diff --git a/hack/update-codegen.sh b/hack/update-codegen.sh new file mode 100755 index 0000000..5faede8 --- /dev/null +++ b/hack/update-codegen.sh @@ -0,0 +1,54 @@ +#!/bin/bash + +set -o errexit +set -o nounset +set -o pipefail + +# setup virtual GOPATH +source "$GARDENER_HACK_DIR"/vgopath-setup.sh + +CODE_GEN_DIR=$(go list -m -f '{{.Dir}}' k8s.io/code-generator) + +# We need to explicitly pass GO111MODULE=off to k8s.io/code-generator as it is significantly slower otherwise, +# see https://github.com/kubernetes/code-generator/issues/100. +export GO111MODULE=off + +rm -f $GOPATH/bin/*-gen + +PROJECT_ROOT=$(dirname $0)/.. + +git config --global --add safe.directory /go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm + +bash "${CODE_GEN_DIR}/generate-internal-groups.sh" \ + deepcopy,defaulter \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/client \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ + "csidriverlvm:v1alpha1" \ + --go-header-file "${PROJECT_ROOT}/hack/boilerplate.txt" + +bash "${CODE_GEN_DIR}/generate-internal-groups.sh" \ + conversion \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/client \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ + "csi-driver-lvm:v1alpha1" \ + --extra-peer-dirs=github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csi-driver-lvm,github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csi-driver-lvm/v1alpha1,k8s.io/apimachinery/pkg/apis/meta/v1,k8s.io/apimachinery/pkg/conversion,k8s.io/apimachinery/pkg/runtime \ + --go-header-file "${PROJECT_ROOT}/hack/boilerplate.txt" + +bash "${CODE_GEN_DIR}/generate-internal-groups.sh" \ + deepcopy,defaulter \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/client/componentconfig \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ + "config:v1alpha1" \ + --go-header-file "${PROJECT_ROOT}/hack/boilerplate.txt" + +bash "${CODE_GEN_DIR}/generate-internal-groups.sh" \ + conversion \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/client/componentconfig \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ + github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ + "config:v1alpha1" \ + --extra-peer-dirs=github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config,github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config/v1alpha1,k8s.io/apimachinery/pkg/apis/meta/v1,k8s.io/apimachinery/pkg/conversion,k8s.io/apimachinery/pkg/runtime \ + --go-header-file "${PROJECT_ROOT}/hack/boilerplate.txt" diff --git a/hack/update-github-templates.sh b/hack/update-github-templates.sh new file mode 100755 index 0000000..9321e78 --- /dev/null +++ b/hack/update-github-templates.sh @@ -0,0 +1,3 @@ +#!/bin/bash + +# we do not need to execute anything here... diff --git a/pkg/apis/config/doc.go b/pkg/apis/config/doc.go new file mode 100644 index 0000000..e2f53ad --- /dev/null +++ b/pkg/apis/config/doc.go @@ -0,0 +1,4 @@ +// +k8s:deepcopy-gen=package +// +groupName="csi-driver-lvm.metal.extensions.config.gardener.cloud" + +package config // import "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config" diff --git a/pkg/apis/config/register.go b/pkg/apis/config/register.go new file mode 100644 index 0000000..46f8b2c --- /dev/null +++ b/pkg/apis/config/register.go @@ -0,0 +1,37 @@ +package config + +import ( + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/runtime/schema" +) + +// GroupName is the group name use in this package +const GroupName = "csi-driver-lvm.metal.extensions.config.gardener.cloud" + +// SchemeGroupVersion is group version used to register these objects +var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: runtime.APIVersionInternal} + +// Kind takes an unqualified kind and returns a Group qualified GroupKind +func Kind(kind string) schema.GroupKind { + return SchemeGroupVersion.WithKind(kind).GroupKind() +} + +// Resource takes an unqualified resource and returns a Group qualified GroupResource +func Resource(resource string) schema.GroupResource { + return SchemeGroupVersion.WithResource(resource).GroupResource() +} + +var ( + // SchemeBuilder used to register the Shoot resource. + SchemeBuilder = runtime.NewSchemeBuilder(addKnownTypes) + // AddToScheme is a pointer to SchemeBuilder.AddToScheme. + AddToScheme = SchemeBuilder.AddToScheme +) + +// Adds the list of known types to api.Scheme. +func addKnownTypes(scheme *runtime.Scheme) error { + scheme.AddKnownTypes(SchemeGroupVersion, + &ControllerConfiguration{}, + ) + return nil +} diff --git a/pkg/apis/config/types.go b/pkg/apis/config/types.go new file mode 100644 index 0000000..9d452d5 --- /dev/null +++ b/pkg/apis/config/types.go @@ -0,0 +1,20 @@ +package config + +import ( + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + + healthcheckconfig "github.com/gardener/gardener/extensions/pkg/apis/config" +) + +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object + +// ControllerConfiguration defines the configuration for the csi-driver-lvm controller. +type ControllerConfiguration struct { + metav1.TypeMeta + + DevicePattern *string + HostWritePath *string + + // HealthCheckConfig is the config for the health check controller + HealthCheckConfig *healthcheckconfig.HealthCheckConfig +} diff --git a/pkg/apis/config/v1alpha1/defaults.go b/pkg/apis/config/v1alpha1/defaults.go new file mode 100644 index 0000000..6b9575c --- /dev/null +++ b/pkg/apis/config/v1alpha1/defaults.go @@ -0,0 +1,9 @@ +package v1alpha1 + +import ( + "k8s.io/apimachinery/pkg/runtime" +) + +func addDefaultingFuncs(scheme *runtime.Scheme) error { + return RegisterDefaults(scheme) +} diff --git a/pkg/apis/config/v1alpha1/doc.go b/pkg/apis/config/v1alpha1/doc.go new file mode 100644 index 0000000..b63adc3 --- /dev/null +++ b/pkg/apis/config/v1alpha1/doc.go @@ -0,0 +1,6 @@ +// +k8s:deepcopy-gen=package +// +k8s:conversion-gen=github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config +// +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta + +package v1alpha1 // import "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config/v1alpha1" diff --git a/pkg/apis/config/v1alpha1/register.go b/pkg/apis/config/v1alpha1/register.go new file mode 100644 index 0000000..80f0069 --- /dev/null +++ b/pkg/apis/config/v1alpha1/register.go @@ -0,0 +1,40 @@ +package v1alpha1 + +import ( + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/runtime/schema" +) + +// GroupName is the group name use in this package +const GroupName = "csi-driver-lvm.metal.extensions.config.gardener.cloud" + +// SchemeGroupVersion is group version used to register these objects +var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1alpha1"} + +// Resource takes an unqualified resource and returns a Group qualified GroupResource +func Resource(resource string) schema.GroupResource { + return SchemeGroupVersion.WithResource(resource).GroupResource() +} + +var ( + // SchemeBuilder used to register the Shoot resource. + SchemeBuilder runtime.SchemeBuilder + localSchemeBuilder = &SchemeBuilder + // AddToScheme is a pointer to SchemeBuilder.AddToScheme. + AddToScheme = localSchemeBuilder.AddToScheme +) + +func init() { + // We only register manually written functions here. The registration of the + // generated functions takes place in the generated files. The separation + // makes the code compile even when the generated files are missing. + localSchemeBuilder.Register(addDefaultingFuncs, addKnownTypes) +} + +// Adds the list of known types to api.Scheme. +func addKnownTypes(scheme *runtime.Scheme) error { + scheme.AddKnownTypes(SchemeGroupVersion, + &ControllerConfiguration{}, + ) + return nil +} diff --git a/pkg/apis/config/v1alpha1/types.go b/pkg/apis/config/v1alpha1/types.go new file mode 100644 index 0000000..cfa0f06 --- /dev/null +++ b/pkg/apis/config/v1alpha1/types.go @@ -0,0 +1,20 @@ +package v1alpha1 + +import ( + healthcheckconfigv1alpha1 "github.com/gardener/gardener/extensions/pkg/apis/config/v1alpha1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" +) + +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object + +// ControllerConfiguration configuration resource +type ControllerConfiguration struct { + metav1.TypeMeta `json:",inline"` + + DevicePattern *string `json:"devicePattern,omitempty"` + HostWritePath *string `json:"hostWritePath,omitempty"` + + // HealthCheckConfig is the config for the health check controller + // +optional + HealthCheckConfig *healthcheckconfigv1alpha1.HealthCheckConfig `json:"healthCheckConfig,omitempty"` +} diff --git a/pkg/apis/config/v1alpha1/zz_generated.conversion.go b/pkg/apis/config/v1alpha1/zz_generated.conversion.go new file mode 100644 index 0000000..b7695ce --- /dev/null +++ b/pkg/apis/config/v1alpha1/zz_generated.conversion.go @@ -0,0 +1,64 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +/* +2024 Copyright metal-stack Authors. +*/ + +// Code generated by conversion-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + unsafe "unsafe" + + apisconfig "github.com/gardener/gardener/extensions/pkg/apis/config" + configv1alpha1 "github.com/gardener/gardener/extensions/pkg/apis/config/v1alpha1" + config "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config" + conversion "k8s.io/apimachinery/pkg/conversion" + runtime "k8s.io/apimachinery/pkg/runtime" +) + +func init() { + localSchemeBuilder.Register(RegisterConversions) +} + +// RegisterConversions adds conversion functions to the given scheme. +// Public to allow building arbitrary schemes. +func RegisterConversions(s *runtime.Scheme) error { + if err := s.AddGeneratedConversionFunc((*ControllerConfiguration)(nil), (*config.ControllerConfiguration)(nil), func(a, b interface{}, scope conversion.Scope) error { + return Convert_v1alpha1_ControllerConfiguration_To_config_ControllerConfiguration(a.(*ControllerConfiguration), b.(*config.ControllerConfiguration), scope) + }); err != nil { + return err + } + if err := s.AddGeneratedConversionFunc((*config.ControllerConfiguration)(nil), (*ControllerConfiguration)(nil), func(a, b interface{}, scope conversion.Scope) error { + return Convert_config_ControllerConfiguration_To_v1alpha1_ControllerConfiguration(a.(*config.ControllerConfiguration), b.(*ControllerConfiguration), scope) + }); err != nil { + return err + } + return nil +} + +func autoConvert_v1alpha1_ControllerConfiguration_To_config_ControllerConfiguration(in *ControllerConfiguration, out *config.ControllerConfiguration, s conversion.Scope) error { + out.DevicePattern = (*string)(unsafe.Pointer(in.DevicePattern)) + out.HostWritePath = (*string)(unsafe.Pointer(in.HostWritePath)) + out.HealthCheckConfig = (*apisconfig.HealthCheckConfig)(unsafe.Pointer(in.HealthCheckConfig)) + return nil +} + +// Convert_v1alpha1_ControllerConfiguration_To_config_ControllerConfiguration is an autogenerated conversion function. +func Convert_v1alpha1_ControllerConfiguration_To_config_ControllerConfiguration(in *ControllerConfiguration, out *config.ControllerConfiguration, s conversion.Scope) error { + return autoConvert_v1alpha1_ControllerConfiguration_To_config_ControllerConfiguration(in, out, s) +} + +func autoConvert_config_ControllerConfiguration_To_v1alpha1_ControllerConfiguration(in *config.ControllerConfiguration, out *ControllerConfiguration, s conversion.Scope) error { + out.DevicePattern = (*string)(unsafe.Pointer(in.DevicePattern)) + out.HostWritePath = (*string)(unsafe.Pointer(in.HostWritePath)) + out.HealthCheckConfig = (*configv1alpha1.HealthCheckConfig)(unsafe.Pointer(in.HealthCheckConfig)) + return nil +} + +// Convert_config_ControllerConfiguration_To_v1alpha1_ControllerConfiguration is an autogenerated conversion function. +func Convert_config_ControllerConfiguration_To_v1alpha1_ControllerConfiguration(in *config.ControllerConfiguration, out *ControllerConfiguration, s conversion.Scope) error { + return autoConvert_config_ControllerConfiguration_To_v1alpha1_ControllerConfiguration(in, out, s) +} diff --git a/pkg/apis/config/v1alpha1/zz_generated.deepcopy.go b/pkg/apis/config/v1alpha1/zz_generated.deepcopy.go new file mode 100644 index 0000000..f9950ef --- /dev/null +++ b/pkg/apis/config/v1alpha1/zz_generated.deepcopy.go @@ -0,0 +1,55 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +/* +2024 Copyright metal-stack Authors. +*/ + +// Code generated by deepcopy-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + configv1alpha1 "github.com/gardener/gardener/extensions/pkg/apis/config/v1alpha1" + runtime "k8s.io/apimachinery/pkg/runtime" +) + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *ControllerConfiguration) DeepCopyInto(out *ControllerConfiguration) { + *out = *in + out.TypeMeta = in.TypeMeta + if in.DevicePattern != nil { + in, out := &in.DevicePattern, &out.DevicePattern + *out = new(string) + **out = **in + } + if in.HostWritePath != nil { + in, out := &in.HostWritePath, &out.HostWritePath + *out = new(string) + **out = **in + } + if in.HealthCheckConfig != nil { + in, out := &in.HealthCheckConfig, &out.HealthCheckConfig + *out = new(configv1alpha1.HealthCheckConfig) + (*in).DeepCopyInto(*out) + } + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ControllerConfiguration. +func (in *ControllerConfiguration) DeepCopy() *ControllerConfiguration { + if in == nil { + return nil + } + out := new(ControllerConfiguration) + in.DeepCopyInto(out) + return out +} + +// DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. +func (in *ControllerConfiguration) DeepCopyObject() runtime.Object { + if c := in.DeepCopy(); c != nil { + return c + } + return nil +} diff --git a/pkg/apis/config/v1alpha1/zz_generated.defaults.go b/pkg/apis/config/v1alpha1/zz_generated.defaults.go new file mode 100644 index 0000000..a8174d2 --- /dev/null +++ b/pkg/apis/config/v1alpha1/zz_generated.defaults.go @@ -0,0 +1,21 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +/* +2024 Copyright metal-stack Authors. +*/ + +// Code generated by defaulter-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + runtime "k8s.io/apimachinery/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + return nil +} diff --git a/pkg/apis/config/zz_generated.deepcopy.go b/pkg/apis/config/zz_generated.deepcopy.go new file mode 100644 index 0000000..e12c56e --- /dev/null +++ b/pkg/apis/config/zz_generated.deepcopy.go @@ -0,0 +1,55 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +/* +2024 Copyright metal-stack Authors. +*/ + +// Code generated by deepcopy-gen. DO NOT EDIT. + +package config + +import ( + apisconfig "github.com/gardener/gardener/extensions/pkg/apis/config" + runtime "k8s.io/apimachinery/pkg/runtime" +) + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *ControllerConfiguration) DeepCopyInto(out *ControllerConfiguration) { + *out = *in + out.TypeMeta = in.TypeMeta + if in.DevicePattern != nil { + in, out := &in.DevicePattern, &out.DevicePattern + *out = new(string) + **out = **in + } + if in.HostWritePath != nil { + in, out := &in.HostWritePath, &out.HostWritePath + *out = new(string) + **out = **in + } + if in.HealthCheckConfig != nil { + in, out := &in.HealthCheckConfig, &out.HealthCheckConfig + *out = new(apisconfig.HealthCheckConfig) + (*in).DeepCopyInto(*out) + } + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ControllerConfiguration. +func (in *ControllerConfiguration) DeepCopy() *ControllerConfiguration { + if in == nil { + return nil + } + out := new(ControllerConfiguration) + in.DeepCopyInto(out) + return out +} + +// DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. +func (in *ControllerConfiguration) DeepCopyObject() runtime.Object { + if c := in.DeepCopy(); c != nil { + return c + } + return nil +} diff --git a/pkg/apis/csidriverlvm/doc.go b/pkg/apis/csidriverlvm/doc.go new file mode 100644 index 0000000..6c0af16 --- /dev/null +++ b/pkg/apis/csidriverlvm/doc.go @@ -0,0 +1,6 @@ +// +k8s:deepcopy-gen=package +// +groupName="csi-driver-lvm.metal.extensions.gardener.cloud" + +//go:generate ../../../hack/update-codegen.sh + +package csidriverlvm // import "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm" diff --git a/pkg/apis/csidriverlvm/install/install.go b/pkg/apis/csidriverlvm/install/install.go new file mode 100644 index 0000000..f448ec1 --- /dev/null +++ b/pkg/apis/csidriverlvm/install/install.go @@ -0,0 +1,29 @@ +package install + +import ( + csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" + + "k8s.io/apimachinery/pkg/runtime" + utilruntime "k8s.io/apimachinery/pkg/util/runtime" +) + +var ( + schemeBuilder = runtime.NewSchemeBuilder( + v1alpha1.AddToScheme, + csidriverlvm.AddToScheme, + setVersionPriority, + ) + + // AddToScheme adds all APIs to the scheme. + AddToScheme = schemeBuilder.AddToScheme +) + +func setVersionPriority(scheme *runtime.Scheme) error { + return scheme.SetVersionPriority(v1alpha1.SchemeGroupVersion) +} + +// Install installs all APIs in the scheme. +func Install(scheme *runtime.Scheme) { + utilruntime.Must(AddToScheme(scheme)) +} diff --git a/pkg/apis/csidriverlvm/register.go b/pkg/apis/csidriverlvm/register.go new file mode 100644 index 0000000..88d79c6 --- /dev/null +++ b/pkg/apis/csidriverlvm/register.go @@ -0,0 +1,37 @@ +package csidriverlvm + +import ( + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/runtime/schema" +) + +// GroupName is the group name use in this package +const GroupName = "csi-driver-lvm.metal.extensions.gardener.cloud" + +// SchemeGroupVersion is group version used to register these objects +var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: runtime.APIVersionInternal} + +// Kind takes an unqualified kind and returns a Group qualified GroupKind +func Kind(kind string) schema.GroupKind { + return SchemeGroupVersion.WithKind(kind).GroupKind() +} + +// Resource takes an unqualified resource and returns a Group qualified GroupResource +func Resource(resource string) schema.GroupResource { + return SchemeGroupVersion.WithResource(resource).GroupResource() +} + +var ( + // SchemeBuilder used to register the Shoot resource. + SchemeBuilder = runtime.NewSchemeBuilder(addKnownTypes) + // AddToScheme is a pointer to SchemeBuilder.AddToScheme. + AddToScheme = SchemeBuilder.AddToScheme +) + +// Adds the list of known types to api.Scheme. +func addKnownTypes(scheme *runtime.Scheme) error { + scheme.AddKnownTypes(SchemeGroupVersion, + &CsiDriverLvmConfig{}, + ) + return nil +} diff --git a/pkg/apis/csidriverlvm/types.go b/pkg/apis/csidriverlvm/types.go new file mode 100644 index 0000000..3d0650e --- /dev/null +++ b/pkg/apis/csidriverlvm/types.go @@ -0,0 +1,12 @@ +package csidriverlvm + +import ( + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" +) + +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object + +// CsiDriverLvmConfig configuration resource +type CsiDriverLvmConfig struct { + metav1.TypeMeta +} diff --git a/pkg/apis/csidriverlvm/v1alpha1/doc.go b/pkg/apis/csidriverlvm/v1alpha1/doc.go new file mode 100644 index 0000000..0b96759 --- /dev/null +++ b/pkg/apis/csidriverlvm/v1alpha1/doc.go @@ -0,0 +1,6 @@ +// +k8s:deepcopy-gen=package +// +k8s:conversion-gen=github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csi-driver-lvm +// +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta + +package v1alpha1 // import "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csi-driver-lvm/v1alpha1" diff --git a/pkg/apis/csidriverlvm/v1alpha1/register.go b/pkg/apis/csidriverlvm/v1alpha1/register.go new file mode 100644 index 0000000..8c88407 --- /dev/null +++ b/pkg/apis/csidriverlvm/v1alpha1/register.go @@ -0,0 +1,37 @@ +package v1alpha1 + +import ( + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/runtime/schema" +) + +// GroupName is the group name use in this package +const GroupName = "csi-driver-lvm.metal.extensions.gardener.cloud" + +// SchemeGroupVersion is group version used to register these objects +var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1alpha1"} + +// Kind takes an unqualified kind and returns a Group qualified GroupKind +func Kind(kind string) schema.GroupKind { + return SchemeGroupVersion.WithKind(kind).GroupKind() +} + +// Resource takes an unqualified resource and returns a Group qualified GroupResource +func Resource(resource string) schema.GroupResource { + return SchemeGroupVersion.WithResource(resource).GroupResource() +} + +var ( + // SchemeBuilder used to register the Shoot resource. + SchemeBuilder = runtime.NewSchemeBuilder(addKnownTypes) + // AddToScheme is a pointer to SchemeBuilder.AddToScheme. + AddToScheme = SchemeBuilder.AddToScheme +) + +// Adds the list of known types to api.Scheme. +func addKnownTypes(scheme *runtime.Scheme) error { + scheme.AddKnownTypes(SchemeGroupVersion, + &CsiDriverLvmConfig{}, + ) + return nil +} diff --git a/pkg/apis/csidriverlvm/v1alpha1/types.go b/pkg/apis/csidriverlvm/v1alpha1/types.go new file mode 100644 index 0000000..31aae83 --- /dev/null +++ b/pkg/apis/csidriverlvm/v1alpha1/types.go @@ -0,0 +1,16 @@ +package v1alpha1 + +import ( + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" +) + +const ( + SeedCsiDriverLvmResourceName = "extension-csi-driver-lvm" +) + +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object + +// ControllerConfiguration configuration resource +type CsiDriverLvmConfig struct { + metav1.TypeMeta `json:",inline"` +} diff --git a/pkg/apis/csidriverlvm/v1alpha1/zz_generated.deepcopy.go b/pkg/apis/csidriverlvm/v1alpha1/zz_generated.deepcopy.go new file mode 100644 index 0000000..90d024c --- /dev/null +++ b/pkg/apis/csidriverlvm/v1alpha1/zz_generated.deepcopy.go @@ -0,0 +1,39 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +/* +2024 Copyright metal-stack Authors. +*/ + +// Code generated by deepcopy-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + runtime "k8s.io/apimachinery/pkg/runtime" +) + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *CsiDriverLvmConfig) DeepCopyInto(out *CsiDriverLvmConfig) { + *out = *in + out.TypeMeta = in.TypeMeta + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CsiDriverLvmConfig. +func (in *CsiDriverLvmConfig) DeepCopy() *CsiDriverLvmConfig { + if in == nil { + return nil + } + out := new(CsiDriverLvmConfig) + in.DeepCopyInto(out) + return out +} + +// DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. +func (in *CsiDriverLvmConfig) DeepCopyObject() runtime.Object { + if c := in.DeepCopy(); c != nil { + return c + } + return nil +} diff --git a/pkg/apis/csidriverlvm/v1alpha1/zz_generated.defaults.go b/pkg/apis/csidriverlvm/v1alpha1/zz_generated.defaults.go new file mode 100644 index 0000000..a8174d2 --- /dev/null +++ b/pkg/apis/csidriverlvm/v1alpha1/zz_generated.defaults.go @@ -0,0 +1,21 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +/* +2024 Copyright metal-stack Authors. +*/ + +// Code generated by defaulter-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + runtime "k8s.io/apimachinery/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + return nil +} diff --git a/pkg/apis/csidriverlvm/zz_generated.deepcopy.go b/pkg/apis/csidriverlvm/zz_generated.deepcopy.go new file mode 100644 index 0000000..9e11620 --- /dev/null +++ b/pkg/apis/csidriverlvm/zz_generated.deepcopy.go @@ -0,0 +1,39 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +/* +2024 Copyright metal-stack Authors. +*/ + +// Code generated by deepcopy-gen. DO NOT EDIT. + +package csidriverlvm + +import ( + runtime "k8s.io/apimachinery/pkg/runtime" +) + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *CsiDriverLvmConfig) DeepCopyInto(out *CsiDriverLvmConfig) { + *out = *in + out.TypeMeta = in.TypeMeta + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CsiDriverLvmConfig. +func (in *CsiDriverLvmConfig) DeepCopy() *CsiDriverLvmConfig { + if in == nil { + return nil + } + out := new(CsiDriverLvmConfig) + in.DeepCopyInto(out) + return out +} + +// DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. +func (in *CsiDriverLvmConfig) DeepCopyObject() runtime.Object { + if c := in.DeepCopy(); c != nil { + return c + } + return nil +} diff --git a/pkg/cmd/config.go b/pkg/cmd/config.go new file mode 100644 index 0000000..53d9bd1 --- /dev/null +++ b/pkg/cmd/config.go @@ -0,0 +1,88 @@ +package cmd + +import ( + "errors" + "os" + + healthcheckconfig "github.com/gardener/gardener/extensions/pkg/apis/config" + configapi "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config/v1alpha1" + + "github.com/spf13/pflag" + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/runtime/serializer" + utilruntime "k8s.io/apimachinery/pkg/util/runtime" +) + +var ( + scheme *runtime.Scheme + decoder runtime.Decoder +) + +func init() { + scheme = runtime.NewScheme() + utilruntime.Must(configapi.AddToScheme(scheme)) + utilruntime.Must(v1alpha1.AddToScheme(scheme)) + + decoder = serializer.NewCodecFactory(scheme).UniversalDecoder() +} + +// RegistryOptions holds options related to the registry service. +type AuthOptions struct { + ConfigLocation string + config *AuthServiceConfig +} + +// AddFlags implements Flagger.AddFlags. +func (o *AuthOptions) AddFlags(fs *pflag.FlagSet) { + fs.StringVar(&o.ConfigLocation, "config", "", "Path to registry service configuration") +} + +// Complete implements Completer.Complete. +func (o *AuthOptions) Complete() error { + if o.ConfigLocation == "" { + return errors.New("config location is not set") + } + data, err := os.ReadFile(o.ConfigLocation) + if err != nil { + return err + } + + config := configapi.ControllerConfiguration{} + _, _, err = decoder.Decode(data, nil, &config) + if err != nil { + return err + } + + // if errs := validation.ValidateConfiguration(&config); len(errs) > 0 { + // return errs.ToAggregate() + // } + + o.config = &AuthServiceConfig{ + config: config, + } + + return nil +} + +// Completed returns the decoded RegistryServiceConfiguration instance. Only call this if `Complete` was successful. +func (o *AuthOptions) Completed() *AuthServiceConfig { + return o.config +} + +// RegistryServiceConfig contains configuration information about the registry service. +type AuthServiceConfig struct { + config configapi.ControllerConfiguration +} + +// Apply applies the RegistryOptions to the passed ControllerOptions instance. +func (c *AuthServiceConfig) Apply(config *configapi.ControllerConfiguration) { + *config = c.config +} + +// ApplyHealthCheckConfig applies the HealthCheckConfig. +func (c *AuthServiceConfig) ApplyHealthCheckConfig(config *healthcheckconfig.HealthCheckConfig) { + if c.config.HealthCheckConfig != nil { + *config = *c.config.HealthCheckConfig + } +} diff --git a/pkg/cmd/options.go b/pkg/cmd/options.go new file mode 100644 index 0000000..e2c1867 --- /dev/null +++ b/pkg/cmd/options.go @@ -0,0 +1,28 @@ +package cmd + +import ( + controllercmd "github.com/gardener/gardener/extensions/pkg/controller/cmd" + extensionshealthcheckcontroller "github.com/gardener/gardener/extensions/pkg/controller/healthcheck" + extensionsheartbeatcontroller "github.com/gardener/gardener/extensions/pkg/controller/heartbeat" + webhookcmd "github.com/gardener/gardener/extensions/pkg/webhook/cmd" + + csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/healthcheck" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/kapiserver" +) + +// ControllerSwitchOptions are the controllercmd.SwitchOptions for the provider controllers. +func ControllerSwitchOptions() *controllercmd.SwitchOptions { + return controllercmd.NewSwitchOptions( + controllercmd.Switch(csidriverlvm.ControllerName, csidriverlvm.AddToManager), + controllercmd.Switch(extensionshealthcheckcontroller.ControllerName, healthcheck.AddToManager), + controllercmd.Switch(extensionsheartbeatcontroller.ControllerName, extensionsheartbeatcontroller.AddToManager), + ) +} + +// WebhookSwitchOptions are the webhookcmd.SwitchOptions for the provider webhooks. +func WebhookSwitchOptions() *webhookcmd.SwitchOptions { + return webhookcmd.NewSwitchOptions( + webhookcmd.Switch("csi-driver-lvm-webhook", kapiserver.New), + ) +} diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go new file mode 100644 index 0000000..f21c4a9 --- /dev/null +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -0,0 +1,726 @@ +package csidriverlvm + +import ( + "context" + "fmt" + "time" + + "github.com/gardener/gardener/extensions/pkg/controller/extension" + "github.com/gardener/gardener/imagevector" + + extensionsv1alpha1 "github.com/gardener/gardener/pkg/apis/extensions/v1alpha1" + "github.com/gardener/gardener/pkg/client/kubernetes" + "github.com/gardener/gardener/pkg/utils/managedresources" + "github.com/go-logr/logr" + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/runtime/serializer" + "k8s.io/apimachinery/pkg/util/intstr" + "sigs.k8s.io/controller-runtime/pkg/client" + "sigs.k8s.io/controller-runtime/pkg/manager" + + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" + "github.com/metal-stack/metal-lib/pkg/pointer" + + appsv1 "k8s.io/api/apps/v1" + corev1 "k8s.io/api/core/v1" + rbacv1 "k8s.io/api/rbac/v1" + storagev1 "k8s.io/api/storage/v1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" +) + +const ( + namespace string = "kube-system" +) + +// NewActuator returns an actuator responsible for Extension resources. +func NewActuator(mgr manager.Manager, config config.ControllerConfiguration) extension.Actuator { + return &actuator{ + client: mgr.GetClient(), + decoder: serializer.NewCodecFactory(mgr.GetScheme(), serializer.EnableStrict).UniversalDecoder(), + config: config, + } +} + +type actuator struct { + client client.Client + decoder runtime.Decoder + config config.ControllerConfiguration +} + +// Reconcile the Extension resource. +func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { + csidriverlvmConfig := &v1alpha1.CsiDriverLvmConfig{} + if ex.Spec.ProviderConfig != nil { + _, _, err := a.decoder.Decode(ex.Spec.ProviderConfig.Raw, nil, csidriverlvmConfig) + if err != nil { + return fmt.Errorf("failed to decode provider config: %w", err) + } + } + + controllerObjects, err := a.controllerObjects(namespace) + if err != nil { + return err + } + + pluginObjects, err := a.pluginObjects(namespace) + if err != nil { + return err + } + + objects := []client.Object{} + objects = append(objects, controllerObjects...) + objects = append(objects, pluginObjects...) + + seedResources, err := managedresources.NewRegistry(kubernetes.SeedScheme, kubernetes.SeedCodec, kubernetes.SeedSerializer).AddAllAndSerialize(objects...) + if err != nil { + return err + } + + err = managedresources.CreateForSeed(ctx, a.client, namespace, v1alpha1.SeedCsiDriverLvmResourceName, false, seedResources) + + if err != nil { + return nil + } + + log.Info("managed resource created succesfully", "name", v1alpha1.SeedCsiDriverLvmResourceName) + + return nil +} + +// Delete the Extension resource. +func (a *actuator) Delete(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { + + err := managedresources.Delete(ctx, a.client, namespace, v1alpha1.SeedCsiDriverLvmResourceName, false) + + if err != nil { + return err + } + + timeoutCtx, cancel := context.WithTimeout(ctx, 2*time.Minute) + defer cancel() + + err = managedresources.WaitUntilDeleted(timeoutCtx, a.client, namespace, v1alpha1.SeedCsiDriverLvmResourceName) + if err != nil { + return err + } + + return nil +} + +// ForceDelete the Extension resource +func (a *actuator) ForceDelete(_ context.Context, _ logr.Logger, _ *extensionsv1alpha1.Extension) error { + return nil +} + +// Restore the Extension resource. +func (a *actuator) Restore(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { + return a.Reconcile(ctx, log, ex) +} + +// Migrate the Extension resource. +func (a *actuator) Migrate(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { + return nil +} + +func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) { + + csidriverlvmServiceAccountController := &corev1.ServiceAccount{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-controller", + Namespace: namespace, + }, + } + + csidriverlvmClusterRoleController := &rbacv1.ClusterRole{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-controller", + Namespace: namespace, + }, + Rules: []rbacv1.PolicyRule{ + { + APIGroups: []string{""}, + Resources: []string{"persistentvolumes"}, + Verbs: []string{"get", "list", "watch", "update", "patch", "create", "delete"}, + }, + { + APIGroups: []string{"storage.k8s.io"}, + Resources: []string{"csinodes"}, + Verbs: []string{"get", "list", "watch"}, + }, + { + APIGroups: []string{"storage.k8s.io"}, + Resources: []string{"volumeattachments"}, + Verbs: []string{"get", "list", "watch", "update", "patch"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"persistentvolumeclaims"}, + Verbs: []string{"get", "list", "watch", "update", "patch"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"persistentvolumeclaims/status"}, + Verbs: []string{"update", "patch"}, + }, + { + APIGroups: []string{"storage.k8s.io"}, + Resources: []string{"storageclaess"}, + Verbs: []string{"get", "list", "watch"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"events"}, + Verbs: []string{"get", "list", "watch", "update", "patch", "create", "delete"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"nodes"}, + Verbs: []string{"get", "list", "watch"}, + }, + { + APIGroups: []string{"storage.k8s.io"}, + Resources: []string{"volumeattachments/status"}, + Verbs: []string{"patch"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"pods"}, + Verbs: []string{"get", "list", "watch"}, + }, + }, + } + + csidriverlvmClusterRoleBindingController := &rbacv1.ClusterRoleBinding{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-controller", + Namespace: namespace, + }, + Subjects: []rbacv1.Subject{ + { + Kind: "ServiceAccount", + Name: "csi-driver-lvm-controller", + Namespace: namespace, + }, + }, + RoleRef: rbacv1.RoleRef{ + APIGroup: "rbac.authorization.k8s.io", + Kind: "ClusterRole", + Name: "csi-driver-lvm-controller", + }, + } + + csiAttacherImage, err := imagevector.ImageVector().FindImage("csi-attacher") + if err != nil { + return nil, fmt.Errorf("failed to find csi-attacher image: %w", err) + } + + csiResizerImage, err := imagevector.ImageVector().FindImage("csi-resizer") + if err != nil { + return nil, fmt.Errorf("failed to find csi-resizer image: %w", err) + } + + var hostPathType corev1.HostPathType = corev1.HostPathDirectoryOrCreate + var replicas = int32(1) + + csidriverlvmStatefulsetController := &appsv1.StatefulSet{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-controller", + Namespace: namespace, + Annotations: map[string]string{}, + Labels: map[string]string{}, + }, + Spec: appsv1.StatefulSetSpec{ + Replicas: &replicas, + ServiceName: "csi-driver-lvm-controller", + Selector: &metav1.LabelSelector{ + MatchLabels: map[string]string{ + "app": "csi-driver-lvm-controller", + }, + }, + Template: corev1.PodTemplateSpec{ + ObjectMeta: metav1.ObjectMeta{ + Labels: map[string]string{ + "app": "csi-driver-lvm", + }, + Annotations: map[string]string{}, + }, + Spec: corev1.PodSpec{ + Affinity: &corev1.Affinity{ + PodAntiAffinity: &corev1.PodAntiAffinity{ + RequiredDuringSchedulingIgnoredDuringExecution: []corev1.PodAffinityTerm{ + { + LabelSelector: &metav1.LabelSelector{ + MatchExpressions: []metav1.LabelSelectorRequirement{ + { + Key: "app", + Operator: "In", + Values: []string{"csi-driver-lvm-controller"}, + }, + }, + }, + TopologyKey: "kubernetes.io/hostname", + }, + }, + }, + }, + NodeSelector: map[string]string{}, + Tolerations: []corev1.Toleration{}, + ServiceAccountName: "csi-driver-lvm-controller", + Containers: []corev1.Container{ + { + Name: "csi-attacher", + Image: csiAttacherImage.String(), + ImagePullPolicy: "IfNotPresent", + Args: []string{"--v=5", "--csi-address=/csi/csi.sock", "--feature-gates=Topology=true"}, + SecurityContext: &corev1.SecurityContext{ + ReadOnlyRootFilesystem: pointer.Pointer(true), + Privileged: pointer.Pointer(true), + }, + VolumeMounts: []corev1.VolumeMount{ + {MountPath: "/csi", Name: "socket-dir"}, + }, + }, + { + Name: "csi-resizer", + Image: csiResizerImage.String(), + ImagePullPolicy: "IfNotPresent", + Args: []string{"--v=5", "--csi-address=/csi/csi.sock"}, + SecurityContext: &corev1.SecurityContext{ + ReadOnlyRootFilesystem: pointer.Pointer(true), + Privileged: pointer.Pointer(true), + }, + VolumeMounts: []corev1.VolumeMount{ + {MountPath: "/csi", Name: "socket-dir"}, + }, + }, + }, + Volumes: []corev1.Volume{ + { + Name: "socket-dir", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/var/lib/kubelet/plugins/csi-driver-lvm", + Type: &hostPathType, + }, + }, + }, + }, + }, + }, + }, + } + + objects := []client.Object{ + csidriverlvmServiceAccountController, + csidriverlvmClusterRoleController, + csidriverlvmClusterRoleBindingController, + csidriverlvmStatefulsetController, + } + + return objects, nil +} + +func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { + + csidriverlvmDriver := &storagev1.CSIDriver{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm", + Namespace: namespace, + }, + Spec: storagev1.CSIDriverSpec{ + VolumeLifecycleModes: []storagev1.VolumeLifecycleMode{"Persistent", "Ephemeral"}, + PodInfoOnMount: pointer.Pointer(true), + AttachRequired: pointer.Pointer(false), + }, + } + + csidriverlvmServiceAccountPlugin := &corev1.ServiceAccount{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-plugin", + Namespace: namespace, + }, + } + + csidriverlvmClusterRolePlugin := &rbacv1.ClusterRole{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-plugin", + Namespace: namespace, + }, + Rules: []rbacv1.PolicyRule{ + { + APIGroups: []string{""}, + Resources: []string{"persistentvolumes"}, + Verbs: []string{"get", "list", "watch", "update", "patch", "create", "delete"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"persistentvolumeclaims"}, + Verbs: []string{"get", "list", "watch"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"persistentvolumeclaims/status"}, + Verbs: []string{"update", "patch"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"events"}, + Verbs: []string{"list", "watch", "update", "patch", "create"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"nodes"}, + Verbs: []string{"get", "list", "watch"}, + }, + { + APIGroups: []string{""}, + Resources: []string{"pods"}, + Verbs: []string{"get", "list", "watch", "create", "delete"}, + }, + }, + } + + csidriverlvmClusterRoleBindingPlugin := &rbacv1.ClusterRoleBinding{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-plugin", + Namespace: namespace, + }, + Subjects: []rbacv1.Subject{ + { + Kind: "ServiceAccount", + Name: "csi-driver-lvm-plugin", + Namespace: namespace, + }, + }, + RoleRef: rbacv1.RoleRef{ + APIGroup: "rbac.authorization.k8s.io", + Kind: "ClusterRole", + Name: "csi-driver-lvm-plugin", + }, + } + + var reclaimPolicy corev1.PersistentVolumeReclaimPolicy = corev1.PersistentVolumeReclaimDelete + var volumeBindingMode storagev1.VolumeBindingMode = storagev1.VolumeBindingWaitForFirstConsumer + + csidriverlvmLinearStorageClass := &storagev1.StorageClass{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-linear", + }, + Provisioner: "lvm.csi.metal-stack.io", + ReclaimPolicy: &reclaimPolicy, + VolumeBindingMode: &volumeBindingMode, + AllowVolumeExpansion: pointer.Pointer(true), + Parameters: map[string]string{ + "type": "linear", + }, + } + + csidriverlvmMirrorStorageClass := &storagev1.StorageClass{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-mirror", + }, + Provisioner: "lvm.csi.metal-stack.io", + ReclaimPolicy: &reclaimPolicy, + VolumeBindingMode: &volumeBindingMode, + AllowVolumeExpansion: pointer.Pointer(true), + Parameters: map[string]string{ + "type": "mirror", + }, + } + + csidriverlvmStripedStorageClass := &storagev1.StorageClass{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-striped", + }, + Provisioner: "lvm.csi.metal-stack.io", + ReclaimPolicy: &reclaimPolicy, + VolumeBindingMode: &volumeBindingMode, + AllowVolumeExpansion: pointer.Pointer(true), + Parameters: map[string]string{ + "type": "striped", + }, + } + + csidriverlvmDefaultStorageClass := &storagev1.StorageClass{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-lvm", + }, + Provisioner: "lvm.csi.metal-stack.io", + ReclaimPolicy: &reclaimPolicy, + VolumeBindingMode: &volumeBindingMode, + AllowVolumeExpansion: pointer.Pointer(true), + Parameters: map[string]string{ + "type": "linear", + }, + } + + csiNodeDriverRegistrarImage, err := imagevector.ImageVector().FindImage("csi-node-driver-registrar") + if err != nil { + return nil, fmt.Errorf("failed to find csi-node-driver-registrar image: %w", err) + } + + livenessprobeImage, err := imagevector.ImageVector().FindImage("livenessprobe") + if err != nil { + return nil, fmt.Errorf("failed to find livenessprobe image: %w", err) + } + + csiDriverLvmImage, err := imagevector.ImageVector().FindImage("csi-driver-lvm") + if err != nil { + return nil, fmt.Errorf("failed to find csi-driver-lvm image: %w", err) + } + + csiDriverLvmProvisionerImage, err := imagevector.ImageVector().FindImage("csi-driver-lvm-provisioner") + if err != nil { + return nil, fmt.Errorf("failed to find csi-driver-lvm-provisioner image: %w", err) + } + + var terminationPolicy corev1.TerminationMessagePolicy = corev1.TerminationMessageReadFile + var mountPropagation corev1.MountPropagationMode = corev1.MountPropagationBidirectional + + var hostPathTypeCreate corev1.HostPathType = corev1.HostPathDirectoryOrCreate + var hostPathTypeDir corev1.HostPathType = corev1.HostPathDirectory + var revisionHistoryLimit = int32(10) + var healthPort = int32(9898) + + csidriverlvmDaemonSetPlugin := &appsv1.DaemonSet{ + ObjectMeta: metav1.ObjectMeta{ + Name: "csi-driver-lvm-plugin", + Namespace: namespace, + }, + Spec: appsv1.DaemonSetSpec{ + RevisionHistoryLimit: &revisionHistoryLimit, + Selector: &metav1.LabelSelector{ + MatchLabels: map[string]string{ + "app": "csi-driver-lvm-plugin", + }, + }, + Template: corev1.PodTemplateSpec{ + ObjectMeta: metav1.ObjectMeta{ + Labels: map[string]string{ + "app": "csi-driver-lvm-plugin", + }, + }, Spec: corev1.PodSpec{ + ServiceAccountName: "csi-driver-lvm-plugin", + Tolerations: []corev1.Toleration{}, + NodeSelector: map[string]string{}, + Containers: []corev1.Container{ + { + Name: "node-driver-registrar", + Image: csiNodeDriverRegistrarImage.String(), + ImagePullPolicy: "IfNotPresent", + Args: []string{"--v=5", "--csi-address=/csi/csi.sock", "--kubelet-registration-path=/var/lib/kubelet/plugins/csi-driver-lvm/csi.sock"}, + SecurityContext: &corev1.SecurityContext{ + ReadOnlyRootFilesystem: pointer.Pointer(true), + // Privileged: pointer.Pointer(true), + }, + Env: []corev1.EnvVar{ + { + Name: "KUBE_NODE_NAME", + ValueFrom: &corev1.EnvVarSource{ + FieldRef: &corev1.ObjectFieldSelector{ + APIVersion: "v1", + FieldPath: "spec.nodeName", + }, + }, + }, + }, + TerminationMessagePath: "/dev/termination-log", + TerminationMessagePolicy: terminationPolicy, + VolumeMounts: []corev1.VolumeMount{ + {MountPath: "/csi", Name: "socket-dir"}, + {MountPath: "/var/lib/kubelet/plugins/csi-driver-lvm/csi.sock", Name: "socket-dir"}, + {MountPath: "/registration", Name: "registration-dir"}, + }, + }, + { + Name: "csi-driver-lvm-plugin", + Image: csiDriverLvmImage.String(), + ImagePullPolicy: "IfNotPresent", + Args: []string{ + "--drivername=lvm.csi.metal-stack.io", + "--endpoint=unix:///csi/csi.sock", + "--hostwritepath=" + *a.config.HostWritePath, + "--devices=" + *a.config.DevicePattern, + "--nodeid=$(KUBE_NODE_NAME)", + "--vgname=csi-lvm", + "--namespace=kube-system", + "--provisionerImage=" + csiDriverLvmProvisionerImage.String(), + "--pullpolicy=IfNotPresent", + }, + SecurityContext: &corev1.SecurityContext{ + ReadOnlyRootFilesystem: pointer.Pointer(true), + Privileged: pointer.Pointer(true), + }, + Env: []corev1.EnvVar{ + { + Name: "KUBE_NODE_NAME", + ValueFrom: &corev1.EnvVarSource{ + FieldRef: &corev1.ObjectFieldSelector{ + APIVersion: "v1", + FieldPath: "spec.nodeName", + }, + }, + }, + }, + LivenessProbe: &corev1.Probe{ + FailureThreshold: 5, + InitialDelaySeconds: 10, + PeriodSeconds: 2, + SuccessThreshold: 1, + TimeoutSeconds: 3, + ProbeHandler: corev1.ProbeHandler{ + HTTPGet: &corev1.HTTPGetAction{ + Path: "/healthz", + Port: intstr.FromInt32(healthPort), + Scheme: corev1.URISchemeHTTP, + }, + }, + }, + Ports: []corev1.ContainerPort{{ + Name: "healthz", + Protocol: corev1.ProtocolTCP, + ContainerPort: 9898, + }}, + TerminationMessagePath: "/dev/termination-log", + TerminationMessagePolicy: terminationPolicy, + VolumeMounts: []corev1.VolumeMount{ + {MountPath: "/csi", Name: "socket-dir"}, + {MountPath: "/var/lib/kubelet/pods", Name: "mountpoint-dir", MountPropagation: &mountPropagation}, + {MountPath: "/var/lib/kubelet/plugins", Name: "plugins-dir", MountPropagation: &mountPropagation}, + {MountPath: "/dev", Name: "dev-dir", MountPropagation: &mountPropagation}, + {MountPath: "/lib/modules", Name: "mod-dir"}, + {MountPath: "/etc/lvm/backup", Name: "lvmbackup", MountPropagation: &mountPropagation}, + {MountPath: "/etc/lvm/cache", Name: "lvmcache", MountPropagation: &mountPropagation}, + {MountPath: "/etc/lvm/archive", Name: "lvmarchive", MountPropagation: &mountPropagation}, + {MountPath: "/etc/lvm/lock", Name: "lvmlock", MountPropagation: &mountPropagation}, + }, + }, + { + Name: "livenessprobe", + Image: livenessprobeImage.String(), + ImagePullPolicy: "IfNotPresent", + Args: []string{ + "--csi-address=/csi/csi.sock", + "--health-port=9898", + }, + SecurityContext: &corev1.SecurityContext{ + ReadOnlyRootFilesystem: pointer.Pointer(true), + }, + TerminationMessagePath: "/dev/termination-log", + TerminationMessagePolicy: terminationPolicy, + VolumeMounts: []corev1.VolumeMount{ + {MountPath: "/csi", Name: "socket-dir"}, + }, + }, + }, + Volumes: []corev1.Volume{ + { + Name: "socket-dir", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/var/lib/kubelet/plugins/csi-driver-lvm", + Type: &hostPathTypeCreate, + }, + }, + }, + { + Name: "mountpoint-dir", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/var/lib/kubelet/pods", + Type: &hostPathTypeCreate, + }, + }, + }, + { + Name: "registration-dir", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/var/lib/kubelet/plugins_registry", + Type: &hostPathTypeDir, + }, + }, + }, + { + Name: "plugins-dir", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/var/lib/kubelet/plugins", + Type: &hostPathTypeDir, + }, + }, + }, + { + Name: "dev-dir", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/dev", + Type: &hostPathTypeDir, + }, + }, + }, + { + Name: "mod-dir", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/lib/modules", + }, + }, + }, + { + Name: "lvmcache", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: *a.config.HostWritePath + "/cache", + Type: &hostPathTypeCreate, + }, + }, + }, + { + Name: "lvmarchive", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: *a.config.HostWritePath + "/archive", + Type: &hostPathTypeCreate, + }, + }, + }, + { + Name: "lvmbackup", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: *a.config.HostWritePath + "/backup", + Type: &hostPathTypeCreate, + }, + }, + }, + { + Name: "lvmlock", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: *a.config.HostWritePath + "/lock", + Type: &hostPathTypeCreate, + }, + }, + }, + }, + }, + }, + }, + } + + objects := []client.Object{ + csidriverlvmDriver, + csidriverlvmServiceAccountPlugin, + csidriverlvmClusterRolePlugin, + csidriverlvmClusterRoleBindingPlugin, + csidriverlvmDefaultStorageClass, + csidriverlvmLinearStorageClass, + csidriverlvmMirrorStorageClass, + csidriverlvmStripedStorageClass, + csidriverlvmDaemonSetPlugin, + } + + return objects, nil +} diff --git a/pkg/controller/csi-driver-lvm/add.go b/pkg/controller/csi-driver-lvm/add.go new file mode 100644 index 0000000..bc35aab --- /dev/null +++ b/pkg/controller/csi-driver-lvm/add.go @@ -0,0 +1,54 @@ +package csidriverlvm + +import ( + "context" + + "github.com/gardener/gardener/extensions/pkg/controller/extension" + "sigs.k8s.io/controller-runtime/pkg/controller" + "sigs.k8s.io/controller-runtime/pkg/manager" + + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config" +) + +const ( + // Type is the type of Extension resource. + Type = "csi-driver-lvm" + // ControllerName is the name of the registry cache service controller. + ControllerName = "csi-driver-lvm" + // FinalizerSuffix is the finalizer suffix for the registry cache service controller. + FinalizerSuffix = "csi-driver-lvm" +) + +var ( + // DefaultAddOptions are the default AddOptions for AddToManager. + DefaultAddOptions = AddOptions{} +) + +// AddOptions are options to apply when adding the registry cache service controller to the manager. +type AddOptions struct { + // ControllerOptions contains options for the controller. + ControllerOptions controller.Options + // Config contains configuration for the registry cache service. + Config config.ControllerConfiguration + // IgnoreOperationAnnotation specifies whether to ignore the operation annotation or not. + IgnoreOperationAnnotation bool +} + +// AddToManager adds a controller with the default Options to the given Controller Manager. +func AddToManager(ctx context.Context, mgr manager.Manager) error { + return AddToManagerWithOptions(ctx, mgr, DefaultAddOptions) +} + +// AddToManagerWithOptions adds a controller with the given Options to the given manager. +// The opts.Reconciler is being set with a newly instantiated actuator. +func AddToManagerWithOptions(ctx context.Context, mgr manager.Manager, opts AddOptions) error { + return extension.Add(ctx, mgr, extension.AddArgs{ + Actuator: NewActuator(mgr, opts.Config), + ControllerOptions: opts.ControllerOptions, + Name: ControllerName, + FinalizerSuffix: FinalizerSuffix, + Resync: 0, + Predicates: extension.DefaultPredicates(ctx, mgr, DefaultAddOptions.IgnoreOperationAnnotation), + Type: Type, + }) +} diff --git a/pkg/controller/healthcheck/registration.go b/pkg/controller/healthcheck/registration.go new file mode 100644 index 0000000..c54a7e0 --- /dev/null +++ b/pkg/controller/healthcheck/registration.go @@ -0,0 +1,53 @@ +package healthcheck + +import ( + "context" + "time" + + extensionsconfig "github.com/gardener/gardener/extensions/pkg/apis/config" + "github.com/gardener/gardener/extensions/pkg/controller/healthcheck" + "github.com/gardener/gardener/extensions/pkg/controller/healthcheck/general" + gardencorev1beta1 "github.com/gardener/gardener/pkg/apis/core/v1beta1" + extensionsv1alpha1 "github.com/gardener/gardener/pkg/apis/extensions/v1alpha1" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" + csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/util/sets" + "sigs.k8s.io/controller-runtime/pkg/client" + "sigs.k8s.io/controller-runtime/pkg/manager" +) + +var ( + defaultSyncPeriod = 60 * time.Second + // DefaultAddOptions contains configuration for the health check controller. + DefaultAddOptions = healthcheck.DefaultAddArgs{ + HealthCheckConfig: extensionsconfig.HealthCheckConfig{SyncPeriod: metav1.Duration{Duration: defaultSyncPeriod}}, + } +) + +// RegisterHealthChecks registers health checks for each extension resource +// HealthChecks are grouped by extension (e.g worker), extension.type (e.g aws) and Health Check Type (e.g SystemComponentsHealthy) +func RegisterHealthChecks(ctx context.Context, mgr manager.Manager, opts healthcheck.DefaultAddArgs) error { + return healthcheck.DefaultRegistration( + ctx, + csidriverlvm.Type, + extensionsv1alpha1.SchemeGroupVersion.WithKind(extensionsv1alpha1.ExtensionResource), + func() client.ObjectList { return &extensionsv1alpha1.ExtensionList{} }, + func() extensionsv1alpha1.Object { return &extensionsv1alpha1.Extension{} }, + mgr, + opts, + nil, + []healthcheck.ConditionTypeToHealthCheck{ + { + ConditionType: string(gardencorev1beta1.ShootSystemComponentsHealthy), + HealthCheck: general.CheckManagedResource(v1alpha1.SeedCsiDriverLvmResourceName), + }, + }, + sets.Set[gardencorev1beta1.ConditionType]{}, + ) +} + +// AddToManager adds a controller with the default Options. +func AddToManager(ctx context.Context, mgr manager.Manager) error { + return RegisterHealthChecks(ctx, mgr, DefaultAddOptions) +} diff --git a/pkg/imagevector/imagevector.go b/pkg/imagevector/imagevector.go new file mode 100644 index 0000000..65b5bf1 --- /dev/null +++ b/pkg/imagevector/imagevector.go @@ -0,0 +1,25 @@ +package imagevector + +import ( + "github.com/gardener/gardener/pkg/utils/imagevector" + "k8s.io/apimachinery/pkg/util/runtime" + + "github.com/metal-stack/gardener-extension-csi-driver-lvm/charts" +) + +var imageVector imagevector.ImageVector + +func init() { + var err error + + imageVector, err = imagevector.Read([]byte(charts.ImagesYAML)) + runtime.Must(err) + + imageVector, err = imagevector.WithEnvOverride(imageVector) + runtime.Must(err) +} + +// ImageVector is the image vector that contains all the needed images. +func ImageVector() imagevector.ImageVector { + return imageVector +} diff --git a/pkg/kapiserver/ensurer.go b/pkg/kapiserver/ensurer.go new file mode 100644 index 0000000..5cb7dc4 --- /dev/null +++ b/pkg/kapiserver/ensurer.go @@ -0,0 +1,110 @@ +package kapiserver + +import ( + "context" + "fmt" + + extensionswebhook "github.com/gardener/gardener/extensions/pkg/webhook" + gcontext "github.com/gardener/gardener/extensions/pkg/webhook/context" + extensionsv1alpha1 "github.com/gardener/gardener/pkg/apis/extensions/v1alpha1" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" + csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" + + "github.com/gardener/gardener/extensions/pkg/webhook/controlplane/genericmutator" + "github.com/go-logr/logr" + + "sigs.k8s.io/controller-runtime/pkg/client" + "sigs.k8s.io/controller-runtime/pkg/manager" + + appsv1 "k8s.io/api/apps/v1" + corev1 "k8s.io/api/core/v1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/runtime/serializer" +) + +// NewEnsurer creates a new controlplane ensurer. +func NewEnsurer(logger logr.Logger, mgr manager.Manager) genericmutator.Ensurer { + return &ensurer{ + client: mgr.GetClient(), + decoder: serializer.NewCodecFactory(mgr.GetScheme(), serializer.EnableStrict).UniversalDecoder(), + logger: logger.WithName("csi-driver-lvm-controlplane-ensurer"), + } +} + +type ensurer struct { + genericmutator.NoopEnsurer + client client.Client + decoder runtime.Decoder + logger logr.Logger +} + +// EnsureKubeAPIServerDeployment ensures that the kube-apiserver deployment conforms to the provider requirements. +func (e *ensurer) EnsureKubeAPIServerDeployment(ctx context.Context, gctx gcontext.GardenContext, new, _ *appsv1.Deployment) error { + cluster, err := gctx.GetCluster(ctx) + if err != nil { + return err + } + + if cluster.Shoot.DeletionTimestamp != nil && !cluster.Shoot.DeletionTimestamp.IsZero() { + e.logger.Info("skip mutating api server because shoot is in deletion") + return nil + } + + namespace := cluster.ObjectMeta.Name + + ex := &extensionsv1alpha1.Extension{ + ObjectMeta: metav1.ObjectMeta{ + Name: csidriverlvm.Type, + Namespace: namespace, + }, + } + err = e.client.Get(ctx, client.ObjectKeyFromObject(ex), ex) + if err != nil { + return fmt.Errorf("unable to find extension resource. this extension needs to be configured with lifecycle policy BeforeKubeAPIServer") + } + + csiDriverLvm := &v1alpha1.CsiDriverLvmConfig{} + if ex.Spec.ProviderConfig != nil { + if _, _, err := e.decoder.Decode(ex.Spec.ProviderConfig.Raw, nil, csiDriverLvm); err != nil { + return fmt.Errorf("failed to decode provider config: %w", err) + } + } + + template := &new.Spec.Template + ps := &template.Spec + if c := extensionswebhook.ContainerWithName(ps.Containers, "kube-apiserver"); c != nil { + e.logger.Info("ensuring kube-apiserver deployment") + ensureKubeAPIServerCommandLineArgs(c) + ensureVolumeMounts(c) + ensureVolumes(ps) + } + + // ? whats this? + // template.Labels["networking.resources.gardener.cloud/to-audit-webhook-backend-tcp-9880"] = "allowed" + + return nil +} + +func ensureVolumeMounts(c *corev1.Container) { + // c.VolumeMounts = extensionswebhook.EnsureVolumeMountWithName(c.VolumeMounts, corev1.VolumeMount{ + // Name: "audit-webhook-config", + // ReadOnly: true, + // MountPath: "/etc/audit-webhook/config", + // }) +} + +func ensureVolumes(ps *corev1.PodSpec) { + // ps.Volumes = extensionswebhook.EnsureVolumeWithName(ps.Volumes, corev1.Volume{ + // Name: "audit-webhook-config", + // VolumeSource: corev1.VolumeSource{ + // Secret: &corev1.SecretVolumeSource{ + // SecretName: "audit-webhook-config", + // }, + // }, + // }) +} + +func ensureKubeAPIServerCommandLineArgs(c *corev1.Container) { + // c.Command = extensionswebhook.EnsureStringWithPrefix(c.Command, "--audit-webhook-config-file=", "/etc/audit-webhook/config/audit-webhook-config.yaml") +} diff --git a/pkg/kapiserver/webhook.go b/pkg/kapiserver/webhook.go new file mode 100644 index 0000000..1015621 --- /dev/null +++ b/pkg/kapiserver/webhook.go @@ -0,0 +1,58 @@ +package kapiserver + +import ( + extensionswebhook "github.com/gardener/gardener/extensions/pkg/webhook" + "github.com/gardener/gardener/extensions/pkg/webhook/controlplane/genericmutator" + v1beta1constants "github.com/gardener/gardener/pkg/apis/core/v1beta1/constants" + "github.com/gardener/gardener/pkg/component/extensions/operatingsystemconfig/original/components/kubelet" + oscutils "github.com/gardener/gardener/pkg/component/extensions/operatingsystemconfig/utils" + appsv1 "k8s.io/api/apps/v1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "sigs.k8s.io/controller-runtime/pkg/log" + "sigs.k8s.io/controller-runtime/pkg/manager" + "sigs.k8s.io/controller-runtime/pkg/webhook/admission" +) + +var logger = log.Log.WithName("csi-driver-lvm-webhook") + +// New returns a new mutating webhook that ensures that the kube-apiserver deployment conforms to the csi-driver-lvm requirements. +func New(mgr manager.Manager) (*extensionswebhook.Webhook, error) { + logger.Info("Adding webhook to manager") + + fciCodec := oscutils.NewFileContentInlineCodec() + + mutator := genericmutator.NewMutator( + mgr, + NewEnsurer(logger, mgr), + oscutils.NewUnitSerializer(), + kubelet.NewConfigCodec(fciCodec), + fciCodec, + logger, + ) + types := []extensionswebhook.Type{ + {Obj: &appsv1.Deployment{}}, + } + + handler, err := extensionswebhook.NewBuilder(mgr, logger).WithMutator(mutator, types...).Build() + if err != nil { + return nil, err + } + + namespaceSelector := &metav1.LabelSelector{ + MatchExpressions: []metav1.LabelSelectorRequirement{ + {Key: v1beta1constants.LabelExtensionPrefix + "csi-driver-lvm", Operator: metav1.LabelSelectorOpIn, Values: []string{"true"}}, + }, + } + + webhook := &extensionswebhook.Webhook{ + Name: "kapiserver", + Provider: "", + Types: types, + Target: extensionswebhook.TargetSeed, + Path: "kapiserver", + Webhook: &admission.Webhook{Handler: handler}, + NamespaceSelector: namespaceSelector, + } + + return webhook, err +} From a2dcb9382dc83cf173a44205cb883c499db311ae Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 8 Nov 2024 13:19:02 +0100 Subject: [PATCH 02/32] fix startup --- .../templates/rbac.yaml | 1 + .../app/options.go | 18 ++++++++++++++++-- 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml index 5549ce8..eebd21a 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml @@ -84,6 +84,7 @@ rules: - leases verbs: - create + - update - list - watch - apiGroups: diff --git a/cmd/gardener-extension-csi-driver-lvm/app/options.go b/cmd/gardener-extension-csi-driver-lvm/app/options.go index 2385d3d..b378520 100644 --- a/cmd/gardener-extension-csi-driver-lvm/app/options.go +++ b/cmd/gardener-extension-csi-driver-lvm/app/options.go @@ -10,9 +10,11 @@ import ( corev1 "k8s.io/api/core/v1" extensionscontroller "github.com/gardener/gardener/extensions/pkg/controller" + heartbeatcontroller "github.com/gardener/gardener/extensions/pkg/controller/heartbeat" heartbeatcmd "github.com/gardener/gardener/extensions/pkg/controller/heartbeat/cmd" webhookcmd "github.com/gardener/gardener/extensions/pkg/webhook/cmd" csidriverlvmcmd "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/cmd" + controller "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" controllercmd "github.com/gardener/gardener/extensions/pkg/controller/cmd" "github.com/gardener/gardener/extensions/pkg/util" @@ -127,8 +129,6 @@ func (options *Options) run(ctx context.Context) error { }, } - //TODO check ALL options -> - mgr, err := manager.New(options.restOptions.Completed().Config, mgrOpts) if err != nil { return fmt.Errorf("could not instantiate controller-manager: %w", err) @@ -150,6 +150,20 @@ func (options *Options) run(ctx context.Context) error { log.Info("added mgr-schme to installation") + ctrlConfig := options.csidriverlvmOptions.Completed() + ctrlConfig.Apply(&controller.DefaultAddOptions.Config) + options.controllerOptions.Completed().Apply(&controller.DefaultAddOptions.ControllerOptions) + options.reconcileOptions.Completed().Apply(&controller.DefaultAddOptions.IgnoreOperationAnnotation) + options.heartbeatOptions.Completed().Apply(&heartbeatcontroller.DefaultAddOptions) + + if err := options.controllerSwitches.Completed().AddToManager(ctx, mgr); err != nil { + return fmt.Errorf("could not add controllers to manager: %w", err) + } + + if _, err := options.webhookOptions.Completed().AddToManager(ctx, mgr, nil); err != nil { + return fmt.Errorf("could not add the mutating webhook to manager: %w", err) + } + if err := mgr.AddReadyzCheck("informer-sync", ghealth.NewCacheSyncHealthz(mgr.GetCache())); err != nil { return fmt.Errorf("could not add ready check for informers: %w", err) } From 8b39be75e67f2fbf1e6c8a3f62ecd1d0a17fd6ea Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 8 Nov 2024 14:32:49 +0100 Subject: [PATCH 03/32] remove webhooks --- .../templates/deployment.yaml | 6 - .../templates/rbac.yaml | 11 -- .../templates/service.yaml | 24 ---- .../values.yaml | 4 - .../app/options.go | 23 +--- example/controller-registration.yaml | 2 +- go.mod | 3 - go.sum | 8 +- pkg/cmd/options.go | 9 -- pkg/kapiserver/ensurer.go | 110 ------------------ pkg/kapiserver/webhook.go | 58 --------- 11 files changed, 3 insertions(+), 255 deletions(-) delete mode 100644 charts/gardener-extension-csi-driver-lvm/templates/service.yaml delete mode 100644 pkg/kapiserver/ensurer.go delete mode 100644 pkg/kapiserver/webhook.go diff --git a/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml b/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml index 760077b..96b1e45 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml @@ -36,8 +36,6 @@ spec: - --max-concurrent-reconciles={{ .Values.controllers.concurrentSyncs }} - --healthcheck-max-concurrent-reconciles={{ .Values.controllers.healthcheck.concurrentSyncs }} - --ignore-operation-annotation={{ .Values.controllers.ignoreOperationAnnotation }} - - --webhook-config-namespace={{ .Release.Namespace }} - - --webhook-config-server-port={{ .Values.webhookConfig.serverPort }} - --disable-controllers={{ .Values.disableControllers | join "," }} {{- if .Values.metricsPort }} - --metrics-bind-address=:{{ .Values.metricsPort }} @@ -65,10 +63,6 @@ spec: - name: IMAGEVECTOR_OVERWRITE value: /charts_overwrite/images_overwrite.yaml {{- end }} - ports: - - name: webhook-server - containerPort: {{ .Values.webhookConfig.serverPort }} - protocol: TCP {{- if .Values.resources }} resources: {{ toYaml .Values.resources | nindent 10 }} diff --git a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml index eebd21a..c6d31e4 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml @@ -15,17 +15,6 @@ rules: - get - list - watch -- apiGroups: - - admissionregistration.k8s.io - resources: - - mutatingwebhookconfigurations - verbs: - - get - - list - - watch - - update - - create - - patch - apiGroups: - extensions.gardener.cloud resources: diff --git a/charts/gardener-extension-csi-driver-lvm/templates/service.yaml b/charts/gardener-extension-csi-driver-lvm/templates/service.yaml deleted file mode 100644 index 6d5f676..0000000 --- a/charts/gardener-extension-csi-driver-lvm/templates/service.yaml +++ /dev/null @@ -1,24 +0,0 @@ -apiVersion: v1 -kind: Service -metadata: - name: {{ include "name" . }} - namespace: {{ .Release.Namespace }} - annotations: - networking.resources.gardener.cloud/from-world-to-ports: '[{"protocol":"TCP","port":{{ .Values.webhookConfig.serverPort }}}]' - networking.resources.gardener.cloud/from-all-seed-scrape-targets-allowed-ports: '[{"port":{{ .Values.metricsPort }},"protocol":"TCP"}]' - networking.resources.gardener.cloud/from-all-webhook-targets-allowed-ports: '[{"protocol":"TCP","port":{{ .Values.webhookConfig.serverPort }}}]' - networking.resources.gardener.cloud/namespace-selectors: '[{"matchLabels":{"kubernetes.io/metadata.name":"garden"}},{"matchLabels":{"gardener.cloud/role":"shoot"}}]' - networking.resources.gardener.cloud/pod-label-selector-namespace-alias: extensions - # TODO: This label approach is deprecated and no longer needed in the future. Remove them as soon as gardener/gardener@v1.75 has been released. - networking.resources.gardener.cloud/from-policy-pod-label-selector: all-seed-scrape-targets - networking.resources.gardener.cloud/from-policy-allowed-ports: '[{"port":{{ .Values.metricsPort }},"protocol":"TCP"}]' - labels: -{{ include "labels" . | indent 4 }} -spec: - type: ClusterIP - selector: -{{ include "labels" . | indent 6 }} - ports: - - port: 443 - protocol: TCP - targetPort: {{ .Values.webhookConfig.serverPort }} diff --git a/charts/gardener-extension-csi-driver-lvm/values.yaml b/charts/gardener-extension-csi-driver-lvm/values.yaml index 72ce9d1..1d32b82 100644 --- a/charts/gardener-extension-csi-driver-lvm/values.yaml +++ b/charts/gardener-extension-csi-driver-lvm/values.yaml @@ -15,7 +15,6 @@ controllers: ignoreOperationAnnotation: false disableControllers: [] -disableWebhooks: [] # imageVectorOverwrite: | # images: @@ -31,9 +30,6 @@ disableWebhooks: [] # version: ">= 1.12" # ... -webhookConfig: - serverPort: 443 - config: clientConnection: acceptContentTypes: application/json diff --git a/cmd/gardener-extension-csi-driver-lvm/app/options.go b/cmd/gardener-extension-csi-driver-lvm/app/options.go index b378520..60f82c3 100644 --- a/cmd/gardener-extension-csi-driver-lvm/app/options.go +++ b/cmd/gardener-extension-csi-driver-lvm/app/options.go @@ -12,7 +12,6 @@ import ( extensionscontroller "github.com/gardener/gardener/extensions/pkg/controller" heartbeatcontroller "github.com/gardener/gardener/extensions/pkg/controller/heartbeat" heartbeatcmd "github.com/gardener/gardener/extensions/pkg/controller/heartbeat/cmd" - webhookcmd "github.com/gardener/gardener/extensions/pkg/webhook/cmd" csidriverlvmcmd "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/cmd" controller "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" @@ -37,27 +36,12 @@ type Options struct { controllerOptions *controllercmd.ControllerOptions heartbeatOptions *heartbeatcmd.Options healthOptions *controllercmd.ControllerOptions - webhookOptions *webhookcmd.AddToManagerOptions controllerSwitches *controllercmd.SwitchOptions reconcileOptions *controllercmd.ReconcilerOptions optionAggregator controllercmd.OptionAggregator } func NewOptions() *Options { - // options for the webhook server - webhookServerOptions := &webhookcmd.ServerOptions{ - Namespace: os.Getenv("WEBHOOK_CONFIG_NAMESPACE"), - } - - webhookSwitches := csidriverlvmcmd.WebhookSwitchOptions() - webhookOptions := webhookcmd.NewAddToManagerOptions( - "csi-driver-lvm", - "", - nil, - webhookServerOptions, - webhookSwitches, - ) - options := &Options{ generalOptions: &controllercmd.GeneralOptions{}, csidriverlvmOptions: &csidriverlvmcmd.AuthOptions{}, @@ -87,7 +71,6 @@ func NewOptions() *Options { }, controllerSwitches: csidriverlvmcmd.ControllerSwitchOptions(), reconcileOptions: &controllercmd.ReconcilerOptions{}, - webhookOptions: webhookOptions, } options.optionAggregator = controllercmd.NewOptionAggregator( @@ -100,7 +83,6 @@ func NewOptions() *Options { controllercmd.PrefixOption("healthcheck-", options.healthOptions), options.controllerSwitches, options.reconcileOptions, - options.webhookOptions, ) return options @@ -152,6 +134,7 @@ func (options *Options) run(ctx context.Context) error { ctrlConfig := options.csidriverlvmOptions.Completed() ctrlConfig.Apply(&controller.DefaultAddOptions.Config) + options.controllerOptions.Completed().Apply(&controller.DefaultAddOptions.ControllerOptions) options.reconcileOptions.Completed().Apply(&controller.DefaultAddOptions.IgnoreOperationAnnotation) options.heartbeatOptions.Completed().Apply(&heartbeatcontroller.DefaultAddOptions) @@ -160,10 +143,6 @@ func (options *Options) run(ctx context.Context) error { return fmt.Errorf("could not add controllers to manager: %w", err) } - if _, err := options.webhookOptions.Completed().AddToManager(ctx, mgr, nil); err != nil { - return fmt.Errorf("could not add the mutating webhook to manager: %w", err) - } - if err := mgr.AddReadyzCheck("informer-sync", ghealth.NewCacheSyncHealthz(mgr.GetCache())); err != nil { return fmt.Errorf("could not add ready check for informers: %w", err) } diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index abb544b..ff5b6b3 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: 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 + rawChart: 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 values: image: tag: v0.0.1 diff --git a/go.mod b/go.mod index 4aa941c..3fc89b0 100644 --- a/go.mod +++ b/go.mod @@ -24,9 +24,7 @@ require ( github.com/Masterminds/semver/v3 v3.3.0 // indirect github.com/Masterminds/sprig/v3 v3.2.3 // indirect github.com/beorn7/perks v1.0.1 // indirect - github.com/blang/semver/v4 v4.0.0 // indirect github.com/cespare/xxhash/v2 v2.3.0 // indirect - github.com/coreos/go-systemd/v22 v22.5.0 // indirect github.com/cyphar/filepath-securejoin v0.2.4 // indirect github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc // indirect github.com/emicklei/go-restful/v3 v3.12.1 // indirect @@ -69,7 +67,6 @@ require ( github.com/mattn/go-colorable v0.1.13 // indirect github.com/mattn/go-isatty v0.0.20 // indirect github.com/mitchellh/copystructure v1.2.0 // indirect - github.com/mitchellh/hashstructure/v2 v2.0.2 // indirect github.com/mitchellh/reflectwalk v1.0.2 // indirect github.com/moby/spdystream v0.4.0 // indirect github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect diff --git a/go.sum b/go.sum index 886b4d1..4544c62 100644 --- a/go.sum +++ b/go.sum @@ -627,6 +627,7 @@ github.com/armon/go-socks5 v0.0.0-20160902184237-e75332964ef5/go.mod h1:wHh0iHkY github.com/asaskevich/govalidator v0.0.0-20190424111038-f61b66f89f4a/go.mod h1:lB+ZfQJz7igIIfQNfa7Ml4HSf2uFQQRzpGGRXenZAgY= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= +github.com/blang/semver v3.5.1+incompatible h1:cQNTCjp13qL8KC3Nbxr/y2Bqb63oX6wdnnjpJbkM4JQ= github.com/blang/semver/v4 v4.0.0 h1:1PFHFE6yCCTv8C1TeyNNarDzntLi7wMI5i/pzqYIsAM= github.com/blang/semver/v4 v4.0.0/go.mod h1:IbckMUScFkM3pff0VJDNKRiT6TG/YpiHIM2yvyW5YoQ= github.com/boombuler/barcode v1.0.0/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8= @@ -656,8 +657,6 @@ github.com/cncf/xds/go v0.0.0-20211011173535-cb28da3451f1/go.mod h1:eXthEFrGJvWH github.com/cncf/xds/go v0.0.0-20220314180256-7f1daf1720fc/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= github.com/cncf/xds/go v0.0.0-20230105202645-06c439db220b/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= github.com/cncf/xds/go v0.0.0-20230310173818-32f1caf87195/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= -github.com/coreos/go-systemd/v22 v22.5.0 h1:RrqgGjYQKalulkV8NGVIfkXQf6YYmOyiJKk8iXXhfZs= -github.com/coreos/go-systemd/v22 v22.5.0/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= github.com/cpuguy83/go-md2man/v2 v2.0.4/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= github.com/cyphar/filepath-securejoin v0.2.4 h1:Ugdm7cg7i6ZK6x3xDF1oEu1nfkyfH53EtKeQYTC3kyg= @@ -759,7 +758,6 @@ github.com/gobuffalo/flect v1.0.2/go.mod h1:A5msMlrHtLqh9umBSnvabjsMrCcCpAyzglnD github.com/gobwas/glob v0.2.3 h1:A4xDbljILXROh+kObIiy5kIaPYD8e96x1tgBhUI5J+Y= github.com/gobwas/glob v0.2.3/go.mod h1:d3Ez4x06l9bZtSvzIay5+Yzi0fmZzPgnTbPcKjJAkT8= github.com/goccy/go-json v0.9.11/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= -github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= @@ -959,8 +957,6 @@ github.com/minio/c2goasm v0.0.0-20190812172519-36a3d3bbc4f3/go.mod h1:RagcQ7I8Ie github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw= github.com/mitchellh/copystructure v1.2.0 h1:vpKXTN4ewci03Vljg/q9QvCGUDttBOGBIa15WveJJGw= github.com/mitchellh/copystructure v1.2.0/go.mod h1:qLl+cE2AmVv+CoeAwDPye/v+N2HKCj9FbZEVFJRxO9s= -github.com/mitchellh/hashstructure/v2 v2.0.2 h1:vGKWl0YJqUNxE8d+h8f6NJLcCJrgbhC4NcD46KavDd4= -github.com/mitchellh/hashstructure/v2 v2.0.2/go.mod h1:MG3aRVU/N29oo/V/IhBX8GR/zz4kQkprJgF2EVszyDE= github.com/mitchellh/reflectwalk v1.0.0/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= github.com/mitchellh/reflectwalk v1.0.2 h1:G2LzWKi524PWgd3mLHV8Y5k7s6XUvT0Gef6zxSIeXaQ= github.com/mitchellh/reflectwalk v1.0.2/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= @@ -1904,8 +1900,6 @@ k8s.io/apiextensions-apiserver v0.29.5 h1:njDywexhE6n+1NEl3A4axT0TMQHREnndrk3/zt k8s.io/apiextensions-apiserver v0.29.5/go.mod h1:pfIvij+MH9a8NQKtW7MD4EFnzvUjJ1ZQsDL8wuP8fnc= k8s.io/apimachinery v0.29.5 h1:Hofa2BmPfpoT+IyDTlcPdCHSnHtEQMoJYGVoQpRTfv4= k8s.io/apimachinery v0.29.5/go.mod h1:i3FJVwhvSp/6n8Fl4K97PJEP8C+MM+aoDq4+ZJBf70Y= -k8s.io/apiserver v0.29.5 h1:223C+JkRnGmudEU00GfpX6quDSrzwwP0DuXOYTyUYb0= -k8s.io/apiserver v0.29.5/go.mod h1:zN9xdatz5g7XwL1Xoz9hD4QQON1GN0c+1kV5e/NHejM= k8s.io/autoscaler/vertical-pod-autoscaler v1.1.2 h1:ENxmnVXLt8+iXhDA0PNFhXb1sgvbvnAc66sC34UGrTw= k8s.io/autoscaler/vertical-pod-autoscaler v1.1.2/go.mod h1:J2cNKnieE7r4bInjpQDBq93D50aD/CmspSi6xRUfKk4= k8s.io/client-go v0.29.5 h1:nlASXmPQy190qTteaVP31g3c/wi2kycznkTP7Sv1zPc= diff --git a/pkg/cmd/options.go b/pkg/cmd/options.go index e2c1867..6219909 100644 --- a/pkg/cmd/options.go +++ b/pkg/cmd/options.go @@ -4,11 +4,9 @@ import ( controllercmd "github.com/gardener/gardener/extensions/pkg/controller/cmd" extensionshealthcheckcontroller "github.com/gardener/gardener/extensions/pkg/controller/healthcheck" extensionsheartbeatcontroller "github.com/gardener/gardener/extensions/pkg/controller/heartbeat" - webhookcmd "github.com/gardener/gardener/extensions/pkg/webhook/cmd" csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/healthcheck" - "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/kapiserver" ) // ControllerSwitchOptions are the controllercmd.SwitchOptions for the provider controllers. @@ -19,10 +17,3 @@ func ControllerSwitchOptions() *controllercmd.SwitchOptions { controllercmd.Switch(extensionsheartbeatcontroller.ControllerName, extensionsheartbeatcontroller.AddToManager), ) } - -// WebhookSwitchOptions are the webhookcmd.SwitchOptions for the provider webhooks. -func WebhookSwitchOptions() *webhookcmd.SwitchOptions { - return webhookcmd.NewSwitchOptions( - webhookcmd.Switch("csi-driver-lvm-webhook", kapiserver.New), - ) -} diff --git a/pkg/kapiserver/ensurer.go b/pkg/kapiserver/ensurer.go deleted file mode 100644 index 5cb7dc4..0000000 --- a/pkg/kapiserver/ensurer.go +++ /dev/null @@ -1,110 +0,0 @@ -package kapiserver - -import ( - "context" - "fmt" - - extensionswebhook "github.com/gardener/gardener/extensions/pkg/webhook" - gcontext "github.com/gardener/gardener/extensions/pkg/webhook/context" - extensionsv1alpha1 "github.com/gardener/gardener/pkg/apis/extensions/v1alpha1" - "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" - csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" - - "github.com/gardener/gardener/extensions/pkg/webhook/controlplane/genericmutator" - "github.com/go-logr/logr" - - "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/manager" - - appsv1 "k8s.io/api/apps/v1" - corev1 "k8s.io/api/core/v1" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "k8s.io/apimachinery/pkg/runtime" - "k8s.io/apimachinery/pkg/runtime/serializer" -) - -// NewEnsurer creates a new controlplane ensurer. -func NewEnsurer(logger logr.Logger, mgr manager.Manager) genericmutator.Ensurer { - return &ensurer{ - client: mgr.GetClient(), - decoder: serializer.NewCodecFactory(mgr.GetScheme(), serializer.EnableStrict).UniversalDecoder(), - logger: logger.WithName("csi-driver-lvm-controlplane-ensurer"), - } -} - -type ensurer struct { - genericmutator.NoopEnsurer - client client.Client - decoder runtime.Decoder - logger logr.Logger -} - -// EnsureKubeAPIServerDeployment ensures that the kube-apiserver deployment conforms to the provider requirements. -func (e *ensurer) EnsureKubeAPIServerDeployment(ctx context.Context, gctx gcontext.GardenContext, new, _ *appsv1.Deployment) error { - cluster, err := gctx.GetCluster(ctx) - if err != nil { - return err - } - - if cluster.Shoot.DeletionTimestamp != nil && !cluster.Shoot.DeletionTimestamp.IsZero() { - e.logger.Info("skip mutating api server because shoot is in deletion") - return nil - } - - namespace := cluster.ObjectMeta.Name - - ex := &extensionsv1alpha1.Extension{ - ObjectMeta: metav1.ObjectMeta{ - Name: csidriverlvm.Type, - Namespace: namespace, - }, - } - err = e.client.Get(ctx, client.ObjectKeyFromObject(ex), ex) - if err != nil { - return fmt.Errorf("unable to find extension resource. this extension needs to be configured with lifecycle policy BeforeKubeAPIServer") - } - - csiDriverLvm := &v1alpha1.CsiDriverLvmConfig{} - if ex.Spec.ProviderConfig != nil { - if _, _, err := e.decoder.Decode(ex.Spec.ProviderConfig.Raw, nil, csiDriverLvm); err != nil { - return fmt.Errorf("failed to decode provider config: %w", err) - } - } - - template := &new.Spec.Template - ps := &template.Spec - if c := extensionswebhook.ContainerWithName(ps.Containers, "kube-apiserver"); c != nil { - e.logger.Info("ensuring kube-apiserver deployment") - ensureKubeAPIServerCommandLineArgs(c) - ensureVolumeMounts(c) - ensureVolumes(ps) - } - - // ? whats this? - // template.Labels["networking.resources.gardener.cloud/to-audit-webhook-backend-tcp-9880"] = "allowed" - - return nil -} - -func ensureVolumeMounts(c *corev1.Container) { - // c.VolumeMounts = extensionswebhook.EnsureVolumeMountWithName(c.VolumeMounts, corev1.VolumeMount{ - // Name: "audit-webhook-config", - // ReadOnly: true, - // MountPath: "/etc/audit-webhook/config", - // }) -} - -func ensureVolumes(ps *corev1.PodSpec) { - // ps.Volumes = extensionswebhook.EnsureVolumeWithName(ps.Volumes, corev1.Volume{ - // Name: "audit-webhook-config", - // VolumeSource: corev1.VolumeSource{ - // Secret: &corev1.SecretVolumeSource{ - // SecretName: "audit-webhook-config", - // }, - // }, - // }) -} - -func ensureKubeAPIServerCommandLineArgs(c *corev1.Container) { - // c.Command = extensionswebhook.EnsureStringWithPrefix(c.Command, "--audit-webhook-config-file=", "/etc/audit-webhook/config/audit-webhook-config.yaml") -} diff --git a/pkg/kapiserver/webhook.go b/pkg/kapiserver/webhook.go deleted file mode 100644 index 1015621..0000000 --- a/pkg/kapiserver/webhook.go +++ /dev/null @@ -1,58 +0,0 @@ -package kapiserver - -import ( - extensionswebhook "github.com/gardener/gardener/extensions/pkg/webhook" - "github.com/gardener/gardener/extensions/pkg/webhook/controlplane/genericmutator" - v1beta1constants "github.com/gardener/gardener/pkg/apis/core/v1beta1/constants" - "github.com/gardener/gardener/pkg/component/extensions/operatingsystemconfig/original/components/kubelet" - oscutils "github.com/gardener/gardener/pkg/component/extensions/operatingsystemconfig/utils" - appsv1 "k8s.io/api/apps/v1" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "sigs.k8s.io/controller-runtime/pkg/log" - "sigs.k8s.io/controller-runtime/pkg/manager" - "sigs.k8s.io/controller-runtime/pkg/webhook/admission" -) - -var logger = log.Log.WithName("csi-driver-lvm-webhook") - -// New returns a new mutating webhook that ensures that the kube-apiserver deployment conforms to the csi-driver-lvm requirements. -func New(mgr manager.Manager) (*extensionswebhook.Webhook, error) { - logger.Info("Adding webhook to manager") - - fciCodec := oscutils.NewFileContentInlineCodec() - - mutator := genericmutator.NewMutator( - mgr, - NewEnsurer(logger, mgr), - oscutils.NewUnitSerializer(), - kubelet.NewConfigCodec(fciCodec), - fciCodec, - logger, - ) - types := []extensionswebhook.Type{ - {Obj: &appsv1.Deployment{}}, - } - - handler, err := extensionswebhook.NewBuilder(mgr, logger).WithMutator(mutator, types...).Build() - if err != nil { - return nil, err - } - - namespaceSelector := &metav1.LabelSelector{ - MatchExpressions: []metav1.LabelSelectorRequirement{ - {Key: v1beta1constants.LabelExtensionPrefix + "csi-driver-lvm", Operator: metav1.LabelSelectorOpIn, Values: []string{"true"}}, - }, - } - - webhook := &extensionswebhook.Webhook{ - Name: "kapiserver", - Provider: "", - Types: types, - Target: extensionswebhook.TargetSeed, - Path: "kapiserver", - Webhook: &admission.Webhook{Handler: handler}, - NamespaceSelector: namespaceSelector, - } - - return webhook, err -} From dd18f464e22aa99ccc2639694b46bbdd72cf62fd Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 8 Nov 2024 17:01:12 +0100 Subject: [PATCH 04/32] fix reconcile of resources --- charts/charts.go | 13 -- .../templates/configmap.yaml | 7 +- .../values.yaml | 3 + charts/images.yaml | 14 +- charts/internal/csi-driver-lvm/Chart.yaml | 5 - .../csi-driver-lvm/templates/daemonset.yaml | 174 ------------------ .../csi-driver-lvm/templates/driver.yaml | 10 - .../csi-driver-lvm/templates/helpers.tpl | 32 ---- .../csi-driver-lvm/templates/rbac.yaml | 89 --------- .../templates/serviceaccount.yaml | 12 -- .../csi-driver-lvm/templates/statefulset.yaml | 77 -------- .../templates/storageclasses.yaml | 66 ------- charts/internal/csi-driver-lvm/values.yaml | 85 --------- example/controller-registration.yaml | 2 +- pkg/apis/config/types.go | 4 +- pkg/apis/config/v1alpha1/types.go | 4 +- .../v1alpha1/zz_generated.conversion.go | 8 +- .../config/v1alpha1/zz_generated.deepcopy.go | 8 +- pkg/apis/config/zz_generated.deepcopy.go | 8 +- pkg/apis/csidriverlvm/types.go | 3 + pkg/apis/csidriverlvm/v1alpha1/types.go | 3 + .../v1alpha1/zz_generated.deepcopy.go | 10 + .../csidriverlvm/zz_generated.deepcopy.go | 10 + pkg/controller/csi-driver-lvm/actuator.go | 49 +++-- 24 files changed, 89 insertions(+), 607 deletions(-) delete mode 100644 charts/charts.go delete mode 100644 charts/internal/csi-driver-lvm/Chart.yaml delete mode 100644 charts/internal/csi-driver-lvm/templates/daemonset.yaml delete mode 100644 charts/internal/csi-driver-lvm/templates/driver.yaml delete mode 100644 charts/internal/csi-driver-lvm/templates/helpers.tpl delete mode 100644 charts/internal/csi-driver-lvm/templates/rbac.yaml delete mode 100644 charts/internal/csi-driver-lvm/templates/serviceaccount.yaml delete mode 100644 charts/internal/csi-driver-lvm/templates/statefulset.yaml delete mode 100644 charts/internal/csi-driver-lvm/templates/storageclasses.yaml delete mode 100644 charts/internal/csi-driver-lvm/values.yaml diff --git a/charts/charts.go b/charts/charts.go deleted file mode 100644 index 4c9b07e..0000000 --- a/charts/charts.go +++ /dev/null @@ -1,13 +0,0 @@ -package charts - -import ( - "embed" -) - -// InternalChart embeds the internal charts in embed.FS -// -//go:embed internal -var InternalChart embed.FS - -// InternalChartsPath is the path to the internal charts -const InternalChartsPath = "internal" diff --git a/charts/gardener-extension-csi-driver-lvm/templates/configmap.yaml b/charts/gardener-extension-csi-driver-lvm/templates/configmap.yaml index ff796a7..60a1423 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/configmap.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/configmap.yaml @@ -17,4 +17,9 @@ data: qps: {{ required ".Values.config.clientConnection.qps is required" .Values.config.clientConnection.qps }} burst: {{ required ".Values.config.clientConnection.burst is required" .Values.config.clientConnection.burst }} {{- end }} - +{{- if .Values.config.hostWritePath }} + defaultHostWritePath: {{ .Values.config.hostWritePath }} +{{- end }} +{{- if .Values.config.devicePattern }} + defaultDevicePattern: {{ .Values.config.devicePattern }} +{{- end }} \ No newline at end of file diff --git a/charts/gardener-extension-csi-driver-lvm/values.yaml b/charts/gardener-extension-csi-driver-lvm/values.yaml index 1d32b82..0bd90f7 100644 --- a/charts/gardener-extension-csi-driver-lvm/values.yaml +++ b/charts/gardener-extension-csi-driver-lvm/values.yaml @@ -37,5 +37,8 @@ config: qps: 100 burst: 130 + devicePattern: /dev/nvme[0-9]n[0-9] + defaultHostWritePath: /etc/lvm + gardener: version: "" diff --git a/charts/images.yaml b/charts/images.yaml index 13c0252..67523ef 100644 --- a/charts/images.yaml +++ b/charts/images.yaml @@ -1,29 +1,29 @@ images: - name: csi-driver-lvm sourceRepository: https://github.com/metal-stack/csi-driver-lvm - repository: ghcr.io/metal-stack/ + repository: ghcr.io/metal-stack/csi-driver-lvm tag: "v0.6.0" - name: csi-driver-lvm-provisioner sourceRepository: https://github.com/metal-stack/csi-driver-lvm - repository: ghcr.io/metal-stack/ + repository: ghcr.io/metal-stack/csi-driver-lvm-provisioner tag: "v0.6.0" - name: csi-attacher sourceRepository: https://github.com/kubernetes-csi/external-attacher - repository: k8s.gcr.io/sig-storage/ + repository: k8s.gcr.io/sig-storage/csi-attacher tag: "v3.5.0" - name: livenessprobe sourceRepository: https://github.com/kubernetes-csi/livenessprobe - repository: k8s.gcr.io/sig-storage/ + repository: k8s.gcr.io/sig-storage/livenessprobe tag: "v2.7.0" - name: csi-provisioner sourceRepository: https://github.com/kubernetes-csi/external-provisioner - repository: k8s.gcr.io/sig-storage/ + repository: k8s.gcr.io/sig-storage/csi-provisioner tag: "v3.2.1" - name: csi-node-driver-registrar sourceRepository: https://github.com/kubernetes-csi/node-driver-registrar - repository: k8s.gcr.io/sig-storage/ + repository: k8s.gcr.io/sig-storage/csi-node-driver-registrar tag: "v2.5.1" - name: csi-resizer sourceRepository: https://github.com/kubernetes-csi/external-resizer - repository: k8s.gcr.io/sig-storage/ + repository: k8s.gcr.io/sig-storage/csi-resizer tag: "v2.5.1" diff --git a/charts/internal/csi-driver-lvm/Chart.yaml b/charts/internal/csi-driver-lvm/Chart.yaml deleted file mode 100644 index 73a6e37..0000000 --- a/charts/internal/csi-driver-lvm/Chart.yaml +++ /dev/null @@ -1,5 +0,0 @@ -apiVersion: v1 -appVersion: "1.0" -description: A Helm chart for the csi-driver-lvm extension -name: gardener-extension-csi-driver-lvm -version: 0.2.0 diff --git a/charts/internal/csi-driver-lvm/templates/daemonset.yaml b/charts/internal/csi-driver-lvm/templates/daemonset.yaml deleted file mode 100644 index b8e67c3..0000000 --- a/charts/internal/csi-driver-lvm/templates/daemonset.yaml +++ /dev/null @@ -1,174 +0,0 @@ -apiVersion: apps/v1 -kind: DaemonSet -metadata: - name: csi-driver-lvm-plugin - namespace: {{ .Release.Namespace }} -spec: - revisionHistoryLimit: 10 - selector: - matchLabels: - app: csi-driver-lvm-plugin - template: - metadata: - labels: - app: csi-driver-lvm-plugin - spec: - serviceAccountName: csi-driver-lvm-plugin -{{- if .Values.tolerations.plugin }} - tolerations: -{{ toYaml .Values.tolerations.plugin | indent 8 }} -{{- end }} -{{- if .Values.nodeSelector.plugin }} - nodeSelector: -{{ toYaml .Values.nodeSelector.plugin | indent 8 }} -{{- end }} - containers: - - name: node-driver-registrar - args: - - --v=5 - - --csi-address=/csi/csi.sock - - --kubelet-registration-path={{ .Values.kubernetes.kubeletPath }}/plugins/csi-driver-lvm/csi.sock - env: - - name: KUBE_NODE_NAME - valueFrom: - fieldRef: - apiVersion: v1 - fieldPath: spec.nodeName - image: {{ .Values.sidecarImages.registrar }} - imagePullPolicy: IfNotPresent - resources: {} - securityContext: - readOnlyRootFilesystem: true - terminationMessagePath: /dev/termination-log - terminationMessagePolicy: File - volumeMounts: - - mountPath: /csi - name: socket-dir - - mountPath: {{ .Values.kubernetes.kubeletPath }}/plugins/csi-driver-lvm - name: socket-dir - - mountPath: /registration - name: registration-dir - - name: csi-driver-lvm-plugin - args: - - --drivername=lvm.csi.metal-stack.io - - --endpoint=unix:///csi/csi.sock - - --hostwritepath={{ .Values.lvm.hostWritePath }} - - --devices={{ .Values.lvm.devicePattern }} - - --nodeid=$(KUBE_NODE_NAME) - - --vgname={{ .Values.lvm.vgName }} - - --namespace={{ .Release.Namespace }} - - --provisionerimage={{ index .Values.images "csi-driver-lvm-provisioner" }} - - --pullpolicy=IfNotPresent - env: - - name: KUBE_NODE_NAME - valueFrom: - fieldRef: - apiVersion: v1 - fieldPath: spec.nodeName - image: {{ index .Values.images "csi-driver-lvm-plugin" }} - imagePullPolicy: IfNotPresent - livenessProbe: - failureThreshold: 5 - httpGet: - path: /healthz - port: healthz - scheme: HTTP - initialDelaySeconds: 10 - periodSeconds: 2 - successThreshold: 1 - timeoutSeconds: 3 - ports: - - containerPort: 9898 - name: healthz - protocol: TCP - resources: {} - securityContext: - readOnlyRootFilesystem: true - privileged: true - terminationMessagePath: /termination.log - terminationMessagePolicy: File - volumeMounts: - - mountPath: /csi - name: socket-dir - - mountPath: {{ .Values.kubernetes.kubeletPath }}/pods - mountPropagation: Bidirectional - name: mountpoint-dir - - mountPath: {{ .Values.kubernetes.kubeletPath }}/plugins - mountPropagation: Bidirectional - name: plugins-dir - - mountPath: /dev - name: dev-dir - mountPropagation: Bidirectional - - mountPath: /lib/modules - name: mod-dir - - mountPath: /etc/lvm/backup - name: lvmbackup - mountPropagation: Bidirectional - - mountPath: /etc/lvm/cache - name: lvmcache - mountPropagation: Bidirectional - - mountPath: /etc/lvm/archive - name: lvmarchive - mountPropagation: Bidirectional - - mountPath: /run/lock/lvm - name: lvmlock - mountPropagation: Bidirectional - - name: liveness-probe - args: - - --csi-address=/csi/csi.sock - - --health-port=9898 - image: {{ .Values.sidecarImages.livenessprobe }} - imagePullPolicy: IfNotPresent - resources: {} - securityContext: - readOnlyRootFilesystem: true - terminationMessagePath: /dev/termination-log - terminationMessagePolicy: File - volumeMounts: - - mountPath: /csi - name: socket-dir - dnsPolicy: ClusterFirst - restartPolicy: Always - schedulerName: default-scheduler - securityContext: {} - terminationGracePeriodSeconds: 30 - volumes: - - hostPath: - path: {{ .Values.kubernetes.kubeletPath }}/plugins/csi-driver-lvm - type: DirectoryOrCreate - name: socket-dir - - hostPath: - path: {{ .Values.kubernetes.kubeletPath }}/pods - type: DirectoryOrCreate - name: mountpoint-dir - - hostPath: - path: {{ .Values.kubernetes.kubeletPath }}/plugins_registry - type: Directory - name: registration-dir - - hostPath: - path: {{ .Values.kubernetes.kubeletPath }}/plugins - type: Directory - name: plugins-dir - - hostPath: - path: /dev - type: Directory - name: dev-dir - - hostPath: - path: /lib/modules - name: mod-dir - - hostPath: - path: {{ .Values.lvm.hostWritePath }}/backup - type: DirectoryOrCreate - name: lvmbackup - - hostPath: - path: {{ .Values.lvm.hostWritePath }}/cache - type: DirectoryOrCreate - name: lvmcache - - hostPath: - path: {{ .Values.lvm.hostWritePath }}/archive - type: DirectoryOrCreate - name: lvmarchive - - hostPath: - path: {{ .Values.lvm.hostWritePath }}/lock - type: DirectoryOrCreate - name: lvmlock \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/driver.yaml b/charts/internal/csi-driver-lvm/templates/driver.yaml deleted file mode 100644 index c45ac81..0000000 --- a/charts/internal/csi-driver-lvm/templates/driver.yaml +++ /dev/null @@ -1,10 +0,0 @@ -apiVersion: storage.k8s.io/v1 -kind: CSIDriver -metadata: - name: csi-driver-lvm -spec: - volumeLifecycleModes: - - Persistent - - Ephemeral - podInfoOnMount: true - attachRequired: false \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/helpers.tpl b/charts/internal/csi-driver-lvm/templates/helpers.tpl deleted file mode 100644 index ff883ef..0000000 --- a/charts/internal/csi-driver-lvm/templates/helpers.tpl +++ /dev/null @@ -1,32 +0,0 @@ -{{- define "name" -}} -gardener-extension-csi-driver-lvm -{{- end -}} - -{{- define "labels.app.key" -}} -app.kubernetes.io/name -{{- end -}} -{{- define "labels.app.value" -}} -{{ include "name" . }} -{{- end -}} - -{{- define "labels" -}} -{{ include "labels.app.key" . }}: {{ include "labels.app.value" . }} -app.kubernetes.io/instance: {{ .Release.Name }} -{{- end -}} - -{{- define "image" -}} - {{- if hasPrefix "sha256:" .Values.image.tag }} - {{- printf "%s@%s" .Values.image.repository .Values.image.tag }} - {{- else }} - {{- printf "%s:%s" .Values.image.repository .Values.image.tag }} - {{- end }} -{{- end }} - -{{- define "deploymentversion" -}} -apps/v1 -{{- end -}} - - -{{- define "storageclassversion" -}} -storage.k8s.io/v1 -{{- end -}} diff --git a/charts/internal/csi-driver-lvm/templates/rbac.yaml b/charts/internal/csi-driver-lvm/templates/rbac.yaml deleted file mode 100644 index 77ccd24..0000000 --- a/charts/internal/csi-driver-lvm/templates/rbac.yaml +++ /dev/null @@ -1,89 +0,0 @@ ---- -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRole -metadata: - name: csi-driver-lvm-controller -rules: - - apiGroups: [""] - resources: ["persistentvolumes"] - verbs: ["get", "list", "watch", "update", "patch", "create", "delete"] - - apiGroups: ["storage.k8s.io"] - resources: ["csinodes"] - verbs: ["get", "list", "watch"] - - apiGroups: ["storage.k8s.io"] - resources: ["volumeattachments"] - verbs: ["get", "list", "watch", "update", "patch"] - - apiGroups: [""] - resources: ["persistentvolumeclaims"] - verbs: ["get", "list", "watch", "update", "patch"] - - apiGroups: [""] - resources: ["persistentvolumeclaims/status"] - verbs: ["update", "patch"] - - apiGroups: ["storage.k8s.io"] - resources: ["storageclasses"] - verbs: ["get", "list", "watch"] - - apiGroups: [""] - resources: ["events"] - verbs: ["list", "watch", "create", "update", "patch"] - - apiGroups: ["storage.k8s.io"] - resources: ["csinodes"] - verbs: ["get", "list", "watch"] - - apiGroups: [""] - resources: ["nodes"] - verbs: ["get", "list", "watch"] - - apiGroups: ["storage.k8s.io"] - resources: ["volumeattachments/status"] - verbs: ["patch"] - - apiGroups: [""] - resources: ["pods"] - verbs: ["get", "list", "watch"] ---- -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRoleBinding -metadata: - name: csi-driver-lvm-controller -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: ClusterRole - name: csi-driver-lvm-controller -subjects: -- kind: ServiceAccount - name: csi-driver-lvm-controller - namespace: {{ .Release.Namespace }} ---- -kind: ClusterRole -apiVersion: rbac.authorization.k8s.io/v1 -metadata: - name: csi-driver-lvm-plugin -rules: - - apiGroups: [""] - resources: ["persistentvolumes"] - verbs: ["get", "list", "watch", "update", "patch", "create", "delete"] - - apiGroups: [""] - resources: ["persistentvolumeclaims"] - verbs: ["get", "list", "watch"] - - apiGroups: [""] - resources: ["persistentvolumeclaims/status"] - verbs: ["update", "patch"] - - apiGroups: [""] - resources: ["events"] - verbs: ["list", "watch", "create", "update", "patch"] - - apiGroups: [""] - resources: ["pods"] - verbs: ["list", "get", "watch", "create", "delete"] - - apiGroups: [""] - resources: ["nodes"] - verbs: ["get", "list", "watch"] ---- -kind: ClusterRoleBinding -apiVersion: rbac.authorization.k8s.io/v1 -metadata: - name: csi-driver-lvm-plugin -subjects: - - kind: ServiceAccount - name: csi-driver-lvm-plugin - namespace: {{ .Release.Namespace }} -roleRef: - kind: ClusterRole - name: csi-driver-lvm-plugin - apiGroup: rbac.authorization.k8s.io \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/serviceaccount.yaml b/charts/internal/csi-driver-lvm/templates/serviceaccount.yaml deleted file mode 100644 index b5a02a1..0000000 --- a/charts/internal/csi-driver-lvm/templates/serviceaccount.yaml +++ /dev/null @@ -1,12 +0,0 @@ ---- -apiVersion: v1 -kind: ServiceAccount -metadata: - name: csi-driver-lvm-controller - namespace: {{ .Release.Namespace }} ---- -apiVersion: v1 -kind: ServiceAccount -metadata: - name: csi-driver-lvm-plugin - namespace: {{ .Release.Namespace }} \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/statefulset.yaml b/charts/internal/csi-driver-lvm/templates/statefulset.yaml deleted file mode 100644 index dfb957b..0000000 --- a/charts/internal/csi-driver-lvm/templates/statefulset.yaml +++ /dev/null @@ -1,77 +0,0 @@ -kind: StatefulSet -apiVersion: apps/v1 -metadata: - name: csi-driver-lvm-controller -spec: - serviceName: csi-driver-lvm-controller - replicas: 1 - selector: - matchLabels: - app: csi-driver-lvm-controller - template: - metadata: - labels: - app: csi-driver-lvm-controller - spec: - affinity: - podAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app - operator: In - values: - - csi-driver-lvm-plugin - topologyKey: kubernetes.io/hostname -{{- if .Values.nodeSelector.provisioner }} - nodeSelector: -{{ toYaml .Values.nodeSelector.provisioner | indent 8 }} -{{- end }} -{{- if .Values.tolerations.provisioner }} - tolerations: -{{ toYaml .Values.tolerations.provisioner | indent 8 }} -{{- end }} - serviceAccountName: csi-driver-lvm-controller - containers: - - name: csi-attacher - image: {{ .Values.sidecarImages.attacher }} - imagePullPolicy: IfNotPresent - args: - - --v=5 - - --csi-address=/csi/csi.sock - securityContext: - readOnlyRootFilesystem: true - privileged: true - volumeMounts: - - mountPath: /csi - name: socket-dir - - name: csi-provisioner - image: {{ .Values.sidecarImages.provisioner }} - imagePullPolicy: IfNotPresent - args: - - -v=5 - - --csi-address=/csi/csi.sock - - --feature-gates=Topology=true - securityContext: - readOnlyRootFilesystem: true - privileged: true - volumeMounts: - - mountPath: /csi - name: socket-dir - - name: csi-resizer - image: {{ .Values.sidecarImages.resizer }} - imagePullPolicy: IfNotPresent - args: - - -v=5 - - -csi-address=/csi/csi.sock - securityContext: - readOnlyRootFilesystem: true - privileged: true - volumeMounts: - - mountPath: /csi - name: socket-dir - volumes: - - hostPath: - path: {{ .Values.kubernetes.kubeletPath }}/plugins/csi-driver-lvm - type: DirectoryOrCreate - name: socket-dir \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/templates/storageclasses.yaml b/charts/internal/csi-driver-lvm/templates/storageclasses.yaml deleted file mode 100644 index 7af6704..0000000 --- a/charts/internal/csi-driver-lvm/templates/storageclasses.yaml +++ /dev/null @@ -1,66 +0,0 @@ ---- -{{- $storageClass := .Values.storageClasses.linear -}} -{{ if $storageClass.enabled }} -apiVersion: storage.k8s.io/v1 -kind: StorageClass -metadata: - name: csi-driver-lvm-linear -{{- if not (empty $storageClass.additionalAnnotations) }} - annotations: - {{- $storageClass.additionalAnnotations | toYaml | nindent 4 -}} -{{ end }} -provisioner: lvm.csi.metal-stack.io -reclaimPolicy: {{ $storageClass.reclaimPolicy }} -volumeBindingMode: WaitForFirstConsumer -allowVolumeExpansion: true -parameters: - type: "linear" -{{ end }} ---- -{{- $storageClass := .Values.storageClasses.mirror -}} -{{ if $storageClass.enabled }} -apiVersion: storage.k8s.io/v1 -kind: StorageClass -metadata: - name: csi-driver-lvm-mirror -{{- if not (empty $storageClass.additionalAnnotations) }} - annotations: - {{- $storageClass.additionalAnnotations | toYaml | nindent 4 -}} -{{ end }} -provisioner: lvm.csi.metal-stack.io -reclaimPolicy: {{ $storageClass.reclaimPolicy }} -volumeBindingMode: WaitForFirstConsumer -allowVolumeExpansion: true -parameters: - type: "mirror" -{{ end }} ---- -{{- $storageClass := .Values.storageClasses.striped -}} -{{ if $storageClass.enabled }} -apiVersion: storage.k8s.io/v1 -kind: StorageClass -metadata: - name: csi-driver-lvm-striped -{{- if not (empty $storageClass.additionalAnnotations) }} - annotations: - {{- $storageClass.additionalAnnotations | toYaml | nindent 4 -}} -{{ end }} -provisioner: lvm.csi-metal-stack.io -reclaimPolicy: {{ $storageClass.reclaimPolicy }} -volumeBindingMode: WaitForFirstConsumer -allowVolumeExpansion: true -parameters: - type: "striped" -{{ end }} ---- -{{- $storageClass := .Values.storageClasses.linear -}} -apiVersion: storage.k8s.io/v1 -kind: StorageClass -metadata: - name: csi-lvm -provisioner: lvm.csi.metal-stack.io -volumeBindingMode: WaitForFirstConsumer -reclaimPolicy: {{ $storageClass.reclaimPolicy }} -parameters: - type: "linear" ---- \ No newline at end of file diff --git a/charts/internal/csi-driver-lvm/values.yaml b/charts/internal/csi-driver-lvm/values.yaml deleted file mode 100644 index 8d1e158..0000000 --- a/charts/internal/csi-driver-lvm/values.yaml +++ /dev/null @@ -1,85 +0,0 @@ ---- -lvm: - # This one you should change - devicePattern: /dev/nvme[0-9]n[0-9] - - # You will want to change this for read-only filesystems - # For example, in Talos OS, set this to "/var/etc/lvm" - hostWritePath: /etc/lvm - -images: - csi-driver-lvm-plugin: image-repository:image-tag - csi-driver-lvm-provisioner: image-repository:image-tag - -sidecarImages: - attacher: k8s.gcr.io/sig-storage/csi-attacher:v3.5.0 - livenessprobe: k8s.gcr.io/sig-storage/livenessprobe:v2.7.0 - provisioner: k8s.gcr.io/sig-storage/csi-provisioner:v3.2.1 - registrar: k8s.gcr.io/sig-storage/csi-node-driver-registrar:v2.5.1 - resizer: k8s.gcr.io/sig-storage/csi-resizer:v1.6.0 - -kubernetes: - kubeletPath: /var/lib/kubelet - -storageClasses: - default: - reclaimPolicy: Delete - linear: - enabled: true - additionalAnnotations: [] - reclaimPolicy: Delete - striped: - enabled: true - additionalAnnotations: [] - reclaimPolicy: Delete - mirror: - enabled: true - additionalAnnotations: [] - reclaimPolicy: Delete - -nodeSelector: - # The plugin daemonset will run on all nodes if it has a toleration, - # so it is not necessary to set a nodeSelector for it - - # plugin: - # node-role.kubernetes.io/master: "" - # Key name may need to be updated to 'node-role.kubernetes.io/control-plane' - # in the future - - # The provisioner has an affinity for nodes with a plugin pod, - # but since that's a daemonset, we allow more fine-grained node selection - - provisioner: - # node-role.kubernetes.io/master: "" - # Key name may need to be updated to 'node-role.kubernetes.io/control-plane' - # in the future - -tolerations: - plugin: - # - key: node-role.kubernetes.io/master - # operator: Exists - # effect: NoSchedule - # - key: node-role.kubernetes.io/control-plane - # operator: Exists - # effect: NoSchedule - provisioner: - # - key: node-role.kubernetes.io/master - # operator: Exists - # effect: NoSchedule - # - key: node-role.kubernetes.io/control-plane - # operator: Exists - # effect: NoSchedule ---- - -# ! unused/unsure -isDefaultStorageClass: true - -# lvm: -# # these are primariliy for testing purposes -# vgName: csi-lvm -# driverName: lvm.csi.metal-stack.io -# storageClassStub: csi-driver-lvm - -rbac: - create: true - pspEnabled: true diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index ff5b6b3..f2a3290 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: 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 + rawChart: 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 values: image: tag: v0.0.1 diff --git a/pkg/apis/config/types.go b/pkg/apis/config/types.go index 9d452d5..86792ea 100644 --- a/pkg/apis/config/types.go +++ b/pkg/apis/config/types.go @@ -12,8 +12,8 @@ import ( type ControllerConfiguration struct { metav1.TypeMeta - DevicePattern *string - HostWritePath *string + DefaultDevicePattern *string + DefaultHostWritePath *string // HealthCheckConfig is the config for the health check controller HealthCheckConfig *healthcheckconfig.HealthCheckConfig diff --git a/pkg/apis/config/v1alpha1/types.go b/pkg/apis/config/v1alpha1/types.go index cfa0f06..cc23f6e 100644 --- a/pkg/apis/config/v1alpha1/types.go +++ b/pkg/apis/config/v1alpha1/types.go @@ -11,8 +11,8 @@ import ( type ControllerConfiguration struct { metav1.TypeMeta `json:",inline"` - DevicePattern *string `json:"devicePattern,omitempty"` - HostWritePath *string `json:"hostWritePath,omitempty"` + DefaultDevicePattern *string `json:"defaultDevicePattern,omitempty"` + DefaultHostWritePath *string `json:"defaultHostWritePath,omitempty"` // HealthCheckConfig is the config for the health check controller // +optional diff --git a/pkg/apis/config/v1alpha1/zz_generated.conversion.go b/pkg/apis/config/v1alpha1/zz_generated.conversion.go index b7695ce..7accd39 100644 --- a/pkg/apis/config/v1alpha1/zz_generated.conversion.go +++ b/pkg/apis/config/v1alpha1/zz_generated.conversion.go @@ -40,8 +40,8 @@ func RegisterConversions(s *runtime.Scheme) error { } func autoConvert_v1alpha1_ControllerConfiguration_To_config_ControllerConfiguration(in *ControllerConfiguration, out *config.ControllerConfiguration, s conversion.Scope) error { - out.DevicePattern = (*string)(unsafe.Pointer(in.DevicePattern)) - out.HostWritePath = (*string)(unsafe.Pointer(in.HostWritePath)) + out.DefaultDevicePattern = (*string)(unsafe.Pointer(in.DefaultDevicePattern)) + out.DefaultHostWritePath = (*string)(unsafe.Pointer(in.DefaultHostWritePath)) out.HealthCheckConfig = (*apisconfig.HealthCheckConfig)(unsafe.Pointer(in.HealthCheckConfig)) return nil } @@ -52,8 +52,8 @@ func Convert_v1alpha1_ControllerConfiguration_To_config_ControllerConfiguration( } func autoConvert_config_ControllerConfiguration_To_v1alpha1_ControllerConfiguration(in *config.ControllerConfiguration, out *ControllerConfiguration, s conversion.Scope) error { - out.DevicePattern = (*string)(unsafe.Pointer(in.DevicePattern)) - out.HostWritePath = (*string)(unsafe.Pointer(in.HostWritePath)) + out.DefaultDevicePattern = (*string)(unsafe.Pointer(in.DefaultDevicePattern)) + out.DefaultHostWritePath = (*string)(unsafe.Pointer(in.DefaultHostWritePath)) out.HealthCheckConfig = (*configv1alpha1.HealthCheckConfig)(unsafe.Pointer(in.HealthCheckConfig)) return nil } diff --git a/pkg/apis/config/v1alpha1/zz_generated.deepcopy.go b/pkg/apis/config/v1alpha1/zz_generated.deepcopy.go index f9950ef..074ca86 100644 --- a/pkg/apis/config/v1alpha1/zz_generated.deepcopy.go +++ b/pkg/apis/config/v1alpha1/zz_generated.deepcopy.go @@ -18,13 +18,13 @@ import ( func (in *ControllerConfiguration) DeepCopyInto(out *ControllerConfiguration) { *out = *in out.TypeMeta = in.TypeMeta - if in.DevicePattern != nil { - in, out := &in.DevicePattern, &out.DevicePattern + if in.DefaultDevicePattern != nil { + in, out := &in.DefaultDevicePattern, &out.DefaultDevicePattern *out = new(string) **out = **in } - if in.HostWritePath != nil { - in, out := &in.HostWritePath, &out.HostWritePath + if in.DefaultHostWritePath != nil { + in, out := &in.DefaultHostWritePath, &out.DefaultHostWritePath *out = new(string) **out = **in } diff --git a/pkg/apis/config/zz_generated.deepcopy.go b/pkg/apis/config/zz_generated.deepcopy.go index e12c56e..40af30e 100644 --- a/pkg/apis/config/zz_generated.deepcopy.go +++ b/pkg/apis/config/zz_generated.deepcopy.go @@ -18,13 +18,13 @@ import ( func (in *ControllerConfiguration) DeepCopyInto(out *ControllerConfiguration) { *out = *in out.TypeMeta = in.TypeMeta - if in.DevicePattern != nil { - in, out := &in.DevicePattern, &out.DevicePattern + if in.DefaultDevicePattern != nil { + in, out := &in.DefaultDevicePattern, &out.DefaultDevicePattern *out = new(string) **out = **in } - if in.HostWritePath != nil { - in, out := &in.HostWritePath, &out.HostWritePath + if in.DefaultHostWritePath != nil { + in, out := &in.DefaultHostWritePath, &out.DefaultHostWritePath *out = new(string) **out = **in } diff --git a/pkg/apis/csidriverlvm/types.go b/pkg/apis/csidriverlvm/types.go index 3d0650e..e9e0ccb 100644 --- a/pkg/apis/csidriverlvm/types.go +++ b/pkg/apis/csidriverlvm/types.go @@ -9,4 +9,7 @@ import ( // CsiDriverLvmConfig configuration resource type CsiDriverLvmConfig struct { metav1.TypeMeta + + DevicePattern *string + HostWritePath *string } diff --git a/pkg/apis/csidriverlvm/v1alpha1/types.go b/pkg/apis/csidriverlvm/v1alpha1/types.go index 31aae83..797ed3e 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/types.go +++ b/pkg/apis/csidriverlvm/v1alpha1/types.go @@ -13,4 +13,7 @@ const ( // ControllerConfiguration configuration resource type CsiDriverLvmConfig struct { metav1.TypeMeta `json:",inline"` + + DevicePattern *string `json:"devicePattern,omitempty"` + HostWritePath *string `json:"hostWritePath,omitempty"` } diff --git a/pkg/apis/csidriverlvm/v1alpha1/zz_generated.deepcopy.go b/pkg/apis/csidriverlvm/v1alpha1/zz_generated.deepcopy.go index 90d024c..1d22b0b 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/zz_generated.deepcopy.go +++ b/pkg/apis/csidriverlvm/v1alpha1/zz_generated.deepcopy.go @@ -17,6 +17,16 @@ import ( func (in *CsiDriverLvmConfig) DeepCopyInto(out *CsiDriverLvmConfig) { *out = *in out.TypeMeta = in.TypeMeta + if in.DevicePattern != nil { + in, out := &in.DevicePattern, &out.DevicePattern + *out = new(string) + **out = **in + } + if in.HostWritePath != nil { + in, out := &in.HostWritePath, &out.HostWritePath + *out = new(string) + **out = **in + } return } diff --git a/pkg/apis/csidriverlvm/zz_generated.deepcopy.go b/pkg/apis/csidriverlvm/zz_generated.deepcopy.go index 9e11620..9699252 100644 --- a/pkg/apis/csidriverlvm/zz_generated.deepcopy.go +++ b/pkg/apis/csidriverlvm/zz_generated.deepcopy.go @@ -17,6 +17,16 @@ import ( func (in *CsiDriverLvmConfig) DeepCopyInto(out *CsiDriverLvmConfig) { *out = *in out.TypeMeta = in.TypeMeta + if in.DevicePattern != nil { + in, out := &in.DevicePattern, &out.DevicePattern + *out = new(string) + **out = **in + } + if in.HostWritePath != nil { + in, out := &in.HostWritePath, &out.HostWritePath + *out = new(string) + **out = **in + } return } diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index f21c4a9..573239b 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -6,7 +6,6 @@ import ( "time" "github.com/gardener/gardener/extensions/pkg/controller/extension" - "github.com/gardener/gardener/imagevector" extensionsv1alpha1 "github.com/gardener/gardener/pkg/apis/extensions/v1alpha1" "github.com/gardener/gardener/pkg/client/kubernetes" @@ -20,6 +19,7 @@ import ( "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config" "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/imagevector" "github.com/metal-stack/metal-lib/pkg/pointer" appsv1 "k8s.io/api/apps/v1" @@ -58,12 +58,23 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension } } + var hostwritepath = csidriverlvmConfig.HostWritePath + var devicepattern = csidriverlvmConfig.DevicePattern + + if hostwritepath == nil { + csidriverlvmConfig.HostWritePath = a.config.DefaultHostWritePath + } + + if devicepattern == nil { + csidriverlvmConfig.DevicePattern = a.config.DefaultDevicePattern + } + controllerObjects, err := a.controllerObjects(namespace) if err != nil { return err } - pluginObjects, err := a.pluginObjects(namespace) + pluginObjects, err := a.pluginObjects(namespace, csidriverlvmConfig, log) if err != nil { return err } @@ -321,7 +332,7 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) return objects, nil } -func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { +func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1.CsiDriverLvmConfig, log logr.Logger) ([]client.Object, error) { csidriverlvmDriver := &storagev1.CSIDriver{ ObjectMeta: metav1.ObjectMeta{ @@ -475,7 +486,7 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { return nil, fmt.Errorf("failed to find csi-driver-lvm-provisioner image: %w", err) } - var terminationPolicy corev1.TerminationMessagePolicy = corev1.TerminationMessageReadFile + // var terminationPolicy corev1.TerminationMessagePolicy = corev1.TerminationMessageReadFile var mountPropagation corev1.MountPropagationMode = corev1.MountPropagationBidirectional var hostPathTypeCreate corev1.HostPathType = corev1.HostPathDirectoryOrCreate @@ -506,12 +517,12 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { NodeSelector: map[string]string{}, Containers: []corev1.Container{ { - Name: "node-driver-registrar", + Name: "csi-node-driver-registrar", Image: csiNodeDriverRegistrarImage.String(), ImagePullPolicy: "IfNotPresent", Args: []string{"--v=5", "--csi-address=/csi/csi.sock", "--kubelet-registration-path=/var/lib/kubelet/plugins/csi-driver-lvm/csi.sock"}, SecurityContext: &corev1.SecurityContext{ - ReadOnlyRootFilesystem: pointer.Pointer(true), + ReadOnlyRootFilesystem: pointer.Pointer(false), // Privileged: pointer.Pointer(true), }, Env: []corev1.EnvVar{ @@ -525,8 +536,8 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { }, }, }, - TerminationMessagePath: "/dev/termination-log", - TerminationMessagePolicy: terminationPolicy, + // TerminationMessagePath: "/dev/termination-log", + // TerminationMessagePolicy: terminationPolicy, VolumeMounts: []corev1.VolumeMount{ {MountPath: "/csi", Name: "socket-dir"}, {MountPath: "/var/lib/kubelet/plugins/csi-driver-lvm/csi.sock", Name: "socket-dir"}, @@ -540,8 +551,8 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { Args: []string{ "--drivername=lvm.csi.metal-stack.io", "--endpoint=unix:///csi/csi.sock", - "--hostwritepath=" + *a.config.HostWritePath, - "--devices=" + *a.config.DevicePattern, + "--hostwritepath=" + pointer.SafeDeref(csidriverlvmConfig.HostWritePath), + "--devices=" + pointer.SafeDeref(csidriverlvmConfig.HostWritePath), "--nodeid=$(KUBE_NODE_NAME)", "--vgname=csi-lvm", "--namespace=kube-system", @@ -549,7 +560,7 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { "--pullpolicy=IfNotPresent", }, SecurityContext: &corev1.SecurityContext{ - ReadOnlyRootFilesystem: pointer.Pointer(true), + ReadOnlyRootFilesystem: pointer.Pointer(false), Privileged: pointer.Pointer(true), }, Env: []corev1.EnvVar{ @@ -582,8 +593,8 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { Protocol: corev1.ProtocolTCP, ContainerPort: 9898, }}, - TerminationMessagePath: "/dev/termination-log", - TerminationMessagePolicy: terminationPolicy, + // TerminationMessagePath: "/dev/termination-log", + // TerminationMessagePolicy: terminationPolicy, VolumeMounts: []corev1.VolumeMount{ {MountPath: "/csi", Name: "socket-dir"}, {MountPath: "/var/lib/kubelet/pods", Name: "mountpoint-dir", MountPropagation: &mountPropagation}, @@ -607,8 +618,8 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), }, - TerminationMessagePath: "/dev/termination-log", - TerminationMessagePolicy: terminationPolicy, + // TerminationMessagePath: "/dev/termination-log", + // TerminationMessagePolicy: terminationPolicy, VolumeMounts: []corev1.VolumeMount{ {MountPath: "/csi", Name: "socket-dir"}, }, @@ -672,7 +683,7 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { Name: "lvmcache", VolumeSource: corev1.VolumeSource{ HostPath: &corev1.HostPathVolumeSource{ - Path: *a.config.HostWritePath + "/cache", + Path: pointer.SafeDeref(csidriverlvmConfig.HostWritePath) + "/cache", Type: &hostPathTypeCreate, }, }, @@ -681,7 +692,7 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { Name: "lvmarchive", VolumeSource: corev1.VolumeSource{ HostPath: &corev1.HostPathVolumeSource{ - Path: *a.config.HostWritePath + "/archive", + Path: pointer.SafeDeref(csidriverlvmConfig.HostWritePath) + "/archive", Type: &hostPathTypeCreate, }, }, @@ -690,7 +701,7 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { Name: "lvmbackup", VolumeSource: corev1.VolumeSource{ HostPath: &corev1.HostPathVolumeSource{ - Path: *a.config.HostWritePath + "/backup", + Path: pointer.SafeDeref(csidriverlvmConfig.HostWritePath) + "/backup", Type: &hostPathTypeCreate, }, }, @@ -699,7 +710,7 @@ func (a *actuator) pluginObjects(namespace string) ([]client.Object, error) { Name: "lvmlock", VolumeSource: corev1.VolumeSource{ HostPath: &corev1.HostPathVolumeSource{ - Path: *a.config.HostWritePath + "/lock", + Path: pointer.SafeDeref(csidriverlvmConfig.HostWritePath) + "/lock", Type: &hostPathTypeCreate, }, }, From e5ce2e2cdabc3eae3a960de30d050a62b7b54715 Mon Sep 17 00:00:00 2001 From: ostempel Date: Mon, 11 Nov 2024 11:16:58 +0100 Subject: [PATCH 05/32] remove healtcheck and test for old csi-lvm --- .../templates/rbac.yaml | 11 +--- example/controller-registration.yaml | 2 +- example/kustomize/patch-registration.yaml | 15 ----- pkg/apis/csidriverlvm/v1alpha1/types.go | 2 +- pkg/cmd/options.go | 3 - pkg/controller/csi-driver-lvm/actuator.go | 58 ++++++++++++++++--- pkg/controller/healthcheck/registration.go | 53 ----------------- 7 files changed, 56 insertions(+), 88 deletions(-) delete mode 100644 example/kustomize/patch-registration.yaml delete mode 100644 pkg/controller/healthcheck/registration.go diff --git a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml index c6d31e4..1a3bcdd 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml @@ -41,20 +41,15 @@ rules: - apiGroups: - "" resources: - - secrets - - configmaps + - namespaces verbs: - get - list - watch - - create - - update - - patch - - delete - apiGroups: - - "" + - "storage.k8s.io" resources: - - namespaces + - storageclasses verbs: - get - list diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index f2a3290..c6607e4 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: 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 + rawChart: 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 values: image: tag: v0.0.1 diff --git a/example/kustomize/patch-registration.yaml b/example/kustomize/patch-registration.yaml deleted file mode 100644 index 3867daa..0000000 --- a/example/kustomize/patch-registration.yaml +++ /dev/null @@ -1,15 +0,0 @@ -apiVersion: core.gardener.cloud/v1beta1 -kind: ControllerRegistration -metadata: - name: csi-driver-lvm -spec: - deployment: - policy: Always - resources: - - kind: Extension - type: csi-driver-lvm - globallyEnabled: true - lifecycle: - delete: BeforeKubeAPIServer - migrate: BeforeKubeAPIServer - reconcile: BeforeKubeAPIServer diff --git a/pkg/apis/csidriverlvm/v1alpha1/types.go b/pkg/apis/csidriverlvm/v1alpha1/types.go index 797ed3e..5c1aa44 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/types.go +++ b/pkg/apis/csidriverlvm/v1alpha1/types.go @@ -5,7 +5,7 @@ import ( ) const ( - SeedCsiDriverLvmResourceName = "extension-csi-driver-lvm" + ShootCsiDriverLvmResourceName = "extension-csi-driver-lvm" ) // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object diff --git a/pkg/cmd/options.go b/pkg/cmd/options.go index 6219909..19da4d2 100644 --- a/pkg/cmd/options.go +++ b/pkg/cmd/options.go @@ -2,18 +2,15 @@ package cmd import ( controllercmd "github.com/gardener/gardener/extensions/pkg/controller/cmd" - extensionshealthcheckcontroller "github.com/gardener/gardener/extensions/pkg/controller/healthcheck" extensionsheartbeatcontroller "github.com/gardener/gardener/extensions/pkg/controller/heartbeat" csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" - "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/healthcheck" ) // ControllerSwitchOptions are the controllercmd.SwitchOptions for the provider controllers. func ControllerSwitchOptions() *controllercmd.SwitchOptions { return controllercmd.NewSwitchOptions( controllercmd.Switch(csidriverlvm.ControllerName, csidriverlvm.AddToManager), - controllercmd.Switch(extensionshealthcheckcontroller.ControllerName, healthcheck.AddToManager), controllercmd.Switch(extensionsheartbeatcontroller.ControllerName, extensionsheartbeatcontroller.AddToManager), ) } diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 573239b..34689ba 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -26,11 +26,16 @@ import ( corev1 "k8s.io/api/core/v1" rbacv1 "k8s.io/api/rbac/v1" storagev1 "k8s.io/api/storage/v1" + apierrors "k8s.io/apimachinery/pkg/api/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" ) const ( namespace string = "kube-system" + + oldName string = "csi-lvm" + oldNamespace string = "csi-lvm" + oldProvisioner string = "metal-stack.io/csi-lvm" ) // NewActuator returns an actuator responsible for Extension resources. @@ -50,6 +55,14 @@ type actuator struct { // Reconcile the Extension resource. func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { + err := a.removeOldCsilvm(ctx) + + if err != nil { + return fmt.Errorf("unable to remove old csi-lvm driver: %w", err) + } + + log.Info("successfully removed old csi-lvm driver") + csidriverlvmConfig := &v1alpha1.CsiDriverLvmConfig{} if ex.Spec.ProviderConfig != nil { _, _, err := a.decoder.Decode(ex.Spec.ProviderConfig.Raw, nil, csidriverlvmConfig) @@ -74,7 +87,7 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension return err } - pluginObjects, err := a.pluginObjects(namespace, csidriverlvmConfig, log) + pluginObjects, err := a.pluginObjects(namespace, csidriverlvmConfig) if err != nil { return err } @@ -88,13 +101,13 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension return err } - err = managedresources.CreateForSeed(ctx, a.client, namespace, v1alpha1.SeedCsiDriverLvmResourceName, false, seedResources) + err = managedresources.CreateForSeed(ctx, a.client, namespace, v1alpha1.ShootCsiDriverLvmResourceName, false, seedResources) if err != nil { return nil } - log.Info("managed resource created succesfully", "name", v1alpha1.SeedCsiDriverLvmResourceName) + log.Info("managed resource created succesfully", "name", v1alpha1.ShootCsiDriverLvmResourceName) return nil } @@ -102,7 +115,7 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension // Delete the Extension resource. func (a *actuator) Delete(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { - err := managedresources.Delete(ctx, a.client, namespace, v1alpha1.SeedCsiDriverLvmResourceName, false) + err := managedresources.Delete(ctx, a.client, namespace, v1alpha1.ShootCsiDriverLvmResourceName, false) if err != nil { return err @@ -111,7 +124,7 @@ func (a *actuator) Delete(ctx context.Context, log logr.Logger, ex *extensionsv1 timeoutCtx, cancel := context.WithTimeout(ctx, 2*time.Minute) defer cancel() - err = managedresources.WaitUntilDeleted(timeoutCtx, a.client, namespace, v1alpha1.SeedCsiDriverLvmResourceName) + err = managedresources.WaitUntilDeleted(timeoutCtx, a.client, namespace, v1alpha1.ShootCsiDriverLvmResourceName) if err != nil { return err } @@ -332,7 +345,7 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) return objects, nil } -func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1.CsiDriverLvmConfig, log logr.Logger) ([]client.Object, error) { +func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1.CsiDriverLvmConfig) ([]client.Object, error) { csidriverlvmDriver := &storagev1.CSIDriver{ ObjectMeta: metav1.ObjectMeta{ @@ -556,7 +569,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. "--nodeid=$(KUBE_NODE_NAME)", "--vgname=csi-lvm", "--namespace=kube-system", - "--provisionerImage=" + csiDriverLvmProvisionerImage.String(), + "--provisionerimage=" + csiDriverLvmProvisionerImage.String(), "--pullpolicy=IfNotPresent", }, SecurityContext: &corev1.SecurityContext{ @@ -735,3 +748,34 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. return objects, nil } + +func (a *actuator) removeOldCsilvm(ctx context.Context) error { + + namespace := &corev1.Namespace{ + ObjectMeta: metav1.ObjectMeta{ + Name: oldNamespace, + }, + } + + err := a.client.Get(ctx, client.ObjectKeyFromObject(namespace), namespace) + if err == nil { + a.client.Delete(ctx, namespace) + } else if !apierrors.IsNotFound(err) { + return fmt.Errorf("error while getting old csi-lvm namespace: %w", err) + } + + storageClass := &storagev1.StorageClass{ + ObjectMeta: metav1.ObjectMeta{ + Name: oldName, + }, + Provisioner: oldProvisioner, + } + + err = a.client.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass) + if err == nil { + a.client.Delete(ctx, storageClass) + } else if !apierrors.IsNotFound(err) { + return fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) + } + return nil +} diff --git a/pkg/controller/healthcheck/registration.go b/pkg/controller/healthcheck/registration.go deleted file mode 100644 index c54a7e0..0000000 --- a/pkg/controller/healthcheck/registration.go +++ /dev/null @@ -1,53 +0,0 @@ -package healthcheck - -import ( - "context" - "time" - - extensionsconfig "github.com/gardener/gardener/extensions/pkg/apis/config" - "github.com/gardener/gardener/extensions/pkg/controller/healthcheck" - "github.com/gardener/gardener/extensions/pkg/controller/healthcheck/general" - gardencorev1beta1 "github.com/gardener/gardener/pkg/apis/core/v1beta1" - extensionsv1alpha1 "github.com/gardener/gardener/pkg/apis/extensions/v1alpha1" - "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" - csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/controller/csi-driver-lvm" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "k8s.io/apimachinery/pkg/util/sets" - "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/manager" -) - -var ( - defaultSyncPeriod = 60 * time.Second - // DefaultAddOptions contains configuration for the health check controller. - DefaultAddOptions = healthcheck.DefaultAddArgs{ - HealthCheckConfig: extensionsconfig.HealthCheckConfig{SyncPeriod: metav1.Duration{Duration: defaultSyncPeriod}}, - } -) - -// RegisterHealthChecks registers health checks for each extension resource -// HealthChecks are grouped by extension (e.g worker), extension.type (e.g aws) and Health Check Type (e.g SystemComponentsHealthy) -func RegisterHealthChecks(ctx context.Context, mgr manager.Manager, opts healthcheck.DefaultAddArgs) error { - return healthcheck.DefaultRegistration( - ctx, - csidriverlvm.Type, - extensionsv1alpha1.SchemeGroupVersion.WithKind(extensionsv1alpha1.ExtensionResource), - func() client.ObjectList { return &extensionsv1alpha1.ExtensionList{} }, - func() extensionsv1alpha1.Object { return &extensionsv1alpha1.Extension{} }, - mgr, - opts, - nil, - []healthcheck.ConditionTypeToHealthCheck{ - { - ConditionType: string(gardencorev1beta1.ShootSystemComponentsHealthy), - HealthCheck: general.CheckManagedResource(v1alpha1.SeedCsiDriverLvmResourceName), - }, - }, - sets.Set[gardencorev1beta1.ConditionType]{}, - ) -} - -// AddToManager adds a controller with the default Options. -func AddToManager(ctx context.Context, mgr manager.Manager) error { - return RegisterHealthChecks(ctx, mgr, DefaultAddOptions) -} From 11ae5d2d11e0ee30cec1201452c9d53844eff0e1 Mon Sep 17 00:00:00 2001 From: ostempel Date: Mon, 11 Nov 2024 11:21:51 +0100 Subject: [PATCH 06/32] add readme --- README.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..749ed87 --- /dev/null +++ b/README.md @@ -0,0 +1,15 @@ +# gardener-extension-csi-driver-lvm + +Provides a Gardener extension for managing [csi-driver-lvm](https://github.com/metal-stack/csi-driver-lvm) for a shoot cluster. + +The extension checks for the old [csi-lvm](https://github.com/metal-stack/csi-lvm/tree/master) and removes it. +After success it applies the new driver. + +## Development + +This extension can be developed in the gardener-local devel environment. + +1. Start up the local devel environment +1. The extension's docker image can be pushed into Kind using `make push-to-gardener-local` +1. Install the extension `kubectl apply -k example/` +1. Parametrize the `example/shoot.yaml` and apply with `kubectl -f example/shoot.yaml` \ No newline at end of file From 36fa4dfa0a5d80bed8448bc66a4b893c076e6f2c Mon Sep 17 00:00:00 2001 From: Oliver <69219753+ostempel@users.noreply.github.com> Date: Tue, 5 Nov 2024 16:52:23 +0100 Subject: [PATCH 07/32] Initial commit Initial commit --- README | 1 + 1 file changed, 1 insertion(+) create mode 100644 README diff --git a/README b/README new file mode 100644 index 0000000..9c469d9 --- /dev/null +++ b/README @@ -0,0 +1 @@ +# gardener-extension-csi-driver-lvm From fa24ef047a5d2656b33e1d0001b62cb3d4c73ff2 Mon Sep 17 00:00:00 2001 From: ostempel Date: Mon, 11 Nov 2024 11:48:47 +0100 Subject: [PATCH 08/32] fix removing of old csi-lvm --- .../templates/rbac.yaml | 2 ++ example/controller-registration.yaml | 2 +- pkg/controller/csi-driver-lvm/actuator.go | 11 +++++++++-- 3 files changed, 12 insertions(+), 3 deletions(-) diff --git a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml index 1a3bcdd..d0a20a6 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml @@ -46,6 +46,7 @@ rules: - get - list - watch + - delete - apiGroups: - "storage.k8s.io" resources: @@ -54,6 +55,7 @@ rules: - get - list - watch + - delete - apiGroups: - "" resources: diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index c6607e4..93e4891 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: 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 + rawChart: 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 values: image: tag: v0.0.1 diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 34689ba..47b7f28 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -758,8 +758,12 @@ func (a *actuator) removeOldCsilvm(ctx context.Context) error { } err := a.client.Get(ctx, client.ObjectKeyFromObject(namespace), namespace) + if err == nil { - a.client.Delete(ctx, namespace) + err = a.client.Delete(ctx, namespace) + if err != nil { + return fmt.Errorf("error while deleting old csi-lvm namespace: %w", err) + } } else if !apierrors.IsNotFound(err) { return fmt.Errorf("error while getting old csi-lvm namespace: %w", err) } @@ -773,7 +777,10 @@ func (a *actuator) removeOldCsilvm(ctx context.Context) error { err = a.client.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass) if err == nil { - a.client.Delete(ctx, storageClass) + err := a.client.Delete(ctx, storageClass) + if err != nil { + return fmt.Errorf("error while deleting old csi-lvm storageclass: %w", err) + } } else if !apierrors.IsNotFound(err) { return fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) } From dccc3b299c627ec9da4afd8e69e280645075e76c Mon Sep 17 00:00:00 2001 From: ostempel Date: Tue, 12 Nov 2024 13:47:43 +0100 Subject: [PATCH 09/32] added migration docs --- docs/migration.md | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 docs/migration.md diff --git a/docs/migration.md b/docs/migration.md new file mode 100644 index 0000000..d92f397 --- /dev/null +++ b/docs/migration.md @@ -0,0 +1,44 @@ +# Migration from csi-lvm to csi-driver-lvm + +## Objective + +The goal of this document is to provide instructions for migrating from the old [csi-lvm](https://github.com/metal-stack/csi-lvm/tree/master) to the new [csi-driver-lvm](https://github.com/metal-stack/csi-driver-lvm). + +## Issues + +### Drop-in replacement not possible + +Deploying the new csi-driver-lvm with the same provisioner-name as the old one is not possible, as it causes errors when using k8s sidecar images for controllers. + +The provisioner name contains "/", which causes problems with node registrar directories (**metal-stack.io/csi-lvm**): + +```sh +I1015 08:09:23.292306 1 node_register.go:53] Starting Registration Server at: /registration/metal-stack.io/csi-lvm-reg.sock + +E1015 08:09:23.292482 1 node_register.go:56] failed to listen on socket: /registration/metal-stack.io/csi-lvm-reg.sock with error: listen unix /registration/metal-stack.io/csi-lvm-reg.sock: bind: no such file or directory +``` + +This problem requires a more complex migration. + +## Solution + +### Local motivation +The migration solution so far has been tested manually: + +1. create old controller & provisioner +2. create pvcs & pod +3. write files to volumes +4. delete old controller & provisioner +5. install new controller & provisioner with helm +6. add additional storage class with name `csi-lvm` and type linear + 1. mimics old storage class + 2. default storage class +7. create new pvcs +8. create new pod with old and new pvcs and test + +### Migration + +To achieve this behaviour for csi-lvm, provided by [gardener-extension-provider-metal](https://github.com/metal-stack/gardener-extension-provider-metal/tree/master), we need to add the following workflow: + +1. Add a feature gate to `gardener-extension-provider-metal` to disable csi-lvm. +2. When deploying `gardener-extension-csi-driver-lvm`, stop reconciliation if old provisioner is still available. \ No newline at end of file From b2d051eb44445bbbfb2693e0eba7afb65714ebad Mon Sep 17 00:00:00 2001 From: ostempel Date: Tue, 12 Nov 2024 13:49:57 +0100 Subject: [PATCH 10/32] adjust readme --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 749ed87..1d8cadf 100644 --- a/README.md +++ b/README.md @@ -2,8 +2,8 @@ Provides a Gardener extension for managing [csi-driver-lvm](https://github.com/metal-stack/csi-driver-lvm) for a shoot cluster. -The extension checks for the old [csi-lvm](https://github.com/metal-stack/csi-lvm/tree/master) and removes it. -After success it applies the new driver. +The extension checks for the old [csi-lvm](https://github.com/metal-stack/csi-lvm/tree/master) and stops reconciling if the old driver is stil available. +If not the extension will reconcile the new `csi-driver-lvm`. ## Development From dd51c25a062e799ad901c22e1af7e5348335f8ef Mon Sep 17 00:00:00 2001 From: ostempel Date: Tue, 12 Nov 2024 14:14:51 +0100 Subject: [PATCH 11/32] add api docs and fix code style --- Makefile | 4 +-- .../Chart.yaml | 2 +- .../templates/rbac.yaml | 2 -- charts/images.yaml | 2 +- example/controller-registration.yaml | 2 +- go.mod | 12 ++++----- go.sum | 24 ++++++++--------- pkg/apis/config/types.go | 3 +++ pkg/apis/config/v1alpha1/types.go | 5 ++++ pkg/controller/csi-driver-lvm/actuator.go | 27 +++++++------------ 10 files changed, 40 insertions(+), 43 deletions(-) diff --git a/Makefile b/Makefile index 8e0a98b..181aff6 100644 --- a/Makefile +++ b/Makefile @@ -1,5 +1,5 @@ ENSURE_GARDENER_MOD := $(shell go get github.com/gardener/gardener@$$(go list -m -f "{{.Version}}" github.com/gardener/gardener)) -GARDENER_HACK_DIR := $(shell go list -m -f "{{.Dir}}" github.com/gardener/gardener)/hack +GARDENER_HACK_DIR := $(shell go list -m -f "{{.Dir}}" github.com/gardener/gardener)/hack IMAGE_TAG := $(or ${GITHUB_TAG_NAME}, latest) REGISTRY := ghcr.io/metal-stack IMAGE_PREFIX := $(REGISTRY) @@ -12,7 +12,7 @@ LEADER_ELECTION := false IGNORE_OPERATION_ANNOTATION := false WEBHOOK_CONFIG_URL := localhost -GOLANGCI_LINT_VERSION := v1.61.0 +GOLANGCI_LINT_VERSION := v1.62.0 GO_VERSION := 1.23 ifeq ($(CI),true) diff --git a/charts/gardener-extension-csi-driver-lvm/Chart.yaml b/charts/gardener-extension-csi-driver-lvm/Chart.yaml index 73a6e37..eaba1c7 100644 --- a/charts/gardener-extension-csi-driver-lvm/Chart.yaml +++ b/charts/gardener-extension-csi-driver-lvm/Chart.yaml @@ -2,4 +2,4 @@ apiVersion: v1 appVersion: "1.0" description: A Helm chart for the csi-driver-lvm extension name: gardener-extension-csi-driver-lvm -version: 0.2.0 +version: 0.1.0 diff --git a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml index d0a20a6..1a3bcdd 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml @@ -46,7 +46,6 @@ rules: - get - list - watch - - delete - apiGroups: - "storage.k8s.io" resources: @@ -55,7 +54,6 @@ rules: - get - list - watch - - delete - apiGroups: - "" resources: diff --git a/charts/images.yaml b/charts/images.yaml index 67523ef..e102f61 100644 --- a/charts/images.yaml +++ b/charts/images.yaml @@ -26,4 +26,4 @@ images: - name: csi-resizer sourceRepository: https://github.com/kubernetes-csi/external-resizer repository: k8s.gcr.io/sig-storage/csi-resizer - tag: "v2.5.1" + tag: "v1.6.0" diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index 93e4891..af71c40 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: H4sIAAAAAAAAA+0cf3PTOpK//Sk0gTcDM2c7TtL2nWe4u9IG6ABtJ+V4d/PmTUexlcTUtvwku7QP+O63kmxHdpw6ptAekB2GOLL2h6Td1WpX6Rwzn8SEmeQqJTEPaGx6PDB9FlxCY3gZ2Q9uDX2Avb0d+QlQ/5TPznDkDHYGu7ui3dkdOHsP0M7tWbdDxlPMEHrAKE1v6tf2/juFeev6HywwS61rHIVfykMs8O5otHb9B4Nhdf0HfWcI69//mgNdBz/5+uMkeEeYWHcXXToGTpLya8+x+j3DJ9xjQZLKpn30koQR8oRKoBllKF0QVNUXVCqSEeOIuKhVw4zLgmPfGlh9476n5KeCdvv3qWfN6W14tNn/aGdU8/97Q2e0tf+7ANueU3cuNACnBPEFMj3Um2J4ePRif3I4Ph5Pzl/uH7w6Pzya2EU/06NxymgYgoowMg94Cq2gOhag1byBhR499nCKLMuGf+/Gk7Ojk+Mn+VdyhaMkJPY6cmLTQeNCMd0q6Z5h2DY6xd4FnpPcJZEYT0PCUWVMWZLQ3F3ljUE8V56LMka8FC35owp/I9Gp/5COqd3+UwJrBBPJvzgS7Bz/DfoDZ2cb/90FdFn/8wUJE9irrTTpFAu2+H9nMNitrf9gZ7i79f93AR8/msgnsyAmqCfitR4yP3822mM2gUdiX/Y2dCIhnpKQWxBIWhfkWpGTX7IpYTEBPbICagtWFRprSFziMMtl+vgRBbEXZn4pqYVyxBsEWcWtCyiouGhNj5y/5LQ6iiAG5Yk9ItGtCQkJ5sQ6BuEaJStFCyLYVJRkCIk3wQwtMD9l8P4K9fgCD3Z2XWD7TrAHVqK/leI5KjESFsTpDPV+4f/6hdd7MpJQHqSUXd9EAsZImgi6X0wQBquNu74gPklCeh2ROM0D/lI5uA1HD3267tsqfh7o4v8hTJoF8wgnplz8SwidKDMpdPzAgpSszRG0xv+79fP/3nBvG//fCeTep2LV7+TCnhTrqnxfJU1wEcS+iw6kPrzBiRGRFPs4xS54AnXqb/bWzYqTI3GIthtcqWxWTkY5ZrfBnQvyn6ARdDlFI9G7EEdy5OdVLXXRJ0HkxlFXyWlO7b6X7KvCF9l/x2xgi/1DrO/U7H/YHzlb+78L+FqGXerGNzVmxaU0YQRgmqb81AdS1WBLDCK0SgXnVk6m0H3LC2nmQwyCw2SBHUmunIg8MaCmJFOJAaPmNXN6XhiAxNAzBlcC3dQ4QepauytbQWTPI4loB8HSt9cJ4XLCGPkzCxjxUa+FvrVKAAW8xO+1ydeEn4ssp7po7SiVhtlNHB2xlOPPpOusAEY3vgKh5DfNGE87cpQ43XgqlOrG0qxVC8rT38SOdIrTRSEnxNQ4C9OX+jtlbS3Irex8chl4onsKB50au0P9XRO7FeQlu/t2dFtohC77//IA1y0AaNn/90a79fzfEB62+/9dgL5tFidxtfcdlqu9cRTwTfZ+nhBPMGbgW4ScLwMuEhGvgygAP92Xb5Iw8DCveKS88YBmcaqYcpBFhPhq+41w6i1ebybHriJQWEJOQJsUuZvHMU1leMCLpjK503a8Krp7C+Jd8CzSjtpVa2w+QFXW47HM5KBH1ttcXOsZrID0/72NjvC9J3LsKgsFwugCatvHDTLfGCN+gbAtYhXaVEgUk/QDZaDFKyFeSk0G+hBExATF54TBwEHvw5B+IP5m+D4sbzeMJJuCJpp5n87YsPai5LYROiOcZswDTVslBGgmX4AX46bIYi4nwEy9xByNhkvKLebwazH1hWkW8SIOgGO5EGabr1AgFdFFvfp5XE86fv7srrxWqcdelc5pFoanFKb7uuIMFEZSvqzoL40iDA6vbDCR3Z7/XnY2c71+apPUs5sHm6uyrZ1fKhQifCWoeBljMMEmI+JLEBL+tBpj5YcR+Zx3PruOPa6PR9BbEBymC2mZ3WlryG18gnlMGTFpQtTByFw6wXXUFcpJgbFfItRp+wEXxVyt1lyROH+9PKFxUND3NIhR72+9usvSXDC4bRZ4/FSUhGsc81fmFPTcxL4P1sSf6oq3BrfBKdaYqilt4qnerGfZjNnOsbT/PNde51tqeP5en9qbcBs4C3IhnZshbCehTgcaX4s2WJj8AIF6QTyjvSbsGWWwJdfQn8tGHf89F3UDDZ/El7rpKpfzbP/g1fj48PxsfDAZvz0/3n8zPjvdPxiXHRGSlZ3njEau1ojQLCChPyGzamverk5ZxcZvlbFOG//Tyfj50X/qzN1iVOYUexcwqSYnHiOpuULu9Xj/cDw5H78eH7w9Ojm+u/F0DF8KeY/e7L8YvwNhTybnJ+/Gk98mR29XZHWRLa9VaLlZuzFZ26R7NcHKfU+XpmyU8V1K/ytuk6xifEJxvq85/doJuZSXhllE3ohQkq8qm3Lq2vAi0VHNbfuecNu5XpdRbxJmZb61foxg/yQOYd9MWUbW27uIGeCMv+95gvBx+w7/EOHZLIiD9NotWxBKqL8Pgdh+wytUplEOM4gO52ewFflZCE9Hcu/Im8dXxMv0dNrDfF5kxHJWCfaLl3JCROA/vkqEq9WD9WUPE12Q67Ul4bJovIKHkNoIgSs6ihteS71vYChYblCArqKlNKHgIq9fCVl71cK0SPvIhchxlAKvRGY1DfSKtK/uLDbO+haQO7U31Ae80aCfv+qk3pspd3d524zlBtl/xOLPg275H7BZiLpYJi8DTzN/TjZLBLXVf3dGe7X8z86gP9zmf+4CcrOcp+ixOIg3ZU+eIKdeAk7kKcq+dKYQOxQJo1PqH5bq8Uyqx/9H5ghOQP+O8SUOQnFikOR5Nm0d8K0zRt+D2+hi/wzi1C/5IUiL/Q+d3Z36/b++s7X/OwFRPtUtW64xztIFZcFf6hb0xa8yplhWh0OYM8ImNCRd7LuL5bIsFNFK/mGK4u4LRrNERjAm0kq51TyXUYn6RVdPCcvhCyj0NG8VrkmGigFXDx+Ebd+K0bJr7asNCpZmmwkgnpLyKUtgasmqVOuyfKtCRTiGgMcvWzcWAs6hWEZGpRRV0XzwjE2i9XqrQpSOfXP2a8mL1L9I5SmdbGCWd/BCzPnXYNjAAgJIOAdWSd80XytEPUqZH8S6da1ykbvfRlzalLgbu6Jd7rs11a4XIwDJF1tHqIraVWE1CcXEP0R+LArkHgjDYWclEZxg0JQgLH5zkR/G/nkrEwQGOf3a1y4meDuH+Awa4Gz6zfwisMiTOcU03SChUV5j0Tx2izwQGL2H1ZReVyGfVQ78XyWOu+9NbwsldIn/8tQPVpqweSTYdv4bjOr3/0aOs73/dyfQeP+vZvL3eoi77wn6waHd/lXS8jZ/AKDt/m+/P6r//m97//+OQFXfZSxVVNtdNF94TEQ48uKsCRPkXWxUEk/x3EVyrxBxQqLV4o9mxzQ9hXhNXCcy9GSLixxjGcehj58NQ6v45pd+9Rq0i3agUStSq+zMul4snULQrPrAW/LhKIZQCJT6TBTCfeg4FGnetWVpF81wyIlhrBacXfT7HwYEtk25bHE9WWTqVUXLlc9FVjvBGVd1bXlhwlAZfTUFE30ZgnSRTS2PRvYyva8/TkM6tSMsYjt7mgWhb0vS9iH1LgibBRDuFQUVjapa2zml85CcL69tKFwTR/7uKEeT69kbij8DoRrKv9TgWI5jXX3fo3JWRtX7x1MxsoF6YVmW1EVxZ8lYd4u76Q43TqR6i062qFcX+rm8T93YQ950dvqq6JBfQ3ZAOQ1Rl6hcvLXhux1fRuT3vvn3P2L5v7HuUrAsQQr7LH/V6Rr6mHvbLXYLW9jCFrawhZ8M/geBRB3TAFAAAA== + rawChart: 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 values: image: tag: v0.0.1 diff --git a/go.mod b/go.mod index 3fc89b0..fcb41af 100644 --- a/go.mod +++ b/go.mod @@ -7,7 +7,7 @@ require ( github.com/gardener/gardener v1.97.4 github.com/go-logr/logr v1.4.2 github.com/golang/mock v1.6.0 - github.com/metal-stack/metal-lib v0.18.4 + github.com/metal-stack/metal-lib v0.19.0 github.com/onsi/ginkgo v1.16.5 github.com/spf13/cobra v1.8.1 github.com/spf13/pflag v1.0.5 @@ -91,15 +91,15 @@ require ( go.uber.org/mock v0.4.0 // indirect go.uber.org/multierr v1.11.0 // indirect go.uber.org/zap v1.27.0 // indirect - golang.org/x/crypto v0.26.0 // indirect + golang.org/x/crypto v0.28.0 // indirect golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 // indirect golang.org/x/mod v0.20.0 // indirect - golang.org/x/net v0.28.0 // indirect + golang.org/x/net v0.30.0 // indirect golang.org/x/oauth2 v0.23.0 // indirect golang.org/x/sync v0.8.0 // indirect - golang.org/x/sys v0.23.0 // indirect - golang.org/x/term v0.23.0 // indirect - golang.org/x/text v0.17.0 // indirect + golang.org/x/sys v0.26.0 // indirect + golang.org/x/term v0.25.0 // indirect + golang.org/x/text v0.19.0 // indirect golang.org/x/time v0.6.0 // indirect golang.org/x/tools v0.24.0 // indirect gomodules.xyz/jsonpatch/v2 v2.4.0 // indirect diff --git a/go.sum b/go.sum index 4544c62..7ca464b 100644 --- a/go.sum +++ b/go.sum @@ -950,8 +950,8 @@ github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/ github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/mattn/go-sqlite3 v1.14.14/go.mod h1:NyWgC/yNuGj7Q9rpYnZvas74GogHl5/Z4A/KQRfk6bU= -github.com/metal-stack/metal-lib v0.18.4 h1:7HnfSwSbrKNHU+i6i79YFk/eeuhBhwIEHWpGqS7pYCc= -github.com/metal-stack/metal-lib v0.18.4/go.mod h1:Ctyi6zaXFr2NVrQZLFsDLnFCzupKnYErTtgRFKAsnbw= +github.com/metal-stack/metal-lib v0.19.0 h1:4yBnp/jPGgX9KeCje3A4MFL2oDjgjOjgsIK391LltRI= +github.com/metal-stack/metal-lib v0.19.0/go.mod h1:fCMaWwVGA/xAoGvBk72/nfzqBkHly0iOzrWpc55Fau4= github.com/minio/asm2plan9s v0.0.0-20200509001527-cdd76441f9d8/go.mod h1:mC1jAcsrzbxHt8iiaC+zU4b1ylILSosueou12R++wfY= github.com/minio/c2goasm v0.0.0-20190812172519-36a3d3bbc4f3/go.mod h1:RagcQ7I8IeTMnF8JTXieKnO4Z6JCsikNEzj0DwauVzE= github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw= @@ -1147,8 +1147,8 @@ golang.org/x/crypto v0.14.0/go.mod h1:MVFd36DqK4CsrnJYDkBA3VC4m2GkXAM0PvzMCn4JQf golang.org/x/crypto v0.16.0/go.mod h1:gCAAfMLgwOJRpTjQ2zCCt2OcSfYMTeZVSRtQlPC7Nq4= golang.org/x/crypto v0.19.0/go.mod h1:Iy9bg/ha4yyC70EfRS8jz+B6ybOBKMaSxLj6P6oBDfU= golang.org/x/crypto v0.21.0/go.mod h1:0BP7YvVV9gBbVKyeTG0Gyn+gZm94bibOW5BjDEYAOMs= -golang.org/x/crypto v0.26.0 h1:RrRspgV4mU+YwB4FYnuBoKsUapNIL5cohGAmSH3azsw= -golang.org/x/crypto v0.26.0/go.mod h1:GY7jblb9wI+FOo5y8/S2oY4zWP07AkOJ4+jxCqdqn54= +golang.org/x/crypto v0.28.0 h1:GBDwsMXVQi34v5CCYUm2jkJvu4cbtru2U4TN2PSyQnw= +golang.org/x/crypto v0.28.0/go.mod h1:rmgy+3RHxRZMyY0jjAJShp2zgEdOqj2AO7U0pYmeQ7U= golang.org/x/exp v0.0.0-20180321215751-8460e604b9de/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20180807140117-3d87b88a115f/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= @@ -1286,8 +1286,8 @@ golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE= golang.org/x/net v0.19.0/go.mod h1:CfAk/cbD4CthTvqiEl8NpboMuiuOYsAr/7NOjZJtv1U= golang.org/x/net v0.21.0/go.mod h1:bIjVDfnllIU7BJ2DNgfnXvpSvtn8VRwhlsaeUTyUS44= golang.org/x/net v0.23.0/go.mod h1:JKghWKKOSdJwpW2GEx0Ja7fmaKnMsbu+MWVZTokSYmg= -golang.org/x/net v0.28.0 h1:a9JDOJc5GMUJ0+UDqmLT86WiEy7iWyIhz8gz8E4e5hE= -golang.org/x/net v0.28.0/go.mod h1:yqtgsTWOOnlGLG9GFRrK3++bGOUEkNBoHZc8MEDWPNg= +golang.org/x/net v0.30.0 h1:AcW1SDZMkb8IpzCdQUaIq2sP4sZ4zw+55h6ynffypl4= +golang.org/x/net v0.30.0/go.mod h1:2wGyMJ5iFasEhkwi13ChkO/t1ECNC4X4eBKkVFyYFlU= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= @@ -1436,8 +1436,8 @@ golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.15.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/sys v0.17.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= -golang.org/x/sys v0.23.0 h1:YfKFowiIMvtgl1UERQoTPPToxltDeZfbj4H7dVUCwmM= -golang.org/x/sys v0.23.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.26.0 h1:KHjCJyddX0LoSTb3J+vWpupP9p0oznkqVk/IfjymZbo= +golang.org/x/sys v0.26.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= @@ -1455,8 +1455,8 @@ golang.org/x/term v0.13.0/go.mod h1:LTmsnFJwVN6bCy1rVCoS+qHT1HhALEFxKncY3WNNh4U= golang.org/x/term v0.15.0/go.mod h1:BDl952bC7+uMoWR75FIrCDx79TPU9oHkTZ9yRbYOrX0= golang.org/x/term v0.17.0/go.mod h1:lLRBjIVuehSbZlaOtGMbcMncT+aqLLLmKrsjNrUguwk= golang.org/x/term v0.18.0/go.mod h1:ILwASektA3OnRv7amZ1xhE/KTR+u50pbXfZ03+6Nx58= -golang.org/x/term v0.23.0 h1:F6D4vR+EHoL9/sWAWgAR1H2DcHr4PareCbAaCo1RpuU= -golang.org/x/term v0.23.0/go.mod h1:DgV24QBUrK6jhZXl+20l6UWznPlwAHm1Q1mGHtydmSk= +golang.org/x/term v0.25.0 h1:WtHI/ltw4NvSUig5KARz9h521QvRC8RmF/cuYqifU24= +golang.org/x/term v0.25.0/go.mod h1:RPyXicDX+6vLxogjjRxjgD2TKtmAO6NZBsBRfrOLu7M= golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= @@ -1477,8 +1477,8 @@ golang.org/x/text v0.11.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= golang.org/x/text v0.12.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= -golang.org/x/text v0.17.0 h1:XtiM5bkSOt+ewxlOE/aE/AKEHibwj/6gvWMl9Rsh0Qc= -golang.org/x/text v0.17.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= +golang.org/x/text v0.19.0 h1:kTxAhCbGbxhK0IwgSKiMO5awPoDQ0RpfiVYBfK860YM= +golang.org/x/text v0.19.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= diff --git a/pkg/apis/config/types.go b/pkg/apis/config/types.go index 86792ea..f85edb3 100644 --- a/pkg/apis/config/types.go +++ b/pkg/apis/config/types.go @@ -12,7 +12,10 @@ import ( type ControllerConfiguration struct { metav1.TypeMeta + // DefaultDevicePattern can be used to configure the glob pattern for the devices used by the LVM driver DefaultDevicePattern *string + + // DefaultHostWritePath can be used to configure the default path for the host write path - used on read-only filesystems (Talos OS "/var/etc/lvm") DefaultHostWritePath *string // HealthCheckConfig is the config for the health check controller diff --git a/pkg/apis/config/v1alpha1/types.go b/pkg/apis/config/v1alpha1/types.go index cc23f6e..b66df9d 100644 --- a/pkg/apis/config/v1alpha1/types.go +++ b/pkg/apis/config/v1alpha1/types.go @@ -11,7 +11,12 @@ import ( type ControllerConfiguration struct { metav1.TypeMeta `json:",inline"` + // DefaultDevicePattern can be used to configure the glob pattern for the devices used by the LVM driver + // +optional DefaultDevicePattern *string `json:"defaultDevicePattern,omitempty"` + + // DefaultHostWritePath can be used to configure the default path for the host write path - used on read-only filesystems (Talos OS "/var/etc/lvm") + // +optional DefaultHostWritePath *string `json:"defaultHostWritePath,omitempty"` // HealthCheckConfig is the config for the health check controller diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 47b7f28..218de9e 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -14,6 +14,7 @@ import ( "k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/runtime/serializer" "k8s.io/apimachinery/pkg/util/intstr" + "k8s.io/utils/ptr" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/manager" @@ -55,7 +56,7 @@ type actuator struct { // Reconcile the Extension resource. func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { - err := a.removeOldCsilvm(ctx) + err := a.checkForOldCsiLvm(ctx) if err != nil { return fmt.Errorf("unable to remove old csi-lvm driver: %w", err) @@ -245,7 +246,6 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) } var hostPathType corev1.HostPathType = corev1.HostPathDirectoryOrCreate - var replicas = int32(1) csidriverlvmStatefulsetController := &appsv1.StatefulSet{ ObjectMeta: metav1.ObjectMeta{ @@ -255,7 +255,7 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) Labels: map[string]string{}, }, Spec: appsv1.StatefulSetSpec{ - Replicas: &replicas, + Replicas: ptr.To(int32(1)), ServiceName: "csi-driver-lvm-controller", Selector: &metav1.LabelSelector{ MatchLabels: map[string]string{ @@ -265,7 +265,7 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) Template: corev1.PodTemplateSpec{ ObjectMeta: metav1.ObjectMeta{ Labels: map[string]string{ - "app": "csi-driver-lvm", + "app": "csi-driver-lvm-controller", }, Annotations: map[string]string{}, }, @@ -504,8 +504,6 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. var hostPathTypeCreate corev1.HostPathType = corev1.HostPathDirectoryOrCreate var hostPathTypeDir corev1.HostPathType = corev1.HostPathDirectory - var revisionHistoryLimit = int32(10) - var healthPort = int32(9898) csidriverlvmDaemonSetPlugin := &appsv1.DaemonSet{ ObjectMeta: metav1.ObjectMeta{ @@ -513,7 +511,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. Namespace: namespace, }, Spec: appsv1.DaemonSetSpec{ - RevisionHistoryLimit: &revisionHistoryLimit, + RevisionHistoryLimit: ptr.To(int32(10)), Selector: &metav1.LabelSelector{ MatchLabels: map[string]string{ "app": "csi-driver-lvm-plugin", @@ -596,7 +594,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. ProbeHandler: corev1.ProbeHandler{ HTTPGet: &corev1.HTTPGetAction{ Path: "/healthz", - Port: intstr.FromInt32(healthPort), + Port: intstr.FromInt(9898), Scheme: corev1.URISchemeHTTP, }, }, @@ -749,8 +747,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. return objects, nil } -func (a *actuator) removeOldCsilvm(ctx context.Context) error { - +func (a *actuator) checkForOldCsiLvm(ctx context.Context) error { namespace := &corev1.Namespace{ ObjectMeta: metav1.ObjectMeta{ Name: oldNamespace, @@ -760,10 +757,7 @@ func (a *actuator) removeOldCsilvm(ctx context.Context) error { err := a.client.Get(ctx, client.ObjectKeyFromObject(namespace), namespace) if err == nil { - err = a.client.Delete(ctx, namespace) - if err != nil { - return fmt.Errorf("error while deleting old csi-lvm namespace: %w", err) - } + return fmt.Errorf("old csi-lvm namespace still exists - please remove it via gardener-extension-provider-metal") } else if !apierrors.IsNotFound(err) { return fmt.Errorf("error while getting old csi-lvm namespace: %w", err) } @@ -777,10 +771,7 @@ func (a *actuator) removeOldCsilvm(ctx context.Context) error { err = a.client.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass) if err == nil { - err := a.client.Delete(ctx, storageClass) - if err != nil { - return fmt.Errorf("error while deleting old csi-lvm storageclass: %w", err) - } + return fmt.Errorf("old csi-lvm storage-class still exists - please remove it via gardener-extension-provider-metal") } else if !apierrors.IsNotFound(err) { return fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) } From c40d04892ef415b0dd953537baa274ed7b25a3ec Mon Sep 17 00:00:00 2001 From: ostempel Date: Tue, 12 Nov 2024 14:58:30 +0100 Subject: [PATCH 12/32] validate csidriverlvm-config --- pkg/apis/csidriverlvm/v1alpha1/types.go | 8 ++++++++ pkg/controller/csi-driver-lvm/actuator.go | 4 ++++ 2 files changed, 12 insertions(+) diff --git a/pkg/apis/csidriverlvm/v1alpha1/types.go b/pkg/apis/csidriverlvm/v1alpha1/types.go index 5c1aa44..bbf4d83 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/types.go +++ b/pkg/apis/csidriverlvm/v1alpha1/types.go @@ -1,6 +1,8 @@ package v1alpha1 import ( + "regexp" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" ) @@ -17,3 +19,9 @@ type CsiDriverLvmConfig struct { DevicePattern *string `json:"devicePattern,omitempty"` HostWritePath *string `json:"hostWritePath,omitempty"` } + +func (config *CsiDriverLvmConfig) IsVaild() bool { + re := regexp.MustCompile(`^(/[^/ ]*)+/?$`) + + return re.MatchString(*config.HostWritePath) && re.MatchString(*config.DevicePattern) +} diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 218de9e..c04dfe6 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -72,6 +72,10 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension } } + if !csidriverlvmConfig.IsVaild() { + return fmt.Errorf("invalid csi-driver-lvm configuration") + } + var hostwritepath = csidriverlvmConfig.HostWritePath var devicepattern = csidriverlvmConfig.DevicePattern From 7cc4401992442e4a291ae2c4cb6c312e0af38bc3 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 15 Nov 2024 09:00:57 +0100 Subject: [PATCH 13/32] fix reconciling of shoot --- pkg/controller/csi-driver-lvm/actuator.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index c04dfe6..85a3f7b 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -101,12 +101,12 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension objects = append(objects, controllerObjects...) objects = append(objects, pluginObjects...) - seedResources, err := managedresources.NewRegistry(kubernetes.SeedScheme, kubernetes.SeedCodec, kubernetes.SeedSerializer).AddAllAndSerialize(objects...) + shootResources, err := managedresources.NewRegistry(kubernetes.ShootScheme, kubernetes.SeedCodec, kubernetes.SeedSerializer).AddAllAndSerialize(objects...) if err != nil { return err } - err = managedresources.CreateForSeed(ctx, a.client, namespace, v1alpha1.ShootCsiDriverLvmResourceName, false, seedResources) + err = managedresources.CreateForShoot(ctx, a.client, namespace, v1alpha1.ShootCsiDriverLvmResourceName, "csi-driver-lvm-extension", false, shootResources) if err != nil { return nil From 534425a5d36adbe73063f40e34b7dc61cc0f6561 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 15 Nov 2024 14:19:28 +0100 Subject: [PATCH 14/32] refactor reconcilation --- .../templates/rbac.yaml | 8 +++ .../values.yaml | 4 +- example/controller-registration.yaml | 2 +- hack/update-codegen.sh | 4 +- pkg/apis/csidriverlvm/v1alpha1/doc.go | 4 +- pkg/apis/csidriverlvm/v1alpha1/register.go | 12 +++- pkg/apis/csidriverlvm/v1alpha1/types.go | 16 ++++- .../v1alpha1/zz_generated.conversion.go | 60 +++++++++++++++++++ pkg/controller/csi-driver-lvm/actuator.go | 59 +++++++++--------- 9 files changed, 129 insertions(+), 40 deletions(-) create mode 100644 pkg/apis/csidriverlvm/v1alpha1/zz_generated.conversion.go diff --git a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml index 1a3bcdd..03f876e 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml @@ -46,6 +46,14 @@ rules: - get - list - watch +- apiGroups: + - "" + resources: + - secrets + verbs: + - get + - list + - watch - apiGroups: - "storage.k8s.io" resources: diff --git a/charts/gardener-extension-csi-driver-lvm/values.yaml b/charts/gardener-extension-csi-driver-lvm/values.yaml index 0bd90f7..d9cce6e 100644 --- a/charts/gardener-extension-csi-driver-lvm/values.yaml +++ b/charts/gardener-extension-csi-driver-lvm/values.yaml @@ -37,8 +37,8 @@ config: qps: 100 burst: 130 - devicePattern: /dev/nvme[0-9]n[0-9] - defaultHostWritePath: /etc/lvm + devicePattern: /dev/loop10[0,1] + hostWritePath: /etc/lvm gardener: version: "" diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index af71c40..554bde4 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: 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 + rawChart: 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 values: image: tag: v0.0.1 diff --git a/hack/update-codegen.sh b/hack/update-codegen.sh index 5faede8..5584536 100755 --- a/hack/update-codegen.sh +++ b/hack/update-codegen.sh @@ -32,8 +32,8 @@ bash "${CODE_GEN_DIR}/generate-internal-groups.sh" \ github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/client \ github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis \ - "csi-driver-lvm:v1alpha1" \ - --extra-peer-dirs=github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csi-driver-lvm,github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csi-driver-lvm/v1alpha1,k8s.io/apimachinery/pkg/apis/meta/v1,k8s.io/apimachinery/pkg/conversion,k8s.io/apimachinery/pkg/runtime \ + "csidriverlvm:v1alpha1" \ + --extra-peer-dirs=github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm,github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1,k8s.io/apimachinery/pkg/apis/meta/v1,k8s.io/apimachinery/pkg/conversion,k8s.io/apimachinery/pkg/runtime \ --go-header-file "${PROJECT_ROOT}/hack/boilerplate.txt" bash "${CODE_GEN_DIR}/generate-internal-groups.sh" \ diff --git a/pkg/apis/csidriverlvm/v1alpha1/doc.go b/pkg/apis/csidriverlvm/v1alpha1/doc.go index 0b96759..c86aa2e 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/doc.go +++ b/pkg/apis/csidriverlvm/v1alpha1/doc.go @@ -1,6 +1,6 @@ // +k8s:deepcopy-gen=package -// +k8s:conversion-gen=github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csi-driver-lvm +// +k8s:conversion-gen=github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm // +k8s:openapi-gen=true // +k8s:defaulter-gen=TypeMeta -package v1alpha1 // import "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csi-driver-lvm/v1alpha1" +package v1alpha1 // import "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" diff --git a/pkg/apis/csidriverlvm/v1alpha1/register.go b/pkg/apis/csidriverlvm/v1alpha1/register.go index 8c88407..da3824d 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/register.go +++ b/pkg/apis/csidriverlvm/v1alpha1/register.go @@ -23,11 +23,19 @@ func Resource(resource string) schema.GroupResource { var ( // SchemeBuilder used to register the Shoot resource. - SchemeBuilder = runtime.NewSchemeBuilder(addKnownTypes) + SchemeBuilder runtime.SchemeBuilder + localSchemeBuilder = &SchemeBuilder // AddToScheme is a pointer to SchemeBuilder.AddToScheme. - AddToScheme = SchemeBuilder.AddToScheme + AddToScheme = localSchemeBuilder.AddToScheme ) +func init() { + // We only register manually written functions here. The registration of the + // generated functions takes place in the generated files. The separation + // makes the code compile even when the generated files are missing. + localSchemeBuilder.Register(addKnownTypes) +} + // Adds the list of known types to api.Scheme. func addKnownTypes(scheme *runtime.Scheme) error { scheme.AddKnownTypes(SchemeGroupVersion, diff --git a/pkg/apis/csidriverlvm/v1alpha1/types.go b/pkg/apis/csidriverlvm/v1alpha1/types.go index bbf4d83..47cfe76 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/types.go +++ b/pkg/apis/csidriverlvm/v1alpha1/types.go @@ -20,8 +20,22 @@ type CsiDriverLvmConfig struct { HostWritePath *string `json:"hostWritePath,omitempty"` } -func (config *CsiDriverLvmConfig) IsVaild() bool { +func (config *CsiDriverLvmConfig) ConfigureDefaults(hostWritePath *string, devicePattern *string) { + if config.HostWritePath == nil { + config.HostWritePath = hostWritePath + } + if config.DevicePattern == nil { + config.DevicePattern = devicePattern + } +} + +func (config *CsiDriverLvmConfig) IsValid() bool { re := regexp.MustCompile(`^(/[^/ ]*)+/?$`) + if (config.HostWritePath == nil) || (config.DevicePattern == nil) { + println("HostWritePath or DevicePattern is nil", config.HostWritePath, config.DevicePattern) + return false + } + return re.MatchString(*config.HostWritePath) && re.MatchString(*config.DevicePattern) } diff --git a/pkg/apis/csidriverlvm/v1alpha1/zz_generated.conversion.go b/pkg/apis/csidriverlvm/v1alpha1/zz_generated.conversion.go new file mode 100644 index 0000000..24797dc --- /dev/null +++ b/pkg/apis/csidriverlvm/v1alpha1/zz_generated.conversion.go @@ -0,0 +1,60 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +/* +2024 Copyright metal-stack Authors. +*/ + +// Code generated by conversion-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + unsafe "unsafe" + + csidriverlvm "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm" + conversion "k8s.io/apimachinery/pkg/conversion" + runtime "k8s.io/apimachinery/pkg/runtime" +) + +func init() { + localSchemeBuilder.Register(RegisterConversions) +} + +// RegisterConversions adds conversion functions to the given scheme. +// Public to allow building arbitrary schemes. +func RegisterConversions(s *runtime.Scheme) error { + if err := s.AddGeneratedConversionFunc((*CsiDriverLvmConfig)(nil), (*csidriverlvm.CsiDriverLvmConfig)(nil), func(a, b interface{}, scope conversion.Scope) error { + return Convert_v1alpha1_CsiDriverLvmConfig_To_csidriverlvm_CsiDriverLvmConfig(a.(*CsiDriverLvmConfig), b.(*csidriverlvm.CsiDriverLvmConfig), scope) + }); err != nil { + return err + } + if err := s.AddGeneratedConversionFunc((*csidriverlvm.CsiDriverLvmConfig)(nil), (*CsiDriverLvmConfig)(nil), func(a, b interface{}, scope conversion.Scope) error { + return Convert_csidriverlvm_CsiDriverLvmConfig_To_v1alpha1_CsiDriverLvmConfig(a.(*csidriverlvm.CsiDriverLvmConfig), b.(*CsiDriverLvmConfig), scope) + }); err != nil { + return err + } + return nil +} + +func autoConvert_v1alpha1_CsiDriverLvmConfig_To_csidriverlvm_CsiDriverLvmConfig(in *CsiDriverLvmConfig, out *csidriverlvm.CsiDriverLvmConfig, s conversion.Scope) error { + out.DevicePattern = (*string)(unsafe.Pointer(in.DevicePattern)) + out.HostWritePath = (*string)(unsafe.Pointer(in.HostWritePath)) + return nil +} + +// Convert_v1alpha1_CsiDriverLvmConfig_To_csidriverlvm_CsiDriverLvmConfig is an autogenerated conversion function. +func Convert_v1alpha1_CsiDriverLvmConfig_To_csidriverlvm_CsiDriverLvmConfig(in *CsiDriverLvmConfig, out *csidriverlvm.CsiDriverLvmConfig, s conversion.Scope) error { + return autoConvert_v1alpha1_CsiDriverLvmConfig_To_csidriverlvm_CsiDriverLvmConfig(in, out, s) +} + +func autoConvert_csidriverlvm_CsiDriverLvmConfig_To_v1alpha1_CsiDriverLvmConfig(in *csidriverlvm.CsiDriverLvmConfig, out *CsiDriverLvmConfig, s conversion.Scope) error { + out.DevicePattern = (*string)(unsafe.Pointer(in.DevicePattern)) + out.HostWritePath = (*string)(unsafe.Pointer(in.HostWritePath)) + return nil +} + +// Convert_csidriverlvm_CsiDriverLvmConfig_To_v1alpha1_CsiDriverLvmConfig is an autogenerated conversion function. +func Convert_csidriverlvm_CsiDriverLvmConfig_To_v1alpha1_CsiDriverLvmConfig(in *csidriverlvm.CsiDriverLvmConfig, out *CsiDriverLvmConfig, s conversion.Scope) error { + return autoConvert_csidriverlvm_CsiDriverLvmConfig_To_v1alpha1_CsiDriverLvmConfig(in, out, s) +} diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 85a3f7b..d51b7a2 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -7,10 +7,17 @@ import ( "github.com/gardener/gardener/extensions/pkg/controller/extension" + gutil "github.com/gardener/gardener/extensions/pkg/util" extensionsv1alpha1 "github.com/gardener/gardener/pkg/apis/extensions/v1alpha1" "github.com/gardener/gardener/pkg/client/kubernetes" "github.com/gardener/gardener/pkg/utils/managedresources" + + extensionsconfig "github.com/gardener/gardener/extensions/pkg/apis/config" "github.com/go-logr/logr" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" + "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/imagevector" + "github.com/metal-stack/metal-lib/pkg/pointer" "k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/runtime/serializer" "k8s.io/apimachinery/pkg/util/intstr" @@ -18,11 +25,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/manager" - "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/config" - "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/apis/csidriverlvm/v1alpha1" - "github.com/metal-stack/gardener-extension-csi-driver-lvm/pkg/imagevector" - "github.com/metal-stack/metal-lib/pkg/pointer" - appsv1 "k8s.io/api/apps/v1" corev1 "k8s.io/api/core/v1" rbacv1 "k8s.io/api/rbac/v1" @@ -56,14 +58,6 @@ type actuator struct { // Reconcile the Extension resource. func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { - err := a.checkForOldCsiLvm(ctx) - - if err != nil { - return fmt.Errorf("unable to remove old csi-lvm driver: %w", err) - } - - log.Info("successfully removed old csi-lvm driver") - csidriverlvmConfig := &v1alpha1.CsiDriverLvmConfig{} if ex.Spec.ProviderConfig != nil { _, _, err := a.decoder.Decode(ex.Spec.ProviderConfig.Raw, nil, csidriverlvmConfig) @@ -72,19 +66,18 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension } } - if !csidriverlvmConfig.IsVaild() { + csidriverlvmConfig.ConfigureDefaults(a.config.DefaultHostWritePath, a.config.DefaultDevicePattern) + if !csidriverlvmConfig.IsValid() { return fmt.Errorf("invalid csi-driver-lvm configuration") } - var hostwritepath = csidriverlvmConfig.HostWritePath - var devicepattern = csidriverlvmConfig.DevicePattern - - if hostwritepath == nil { - csidriverlvmConfig.HostWritePath = a.config.DefaultHostWritePath + isOldCsiLvmExisting, err := a.isOldCsiLvmExisting(ctx, ex.Namespace) + if err != nil { + return fmt.Errorf("failed to check if old csi-lvm is existing: %w", err) } - - if devicepattern == nil { - csidriverlvmConfig.DevicePattern = a.config.DefaultDevicePattern + if isOldCsiLvmExisting { + log.Info("old csi-lvm is existing, skipping reconcilation") + return nil } controllerObjects, err := a.controllerObjects(namespace) @@ -751,19 +744,25 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. return objects, nil } -func (a *actuator) checkForOldCsiLvm(ctx context.Context) error { +func (a *actuator) isOldCsiLvmExisting(ctx context.Context, shootNamespace string) (bool, error) { + _, shootClient, err := gutil.NewClientForShoot(ctx, a.client, shootNamespace, client.Options{}, extensionsconfig.RESTOptions{}) + + if err != nil { + return true, fmt.Errorf("failed to create shoot client: %w", err) + } + namespace := &corev1.Namespace{ ObjectMeta: metav1.ObjectMeta{ Name: oldNamespace, }, } - err := a.client.Get(ctx, client.ObjectKeyFromObject(namespace), namespace) + err = shootClient.Get(ctx, client.ObjectKeyFromObject(namespace), namespace) if err == nil { - return fmt.Errorf("old csi-lvm namespace still exists - please remove it via gardener-extension-provider-metal") + return true, nil } else if !apierrors.IsNotFound(err) { - return fmt.Errorf("error while getting old csi-lvm namespace: %w", err) + return true, fmt.Errorf("error while getting old csi-lvm namespace: %w", err) } storageClass := &storagev1.StorageClass{ @@ -773,11 +772,11 @@ func (a *actuator) checkForOldCsiLvm(ctx context.Context) error { Provisioner: oldProvisioner, } - err = a.client.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass) + err = shootClient.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass) if err == nil { - return fmt.Errorf("old csi-lvm storage-class still exists - please remove it via gardener-extension-provider-metal") + return true, nil } else if !apierrors.IsNotFound(err) { - return fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) + return true, fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) } - return nil + return false, nil } From 751bd21e98cf97e0997d417b68a3e021e0d44aa7 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 15 Nov 2024 17:13:55 +0100 Subject: [PATCH 15/32] fix controller images --- .../templates/rbac.yaml | 2 ++ example/controller-registration.yaml | 2 +- pkg/controller/csi-driver-lvm/actuator.go | 36 +++++++++++++++---- 3 files changed, 32 insertions(+), 8 deletions(-) diff --git a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml index 03f876e..4ba9d1c 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/rbac.yaml @@ -54,6 +54,8 @@ rules: - get - list - watch + - create + - delete - apiGroups: - "storage.k8s.io" resources: diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index 554bde4..e276a8f 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: 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 + rawChart: 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 values: image: tag: v0.0.1 diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index d51b7a2..02a4009 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -34,7 +34,8 @@ import ( ) const ( - namespace string = "kube-system" + namespace string = "kube-system" + provisioner string = "lvm.csi.metal-stack.io" oldName string = "csi-lvm" oldNamespace string = "csi-lvm" @@ -94,15 +95,15 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension objects = append(objects, controllerObjects...) objects = append(objects, pluginObjects...) - shootResources, err := managedresources.NewRegistry(kubernetes.ShootScheme, kubernetes.SeedCodec, kubernetes.SeedSerializer).AddAllAndSerialize(objects...) + shootResources, err := managedresources.NewRegistry(kubernetes.ShootScheme, kubernetes.ShootCodec, kubernetes.ShootSerializer).AddAllAndSerialize(objects...) if err != nil { return err } - err = managedresources.CreateForShoot(ctx, a.client, namespace, v1alpha1.ShootCsiDriverLvmResourceName, "csi-driver-lvm-extension", false, shootResources) + err = managedresources.CreateForShoot(ctx, a.client, ex.Namespace, v1alpha1.ShootCsiDriverLvmResourceName, "csi-driver-lvm-extension", false, shootResources) if err != nil { - return nil + return err } log.Info("managed resource created succesfully", "name", v1alpha1.ShootCsiDriverLvmResourceName) @@ -242,6 +243,11 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) return nil, fmt.Errorf("failed to find csi-resizer image: %w", err) } + csiProvisionerImage, err := imagevector.ImageVector().FindImage("csi-provisioner") + if err != nil { + return nil, fmt.Errorf("failed to find csi-provisioner image: %w", err) + } + var hostPathType corev1.HostPathType = corev1.HostPathDirectoryOrCreate csidriverlvmStatefulsetController := &appsv1.StatefulSet{ @@ -293,6 +299,19 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) Name: "csi-attacher", Image: csiAttacherImage.String(), ImagePullPolicy: "IfNotPresent", + Args: []string{"--v=5", "--csi-address=/csi/csi.sock"}, + SecurityContext: &corev1.SecurityContext{ + ReadOnlyRootFilesystem: pointer.Pointer(true), + Privileged: pointer.Pointer(true), + }, + VolumeMounts: []corev1.VolumeMount{ + {MountPath: "/csi", Name: "socket-dir"}, + }, + }, + { + Name: "csi-provisioner", + Image: csiProvisionerImage.String(), + ImagePullPolicy: "IfNotPresent", Args: []string{"--v=5", "--csi-address=/csi/csi.sock", "--feature-gates=Topology=true"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), @@ -769,12 +788,15 @@ func (a *actuator) isOldCsiLvmExisting(ctx context.Context, shootNamespace strin ObjectMeta: metav1.ObjectMeta{ Name: oldName, }, - Provisioner: oldProvisioner, } - err = shootClient.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass) + err = shootClient.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass, &client.GetOptions{}) if err == nil { - return true, nil + if storageClass.Provisioner == provisioner { + return true, nil + } else { + return false, fmt.Errorf("old csi-lvm storageclass is existing ") + } } else if !apierrors.IsNotFound(err) { return true, fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) } From 8f8b40d840042b5dea0bec5c28f971e9c90b1649 Mon Sep 17 00:00:00 2001 From: ostempel Date: Mon, 18 Nov 2024 10:34:43 +0100 Subject: [PATCH 16/32] fix reconciling of shoot --- example/pod.yaml | 39 ++++++++++++++++++ example/pvc.yaml | 48 +++++++++++++++++++++++ go.mod | 2 +- pkg/controller/csi-driver-lvm/actuator.go | 8 ++-- 4 files changed, 92 insertions(+), 5 deletions(-) create mode 100644 example/pod.yaml create mode 100644 example/pvc.yaml diff --git a/example/pod.yaml b/example/pod.yaml new file mode 100644 index 0000000..7fe7961 --- /dev/null +++ b/example/pod.yaml @@ -0,0 +1,39 @@ +--- +apiVersion: v1 +kind: Pod +metadata: + name: volume-test + namespace: default +spec: + containers: + - name: volume-test + image: nginx:stable-alpine + imagePullPolicy: IfNotPresent + volumeMounts: + - name: linear + mountPath: /linear + - name: mirror + mountPath: /mirror + - name: striped + mountPath: /striped + - name: default + mountPath: /default + ports: + - containerPort: 80 + resources: + limits: + cpu: 100m + memory: 100M + volumes: + - name: linear + persistentVolumeClaim: + claimName: csi-pvc-linear + - name: mirror + persistentVolumeClaim: + claimName: csi-pvc-mirror + - name: striped + persistentVolumeClaim: + claimName: csi-pvc-striped + - name: default + persistentVolumeClaim: + claimName: csi-pvc-default \ No newline at end of file diff --git a/example/pvc.yaml b/example/pvc.yaml new file mode 100644 index 0000000..2fd7c88 --- /dev/null +++ b/example/pvc.yaml @@ -0,0 +1,48 @@ +--- +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: csi-pvc-linear +spec: + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 10Mi + storageClassName: csi-driver-lvm-linear +--- +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: csi-pvc-striped +spec: + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 10Mi + storageClassName: csi-driver-lvm-striped +--- +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: csi-pvc-mirror +spec: + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 10Mi + storageClassName: csi-driver-lvm-mirror +--- +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: csi-pvc-default +spec: + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 10Mi + storageClassName: csi-lvm \ No newline at end of file diff --git a/go.mod b/go.mod index fcb41af..1dcc3cc 100644 --- a/go.mod +++ b/go.mod @@ -15,6 +15,7 @@ require ( k8s.io/apimachinery v0.31.1 k8s.io/code-generator v0.31.1 k8s.io/component-base v0.31.1 + k8s.io/utils v0.0.0-20240711033017-18e509b52bc8 sigs.k8s.io/controller-runtime v0.17.5 ) @@ -122,7 +123,6 @@ require ( k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 // indirect k8s.io/kubelet v0.29.5 // indirect k8s.io/metrics v0.29.5 // indirect - k8s.io/utils v0.0.0-20240711033017-18e509b52bc8 // indirect sigs.k8s.io/controller-runtime/tools/setup-envtest v0.0.0-20231015215740-bf15e44028f9 // indirect sigs.k8s.io/controller-tools v0.14.0 // indirect sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd // indirect diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 02a4009..e9c9221 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -188,7 +188,7 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) }, { APIGroups: []string{"storage.k8s.io"}, - Resources: []string{"storageclaess"}, + Resources: []string{"storageclasses"}, Verbs: []string{"get", "list", "watch"}, }, { @@ -779,7 +779,7 @@ func (a *actuator) isOldCsiLvmExisting(ctx context.Context, shootNamespace strin err = shootClient.Get(ctx, client.ObjectKeyFromObject(namespace), namespace) if err == nil { - return true, nil + return true, fmt.Errorf("old csi-lvm namespace is existing") } else if !apierrors.IsNotFound(err) { return true, fmt.Errorf("error while getting old csi-lvm namespace: %w", err) } @@ -793,9 +793,9 @@ func (a *actuator) isOldCsiLvmExisting(ctx context.Context, shootNamespace strin err = shootClient.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass, &client.GetOptions{}) if err == nil { if storageClass.Provisioner == provisioner { - return true, nil + return false, nil } else { - return false, fmt.Errorf("old csi-lvm storageclass is existing ") + return true, fmt.Errorf("old csi-lvm storageclass is existing") } } else if !apierrors.IsNotFound(err) { return true, fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) From 28e534884f4553efd938f58457c40e7f2b56e040 Mon Sep 17 00:00:00 2001 From: ostempel Date: Mon, 18 Nov 2024 11:20:49 +0100 Subject: [PATCH 17/32] adjust readme --- README.md | 49 ++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 48 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 1d8cadf..db1be31 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,54 @@ If not the extension will reconcile the new `csi-driver-lvm`. ## Development -This extension can be developed in the gardener-local devel environment. +This extension can be developed in the gardener-local devel environment. Before make sure you have created loop-devices on your machine. + +```sh +for i in 100 101; do fallocate -l 1G loop${i}.img ; sudo losetup /dev/loop${i} loop${i}.img; done +sudo losetup -a +# use this for recreation or cleanup +# for i in 100 101; do sudo losetup -d /dev/loop${i}; rm -f loop${i}.img; done +``` + +Next you need to add these devices to the gardener kind cluster config (`example/gardener-local/kind/cluster/templates/cluster.yaml`). +```yaml + - hostPath: /dev/loop100 + containerPath: /dev/loop100 + - hostPath: /dev/loop101 + containerPath: /dev/loop101 +``` + +In the end you also have to mount these volumes on machine creation (`pkg/provider-local/machine-provider/local/create_machine.go`): + +```go +// applyPod() +// Volume-Mounts + { + Name: "loop100", + MountPath: "/dev/loop100", + }, + { + Name: "loop101", + MountPath: "/dev/loop101", + }, +// Volumes + { + Name: "loop100", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/dev/loop100", + }, + }, + }, + { + Name: "loop101", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/dev/loop101", + }, + }, + }, +``` 1. Start up the local devel environment 1. The extension's docker image can be pushed into Kind using `make push-to-gardener-local` From a281ac97f6ad10669ae61720bb15657470a65b35 Mon Sep 17 00:00:00 2001 From: ostempel Date: Mon, 18 Nov 2024 11:59:36 +0100 Subject: [PATCH 18/32] fix testing of old csi-lvm --- example/{pod.yaml => pod-migration.yaml} | 25 ++++++++++++++++++----- example/{pvc.yaml => pvc-migration.yaml} | 8 ++++---- pkg/controller/csi-driver-lvm/actuator.go | 4 ++-- 3 files changed, 26 insertions(+), 11 deletions(-) rename example/{pod.yaml => pod-migration.yaml} (52%) rename example/{pvc.yaml => pvc-migration.yaml} (84%) diff --git a/example/pod.yaml b/example/pod-migration.yaml similarity index 52% rename from example/pod.yaml rename to example/pod-migration.yaml index 7fe7961..328c942 100644 --- a/example/pod.yaml +++ b/example/pod-migration.yaml @@ -2,7 +2,7 @@ apiVersion: v1 kind: Pod metadata: - name: volume-test + name: volume-test-migration namespace: default spec: containers: @@ -18,6 +18,12 @@ spec: mountPath: /striped - name: default mountPath: /default + - name: linear-old + mountPath: /linear-old + - name: mirror-old + mountPath: /mirror-old + - name: striped-old + mountPath: /striped-old ports: - containerPort: 80 resources: @@ -27,13 +33,22 @@ spec: volumes: - name: linear persistentVolumeClaim: - claimName: csi-pvc-linear + claimName: csi-driver-lvm-pvc-linear - name: mirror persistentVolumeClaim: - claimName: csi-pvc-mirror + claimName: csi-driver-lvm-pvc-mirror - name: striped persistentVolumeClaim: - claimName: csi-pvc-striped + claimName: csi-driver-lvm-pvc-striped - name: default persistentVolumeClaim: - claimName: csi-pvc-default \ No newline at end of file + claimName: csi-driver-lvm-pvc-default + - name: linear-old + persistentVolumeClaim: + claimName: lvm-pvc-linear + - name: mirror-old + persistentVolumeClaim: + claimName: lvm-pvc-mirror + - name: striped-old + persistentVolumeClaim: + claimName: lvm-pvc-striped \ No newline at end of file diff --git a/example/pvc.yaml b/example/pvc-migration.yaml similarity index 84% rename from example/pvc.yaml rename to example/pvc-migration.yaml index 2fd7c88..cce6da3 100644 --- a/example/pvc.yaml +++ b/example/pvc-migration.yaml @@ -2,7 +2,7 @@ apiVersion: v1 kind: PersistentVolumeClaim metadata: - name: csi-pvc-linear + name: csi-driver-lvm-pvc-linear spec: accessModes: - ReadWriteOnce @@ -14,7 +14,7 @@ spec: apiVersion: v1 kind: PersistentVolumeClaim metadata: - name: csi-pvc-striped + name: csi-driver-lvm-pvc-striped spec: accessModes: - ReadWriteOnce @@ -26,7 +26,7 @@ spec: apiVersion: v1 kind: PersistentVolumeClaim metadata: - name: csi-pvc-mirror + name: csi-driver-lvm-pvc-mirror spec: accessModes: - ReadWriteOnce @@ -38,7 +38,7 @@ spec: apiVersion: v1 kind: PersistentVolumeClaim metadata: - name: csi-pvc-default + name: csi-driver-lvm-pvc-default spec: accessModes: - ReadWriteOnce diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index e9c9221..f8d0454 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -779,7 +779,7 @@ func (a *actuator) isOldCsiLvmExisting(ctx context.Context, shootNamespace strin err = shootClient.Get(ctx, client.ObjectKeyFromObject(namespace), namespace) if err == nil { - return true, fmt.Errorf("old csi-lvm namespace is existing") + return true, nil } else if !apierrors.IsNotFound(err) { return true, fmt.Errorf("error while getting old csi-lvm namespace: %w", err) } @@ -795,7 +795,7 @@ func (a *actuator) isOldCsiLvmExisting(ctx context.Context, shootNamespace strin if storageClass.Provisioner == provisioner { return false, nil } else { - return true, fmt.Errorf("old csi-lvm storageclass is existing") + return true, nil } } else if !apierrors.IsNotFound(err) { return true, fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) From 2fceb161593f2aba07f9ac962c8604d84930bf05 Mon Sep 17 00:00:00 2001 From: ostempel Date: Tue, 19 Nov 2024 13:02:06 +0100 Subject: [PATCH 19/32] fix deletion of managed resource --- pkg/controller/csi-driver-lvm/actuator.go | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index f8d0454..e64d58c 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -114,7 +114,8 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension // Delete the Extension resource. func (a *actuator) Delete(ctx context.Context, log logr.Logger, ex *extensionsv1alpha1.Extension) error { - err := managedresources.Delete(ctx, a.client, namespace, v1alpha1.ShootCsiDriverLvmResourceName, false) + log.Info("deleting managed resource") + err := managedresources.Delete(ctx, a.client, ex.Namespace, v1alpha1.ShootCsiDriverLvmResourceName, false) if err != nil { return err @@ -123,11 +124,13 @@ func (a *actuator) Delete(ctx context.Context, log logr.Logger, ex *extensionsv1 timeoutCtx, cancel := context.WithTimeout(ctx, 2*time.Minute) defer cancel() - err = managedresources.WaitUntilDeleted(timeoutCtx, a.client, namespace, v1alpha1.ShootCsiDriverLvmResourceName) + err = managedresources.WaitUntilDeleted(timeoutCtx, a.client, ex.Namespace, v1alpha1.ShootCsiDriverLvmResourceName) if err != nil { return err } + log.Info("successfully deleted managed resource") + return nil } From 0b7d8246255b6aa6a1c96c398557971952e9123c Mon Sep 17 00:00:00 2001 From: ostempel Date: Tue, 19 Nov 2024 14:03:03 +0100 Subject: [PATCH 20/32] finish draft --- example/pod-migration.yaml | 17 +---------------- example/shoot.yaml | 3 +++ pkg/controller/csi-driver-lvm/actuator.go | 2 +- 3 files changed, 5 insertions(+), 17 deletions(-) diff --git a/example/pod-migration.yaml b/example/pod-migration.yaml index 328c942..2d0952c 100644 --- a/example/pod-migration.yaml +++ b/example/pod-migration.yaml @@ -18,12 +18,6 @@ spec: mountPath: /striped - name: default mountPath: /default - - name: linear-old - mountPath: /linear-old - - name: mirror-old - mountPath: /mirror-old - - name: striped-old - mountPath: /striped-old ports: - containerPort: 80 resources: @@ -42,13 +36,4 @@ spec: claimName: csi-driver-lvm-pvc-striped - name: default persistentVolumeClaim: - claimName: csi-driver-lvm-pvc-default - - name: linear-old - persistentVolumeClaim: - claimName: lvm-pvc-linear - - name: mirror-old - persistentVolumeClaim: - claimName: lvm-pvc-mirror - - name: striped-old - persistentVolumeClaim: - claimName: lvm-pvc-striped \ No newline at end of file + claimName: csi-driver-lvm-pvc-default \ No newline at end of file diff --git a/example/shoot.yaml b/example/shoot.yaml index b4437cf..20d5049 100644 --- a/example/shoot.yaml +++ b/example/shoot.yaml @@ -17,6 +17,9 @@ spec: providerConfig: apiVersion: csi-driver-lvm.metal.extensions.gardener.cloud/v1alpha1 kind: CsiDriverLvmConfig + # Your configuration here + # devicePattern: /dev/nvme[0-9]n[0-9] + # hostWritePath: /etc/lib networking: type: calico nodes: 10.10.0.0/16 diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index e64d58c..525d0d0 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -582,7 +582,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. "--drivername=lvm.csi.metal-stack.io", "--endpoint=unix:///csi/csi.sock", "--hostwritepath=" + pointer.SafeDeref(csidriverlvmConfig.HostWritePath), - "--devices=" + pointer.SafeDeref(csidriverlvmConfig.HostWritePath), + "--devices=" + pointer.SafeDeref(csidriverlvmConfig.DevicePattern), "--nodeid=$(KUBE_NODE_NAME)", "--vgname=csi-lvm", "--namespace=kube-system", From 5bf755a3ecec9ad1632baf6b4c59e501881c8da4 Mon Sep 17 00:00:00 2001 From: ostempel Date: Tue, 19 Nov 2024 15:28:25 +0100 Subject: [PATCH 21/32] adjust makefile --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 181aff6..d830f75 100644 --- a/Makefile +++ b/Makefile @@ -85,8 +85,8 @@ generate-in-docker: tidy $(HELM) $(YQ) # echo $(shell git describe --abbrev=0 --tags) > VERSION docker run --rm -i$(DOCKER_TTY_ARG) -v $(PWD):/go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm golang:$(GO_VERSION) \ sh -c "cd /go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm \ + && chown -R $(shell id -u):$(shell id -g) . \ && make generate \ - # && make install generate \ && chown -R $(shell id -u):$(shell id -g) ." .PHONY: test From 4839b658f983378f90b9b09c50dbbacb2e711934 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 22 Nov 2024 13:37:11 +0100 Subject: [PATCH 22/32] fix generate-in-docker --- Makefile | 5 ++--- example/controller-registration.yaml | 2 +- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/Makefile b/Makefile index d830f75..762770b 100644 --- a/Makefile +++ b/Makefile @@ -78,14 +78,13 @@ check-generate: .PHONY: generate generate: $(VGOPATH) $(HELM) $(YQ) + # echo $(shell git -c safe.directory=/go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm describe --abbrev=0 --tags) > VERSION @REPO_ROOT=$(REPO_ROOT) VGOPATH=$(VGOPATH) GARDENER_HACK_DIR=$(GARDENER_HACK_DIR) bash $(GARDENER_HACK_DIR)/generate-sequential.sh ./charts/... ./cmd/... ./pkg/... .PHONY: generate-in-docker -generate-in-docker: tidy $(HELM) $(YQ) - # echo $(shell git describe --abbrev=0 --tags) > VERSION +generate-in-docker: tidy install $(HELM) $(YQ) docker run --rm -i$(DOCKER_TTY_ARG) -v $(PWD):/go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm golang:$(GO_VERSION) \ sh -c "cd /go/src/github.com/metal-stack/gardener-extension-csi-driver-lvm \ - && chown -R $(shell id -u):$(shell id -g) . \ && make generate \ && chown -R $(shell id -u):$(shell id -g) ." diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index e276a8f..1b58a3f 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: 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 + rawChart: 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 values: image: tag: v0.0.1 From cbfddd7b02def115906b15ad423647dc7697e8ef Mon Sep 17 00:00:00 2001 From: ostempel Date: Mon, 25 Nov 2024 10:18:17 +0100 Subject: [PATCH 23/32] adjust to feedback --- .../templates/deployment.yaml | 9 -- .../templates/poddisruptionbudget.yaml | 2 +- .../values.yaml | 2 +- .../app/options.go | 10 +- docs/migration.md | 4 +- example/controller-registration.yaml | 2 +- go.mod | 2 + pkg/apis/csidriverlvm/types.go | 3 + pkg/apis/csidriverlvm/v1alpha1/types.go | 34 +++++- pkg/apis/csidriverlvm/v1alpha1/types_test.go | 112 ++++++++++++++++++ pkg/controller/csi-driver-lvm/actuator.go | 90 +++++++------- 11 files changed, 193 insertions(+), 77 deletions(-) create mode 100644 pkg/apis/csidriverlvm/v1alpha1/types_test.go diff --git a/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml b/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml index 96b1e45..e821a9d 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/deployment.yaml @@ -20,10 +20,7 @@ spec: checksum/configmap-{{ include "name" . }}-config: {{ include (print $.Template.BasePath "/configmap.yaml") . | sha256sum }} labels: networking.gardener.cloud/to-runtime-apiserver: allowed - networking.gardener.cloud/to-dns: allowed - networking.gardener.cloud/to-public-networks: allowed networking.gardener.cloud/to-private-networks: allowed - networking.resources.gardener.cloud/to-all-shoots-kube-apiserver-tcp-443: allowed {{ include "labels" . | indent 8 }} spec: containers: @@ -49,12 +46,6 @@ spec: - --log-level={{ .Values.logLevel | default "info" }} - --log-format={{ .Values.logFormat | default "json" }} env: - - name: BACKEND_SECRET_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - - name: BACKEND_SECRET_PREFIX - value: default-backend-secret- - name: LEADER_ELECTION_NAMESPACE valueFrom: fieldRef: diff --git a/charts/gardener-extension-csi-driver-lvm/templates/poddisruptionbudget.yaml b/charts/gardener-extension-csi-driver-lvm/templates/poddisruptionbudget.yaml index 6a135cc..0e757eb 100644 --- a/charts/gardener-extension-csi-driver-lvm/templates/poddisruptionbudget.yaml +++ b/charts/gardener-extension-csi-driver-lvm/templates/poddisruptionbudget.yaml @@ -1,5 +1,5 @@ {{- if gt (int .Values.replicaCount) 1 }} -apiVersion: policy/v1beta1 +apiVersion: policy/v1 kind: PodDisruptionBudget metadata: name: {{ include "name" . }} diff --git a/charts/gardener-extension-csi-driver-lvm/values.yaml b/charts/gardener-extension-csi-driver-lvm/values.yaml index d9cce6e..5d0f219 100644 --- a/charts/gardener-extension-csi-driver-lvm/values.yaml +++ b/charts/gardener-extension-csi-driver-lvm/values.yaml @@ -37,7 +37,7 @@ config: qps: 100 burst: 130 - devicePattern: /dev/loop10[0,1] + devicePattern: /dev/nvme[0-1]n[0-9] hostWritePath: /etc/lvm gardener: diff --git a/cmd/gardener-extension-csi-driver-lvm/app/options.go b/cmd/gardener-extension-csi-driver-lvm/app/options.go index 60f82c3..e5a34b2 100644 --- a/cmd/gardener-extension-csi-driver-lvm/app/options.go +++ b/cmd/gardener-extension-csi-driver-lvm/app/options.go @@ -115,22 +115,19 @@ func (options *Options) run(ctx context.Context) error { if err != nil { return fmt.Errorf("could not instantiate controller-manager: %w", err) } - log.Info("completed rest-options") err = extensionscontroller.AddToScheme(mgr.GetScheme()) if err != nil { return fmt.Errorf("could not add mgr-scheme to extension-controller: %w", err) } - log.Info("added mgr-scheme to extensionscontroller") err = install.AddToScheme(mgr.GetScheme()) if err != nil { return fmt.Errorf("could not add mgr-scheme to installation") } - - log.Info("added mgr-schme to installation") + log.Info("added mgr-scheme to installation") ctrlConfig := options.csidriverlvmOptions.Completed() ctrlConfig.Apply(&controller.DefaultAddOptions.Config) @@ -142,24 +139,21 @@ func (options *Options) run(ctx context.Context) error { if err := options.controllerSwitches.Completed().AddToManager(ctx, mgr); err != nil { return fmt.Errorf("could not add controllers to manager: %w", err) } + log.Info("added controllers to manager") if err := mgr.AddReadyzCheck("informer-sync", ghealth.NewCacheSyncHealthz(mgr.GetCache())); err != nil { return fmt.Errorf("could not add ready check for informers: %w", err) } - log.Info("added readyzcheck") if err := mgr.AddHealthzCheck("ping", healthz.Ping); err != nil { return fmt.Errorf("could not add health check to manager: %w", err) } - log.Info("added healthzcheck") if err := mgr.Start(ctx); err != nil { return fmt.Errorf("error running manager: %w", err) } - log.Info("started successfully") - return nil } diff --git a/docs/migration.md b/docs/migration.md index d92f397..2ed4beb 100644 --- a/docs/migration.md +++ b/docs/migration.md @@ -32,7 +32,7 @@ The migration solution so far has been tested manually: 5. install new controller & provisioner with helm 6. add additional storage class with name `csi-lvm` and type linear 1. mimics old storage class - 2. default storage class + 2. default storage class (not supported yet -> see default storage class of `gardener-extension-provider-metal`) 7. create new pvcs 8. create new pod with old and new pvcs and test @@ -41,4 +41,4 @@ The migration solution so far has been tested manually: To achieve this behaviour for csi-lvm, provided by [gardener-extension-provider-metal](https://github.com/metal-stack/gardener-extension-provider-metal/tree/master), we need to add the following workflow: 1. Add a feature gate to `gardener-extension-provider-metal` to disable csi-lvm. -2. When deploying `gardener-extension-csi-driver-lvm`, stop reconciliation if old provisioner is still available. \ No newline at end of file +2. When deploying `gardener-extension-csi-driver-lvm`, stop reconciliation if old provisioner is still available. diff --git a/example/controller-registration.yaml b/example/controller-registration.yaml index 1b58a3f..e276a8f 100644 --- a/example/controller-registration.yaml +++ b/example/controller-registration.yaml @@ -4,7 +4,7 @@ kind: ControllerDeployment metadata: name: csi-driver-lvm helm: - rawChart: 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 + rawChart: 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 values: image: tag: v0.0.1 diff --git a/go.mod b/go.mod index 1dcc3cc..93f67f2 100644 --- a/go.mod +++ b/go.mod @@ -11,6 +11,7 @@ require ( github.com/onsi/ginkgo v1.16.5 github.com/spf13/cobra v1.8.1 github.com/spf13/pflag v1.0.5 + github.com/stretchr/testify v1.9.0 k8s.io/api v0.31.1 k8s.io/apimachinery v0.31.1 k8s.io/code-generator v0.31.1 @@ -77,6 +78,7 @@ require ( github.com/nxadm/tail v1.4.8 // indirect github.com/onsi/ginkgo/v2 v2.19.0 // indirect github.com/pkg/errors v0.9.1 // indirect + github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 // indirect github.com/prometheus-operator/prometheus-operator/pkg/apis/monitoring v0.74.0 // indirect github.com/prometheus/client_golang v1.19.1 // indirect github.com/prometheus/client_model v0.6.1 // indirect diff --git a/pkg/apis/csidriverlvm/types.go b/pkg/apis/csidriverlvm/types.go index e9e0ccb..bd61f46 100644 --- a/pkg/apis/csidriverlvm/types.go +++ b/pkg/apis/csidriverlvm/types.go @@ -10,6 +10,9 @@ import ( type CsiDriverLvmConfig struct { metav1.TypeMeta + // DevicePattern can be used to configure the glob pattern for the devices used by the LVM driver DevicePattern *string + + // HostWritePath can be used to configure the host write path - used on read-only filesystems (Talos OS "/var/etc/lvm") HostWritePath *string } diff --git a/pkg/apis/csidriverlvm/v1alpha1/types.go b/pkg/apis/csidriverlvm/v1alpha1/types.go index 47cfe76..ebe7cc7 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/types.go +++ b/pkg/apis/csidriverlvm/v1alpha1/types.go @@ -1,8 +1,9 @@ package v1alpha1 import ( - "regexp" + "path/filepath" + "github.com/go-logr/logr" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" ) @@ -16,7 +17,12 @@ const ( type CsiDriverLvmConfig struct { metav1.TypeMeta `json:",inline"` + // DevicePattern can be used to configure the glob pattern for the devices used by the LVM driver + // +optional DevicePattern *string `json:"devicePattern,omitempty"` + + // HostWritePath can be used to configure the host write path - used on read-only filesystems (Talos OS "/var/etc/lvm") + // +optional HostWritePath *string `json:"hostWritePath,omitempty"` } @@ -29,13 +35,29 @@ func (config *CsiDriverLvmConfig) ConfigureDefaults(hostWritePath *string, devic } } -func (config *CsiDriverLvmConfig) IsValid() bool { - re := regexp.MustCompile(`^(/[^/ ]*)+/?$`) - +func (config *CsiDriverLvmConfig) IsValid(log logr.Logger) bool { if (config.HostWritePath == nil) || (config.DevicePattern == nil) { - println("HostWritePath or DevicePattern is nil", config.HostWritePath, config.DevicePattern) + log.Info("hostWritePath or devicePattern is nil", config.HostWritePath, config.DevicePattern) + return false + } + + if *config.HostWritePath == "" || *config.DevicePattern == "" { + log.Info("hostWritePath or devicePattern is empty", config.HostWritePath, config.DevicePattern) + return false + } + + //glob pattern validation could be problematic -> go glob interpretation can be different from bash + _, err := filepath.Match(*config.DevicePattern, "") + if err != nil { + log.Info("bad device pattern") + return false + } + + hasValidHostWritePath := filepath.IsAbs(*config.HostWritePath) + if !hasValidHostWritePath { + log.Info("hostWritePath is not absolute") return false } - return re.MatchString(*config.HostWritePath) && re.MatchString(*config.DevicePattern) + return true } diff --git a/pkg/apis/csidriverlvm/v1alpha1/types_test.go b/pkg/apis/csidriverlvm/v1alpha1/types_test.go new file mode 100644 index 0000000..d983ff7 --- /dev/null +++ b/pkg/apis/csidriverlvm/v1alpha1/types_test.go @@ -0,0 +1,112 @@ +package v1alpha1 + +import ( + "testing" + + "github.com/go-logr/logr" + "github.com/stretchr/testify/assert" +) + +var log = logr.New(logr.Discard().GetSink()) + +func stringPtr(s string) *string { + return &s +} + +func TestConfig(t *testing.T) { + + tt := []struct { + desc string + customData *CsiDriverLvmConfig + valid bool + }{ + { + desc: "test nil config", + customData: &CsiDriverLvmConfig{ + DevicePattern: nil, + HostWritePath: nil, + }, + valid: false, + }, + { + desc: "test devicePattern nil config", + customData: &CsiDriverLvmConfig{ + DevicePattern: nil, + HostWritePath: stringPtr("/etc/lvm"), + }, + valid: false, + }, + { + desc: "test hostWritePath nil config", + customData: &CsiDriverLvmConfig{ + DevicePattern: stringPtr("/dev/loop100"), + HostWritePath: nil, + }, + valid: false, + }, + { + desc: "test empty config", + customData: &CsiDriverLvmConfig{ + DevicePattern: stringPtr(""), + HostWritePath: stringPtr(""), + }, + valid: false, + }, + { + desc: "test empty devicePattern config", + customData: &CsiDriverLvmConfig{ + DevicePattern: stringPtr(""), + HostWritePath: stringPtr("/etc/lvm"), + }, + valid: false, + }, + { + desc: "test empty hostWritePath config", + customData: &CsiDriverLvmConfig{ + DevicePattern: stringPtr("/dev/loop1"), + HostWritePath: stringPtr(""), + }, + valid: false, + }, + { + desc: "test invalid devicePattern config", + customData: &CsiDriverLvmConfig{ + DevicePattern: stringPtr("[a-"), + HostWritePath: stringPtr("/etc/lvm"), + }, + valid: false, + }, + { + desc: "test not absolute hostWritePath config", + customData: &CsiDriverLvmConfig{ + DevicePattern: stringPtr("[a-z]"), + HostWritePath: stringPtr("./etc/lvm"), + }, + valid: false, + }, + { + desc: "test not absolute hostWritePath config", + customData: &CsiDriverLvmConfig{ + DevicePattern: stringPtr("[a-z]"), + HostWritePath: stringPtr("etc/lvm"), + }, + valid: false, + }, + { + desc: "test valid config", + customData: &CsiDriverLvmConfig{ + DevicePattern: stringPtr("/dev/loop10[0,1]"), + HostWritePath: stringPtr("/etc/lvm"), + }, + valid: true, + }, + } + + for _, tc := range tt { + t.Run(tc.desc, func(t *testing.T) { + println(tc.desc) + isConfigValid := tc.customData.IsValid(log) + assert.Equal(t, tc.valid, isConfigValid) + }) + } +} diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 525d0d0..2305f51 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -34,12 +34,14 @@ import ( ) const ( - namespace string = "kube-system" - provisioner string = "lvm.csi.metal-stack.io" + shootNamespace string = "kube-system" + provisioner string = "lvm.csi.metal-stack.io" oldName string = "csi-lvm" oldNamespace string = "csi-lvm" oldProvisioner string = "metal-stack.io/csi-lvm" + + pullPolicy string = "IfNotPresent" ) // NewActuator returns an actuator responsible for Extension resources. @@ -68,7 +70,7 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension } csidriverlvmConfig.ConfigureDefaults(a.config.DefaultHostWritePath, a.config.DefaultDevicePattern) - if !csidriverlvmConfig.IsValid() { + if !csidriverlvmConfig.IsValid(log) { return fmt.Errorf("invalid csi-driver-lvm configuration") } @@ -81,12 +83,12 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension return nil } - controllerObjects, err := a.controllerObjects(namespace) + controllerObjects, err := a.controllerObjects() if err != nil { return err } - pluginObjects, err := a.pluginObjects(namespace, csidriverlvmConfig) + pluginObjects, err := a.pluginObjects(csidriverlvmConfig) if err != nil { return err } @@ -149,19 +151,19 @@ func (a *actuator) Migrate(ctx context.Context, log logr.Logger, ex *extensionsv return nil } -func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) { +func (a *actuator) controllerObjects() ([]client.Object, error) { csidriverlvmServiceAccountController := &corev1.ServiceAccount{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm-controller", - Namespace: namespace, + Namespace: shootNamespace, }, } csidriverlvmClusterRoleController := &rbacv1.ClusterRole{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm-controller", - Namespace: namespace, + Namespace: shootNamespace, }, Rules: []rbacv1.PolicyRule{ { @@ -220,13 +222,13 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) csidriverlvmClusterRoleBindingController := &rbacv1.ClusterRoleBinding{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm-controller", - Namespace: namespace, + Namespace: shootNamespace, }, Subjects: []rbacv1.Subject{ { Kind: "ServiceAccount", Name: "csi-driver-lvm-controller", - Namespace: namespace, + Namespace: shootNamespace, }, }, RoleRef: rbacv1.RoleRef{ @@ -256,7 +258,7 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) csidriverlvmStatefulsetController := &appsv1.StatefulSet{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm-controller", - Namespace: namespace, + Namespace: shootNamespace, Annotations: map[string]string{}, Labels: map[string]string{}, }, @@ -294,14 +296,12 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) }, }, }, - NodeSelector: map[string]string{}, - Tolerations: []corev1.Toleration{}, ServiceAccountName: "csi-driver-lvm-controller", Containers: []corev1.Container{ { Name: "csi-attacher", Image: csiAttacherImage.String(), - ImagePullPolicy: "IfNotPresent", + ImagePullPolicy: "pullPolicy", Args: []string{"--v=5", "--csi-address=/csi/csi.sock"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), @@ -314,7 +314,7 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) { Name: "csi-provisioner", Image: csiProvisionerImage.String(), - ImagePullPolicy: "IfNotPresent", + ImagePullPolicy: "pullPolicy", Args: []string{"--v=5", "--csi-address=/csi/csi.sock", "--feature-gates=Topology=true"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), @@ -327,7 +327,7 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) { Name: "csi-resizer", Image: csiResizerImage.String(), - ImagePullPolicy: "IfNotPresent", + ImagePullPolicy: "pullPolicy", Args: []string{"--v=5", "--csi-address=/csi/csi.sock"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), @@ -364,12 +364,12 @@ func (a *actuator) controllerObjects(namespace string) ([]client.Object, error) return objects, nil } -func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1.CsiDriverLvmConfig) ([]client.Object, error) { +func (a *actuator) pluginObjects(csidriverlvmConfig *v1alpha1.CsiDriverLvmConfig) ([]client.Object, error) { csidriverlvmDriver := &storagev1.CSIDriver{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm", - Namespace: namespace, + Namespace: shootNamespace, }, Spec: storagev1.CSIDriverSpec{ VolumeLifecycleModes: []storagev1.VolumeLifecycleMode{"Persistent", "Ephemeral"}, @@ -381,14 +381,14 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. csidriverlvmServiceAccountPlugin := &corev1.ServiceAccount{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm-plugin", - Namespace: namespace, + Namespace: shootNamespace, }, } csidriverlvmClusterRolePlugin := &rbacv1.ClusterRole{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm-plugin", - Namespace: namespace, + Namespace: shootNamespace, }, Rules: []rbacv1.PolicyRule{ { @@ -427,13 +427,13 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. csidriverlvmClusterRoleBindingPlugin := &rbacv1.ClusterRoleBinding{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm-plugin", - Namespace: namespace, + Namespace: shootNamespace, }, Subjects: []rbacv1.Subject{ { Kind: "ServiceAccount", Name: "csi-driver-lvm-plugin", - Namespace: namespace, + Namespace: shootNamespace, }, }, RoleRef: rbacv1.RoleRef{ @@ -518,7 +518,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. return nil, fmt.Errorf("failed to find csi-driver-lvm-provisioner image: %w", err) } - // var terminationPolicy corev1.TerminationMessagePolicy = corev1.TerminationMessageReadFile + var terminationPolicy corev1.TerminationMessagePolicy = corev1.TerminationMessageReadFile var mountPropagation corev1.MountPropagationMode = corev1.MountPropagationBidirectional var hostPathTypeCreate corev1.HostPathType = corev1.HostPathDirectoryOrCreate @@ -527,7 +527,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. csidriverlvmDaemonSetPlugin := &appsv1.DaemonSet{ ObjectMeta: metav1.ObjectMeta{ Name: "csi-driver-lvm-plugin", - Namespace: namespace, + Namespace: shootNamespace, }, Spec: appsv1.DaemonSetSpec{ RevisionHistoryLimit: ptr.To(int32(10)), @@ -543,17 +543,15 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. }, }, Spec: corev1.PodSpec{ ServiceAccountName: "csi-driver-lvm-plugin", - Tolerations: []corev1.Toleration{}, - NodeSelector: map[string]string{}, Containers: []corev1.Container{ { Name: "csi-node-driver-registrar", Image: csiNodeDriverRegistrarImage.String(), - ImagePullPolicy: "IfNotPresent", + ImagePullPolicy: "pullPolicy", Args: []string{"--v=5", "--csi-address=/csi/csi.sock", "--kubelet-registration-path=/var/lib/kubelet/plugins/csi-driver-lvm/csi.sock"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(false), - // Privileged: pointer.Pointer(true), + Privileged: pointer.Pointer(true), }, Env: []corev1.EnvVar{ { @@ -566,8 +564,8 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. }, }, }, - // TerminationMessagePath: "/dev/termination-log", - // TerminationMessagePolicy: terminationPolicy, + TerminationMessagePath: "/dev/termination-log", + TerminationMessagePolicy: terminationPolicy, VolumeMounts: []corev1.VolumeMount{ {MountPath: "/csi", Name: "socket-dir"}, {MountPath: "/var/lib/kubelet/plugins/csi-driver-lvm/csi.sock", Name: "socket-dir"}, @@ -577,7 +575,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. { Name: "csi-driver-lvm-plugin", Image: csiDriverLvmImage.String(), - ImagePullPolicy: "IfNotPresent", + ImagePullPolicy: "pullPolicy", Args: []string{ "--drivername=lvm.csi.metal-stack.io", "--endpoint=unix:///csi/csi.sock", @@ -587,7 +585,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. "--vgname=csi-lvm", "--namespace=kube-system", "--provisionerimage=" + csiDriverLvmProvisionerImage.String(), - "--pullpolicy=IfNotPresent", + "--pullpolicy=pullPolicy", }, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(false), @@ -623,8 +621,8 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. Protocol: corev1.ProtocolTCP, ContainerPort: 9898, }}, - // TerminationMessagePath: "/dev/termination-log", - // TerminationMessagePolicy: terminationPolicy, + TerminationMessagePath: "/dev/termination-log", + TerminationMessagePolicy: terminationPolicy, VolumeMounts: []corev1.VolumeMount{ {MountPath: "/csi", Name: "socket-dir"}, {MountPath: "/var/lib/kubelet/pods", Name: "mountpoint-dir", MountPropagation: &mountPropagation}, @@ -640,7 +638,7 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. { Name: "livenessprobe", Image: livenessprobeImage.String(), - ImagePullPolicy: "IfNotPresent", + ImagePullPolicy: "pullPolicy", Args: []string{ "--csi-address=/csi/csi.sock", "--health-port=9898", @@ -648,8 +646,8 @@ func (a *actuator) pluginObjects(namespace string, csidriverlvmConfig *v1alpha1. SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), }, - // TerminationMessagePath: "/dev/termination-log", - // TerminationMessagePolicy: terminationPolicy, + TerminationMessagePath: "/dev/termination-log", + TerminationMessagePolicy: terminationPolicy, VolumeMounts: []corev1.VolumeMount{ {MountPath: "/csi", Name: "socket-dir"}, }, @@ -778,7 +776,6 @@ func (a *actuator) isOldCsiLvmExisting(ctx context.Context, shootNamespace strin Name: oldNamespace, }, } - err = shootClient.Get(ctx, client.ObjectKeyFromObject(namespace), namespace) if err == nil { @@ -787,21 +784,16 @@ func (a *actuator) isOldCsiLvmExisting(ctx context.Context, shootNamespace strin return true, fmt.Errorf("error while getting old csi-lvm namespace: %w", err) } - storageClass := &storagev1.StorageClass{ - ObjectMeta: metav1.ObjectMeta{ - Name: oldName, - }, + storageClassList := &storagev1.StorageClassList{} + err = shootClient.List(ctx, storageClassList) + if err != nil { + return false, fmt.Errorf("failed to list storage classes: %w", err) } - err = shootClient.Get(ctx, client.ObjectKeyFromObject(storageClass), storageClass, &client.GetOptions{}) - if err == nil { - if storageClass.Provisioner == provisioner { - return false, nil - } else { + for _, sc := range storageClassList.Items { + if sc.Provisioner == oldProvisioner { return true, nil } - } else if !apierrors.IsNotFound(err) { - return true, fmt.Errorf("error while getting old csi-lvm storageclass: %w", err) } return false, nil } From 3cb4dcb1aa54b6598ac511599d741e9d489826b4 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 13 Dec 2024 14:10:43 +0100 Subject: [PATCH 24/32] added pipeline --- .github/release-drafter.yml | 30 +++++++++++++++++ .github/workflows/docker.yaml | 45 ++++++++++++++++++++++++++ .github/workflows/release-drafter.yaml | 15 +++++++++ .github/workflows/test.yaml | 35 ++++++++++++++++++++ 4 files changed, 125 insertions(+) create mode 100644 .github/release-drafter.yml create mode 100644 .github/workflows/docker.yaml create mode 100644 .github/workflows/release-drafter.yaml create mode 100644 .github/workflows/test.yaml diff --git a/.github/release-drafter.yml b/.github/release-drafter.yml new file mode 100644 index 0000000..59bc948 --- /dev/null +++ b/.github/release-drafter.yml @@ -0,0 +1,30 @@ +name-template: 'v$RESOLVED_VERSION' +tag-template: 'v$RESOLVED_VERSION' + +template: | + ## General Changes + + $CHANGES + +categories: +- title: '🚀 Features' + labels: + - 'feature' + - 'enhancement' +- title: '🐛 Bug Fixes' + labels: + - 'fix' + - 'bugfix' + - 'bug' + +version-resolver: + major: + labels: + - 'major' + minor: + labels: + - 'minor' + patch: + labels: + - 'patch' + default: patch diff --git a/.github/workflows/docker.yaml b/.github/workflows/docker.yaml new file mode 100644 index 0000000..88238e9 --- /dev/null +++ b/.github/workflows/docker.yaml @@ -0,0 +1,45 @@ +--- +name: Docker Build Action +on: + pull_request: + branches: + - main + release: + types: + - published + push: + branches: + - main + +env: + REGISTRY: ghcr.io + IMAGE_NAME: ${{ github.repository }} + +jobs: + build: + name: Docker Build + runs-on: ubuntu-latest + + steps: + - name: Log in to the container registry + uses: docker/login-action@v2 + with: + registry: ${{ env.REGISTRY }} + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Checkout + uses: actions/checkout@v3 + + - name: Make tag + run: | + [ "${GITHUB_EVENT_NAME}" == 'pull_request' ] && echo "tag=${GITHUB_HEAD_REF##*/}" >> $GITHUB_ENV || true + [ "${GITHUB_EVENT_NAME}" == 'release' ] && echo "tag=${GITHUB_REF##*/}" >> $GITHUB_ENV || true + [ "${GITHUB_EVENT_NAME}" == 'push' ] && echo "tag=latest" >> $GITHUB_ENV || true + + - name: Build and push image + uses: docker/build-push-action@v4 + with: + context: . + push: true + tags: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.tag }} diff --git a/.github/workflows/release-drafter.yaml b/.github/workflows/release-drafter.yaml new file mode 100644 index 0000000..0a81725 --- /dev/null +++ b/.github/workflows/release-drafter.yaml @@ -0,0 +1,15 @@ +--- +name: Release Drafter Action + +on: + push: + branches: + - main + +jobs: + build: + runs-on: ubuntu-latest + steps: + - uses: release-drafter/release-drafter@v5 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml new file mode 100644 index 0000000..6801bb6 --- /dev/null +++ b/.github/workflows/test.yaml @@ -0,0 +1,35 @@ +--- +name: Test Action +on: + pull_request: + branches: + - main + release: + types: + - published + push: + branches: + - main + +jobs: + build: + name: Test and Lint + runs-on: ubuntu-latest + + steps: + - name: Checkout + uses: actions/checkout@v3 + + - name: Setup Go + uses: actions/setup-go@v4 + with: + go-version-file: 'go.mod' + cache: false + + - name: Lint + uses: golangci/golangci-lint-action@v3 + with: + args: --build-tags integration -p bugs -p unused --timeout=3m + + - name: Test + run: make test From 2a039451c570611fd96309a7857a53f87e555cc1 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 13 Dec 2024 14:27:16 +0100 Subject: [PATCH 25/32] fixed linting --- pkg/controller/csi-driver-lvm/actuator.go | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 2305f51..88d274e 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -41,7 +41,7 @@ const ( oldNamespace string = "csi-lvm" oldProvisioner string = "metal-stack.io/csi-lvm" - pullPolicy string = "IfNotPresent" + pullPolicy corev1.PullPolicy = corev1.PullIfNotPresent ) // NewActuator returns an actuator responsible for Extension resources. @@ -301,7 +301,7 @@ func (a *actuator) controllerObjects() ([]client.Object, error) { { Name: "csi-attacher", Image: csiAttacherImage.String(), - ImagePullPolicy: "pullPolicy", + ImagePullPolicy: pullPolicy, Args: []string{"--v=5", "--csi-address=/csi/csi.sock"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), @@ -314,7 +314,7 @@ func (a *actuator) controllerObjects() ([]client.Object, error) { { Name: "csi-provisioner", Image: csiProvisionerImage.String(), - ImagePullPolicy: "pullPolicy", + ImagePullPolicy: pullPolicy, Args: []string{"--v=5", "--csi-address=/csi/csi.sock", "--feature-gates=Topology=true"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), @@ -327,7 +327,7 @@ func (a *actuator) controllerObjects() ([]client.Object, error) { { Name: "csi-resizer", Image: csiResizerImage.String(), - ImagePullPolicy: "pullPolicy", + ImagePullPolicy: pullPolicy, Args: []string{"--v=5", "--csi-address=/csi/csi.sock"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(true), @@ -547,7 +547,7 @@ func (a *actuator) pluginObjects(csidriverlvmConfig *v1alpha1.CsiDriverLvmConfig { Name: "csi-node-driver-registrar", Image: csiNodeDriverRegistrarImage.String(), - ImagePullPolicy: "pullPolicy", + ImagePullPolicy: pullPolicy, Args: []string{"--v=5", "--csi-address=/csi/csi.sock", "--kubelet-registration-path=/var/lib/kubelet/plugins/csi-driver-lvm/csi.sock"}, SecurityContext: &corev1.SecurityContext{ ReadOnlyRootFilesystem: pointer.Pointer(false), @@ -575,7 +575,7 @@ func (a *actuator) pluginObjects(csidriverlvmConfig *v1alpha1.CsiDriverLvmConfig { Name: "csi-driver-lvm-plugin", Image: csiDriverLvmImage.String(), - ImagePullPolicy: "pullPolicy", + ImagePullPolicy: pullPolicy, Args: []string{ "--drivername=lvm.csi.metal-stack.io", "--endpoint=unix:///csi/csi.sock", @@ -638,7 +638,7 @@ func (a *actuator) pluginObjects(csidriverlvmConfig *v1alpha1.CsiDriverLvmConfig { Name: "livenessprobe", Image: livenessprobeImage.String(), - ImagePullPolicy: "pullPolicy", + ImagePullPolicy: pullPolicy, Args: []string{ "--csi-address=/csi/csi.sock", "--health-port=9898", From 1ffd4a85ab8f24a12cfae1ce9fb08c2fcdff5a46 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 13 Dec 2024 15:24:54 +0100 Subject: [PATCH 26/32] update alpine version --- Dockerfile | 2 +- Dockerfile.dev | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Dockerfile b/Dockerfile index 51888cd..876843f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -5,7 +5,7 @@ COPY . . RUN make install \ && strip /go/bin/gardener-extension-csi-driver-lvm -FROM alpine:3.20 +FROM alpine:3.21 WORKDIR / COPY charts /charts COPY --from=builder /go/bin/gardener-extension-csi-driver-lvm /gardener-extension-csi-driver-lvm diff --git a/Dockerfile.dev b/Dockerfile.dev index 0dfa6b1..65da8cc 100644 --- a/Dockerfile.dev +++ b/Dockerfile.dev @@ -1,3 +1,3 @@ -FROM alpine:3.20 +FROM alpine:3.21 COPY bin/gardener-extension-csi-driver-lvm /gardener-extension-csi-driver-lvm CMD ["/gardener-extension-csi-driver-lvm"] From 60ff6128cab1c5cdfb647617fc7f801f7442f3f8 Mon Sep 17 00:00:00 2001 From: Oliver <69219753+ostempel@users.noreply.github.com> Date: Fri, 13 Dec 2024 15:45:29 +0100 Subject: [PATCH 27/32] Update README.md Co-authored-by: Gerrit --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index db1be31..7f433ee 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ Provides a Gardener extension for managing [csi-driver-lvm](https://github.com/metal-stack/csi-driver-lvm) for a shoot cluster. -The extension checks for the old [csi-lvm](https://github.com/metal-stack/csi-lvm/tree/master) and stops reconciling if the old driver is stil available. +As a safety measurement, the extension checks for the old [csi-lvm](https://github.com/metal-stack/csi-lvm/tree/master) and stops reconciling if the old driver is still available. If not the extension will reconcile the new `csi-driver-lvm`. ## Development From afe767824d8bc966a78bcd0fdb5062213b881bb7 Mon Sep 17 00:00:00 2001 From: Oliver <69219753+ostempel@users.noreply.github.com> Date: Fri, 13 Dec 2024 15:45:39 +0100 Subject: [PATCH 28/32] Update README.md Co-authored-by: Gerrit --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 7f433ee..9f653e4 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,7 @@ If not the extension will reconcile the new `csi-driver-lvm`. ## Development -This extension can be developed in the gardener-local devel environment. Before make sure you have created loop-devices on your machine. +This extension can be developed in the gardener-local devel environment. Before make sure you have created loop-devices on your machine (identical to how you would develop the csi-driver-lvm locally, refer to the repository [docs](https://github.com/metal-stack/csi-driver-lvm?tab=readme-ov-file#development) for further information). ```sh for i in 100 101; do fallocate -l 1G loop${i}.img ; sudo losetup /dev/loop${i} loop${i}.img; done From 929ecdc8ef42a203da42b2cd2ee00b5eb6f8ebb4 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 13 Dec 2024 15:47:51 +0100 Subject: [PATCH 29/32] update Readme --- README.md | 43 ++----------------------------------------- 1 file changed, 2 insertions(+), 41 deletions(-) diff --git a/README.md b/README.md index db1be31..38501eb 100644 --- a/README.md +++ b/README.md @@ -16,47 +16,8 @@ sudo losetup -a # for i in 100 101; do sudo losetup -d /dev/loop${i}; rm -f loop${i}.img; done ``` -Next you need to add these devices to the gardener kind cluster config (`example/gardener-local/kind/cluster/templates/cluster.yaml`). -```yaml - - hostPath: /dev/loop100 - containerPath: /dev/loop100 - - hostPath: /dev/loop101 - containerPath: /dev/loop101 -``` - -In the end you also have to mount these volumes on machine creation (`pkg/provider-local/machine-provider/local/create_machine.go`): - -```go -// applyPod() -// Volume-Mounts - { - Name: "loop100", - MountPath: "/dev/loop100", - }, - { - Name: "loop101", - MountPath: "/dev/loop101", - }, -// Volumes - { - Name: "loop100", - VolumeSource: corev1.VolumeSource{ - HostPath: &corev1.HostPathVolumeSource{ - Path: "/dev/loop100", - }, - }, - }, - { - Name: "loop101", - VolumeSource: corev1.VolumeSource{ - HostPath: &corev1.HostPathVolumeSource{ - Path: "/dev/loop101", - }, - }, - }, -``` - 1. Start up the local devel environment 1. The extension's docker image can be pushed into Kind using `make push-to-gardener-local` 1. Install the extension `kubectl apply -k example/` -1. Parametrize the `example/shoot.yaml` and apply with `kubectl -f example/shoot.yaml` \ No newline at end of file +1. Parametrize the `example/shoot.yaml` and apply with `kubectl -f example/shoot.yaml` + From 9647a5b7aed4c4761224b3c64c0b43d75d3b6d38 Mon Sep 17 00:00:00 2001 From: Oliver <69219753+ostempel@users.noreply.github.com> Date: Fri, 13 Dec 2024 15:49:28 +0100 Subject: [PATCH 30/32] fix type Co-authored-by: Gerrit --- pkg/controller/csi-driver-lvm/actuator.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pkg/controller/csi-driver-lvm/actuator.go b/pkg/controller/csi-driver-lvm/actuator.go index 88d274e..f7b8bff 100644 --- a/pkg/controller/csi-driver-lvm/actuator.go +++ b/pkg/controller/csi-driver-lvm/actuator.go @@ -79,7 +79,7 @@ func (a *actuator) Reconcile(ctx context.Context, log logr.Logger, ex *extension return fmt.Errorf("failed to check if old csi-lvm is existing: %w", err) } if isOldCsiLvmExisting { - log.Info("old csi-lvm is existing, skipping reconcilation") + log.Info("old csi-lvm is existing, skipping reconciliation") return nil } From fb7f609702e10c4a4c7df00b3c4d23154a663582 Mon Sep 17 00:00:00 2001 From: Oliver <69219753+ostempel@users.noreply.github.com> Date: Fri, 13 Dec 2024 15:49:40 +0100 Subject: [PATCH 31/32] fix typo Co-authored-by: Gerrit --- cmd/gardener-extension-csi-driver-lvm/app/app.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmd/gardener-extension-csi-driver-lvm/app/app.go b/cmd/gardener-extension-csi-driver-lvm/app/app.go index 78362a0..f1708df 100644 --- a/cmd/gardener-extension-csi-driver-lvm/app/app.go +++ b/cmd/gardener-extension-csi-driver-lvm/app/app.go @@ -14,7 +14,7 @@ func NewControllerManagerCommand(ctx context.Context) *cobra.Command { options := NewOptions() cmd := &cobra.Command{ Use: "gardener-extension-csi-driver-lvm", - Short: "provides csi-driver-lvm for shoot cluster", + Short: "provides csi-driver-lvm for shoot clusters", SilenceErrors: true, RunE: func(cmd *cobra.Command, args []string) error { err := options.optionAggregator.Complete() From 10b3e2759455aeecfe0ecd878548b54aef14c088 Mon Sep 17 00:00:00 2001 From: ostempel Date: Fri, 13 Dec 2024 16:03:50 +0100 Subject: [PATCH 32/32] remove own ptr-func from test --- pkg/apis/csidriverlvm/v1alpha1/types_test.go | 37 +++++++++----------- 1 file changed, 17 insertions(+), 20 deletions(-) diff --git a/pkg/apis/csidriverlvm/v1alpha1/types_test.go b/pkg/apis/csidriverlvm/v1alpha1/types_test.go index d983ff7..0742018 100644 --- a/pkg/apis/csidriverlvm/v1alpha1/types_test.go +++ b/pkg/apis/csidriverlvm/v1alpha1/types_test.go @@ -5,14 +5,11 @@ import ( "github.com/go-logr/logr" "github.com/stretchr/testify/assert" + "k8s.io/utils/ptr" ) var log = logr.New(logr.Discard().GetSink()) -func stringPtr(s string) *string { - return &s -} - func TestConfig(t *testing.T) { tt := []struct { @@ -32,14 +29,14 @@ func TestConfig(t *testing.T) { desc: "test devicePattern nil config", customData: &CsiDriverLvmConfig{ DevicePattern: nil, - HostWritePath: stringPtr("/etc/lvm"), + HostWritePath: ptr.To("/etc/lvm"), }, valid: false, }, { desc: "test hostWritePath nil config", customData: &CsiDriverLvmConfig{ - DevicePattern: stringPtr("/dev/loop100"), + DevicePattern: ptr.To("/dev/loop100"), HostWritePath: nil, }, valid: false, @@ -47,56 +44,56 @@ func TestConfig(t *testing.T) { { desc: "test empty config", customData: &CsiDriverLvmConfig{ - DevicePattern: stringPtr(""), - HostWritePath: stringPtr(""), + DevicePattern: ptr.To(""), + HostWritePath: ptr.To(""), }, valid: false, }, { desc: "test empty devicePattern config", customData: &CsiDriverLvmConfig{ - DevicePattern: stringPtr(""), - HostWritePath: stringPtr("/etc/lvm"), + DevicePattern: ptr.To(""), + HostWritePath: ptr.To("/etc/lvm"), }, valid: false, }, { desc: "test empty hostWritePath config", customData: &CsiDriverLvmConfig{ - DevicePattern: stringPtr("/dev/loop1"), - HostWritePath: stringPtr(""), + DevicePattern: ptr.To("/dev/loop1"), + HostWritePath: ptr.To(""), }, valid: false, }, { desc: "test invalid devicePattern config", customData: &CsiDriverLvmConfig{ - DevicePattern: stringPtr("[a-"), - HostWritePath: stringPtr("/etc/lvm"), + DevicePattern: ptr.To("[a-"), + HostWritePath: ptr.To("/etc/lvm"), }, valid: false, }, { desc: "test not absolute hostWritePath config", customData: &CsiDriverLvmConfig{ - DevicePattern: stringPtr("[a-z]"), - HostWritePath: stringPtr("./etc/lvm"), + DevicePattern: ptr.To("[a-z]"), + HostWritePath: ptr.To("./etc/lvm"), }, valid: false, }, { desc: "test not absolute hostWritePath config", customData: &CsiDriverLvmConfig{ - DevicePattern: stringPtr("[a-z]"), - HostWritePath: stringPtr("etc/lvm"), + DevicePattern: ptr.To("[a-z]"), + HostWritePath: ptr.To("etc/lvm"), }, valid: false, }, { desc: "test valid config", customData: &CsiDriverLvmConfig{ - DevicePattern: stringPtr("/dev/loop10[0,1]"), - HostWritePath: stringPtr("/etc/lvm"), + DevicePattern: ptr.To("/dev/loop10[0,1]"), + HostWritePath: ptr.To("/etc/lvm"), }, valid: true, },