From 36f4ee4ec18a9457b887e2f67a65e3f733569cbe Mon Sep 17 00:00:00 2001 From: FrancescoFioraEst Date: Tue, 2 Aug 2022 11:53:48 +0100 Subject: Create Dockerfile for the test microservice Issue-ID: POLICY-4318 Change-Id: Ic7099e9a7fd5839630a6dc5cc4fa2ea2300c9c58 Signed-off-by: FrancescoFioraEst --- packages/policy-clamp-docker/pom.xml | 37 +++++++++++++ .../main/docker/ElementParticipant-Suse.Dockerfile | 64 ++++++++++++++++++++++ .../src/main/docker/ElementParticipant.Dockerfile | 58 ++++++++++++++++++++ .../src/main/docker/element-participant.sh | 59 ++++++++++++++++++++ packages/policy-clamp-tarball/pom.xml | 7 ++- .../etc/ElementParticipantParameters.yaml | 22 ++++++++ 6 files changed, 246 insertions(+), 1 deletion(-) create mode 100644 packages/policy-clamp-docker/src/main/docker/ElementParticipant-Suse.Dockerfile create mode 100644 packages/policy-clamp-docker/src/main/docker/ElementParticipant.Dockerfile create mode 100644 packages/policy-clamp-docker/src/main/docker/element-participant.sh create mode 100644 packages/policy-clamp-tarball/src/main/resources/etc/ElementParticipantParameters.yaml (limited to 'packages') diff --git a/packages/policy-clamp-docker/pom.xml b/packages/policy-clamp-docker/pom.xml index 96d1ec0d9..cd9cb172b 100644 --- a/packages/policy-clamp-docker/pom.xml +++ b/packages/policy-clamp-docker/pom.xml @@ -228,6 +228,38 @@ + + onap/policy-clamp-acm-element-impl + onap-policy-clamp-acm-element-impl + + try + ElementParticipant${dockerFileFlavor}.Dockerfile + + ${project.version} + ${project.version}-${maven.build.timestamp} + ${project.docker.latest.minmax.tag.version} + + + + + + + org.onap.policy.clamp:policy-clamp-tarball + + /lib + element-participant.tar.gz + + + + org.onap.policy.clamp.participant:policy-clamp-acm-element-impl + + policy-clamp-acm-element-impl.jar + + + + + + @@ -295,5 +327,10 @@ policy-clamp-participant-impl-http ${project.version} + + org.onap.policy.clamp.participant + policy-clamp-acm-element-impl + ${project.version} + diff --git a/packages/policy-clamp-docker/src/main/docker/ElementParticipant-Suse.Dockerfile b/packages/policy-clamp-docker/src/main/docker/ElementParticipant-Suse.Dockerfile new file mode 100644 index 000000000..ed809620a --- /dev/null +++ b/packages/policy-clamp-docker/src/main/docker/ElementParticipant-Suse.Dockerfile @@ -0,0 +1,64 @@ +#------------------------------------------------------------------------------- +# ============LICENSE_START======================================================= +# Copyright (C) 2022 Nordix Foundation. +# ================================================================================ +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# SPDX-License-Identifier: Apache-2.0 +# ============LICENSE_END========================================================= +#------------------------------------------------------------------------------- + +FROM busybox AS tarball +RUN mkdir /packages /extracted +COPY /maven/lib/element-participant.tar.gz /packages +RUN tar xvfz /packages/element-participant.tar.gz --directory /extracted/ + +FROM opensuse/leap:15.4 + +LABEL maintainer="Policy Team" +LABEL org.opencontainers.image.title="Policy CLAMP ACM Element Participant" +LABEL org.opencontainers.image.description="Policy CLAMP ACM Element Participant image based on OpenSuse" +LABEL org.opencontainers.image.url="https://github.com/onap/policy-clamp" +LABEL org.opencontainers.image.vendor="ONAP Policy Team" +LABEL org.opencontainers.image.licenses="Apache-2.0" +LABEL org.opencontainers.image.created="${git.build.time}" +LABEL org.opencontainers.image.version="${git.build.version}" +LABEL org.opencontainers.image.revision="${git.commit.id.abbrev}" + +ARG POLICY_LOGS=/var/log/onap/policy/element-participant + +ENV POLICY_LOGS=$POLICY_LOGS +ENV POLICY_HOME=/opt/app/policy/clamp +ENV LANG=en_US.UTF-8 LANGUAGE=en_US:en LC_ALL=en_US.UTF-8 +ENV JAVA_HOME=/usr/lib64/jvm/java-11-openjdk-11 + +RUN zypper -n -q install --no-recommends java-11-openjdk-headless netcat-openbsd && \ + zypper -n -q update && zypper -n -q clean --all && \ + groupadd --system policy && \ + useradd --system --shell /bin/sh -G policy policy && \ + mkdir -p $POLICY_HOME $POLICY_LOGS && \ + chown -R policy:policy $POLICY_HOME $POLICY_LOGS + +COPY --chown=policy:policy --from=tarball /extracted $POLICY_HOME + +WORKDIR $POLICY_HOME +COPY --chown=policy:policy element-participant.sh bin/ +COPY --chown=policy:policy /maven/policy-clamp-acm-element-impl.jar /app/app.jar + +RUN chmod 755 bin/*.sh + +EXPOSE 8084 + +USER policy +WORKDIR $POLICY_HOME/bin +ENTRYPOINT [ "./element-participant.sh" ] diff --git a/packages/policy-clamp-docker/src/main/docker/ElementParticipant.Dockerfile b/packages/policy-clamp-docker/src/main/docker/ElementParticipant.Dockerfile new file mode 100644 index 000000000..15a569655 --- /dev/null +++ b/packages/policy-clamp-docker/src/main/docker/ElementParticipant.Dockerfile @@ -0,0 +1,58 @@ +#------------------------------------------------------------------------------- +# ============LICENSE_START======================================================= +# Copyright (C) 2022 Nordix Foundation. +# ================================================================================ +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# SPDX-License-Identifier: Apache-2.0 +# ============LICENSE_END========================================================= +#------------------------------------------------------------------------------- + +FROM busybox AS tarball +RUN mkdir /packages /extracted +COPY /maven/lib/element-participant.tar.gz /packages +RUN tar xvfz /packages/element-participant.tar.gz --directory /extracted/ + +FROM onap/policy-jre-alpine:2.5.0-SNAPSHOT + +LABEL maintainer="Policy Team" +LABEL org.opencontainers.image.title="Policy CLAMP ACM Element" +LABEL org.opencontainers.image.description="Policy CLAMP ACM Element image based on Alpine" +LABEL org.opencontainers.image.url="https://github.com/onap/policy-clamp" +LABEL org.opencontainers.image.vendor="ONAP Policy Team" +LABEL org.opencontainers.image.licenses="Apache-2.0" +LABEL org.opencontainers.image.created="${git.build.time}" +LABEL org.opencontainers.image.version="${git.build.version}" +LABEL org.opencontainers.image.revision="${git.commit.id.abbrev}" + +ARG POLICY_LOGS=/var/log/onap/policy/element-participant + +ENV POLICY_LOGS=$POLICY_LOGS +ENV POLICY_HOME=$POLICY_HOME/clamp + +RUN mkdir -p $POLICY_LOGS $POLICY_HOME && \ + chown -R policy:policy $POLICY_HOME $POLICY_LOGS + +COPY --chown=policy:policy --from=tarball /extracted $POLICY_HOME + +WORKDIR $POLICY_HOME +COPY --chown=policy:policy element-participant.sh bin/ +COPY --chown=policy:policy /maven/policy-clamp-acm-element-impl.jar /app/app.jar + +RUN chmod 755 bin/*.sh + +EXPOSE 8084 + +USER policy +WORKDIR $POLICY_HOME/bin +ENTRYPOINT [ "./element-participant.sh" ] diff --git a/packages/policy-clamp-docker/src/main/docker/element-participant.sh b/packages/policy-clamp-docker/src/main/docker/element-participant.sh new file mode 100644 index 000000000..8055a4d92 --- /dev/null +++ b/packages/policy-clamp-docker/src/main/docker/element-participant.sh @@ -0,0 +1,59 @@ +#!/usr/bin/env sh +# +# ============LICENSE_START======================================================= +# Copyright (C) 2022 Nordix Foundation. +# ================================================================================ +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# SPDX-License-Identifier: Apache-2.0 +# ============LICENSE_END========================================================= +# + +KEYSTORE="${KEYSTORE:-$POLICY_HOME/etc/ssl/policy-keystore}" +TRUSTSTORE="${TRUSTSTORE:-$POLICY_HOME/etc/ssl/policy-truststore}" +KEYSTORE_PASSWD="${KEYSTORE_PASSWD:-Pol1cy_0nap}" +TRUSTSTORE_PASSWD="${TRUSTSTORE_PASSWD:-Pol1cy_0nap}" + +if [ "$#" -eq 1 ]; then + CONFIG_FILE=$1 +fi + +if [ -z "$CONFIG_FILE" ]; then + CONFIG_FILE="${POLICY_HOME}/etc/ElementParticipantParameters.yaml" +fi + +echo "Policy clamp Element participant config file: $CONFIG_FILE" + +if [ -f "${POLICY_HOME}/etc/mounted/policy-truststore" ]; then + echo "overriding policy-truststore" + cp -f "${POLICY_HOME}"/etc/mounted/policy-truststore "${TRUSTSTORE}" +fi + +if [ -f "${POLICY_HOME}/etc/mounted/policy-keystore" ]; then + echo "overriding policy-keystore" + cp -f "${POLICY_HOME}"/etc/mounted/policy-keystore "${KEYSTORE}" +fi + +if [ -f "${POLICY_HOME}/etc/mounted/logback.xml" ]; then + echo "overriding logback xml files" + cp -f "${POLICY_HOME}"/etc/mounted/logback*.xml "${POLICY_HOME}"/etc/ +fi + +$JAVA_HOME/bin/java \ + -Dlogging.config="${POLICY_HOME}/etc/logback.xml" \ + -Dserver.ssl.keyStore="${KEYSTORE}" \ + -Dserver.ssl.keyStorePassword="${KEYSTORE_PASSWD}" \ + -Djavax.net.ssl.trustStore="${TRUSTSTORE}" \ + -Djavax.net.ssl.trustStorePassword="${TRUSTSTORE_PASSWD}" \ + -jar /app/app.jar \ + --spring.config.location="${CONFIG_FILE}" diff --git a/packages/policy-clamp-tarball/pom.xml b/packages/policy-clamp-tarball/pom.xml index 2cab0ee3f..380b534e6 100644 --- a/packages/policy-clamp-tarball/pom.xml +++ b/packages/policy-clamp-tarball/pom.xml @@ -1,6 +1,6 @@