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