# Use docker multi-stage build to create the Seed Controller image
# Base image - needs BOTH alpine 3.7 and python 3.5.5 so needs to be customized
# Build binaries
FROM golang:alpine as builder

RUN apk add --no-cache --virtual --update \
    git \
    curl \
    make \
    openssh \
    bash \
    tzdata &&\
    mkdir -p /go/src/github.com/open-cluster-management/hcm-compliance
RUN go version

COPY . /go/src/github.com/open-cluster-management/hcm-compliance
WORKDIR /go/src/github.com/open-cluster-management/hcm-compliance

RUN ./build-tools/build-all.sh

############################################################
################# Target image #############################
############################################################
FROM registry.access.redhat.com/ubi8/ubi-minimal:8.1-398

ARG VCS_REF
ARG VCS_URL
ARG IMAGE_NAME
ARG IMAGE_DESCRIPTION
ARG IMAGE_DISPLAY_NAME
ARG IMAGE_NAME_ARCH
ARG IMAGE_MAINTAINER
ARG IMAGE_VENDOR
ARG IMAGE_VERSION
ARG IMAGE_DESCRIPTION
ARG IMAGE_SUMMARY
ARG IMAGE_OPENSHIFT_TAGS

LABEL org.label-schema.vendor="Red Hat" \
      org.label-schema.name="$IMAGE_NAME_ARCH" \
      org.label-schema.description="$IMAGE_DESCRIPTION" \
      org.label-schema.vcs-ref=$VCS_REF \
      org.label-schema.vcs-url=$VCS_URL \
      org.label-schema.license="Red Hat Advanced Cluster Management for Kubernetes EULA" \
      org.label-schema.schema-version="1.0" \
      name="$IMAGE_NAME" \
      maintainer="$IMAGE_MAINTAINER" \
      vendor="$IMAGE_VENDOR" \
      version="$IMAGE_VERSION" \
      release="$VCS_REF" \
      description="$IMAGE_DESCRIPTION" \
      summary="$IMAGE_SUMMARY" \
      io.k8s.display-name="$IMAGE_DISPLAY_NAME" \
      io.k8s.description="$IMAGE_DESCRIPTION" \
      io.openshift.tags="$IMAGE_OPENSHIFT_TAGS"

RUN microdnf install ca-certificates && \
    microdnf update && \
    microdnf clean all

RUN mkdir -p /opt/ibm/hybrid-cluster-manager && mkdir -p /opt/ibm/hybrid-cluster-manager/bin
RUN mkdir -p /opt/ibm/hybrid-cluster-manager /licenses
WORKDIR /opt/ibm/hybrid-cluster-manager

ENV USER_UID=10001

# get binaries (or any other artifacts that might be needed) from builder image
COPY --from=builder /go/src/github.com/open-cluster-management/hcm-compliance/bin bin/.

RUN ln -s /opt/ibm/hybrid-cluster-manager/bin/sync-controller-linux-amd64 /usr/local/bin/sync-controller; \
    ln -s /opt/ibm/hybrid-cluster-manager/bin/policy-controller-linux-amd64 /usr/local/bin/policy-controller; \
    ln -s /opt/ibm/hybrid-cluster-manager/bin/policy-propagator-controller-linux-amd64 /usr/local/bin/policy-propagator-controller; \
    # ln -s /opt/ibm/hybrid-cluster-manager/bin/propagator-controller-linux-amd64 /usr/local/bin/propagator-controller; \
    # ln -s /opt/ibm/hybrid-cluster-manager/bin/compliance-controller-linux-amd64 /usr/local/bin/compliance-controller; \
    # ln -s /opt/ibm/hybrid-cluster-manager/bin/accesspolicy-linux-amd64 /usr/local/bin/accesspolicy-controller; \
    ln -s /opt/ibm/hybrid-cluster-manager/bin/uninstall-crd-linux-amd64 /usr/local/bin/uninstall-crd;

USER ${USER_UID}
# the docker image contains multiple binaries and works similarly to the docker
# image for kube binaries, so there is no default command we use