3e44c42989
The KRM based k8s applier solves multiple design problems which were introduced in previous airshipctl generation, making apply code and process more clear, reliable and readable. In particular: * k8s applier now is a KRM function and it allows the end user to choose or implement desired backend for k8s apply operations; * the related amount of code was reduced by three times, multiple unused and unnecessary structs/interfaces/design patterns were removed or rewrited in more clean and efficient way; * removed cli-utils dependency from airshipctl; * fixed several bugs and code issues, such as incorrect printing of tables, duplicated unit tests, improper generation and applying inventory config map, etc; * cli-utils version used in KRM function was bumped to 0.26.0; * phases with duplicated k8s resources were removed or fixed; * unit test coverage increased to 83.1%; * KRM function logs were integrated with klog library which allows to observe logs directly from cli-utils and other dependent libs. Change-Id: Ief509f1d6abefd53caf7fcffc4e36b0319815373 Signed-off-by: Ruslan Aliev <raliev@mirantis.com> Closes: #646
32 lines
1.3 KiB
Docker
32 lines
1.3 KiB
Docker
ARG GO_IMAGE=quay.io/airshipit/golang:1.16.8-buster
|
|
ARG PLUGINS_RELEASE_IMAGE=quay.io/airshipit/alpine:3.13.5
|
|
|
|
FROM ${GO_IMAGE} as function
|
|
ARG GOPROXY=""
|
|
# Inject custom root certificate authorities if needed
|
|
# Docker does not have a good conditional copy statement and requires that a source file exists
|
|
# to complete the copy function without error. Therefore the README.md file will be copied to
|
|
# the image every time even if there are no .crt files.
|
|
COPY ./certs/* /usr/local/share/ca-certificates/
|
|
RUN update-ca-certificates
|
|
ENV PATH "/usr/local/go/bin:$PATH"
|
|
ENV CGO_ENABLED=0
|
|
WORKDIR /go/src/
|
|
COPY image/ .
|
|
RUN go mod download
|
|
RUN go build -v -o /usr/local/bin/config-function ./
|
|
|
|
FROM ${PLUGINS_RELEASE_IMAGE} as release
|
|
# Inject custom root certificate authorities if needed
|
|
# Docker does not have a good conditional copy statement and requires that a source file exists
|
|
# to complete the copy function without error. Therefore the README.md file will be copied to
|
|
# the image every time even if there are no .crt files.
|
|
RUN apk update && apk add ca-certificates && rm -rf /var/cache/apk/*
|
|
COPY ./certs/* /usr/local/share/ca-certificates/
|
|
RUN update-ca-certificates
|
|
COPY --from=function /usr/local/bin/config-function /usr/local/bin/config-function
|
|
ENV HOME=/home/applier
|
|
WORKDIR $HOME
|
|
RUN chmod -R a+w $HOME
|
|
CMD ["config-function"]
|