-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathMakefile
117 lines (93 loc) · 5.01 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
# SPDX-FileCopyrightText: 2022 SAP SE or an SAP affiliate company and Gardener contributors
#
# SPDX-License-Identifier: Apache-2.0
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
VERSION := $(shell cat VERSION)
REPO_ROOT := $(shell dirname $(realpath $(lastword $(MAKEFILE_LIST))))
HACK_DIR := $(REPO_ROOT)/hack
REGISTRY := europe-docker.pkg.dev/gardener-project/public/gardener
VPN_SERVER_IMAGE_REPOSITORY := $(REGISTRY)/vpn-server
VPN_SERVER_IMAGE_TAG := $(VERSION)
LOCAL_VPN_SERVER_IMAGE_REPO := localhost:5001/$(subst /,_,$(subst .,_,$(VPN_SERVER_IMAGE_REPOSITORY)))
VPN_CLIENT_IMAGE_REPOSITORY := $(REGISTRY)/vpn-client
VPN_CLIENT_IMAGE_TAG := $(VERSION)
LOCAL_VPN_CLIENT_IMAGE_REPO := localhost:5001/$(subst /,_,$(subst .,_,$(VPN_CLIENT_IMAGE_REPOSITORY)))
LD_FLAGS := "-w $(shell bash $(GARDENER_HACK_DIR)/get-build-ld-flags.sh k8s.io/component-base $(REPO_ROOT)/VERSION "vpn2")"
IMAGE_TAG := $(VERSION)
EFFECTIVE_VERSION := $(VERSION)-$(shell git rev-parse HEAD)
ARCH ?= amd64
PATH := $(GOBIN):$(PATH)
TOOLS_DIR := $(HACK_DIR)/tools
include $(GARDENER_HACK_DIR)/tools.mk
export PATH
.PHONY: tidy
tidy:
@GO111MODULE=on go mod tidy
@mkdir -p $(HACK_DIR) && cp $(GARDENER_HACK_DIR)/sast.sh $(HACK_DIR)/sast.sh && chmod +xw $(HACK_DIR)/sast.sh
.PHONY: vpn-server-docker-image
vpn-server-docker-image:
@docker buildx build --platform=linux/$(ARCH) --build-arg DEBUG=$(DEBUG) -t $(VPN_SERVER_IMAGE_REPOSITORY):$(VPN_SERVER_IMAGE_TAG) -f Dockerfile --target vpn-server --rm .
.PHONY: vpn-client-docker-image
vpn-client-docker-image:
@docker buildx build --platform=linux/$(ARCH) --build-arg DEBUG=$(DEBUG) -t $(VPN_CLIENT_IMAGE_REPOSITORY):$(VPN_CLIENT_IMAGE_TAG) -f Dockerfile --target vpn-client --rm .
.PHONY: vpn-server-to-gardener-local
vpn-server-to-gardener-local: vpn-server-docker-image
@docker tag $(VPN_SERVER_IMAGE_REPOSITORY):$(VPN_SERVER_IMAGE_TAG) $(LOCAL_VPN_SERVER_IMAGE_REPO):$(VPN_SERVER_IMAGE_TAG)
@docker push $(LOCAL_VPN_SERVER_IMAGE_REPO):$(VPN_SERVER_IMAGE_TAG)
@echo "VPN server image: $(LOCAL_VPN_SERVER_IMAGE_REPO):$(VPN_SERVER_IMAGE_TAG)"
.PHONY: vpn-client-to-gardener-local
vpn-client-to-gardener-local: vpn-client-docker-image
@docker tag $(VPN_CLIENT_IMAGE_REPOSITORY):$(VPN_CLIENT_IMAGE_TAG) $(LOCAL_VPN_CLIENT_IMAGE_REPO):$(VPN_CLIENT_IMAGE_TAG)
@docker push $(LOCAL_VPN_CLIENT_IMAGE_REPO):$(VPN_CLIENT_IMAGE_TAG)
@echo "VPN client image: $(LOCAL_VPN_CLIENT_IMAGE_REPO):$(VPN_CLIENT_IMAGE_TAG)"
.PHONY: docker-images
docker-images: vpn-server-docker-image vpn-client-docker-image
.PHONY: docker-images-to-gardener-local
docker-images-to-gardener-local: vpn-server-to-gardener-local vpn-client-to-gardener-local
.PHONY: release
release: docker-images docker-login docker-push
.PHONY: docker-login
docker-login:
@gcloud auth activate-service-account --key-file .kube-secrets/gcr/gcr-readwrite.json
.PHONY: docker-push
docker-push:
@if ! docker images $(VPN_SERVER_IMAGE_REPOSITORY) | awk '{ print $$2 }' | grep -q -F $(VPN_SERVER_IMAGE_TAG); then echo "$(VPN_SERVER_IMAGE_REPOSITORY) version $(VPN_SERVER_IMAGE_TAG) is not yet built. Please run 'make vpn-server-docker-image'"; false; fi
@if ! docker images $(VPN_CLIENT_IMAGE_REPOSITORY) | awk '{ print $$2 }' | grep -q -F $(VPN_CLIENT_IMAGE_TAG); then echo "$(VPN_CLIENT_IMAGE_REPOSITORY) version $(VPN_CLIENT_IMAGE_TAG) is not yet built. Please run 'make vpn-client-docker-image'"; false; fi
@gcloud docker -- push $(VPN_SERVER_IMAGE_REPOSITORY):$(VPN_SERVER_IMAGE_TAG)
@gcloud docker -- push $(VPN_CLIENT_IMAGE_REPOSITORY):$(VPN_CLIENT_IMAGE_TAG)
.PHONY: check
check: sast-report
go fmt ./...
go vet ./...
# TODO(scheererj): Remove once https://github.com/gardener/gardener/pull/10642 is available as release.
TOOLS_PKG_PATH := $(shell go list -tags tools -f '{{ .Dir }}' github.com/gardener/gardener/hack/tools 2>/dev/null)
.PHONY: adjust-install-gosec.sh
adjust-install-gosec.sh:
@chmod +xw $(TOOLS_PKG_PATH)/install-gosec.sh
.PHONY: sast
sast: adjust-install-gosec.sh $(GOSEC)
@./hack/sast.sh
.PHONY: sast-report
sast-report: adjust-install-gosec.sh $(GOSEC)
@./hack/sast.sh --gosec-report true
.PHONY: test
test:
go test ./...
.PHONY: build
build: build-vpn-server build-vpn-client
.PHONY: build-vpn-server
build-vpn-server:
@CGO_ENABLED=0 GOOS=linux GOARCH=$(ARCH) go build -o bin/vpn-server \
-ldflags $(LD_FLAGS)\
./cmd/vpn_server/main.go
.PHONY: build-vpn-client
build-vpn-client:
@CGO_ENABLED=0 GOOS=linux GOARCH=$(ARCH) go build -o bin/vpn-client \
-ldflags $(LD_FLAGS)\
./cmd/vpn_client/main.go
.PHONY: build-tunnel-controller
build-tunnel-controller:
@CGO_ENABLED=0 GOOS=linux GOARCH=$(ARCH) go build -o bin/tunnel-controller \
-ldflags $(LD_FLAGS)\
./cmd/tunnel_controller/main.go