FROM openshift/golang-builder@sha256:4820580c3368f320581eb9e32cf97aeec179a86c5749753a14ed76410a293d83 AS builder
ENV __doozer=update BUILD_RELEASE=202203142027.p0.g118b8ce.assembly.stream BUILD_VERSION=v4.10.0 OS_GIT_MAJOR=4 OS_GIT_MINOR=10 OS_GIT_PATCH=0 OS_GIT_TREE_STATE=clean OS_GIT_VERSION=4.10.0-202203142027.p0.g118b8ce.assembly.stream SOURCE_GIT_TREE_STATE=clean 
ENV __doozer=merge OS_GIT_COMMIT=118b8ce OS_GIT_VERSION=4.10.0-202203142027.p0.g118b8ce.assembly.stream-118b8ce SOURCE_DATE_EPOCH=1643323133 SOURCE_GIT_COMMIT=118b8cea53638d2d8f096c72b64e5b7fdabefd9f SOURCE_GIT_TAG=118b8cea5 SOURCE_GIT_URL=https://github.com/openshift/ocp-release-operator-sdk 

ENV GO111MODULE=on \
    GOFLAGS=-mod=vendor

# we need to patch the Makefile prior to building
COPY . /go/src/github.com/operator-framework/operator-sdk
RUN cd /go/src/github.com/operator-framework/operator-sdk \
 && make -f ci/prow.Makefile patch build

FROM openshift/ose-base:v4.10.0-202203081809.p0.g5d526c4.assembly.stream
ENV __doozer=update BUILD_RELEASE=202203142027.p0.g118b8ce.assembly.stream BUILD_VERSION=v4.10.0 OS_GIT_MAJOR=4 OS_GIT_MINOR=10 OS_GIT_PATCH=0 OS_GIT_TREE_STATE=clean OS_GIT_VERSION=4.10.0-202203142027.p0.g118b8ce.assembly.stream SOURCE_GIT_TREE_STATE=clean 
ENV __doozer=merge OS_GIT_COMMIT=118b8ce OS_GIT_VERSION=4.10.0-202203142027.p0.g118b8ce.assembly.stream-118b8ce SOURCE_DATE_EPOCH=1643323133 SOURCE_GIT_COMMIT=118b8cea53638d2d8f096c72b64e5b7fdabefd9f SOURCE_GIT_TAG=118b8cea5 SOURCE_GIT_URL=https://github.com/openshift/ocp-release-operator-sdk 

RUN mkdir -p /etc/ansible \
    && echo "localhost ansible_connection=local" > /etc/ansible/hosts \
    && echo '[defaults]' > /etc/ansible/ansible.cfg \
    && echo 'roles_path = /opt/ansible/roles' >> /etc/ansible/ansible.cfg \
    && echo 'library = /usr/share/ansible/openshift' >> /etc/ansible/ansible.cfg

ENV HOME=/opt/ansible \
    USER_NAME=ansible \
    USER_UID=1001

RUN yum install -y \
      ansible \
      ansible-runner \
      ansible-runner-http \
      python3-kubernetes \
      python3-openshift \
      python3-oauthlib \
      python3-requests-oauthlib \
      python3-jmespath \
      tini \
 && yum clean all \
 && rm -rf /var/cache/yum

COPY --from=builder /go/src/github.com/operator-framework/operator-sdk/build/ansible-operator /usr/local/bin/ansible-operator
COPY release/ansible/ansible_collections ${HOME}/.ansible/collections/ansible_collections

COPY release/ansible/bin /usr/local/bin

RUN /usr/local/bin/user_setup

# Ensure directory permissions are properly set
RUN mkdir -p ${HOME}/.ansible/tmp \
 && chown -R ${USER_UID}:0 ${HOME} \
 && chmod -R ug+rwx ${HOME}


WORKDIR ${HOME}
USER ${USER_UID}
ENTRYPOINT ["/usr/bin/tini", "--", "/usr/local/bin/ansible-operator", "run", "--watches-file=./watches.yaml"]

LABEL \
        name="openshift/ose-ansible-operator" \
        com.redhat.component="openshift-enterprise-ansible-operator-container" \
        io.openshift.maintainer.product="OpenShift Container Platform" \
        io.openshift.maintainer.component="Operator SDK" \
        release="202203142027.p0.g118b8ce.assembly.stream" \
        io.openshift.build.commit.id="118b8cea53638d2d8f096c72b64e5b7fdabefd9f" \
        io.openshift.build.source-location="https://github.com/openshift/ocp-release-operator-sdk" \
        io.openshift.build.commit.url="https://github.com/openshift/ocp-release-operator-sdk/commit/118b8cea53638d2d8f096c72b64e5b7fdabefd9f" \
        version="v4.10.0"

