|
| 1 | +VERSION?=latest |
| 2 | +REPOSITORY?=ghcr.io/open-telemetry/opentelemetry-operator |
| 3 | +GO_BUILD_LDFLAGS ?= '-w -s -extldflags "-static"' |
| 4 | + |
| 5 | +.PHONY := build |
| 6 | +build: |
| 7 | + mkdir -p bin |
| 8 | + CGO_ENABLED=0 go build -trimpath -o ./bin/cp_$(GOOS)_$(GOARCH)$(EXTRA)$(EXTENSION) -ldflags $(GO_BUILD_LDFLAGS) |
| 9 | + |
| 10 | +bin/cp_linux_amd64: main.go go.mod |
| 11 | + GOOS=linux GOARCH=amd64 EXTENSION="" EXTRA="" make build |
| 12 | + |
| 13 | +bin/cp_linux_arm64: main.go go.mod |
| 14 | + GOOS=linux GOARCH=arm64 EXTENSION="" EXTRA="" make build |
| 15 | + |
| 16 | +bin/cp_linux_ppc64le: main.go go.mod |
| 17 | + GOOS=linux GOARCH=ppc64le EXTENSION="" EXTRA="" make build |
| 18 | + |
| 19 | +bin/cp_linux_s390x: main.go go.mod |
| 20 | + GOOS=linux GOARCH=s390x EXTENSION="" EXTRA="" make build |
| 21 | + |
| 22 | +bin/cp_windows_arm64.exe: main.go go.mod |
| 23 | + GOOS=windows GOARCH=arm64 EXTENSION=".exe" EXTRA="" make build |
| 24 | + |
| 25 | +bin/cp_windows_amd64.exe: main.go go.mod |
| 26 | + GOOS=windows GOARCH=amd64 EXTENSION=".exe" EXTRA="" make build |
| 27 | + |
| 28 | +bin/cp_linux_amd64_fips: main.go go.mod |
| 29 | + GOEXPERIMENT=boringcrypto GOOS=linux GOARCH=amd64 EXTENSION="" EXTRA="_fips" make build |
| 30 | + |
| 31 | +bin/cp_linux_arm64_fips: main.go go.mod |
| 32 | + GOEXPERIMENT=boringcrypto GOOS=linux GOARCH=arm64 EXTENSION="" EXTRA="_fips" make build |
| 33 | + |
| 34 | +bin/cp_windows_arm64_fips.exe: main.go go.mod |
| 35 | + GOEXPERIMENT=boringcrypto GOOS=windows GOARCH=arm64 EXTENSION=".exe" EXTRA="_fips" make build |
| 36 | + |
| 37 | +bin/cp_windows_amd64_fips.exe: main.go go.mod |
| 38 | + GOEXPERIMENT=boringcrypto GOOS=windows GOARCH=amd64 EXTENSION=".exe" EXTRA="_fips" make build |
| 39 | + |
| 40 | +## Docker build |
| 41 | + |
| 42 | +.PHONY := docker_linux_amd64 |
| 43 | +docker_linux_amd64: bin/cp_linux_amd64 |
| 44 | + docker buildx build --platform="linux/amd64" --push -t $(REPOSITORY)/cp_linux_amd64:$(VERSION) --build-arg cp=bin/cp_linux_amd64 . |
| 45 | + |
| 46 | +.PHONY := docker_linux_arm64 |
| 47 | +docker_linux_arm64: bin/cp_linux_arm64 |
| 48 | + docker buildx build --platform="linux/arm64" --push -t $(REPOSITORY)/cp_linux_arm64:$(VERSION) --build-arg cp=bin/cp_linux_arm64 . |
| 49 | + |
| 50 | +.PHONY := docker_linux_ppc64le |
| 51 | +docker_linux_ppc64le: bin/cp_linux_ppc64le |
| 52 | + docker buildx build --platform="linux/ppc64le" --push -t $(REPOSITORY)/cp_linux_ppc64le:$(VERSION) --build-arg cp=bin/cp_linux_ppc64le . |
| 53 | + |
| 54 | +.PHONY := docker_linux_s390x |
| 55 | +docker_linux_s390x: bin/cp_linux_s390x |
| 56 | + docker buildx build --platform="linux/s390x" --push -t $(REPOSITORY)/cp_linux_s390x:$(VERSION) --build-arg cp=bin/cp_linux_s390x . |
| 57 | + |
| 58 | +.PHONY := docker_windows_arm64 |
| 59 | +docker_windows_arm64: bin/cp_windows_arm64.exe |
| 60 | + docker buildx build --platform="windows/arm64" --push -f Dockerfile.windows -t $(REPOSITORY)/cp_windows_arm64:$(VERSION) --build-arg cp=bin/cp_windows_arm64.exe . |
| 61 | + |
| 62 | +.PHONY := docker_windows_amd64 |
| 63 | +docker_windows_amd64: bin/cp_windows_amd64.exe |
| 64 | + docker buildx build --platform="windows/amd64" --push -f Dockerfile.windows -t $(REPOSITORY)/cp_windows_amd64:$(VERSION) --build-arg cp=bin/cp_windows_amd64.exe . |
| 65 | + |
| 66 | +.PHONY := docker_linux_amd64_fips |
| 67 | +docker_linux_amd64_fips: bin/cp_linux_amd64_fips |
| 68 | + docker buildx build --platform="linux/amd64" --push -t $(REPOSITORY)/cp_linux_amd64_fips:$(VERSION) --build-arg cp=bin/cp_linux_amd64_fips . |
| 69 | + |
| 70 | +.PHONY := docker_linux_arm64_fips |
| 71 | +docker_linux_arm64_fips: bin/cp_linux_arm64_fips |
| 72 | + docker buildx build --platform="linux/arm64" --push -t $(REPOSITORY)/cp_linux_arm64_fips:$(VERSION) --build-arg cp=bin/cp_linux_arm64_fips . |
| 73 | + |
| 74 | +.PHONY := docker_windows_amd64_fips |
| 75 | +docker_windows_amd64_fips: bin/cp_windows_amd64_fips.exe |
| 76 | + docker buildx build --platform="windows/amd64" --push -f Dockerfile.windows -t $(REPOSITORY)/cp_windows_amd64_fips:$(VERSION) --build-arg cp=bin/cp_windows_amd64_fips.exe . |
| 77 | + |
| 78 | +.PHONY := docker_windows_arm64_fips |
| 79 | +docker_windows_arm64_fips: bin/cp_windows_arm64_fips.exe |
| 80 | + docker buildx build --platform="windows/arm64" --push -f Dockerfile.windows -t $(REPOSITORY)/cp_windows_arm64_fips:$(VERSION) --build-arg cp=bin/cp_windows_arm64_fips.exe . |
| 81 | + |
| 82 | +.PHONY := docker |
| 83 | +docker: docker_linux_amd64 docker_linux_arm64 docker_linux_ppc64le docker_linux_s390x docker_windows_amd64 docker_windows_arm64 docker_linux_amd64_fips docker_linux_arm64_fips docker_windows_amd64_fips docker_windows_arm64_fips |
| 84 | + docker buildx imagetools create -t $(REPOSITORY)/cp:$(VERSION) \ |
| 85 | + $(REPOSITORY)/cp_linux_amd64:$(VERSION) \ |
| 86 | + $(REPOSITORY)/cp_linux_arm64:$(VERSION) \ |
| 87 | + $(REPOSITORY)/cp_linux_ppc64le:$(VERSION) \ |
| 88 | + $(REPOSITORY)/cp_linux_s390x:$(VERSION) \ |
| 89 | + $(REPOSITORY)/cp_windows_amd64:$(VERSION) \ |
| 90 | + $(REPOSITORY)/cp_windows_arm64:$(VERSION) |
| 91 | + |
| 92 | + docker buildx imagetools create \ |
| 93 | + -t $(REPOSITORY)/cp:$(VERSION)-fips \ |
| 94 | + $(REPOSITORY)/cp_linux_amd64_fips:$(VERSION) \ |
| 95 | + $(REPOSITORY)/cp_linux_arm64_fips:$(VERSION) \ |
| 96 | + $(REPOSITORY)/cp_windows_amd64_fips:$(VERSION) \ |
| 97 | + $(REPOSITORY)/cp_windows_arm64_fips:$(VERSION) |
0 commit comments