-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile-ci
81 lines (52 loc) · 2.5 KB
/
Dockerfile-ci
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
FROM hashicorp/terraform:1.3.5 AS terraform
FROM regclient/regctl:edge-alpine AS regctl
FROM golang:1.19.3-alpine AS go
RUN apk add --update git
RUN GO111MODULE=on go install github.com/raviqqe/liche@latest
FROM gcr.io/tekton-releases/github.com/tektoncd/pipeline/cmd/git-init:v0.45.0 AS git-init
FROM alpine:3.20 AS kubectl
ENV VERSION="v1.32.0"
ENV BINARY="/bin/kubectl"
RUN if [ $(uname -m) == "aarch64" ]; then ARCH="arm64"; else ARCH="amd64"; fi; \
wget -q "https://dl.k8s.io/release/${VERSION}/bin/linux/${ARCH}/kubectl" -O ${BINARY}
FROM alpine:3.20 AS policygenerator
ENV VERSION="v1.16.0"
ENV REGISTRY="open-cluster-management-io/policy-generator-plugin"
ENV BINARY="/bin/PolicyGenerator"
RUN if [ $(uname -m) == "aarch64" ]; then ARCH="arm64"; else ARCH="amd64"; fi; \
wget -q "https://github.com/${REGISTRY}/releases/download/${VERSION}/linux-${ARCH}-PolicyGenerator" -O ${BINARY}
FROM alpine:3.20 AS gh
ENV GITHUB_CLI_VERSION=2.0.0
RUN if [ $(uname -m) == "aarch64" ]; then ARCH=arm64; else ARCH=amd64; fi; \
wget -O /tmp/gh.tgz https://github.com/cli/cli/releases/download/v${GITHUB_CLI_VERSION}/gh_${GITHUB_CLI_VERSION}_linux_${ARCH}.tar.gz && \
tar --strip-components=2 --extract --file /tmp/gh.tgz \
gh_${GITHUB_CLI_VERSION}_linux_${ARCH}/bin/gh && mv -v gh /bin/gh
FROM alpine:3.20 AS yq
ENV VERSION=v4.30.5
RUN if [ $(uname -m) == "aarch64" ]; then ARCH=arm64; else ARCH=amd64; fi; \
wget -O /tmp/yq.tgz https://github.com/mikefarah/yq/releases/download/${VERSION}/yq_linux_${ARCH}.tar.gz && \
tar --extract --file /tmp/yq.tgz \
./yq_linux_${ARCH} && mv -v yq_linux_${ARCH} /bin/yq
FROM alpine:3.20
RUN apk add --update \
git make bash jq curl gpg gnupg less openssh patch pigz \
python3 py3-boto3 aws-cli && \
apk --purge -v del py-pip && \
rm -rf /var/cache/apk/* && \
rm -rf $HOME/.cache
COPY --from=git-init /ko-app/git-init /usr/local/bin
COPY --from=terraform /bin/terraform /usr/local/bin
COPY --from=regctl /usr/local/bin/regctl /usr/local/bin
COPY --from=gh /bin/gh /usr/local/bin
COPY --from=yq /bin/yq /usr/local/bin
COPY --from=kubectl --chmod=775 /bin/kubectl /usr/local/bin
ENV KUSTOMIZE_PLUGIN_HOME="/opt/kustomize/plugin"
COPY --from=policygenerator --chmod=775 /bin/PolicyGenerator \
/opt/kustomize/plugin/policy.open-cluster-management.io/v1/policygenerator/PolicyGenerator
ENV GO_BIN="/go/bin"
ENV PATH="$GO_BIN:$PATH"
COPY --from=go /go/bin $GO_BIN
ENV BIN_3SCALE="/opt/3scale/bin"
ENV PATH="$BIN_3SCALE:$PATH"
ADD bin/ $BIN_3SCALE
RUN chmod -R 0755 $BIN_3SCALE