SDNR Add sdnr feature to SDNC
[sdnc/oam.git] / installation / sdnc / src / main / docker / Dockerfile
1 # Base ubuntu with added packages needed for open ecomp
2 FROM onap/ccsdk-odlsli-alpine-image:${ccsdk.docker.version}
3
4 MAINTAINER SDN-C Team (sdnc@lists.onap.org)
5
6 #ENV JAVA_HOME /usr/lib/jvm/java-8-openjdk-amd64
7 ENV JAVA_HOME /usr/lib/jvm/java-1.8-openjdk
8 ENV ODL_HOME /opt/opendaylight
9 ENV SDNC_CONFIG_DIR /opt/onap/sdnc/data/properties
10 ENV SDNC_STORE_DIR /opt/onap/sdnc/data/stores
11 ENV SSL_CERTS_DIR /etc/ssl/certs
12 ENV JAVA_SECURITY_DIR $SSL_CERTS_DIR/java
13 ENV SDNC_NORTHBOUND_REPO mvn:org.onap.sdnc.northbound/sdnc-northbound-all/${sdnc.northbound.version}/xml/features
14 ENV SDNR_NORTHBOUND_REPO mvn:org.onap.ccsdk.features.sdnr.northbound/sdnr-northbound-all/${ccsdk.features.version}/xml/features
15 ENV SDNR_WT_REPO mvn:org.onap.ccsdk.features.sdnr.wt/sdnr-wt-feature-aggregator/${ccsdk.features.version}/xml/features
16 ENV SDNC_KEYSTORE ${sdnc.keystore}
17 ENV SDNC_KEYPASS ${sdnc.keypass}
18 ENV SDNC_SECUREPORT ${sdnc.secureport}
19
20 USER root
21
22 # copy onap
23 COPY opt /opt
24 RUN test -L /opt/sdnc || ln -s /opt/onap/sdnc /opt/sdnc
25 RUN mkdir /opt/opendaylight/current/certs
26
27 # copy SDNC mvn artifacts to ODL repository
28 COPY system /tmp/system
29 RUN rsync -a /tmp/system $ODL_HOME && rm -rf /tmp/system
30
31 # Add SDNC repositories to boot repositories
32 RUN cp $ODL_HOME/etc/org.apache.karaf.features.cfg $ODL_HOME/etc/org.apache.karaf.features.cfg.orig
33 RUN sed -i -e "\|featuresRepositories|s|$|,${SDNC_NORTHBOUND_REPO}, ${SDNR_NORTHBOUND_REPO}, ${SDNR_WT_REPO}|"  $ODL_HOME/etc/org.apache.karaf.features.cfg
34 RUN sed -i -e "\|featuresBoot[^a-zA-Z]|s|$|,sdnc-northbound-all, sdnr-northbound-all|"  $ODL_HOME/etc/org.apache.karaf.features.cfg
35 RUN sed -i "s/odl-restconf-all/odl-restconf-all,odl-netconf-topology/g"  $ODL_HOME/etc/org.apache.karaf.features.cfg
36
37 # install AAF configs
38 COPY aaa-app-config.xml $ODL_HOME/etc/opendaylight/datastore/initial/config/
39 RUN echo "cadi_prop_files=$SDNC_CONFIG_DIR/org.onap.sdnc.props" >> $ODL_HOME/etc/system.properties
40
41 # install ssl and java certificates
42 COPY truststoreONAPall.jks $JAVA_SECURITY_DIR
43 COPY truststoreONAPall.jks $SDNC_STORE_DIR
44
45 RUN keytool -importkeystore -srckeystore $JAVA_SECURITY_DIR/truststoreONAPall.jks -srcstorepass changeit -destkeystore $JAVA_SECURITY_DIR/cacerts  -deststorepass changeit
46
47 # Secure with TLS
48 RUN echo org.osgi.service.http.secure.enabled=true >> $ODL_HOME/etc/custom.properties
49 RUN echo org.osgi.service.http.secure.port=$SDNC_SECUREPORT >> $ODL_HOME/etc/custom.properties
50 RUN echo org.ops4j.pax.web.ssl.keystore=$SDNC_STORE_DIR/$SDNC_KEYSTORE >> $ODL_HOME/etc/custom.properties
51 RUN echo org.ops4j.pax.web.ssl.password=$SDNC_KEYPASS >> $ODL_HOME/etc/custom.properties
52 RUN echo org.ops4j.pax.web.ssl.keypassword=$SDNC_KEYPASS >> $ODL_HOME/etc/custom.properties
53
54
55
56
57 RUN chown -R odl /opt
58 USER odl
59
60 ENTRYPOINT /opt/onap/sdnc/bin/startODL.sh
61 EXPOSE 8181