Resolve issues starting with docker-compose
[sdnc/oam.git] / installation / sdnc / src / main / docker / standalone.Dockerfile
1 # Prepare stage for multistage image build
2 ## START OF STAGE0 ##
3 FROM onap/ccsdk-odlsli-alpine-image:${ccsdk.docker.version} AS stage0
4
5 USER root
6
7 # copy onap
8 COPY opt /opt
9 RUN test -L /opt/sdnc || ln -s /opt/onap/sdnc /opt/sdnc
10 RUN mkdir $ODL_HOME/current/certs
11
12 # copy SDNC mvn artifacts to ODL repository
13 COPY system /tmp/system
14 RUN rsync -a /tmp/system $ODL_HOME
15 ## END OF STAGE0 ##
16
17 FROM onap/ccsdk-odlsli-alpine-image:${ccsdk.docker.version}
18
19 LABEL maintainer="SDN-C Team (sdnc@lists.onap.org)"
20
21 ENV SDNC_CONFIG_DIR /opt/onap/sdnc/data/properties
22 ENV SDNC_STORE_DIR /opt/onap/sdnc/data/stores
23 ENV SSL_CERTS_DIR /etc/ssl/certs
24 ENV JAVA_SECURITY_DIR $SSL_CERTS_DIR/java
25 ENV SDNC_NORTHBOUND_REPO mvn:org.onap.sdnc.northbound/sdnc-northbound-all/${sdnc.northbound.version}/xml/features
26 ENV SDNC_KEYSTORE ${sdnc.keystore}
27 ENV SDNC_KEYPASS ${sdnc.keypass}
28 ENV SDNC_SECUREPORT ${sdnc.secureport}
29
30 USER root
31
32 COPY --from=stage0 --chown=odl:odl /opt /opt
33
34 # Add SDNC repositories to boot repositories
35 RUN cp $ODL_HOME/etc/org.apache.karaf.features.cfg $ODL_HOME/etc/org.apache.karaf.features.cfg.orig
36 RUN sed -i -e "\|featuresRepositories|s|$|,${SDNC_NORTHBOUND_REPO}|"  $ODL_HOME/etc/org.apache.karaf.features.cfg
37 RUN sed -i -e "\|featuresBoot[^a-zA-Z]|s|$|,sdnc-northbound-all|"  $ODL_HOME/etc/org.apache.karaf.features.cfg
38 RUN sed -i "s/odl-restconf-all/odl-restconf-all,odl-netconf-topology/g"  $ODL_HOME/etc/org.apache.karaf.features.cfg
39
40 # Install ssl and java certificates
41 COPY truststoreONAPall.jks $SDNC_STORE_DIR
42 RUN if [ -f $JAVA_SECURITY_DIR}/cacerts ] ; then keytool -importkeystore -srckeystore $SDNC_STORE_DIR/truststoreONAPall.jks -srcstorepass changeit -destkeystore $JAVA_SECURITY_DIR/cacerts  -deststorepass changeit -noprompt ; fi
43 RUN keytool -importkeystore -srckeystore $SDNC_STORE_DIR/truststoreONAPall.jks -srcstorepass changeit -destkeystore /opt/java/openjdk/lib/security/cacerts  -deststorepass changeit -noprompt
44
45
46 # Secure with TLS
47 RUN echo org.osgi.service.http.secure.enabled=true >> $ODL_HOME/etc/custom.properties
48 RUN echo org.osgi.service.http.secure.port=$SDNC_SECUREPORT >> $ODL_HOME/etc/custom.properties
49 RUN echo org.ops4j.pax.web.ssl.keystore=$SDNC_STORE_DIR/$SDNC_KEYSTORE >> $ODL_HOME/etc/custom.properties
50 RUN echo org.ops4j.pax.web.ssl.password=$SDNC_KEYPASS >> $ODL_HOME/etc/custom.properties
51 RUN echo org.ops4j.pax.web.ssl.keypassword=$SDNC_KEYPASS >> $ODL_HOME/etc/custom.properties
52
53 # Overwrite svclogic compiler properties
54 RUN cp /opt/onap/sdnc/data/properties/svclogic-compiler.properties /opt/onap/sdnc/svclogic/config/svclogic.properties
55 RUN chown -R odl:odl /opt
56
57 USER odl
58
59 ENTRYPOINT /opt/onap/sdnc/bin/startODL.sh
60 EXPOSE 8181