4 # ============LICENSE_START=======================================================
6 # ================================================================================
7 # Copyright (C) 2020 Samsung Electronics
8 # Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
9 # Copyright (C) 2020 Highstreet Technologies
10 # ================================================================================
11 # Licensed under the Apache License, Version 2.0 (the "License");
12 # you may not use this file except in compliance with the License.
13 # You may obtain a copy of the License at
15 # http://www.apache.org/licenses/LICENSE-2.0
17 # Unless required by applicable law or agreed to in writing, software
18 # distributed under the License is distributed on an "AS IS" BASIS,
19 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20 # See the License for the specific language governing permissions and
21 # limitations under the License.
22 # ============LICENSE_END=========================================================
24 # A single entry point script that can be used in Kubernetes based deployments (via OOM) and standalone docker deployments.
25 # Please see https://wiki.onap.org/display/DW/startODL.sh+-+Important+Environment+variables+and+their+description for more details
29 # Test if repository exists, like this mvn:org.onap.ccsdk.features.sdnr.wt/sdnr-wt-devicemanager-oran-feature/0.7.2/xml/features
31 function isRepoExisting() {
32 REPO=$(echo $1 | sed -E "s#mvn:(.*)/xml/features\$#\1#")
36 path="$ODL_HOME/system/"${parts[0]//./\/}"/"${parts[1]}"/"${parts[2]}
40 # Add features repository to karaf featuresRepositories configuration
41 # $1 repositories to be added
42 function addRepository() {
43 CFG=$ODL_FEATURES_BOOT_FILE
45 if isRepoExisting "$1" ; then
46 echo "Add repository: $1"
47 sed -i "\|featuresRepositories|s|$|, $1|" $CFG
49 echo "Repo does not exist: $1"
53 # Append features to karaf boot feature configuration
54 # $1 additional feature to be added
55 # $2 repositories to be added (optional)
56 function addToFeatureBoot() {
57 CFG=$ODL_FEATURES_BOOT_FILE
60 echo "Add repository: $2"
62 cat $ORIG | sed -e "\|featuresRepositories|s|$|,$2|" > $CFG
64 echo "Add boot feature: $1"
66 cat $ORIG | sed -e "\|featuresBoot *=|s|$|,$1|" > $CFG
69 # Append features to karaf boot feature configuration
72 function replaceFeatureBoot() {
73 CFG=$ODL_HOME/etc/org.apache.karaf.features.cfg
75 echo "Replace boot feature $1 with: $2"
76 sed -i "/featuresBoot/ s/$1/$2/g" $CFG
79 # Remove all sdnc specific features
80 function cleanupFeatureBoot() {
81 echo "Remove northbound bootfeatures "
82 sed -i "/featuresBoot/ s/,ccsdk-sli-core-all.*$//g" $ODL_FEATURES_BOOT_FILE
85 function initialize_sdnr() {
86 echo "SDN-R Database Initialization"
87 INITCMD="$JAVA_HOME/bin/java -jar "
88 INITCMD+="$ODL_HOME/system/org/onap/ccsdk/features/sdnr/wt/sdnr-wt-data-provider-setup/$CCSDKFEATUREVERSION/sdnr-dmt.jar "
89 INITCMD+="$SDNRDBCOMMAND"
90 echo "Execute: $INITCMD"
92 until [ $n -ge 5 ] ; do
100 function install_sdnrwt_features() {
101 # Repository setup provided via sdnc dockerfile
103 addRepository $SDNRDM_BASE_REPO
104 addRepository $SDNRDM_ONF_REPO
110 addToFeatureBoot "$SDNRDM_BOOTFEATURES"
112 addToFeatureBoot "$SDNRWT_BOOTFEATURES"
117 function install_sdnr_northbound_features() {
118 addToFeatureBoot "$SDNR_NORTHBOUND_BOOTFEATURES"
121 # Reconfigure ODL from default single node configuration to cluster
123 function enable_odl_cluster() {
124 if [ -z $SDNC_REPLICAS ]; then
125 echo "SDNC_REPLICAS is not configured in Env field"
130 echo "Installing Opendaylight cluster features for mdsal and netconf"
132 #Be sure to remove feature odl-netconf-connector-all from list
133 replaceFeatureBoot "odl-netconf-connector-all,"
135 echo "Installing Opendaylight cluster features"
136 replaceFeatureBoot odl-netconf-topology odl-netconf-clustered-topology
137 replaceFeatureBoot odl-mdsal-all odl-mdsal-all,odl-mdsal-clustering
138 addToFeatureBoot odl-jolokia
139 #${ODL_HOME}/bin/client feature:install odl-mdsal-clustering
140 #${ODL_HOME}/bin/client feature:install odl-jolokia
142 # ODL Cluster or Geo cluster configuration
144 echo "Update cluster information statically"
146 echo "Get current fqdn ${fqdn}"
148 # Extract node index using first digit after "-"
149 # Example 2 from "sdnr-2.logo.ost.das.r32.com"
150 node_index=`(echo ${fqdn} | sed -r 's/.*-([0-9]).*/\1/g')`
153 if $GEO_ENABLED; then
154 echo "This is a Geo cluster"
156 if [ -z $IS_PRIMARY_CLUSTER ] || [ -z $MY_ODL_CLUSTER ] || [ -z $PEER_ODL_CLUSTER ]; then
157 echo "IS_PRIMARY_CLUSTER, MY_ODL_CLUSTER and PEER_ODL_CLUSTER must all be configured in Env field"
161 if $IS_PRIMARY_CLUSTER; then
162 PRIMARY_NODE=${MY_ODL_CLUSTER}
163 SECONDARY_NODE=${PEER_ODL_CLUSTER}
165 PRIMARY_NODE=${PEER_ODL_CLUSTER}
166 SECONDARY_NODE=${MY_ODL_CLUSTER}
170 node_list="${PRIMARY_NODE} ${SECONDARY_NODE}"
172 ${SDNC_BIN}/configure_geo_cluster.sh $((node_index+member_offset)) ${node_list}
174 echo "This is a local cluster"
176 # SERVICE_NAME and NAMESPACE are used to create cluster node names and are provided via Helm charts in OOM environment
177 if [ ! -z "$SERVICE_NAME" ] && [ ! -z "$NAMESPACE" ]; then
178 # Extract node name minus the index
179 # Example sdnr from "sdnr-2.logo.ost.das.r32.com"
180 node_name=($(echo ${fqdn} | sed 's/-[0-9].*$//g'))
181 for ((i=0;i<${SDNC_REPLICAS};i++));
183 node_list="${node_list} ${node_name}-$i.${SERVICE_NAME}-cluster.${NAMESPACE}"
185 ${ODL_HOME}/bin/configure_cluster.sh $((node_index+1)) ${node_list}
186 elif [ -z "$SERVICE_NAME" ] && [ -z "$NAMESPACE" ]; then
187 # Hostname is used in Standalone environment to create cluster node names
188 for ((i=0;i<${SDNC_REPLICAS};i++));
190 #assemble node list by replacing node-index in hostname with "i"
191 node_name=`(echo ${fqdn} | sed -r "s/-[0-9]/-$i/g")`
192 node_list="${node_list} ${node_name}"
194 ${ODL_HOME}/bin/configure_cluster.sh $((node_index+1)) ${node_list}
196 echo "Unhandled cluster scenario. Terminating the container"
197 echo "Any one of the below 2 conditions should be satisfied for successfully enabling cluster mode : "
198 echo "1. OOM Environment - Both SERVICE_NAME and NAMESPACE environment variables have to be set."
199 echo "2. Docker (standalone) Environment - Neither of SERVICE_NAME and NAMESPACE have to be set."
200 echo "Current configuration - SERVICE_NAME = $SERVICE_NAME NAMESPACE = $NAMESPACE"
207 # Install SDN-C platform components if not already installed and start container
209 # -----------------------
210 # Main script starts here
212 ODL_HOME=${ODL_HOME:-/opt/opendaylight/current}
213 ODL_FEATURES_BOOT_FILE=$ODL_HOME/etc/org.apache.karaf.features.cfg
215 ODL_REMOVEIDMDB=${ODL_REMOVEIDMDB:-false}
217 ODL_ADMIN_USERNAME=${ODL_ADMIN_USERNAME:-admin}
218 if $ODL_REMOVEIDMDB ; then
219 echo "Remove odl idmdb"
220 rm $ODL_HOME/data/idmlight.db.mv.db
221 ODL_ADMIN_PASSWORD=${ODL_ADMIN_PASSWORD:-admin}
223 ODL_ADMIN_PASSWORD=${ODL_ADMIN_PASSWORD:-Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U}
225 ODL_ADMIN_PASSWORD=${ODL_ADMIN_PASSWORD:-Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U}
226 SDNC_HOME=${SDNC_HOME:-/opt/onap/sdnc}
227 SDNC_BIN=${SDNC_BIN:-/opt/onap/sdnc/bin}
228 # Whether to intialize MYSql DB or not. Default is to initialize
229 SDNC_DB_INIT=${SDNC_DB_INIT:-false}
230 CCSDK_HOME=${CCSDK_HOME:-/opt/onap/ccsdk}
231 JDEBUG=${JDEBUG:-false}
232 MYSQL_PASSWD=${MYSQL_PASSWD:-openECOMP1.0}
233 ENABLE_ODL_CLUSTER=${ENABLE_ODL_CLUSTER:-false}
234 GEO_ENABLED=${GEO_ENABLED:-false}
235 SDNC_AAF_ENABLED=${SDNC_AAF_ENABLED:-false}
236 IS_PRIMARY_CLUSTER=${IS_PRIMARY_CLUSTER:-false}
237 MY_ODL_CLUSTER=${MY_ODL_CLUSTER:-127.0.0.1}
238 INSTALLED_DIR=${INSTALLED_FILE:-/opt/opendaylight/current/daexim}
239 SDNRWT=${SDNRWT:-false}
240 SDNRWT_BOOTFEATURES=${SDNRWT_BOOTFEATURES:-sdnr-wt-feature-aggregator}
241 SDNRDM=${SDNRDM:-false}
242 # Add devicemanager base and specific repositories
243 SDNRDM_BASE_REPO=${SDNRDM_BASE_REPO:-mvn:org.onap.ccsdk.features.sdnr.wt/sdnr-wt-feature-aggregator-devicemanager-base/$CCSDKFEATUREVERSION/xml/features}
244 SDNRDM_ONF_REPO=${SDNRDM_ONF_REPO:-mvn:org.onap.ccsdk.features.sdnr.wt/sdnr-wt-devicemanager-onf-feature/$CCSDKFEATUREVERSION/xml/features}
245 # Add devicemanager features
246 SDNRDM_SDM_LIST=${SDNRDM_SDM_LIST:-sdnr-wt-devicemanager-onf-feature}
247 SDNRDM_BOOTFEATURES=${SDNRDM_BOOTFEATURES:-sdnr-wt-feature-aggregator-devicemanager-base, ${SDNRDM_SDM_LIST}}
248 # Whether to Initialize the ElasticSearch DB.
249 SDNRINIT=${SDNRINIT:-false}
250 SDNRONLY=${SDNRONLY:-false}
251 SDNRDBURL=${SDNRDBURL:-http://sdnrdb:9200}
252 SDNRDBCOMMAND=${SDNRDBCOMMAND:--c init -db $SDNRDBURL -dbu $SDNRDBUSERNAME -dbp $SDNRDBPASSWORD $SDNRDBPARAMETER}
254 SDNR_NORTHBOUND=${SDNR_NORTHBOUND:-false}
255 SDNR_NORTHBOUND_BOOTFEATURES=${SDNR_NORTHBOUND_BOOTFEATURES:-sdnr-northbound-all}
257 export ODL_ADMIN_PASSWORD ODL_ADMIN_USERNAME
260 echo "Activate remote debugging"
261 #JSTADTPOLICYFILE="$ODL_HOME/etc/tools.policy"
262 #echo -e "grant codebase \"file:${JAVA_HOME}/lib/tools.jar\" {\n permission java.security.AllPermission;\n };" > $JSTADTPOLICYFILE
264 #$JAVA_HOME/bin/jstatd -p 1089 -J-Djava.security.policy=$JSTADTPOLICYFILE &
265 EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.port=1090"
266 EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.rmi.port=1090"
267 EXTRA_JAVA_OPTS+=" -Djava.rmi.server.hostname=$HOSTNAME"
268 EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.local.only=false"
269 EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.ssl=false"
270 EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.authenticate=false"
271 export EXTRA_JAVA_OPTS
276 echo " SDNC_BIN=$SDNC_BIN"
277 echo " SDNC_HOME=$SDNC_HOME"
278 echo " SDNC_DB_INIT=$SDNC_DB_INIT"
279 echo " ODL_CERT_DIR=$ODL_CERT_DIR"
280 echo " CCSDKFEATUREVERSION=$CCSDKFEATUREVERSION"
281 echo " ENABLE_ODL_CLUSTER=$ENABLE_ODL_CLUSTER"
282 echo " ODL_REMOVEIDMDB=$ODL_REMOVEIDMDB"
283 echo " SDNC_REPLICAS=$SDNC_REPLICAS"
284 echo " SDNRWT=$SDNRWT"
285 echo " SDNRDM=$SDNRDM"
286 echo " SDNRONLY=$SDNRONLY"
287 echo " SDNRINIT=$SDNRINIT"
288 echo " SDNRDBURL=$SDNRDBURL"
289 echo " SDNRDBUSERNAME=$SDNRDBUSERNAME"
290 echo " GEO_ENABLED=$GEO_ENABLED"
291 echo " IS_PRIMARY_CLUSTER=$IS_PRIMARY_CLUSTER"
292 echo " MY_ODL_CLUSTER=$MY_ODL_CLUSTER"
293 echo " PEER_ODL_CLUSTER=$PEER_ODL_CLUSTER"
294 echo " SDNR_NORTHBOUND=$SDNR_NORTHBOUND"
295 echo " AAF_ENABLED=$SDNC_AAF_ENABLED"
296 echo " SERVICE_NAME=$SERVICE_NAME"
297 echo " NAMESPACE=$NAMESPACE"
299 if $SDNC_AAF_ENABLED; then
300 export SDNC_AAF_STORE_DIR=/opt/app/osaaf/local
301 export SDNC_AAF_CONFIG_DIR=/opt/app/osaaf/local
302 export SDNC_KEYPASS=`cat /opt/app/osaaf/local/.pass`
303 export SDNC_KEYSTORE=org.onap.sdnc.p12
304 sed -i '/cadi_prop_files/d' $ODL_HOME/etc/system.properties
305 echo "cadi_prop_files=$SDNC_AAF_CONFIG_DIR/org.onap.sdnc.props" >> $ODL_HOME/etc/system.properties
307 sed -i '/org.ops4j.pax.web.ssl.keystore/d' $ODL_HOME/etc/custom.properties
308 sed -i '/org.ops4j.pax.web.ssl.password/d' $ODL_HOME/etc/custom.properties
309 sed -i '/org.ops4j.pax.web.ssl.keypassword/d' $ODL_HOME/etc/custom.properties
310 echo org.ops4j.pax.web.ssl.keystore=$SDNC_AAF_STORE_DIR/$SDNC_KEYSTORE >> $ODL_HOME/etc/custom.properties
311 echo org.ops4j.pax.web.ssl.password=$SDNC_KEYPASS >> $ODL_HOME/etc/custom.properties
312 echo org.ops4j.pax.web.ssl.keypassword=$SDNC_KEYPASS >> $ODL_HOME/etc/custom.properties
316 #One time intialization action
319 echo "Result of init script: $init_result"
321 echo "Proceed to initialize sdnr"
327 # Check for MySQL DB connectivity only if SDNC_DB_INIT is set to "true"
328 if $SDNC_DB_INIT; then
332 echo "Waiting for mysql"
333 until mysql -h dbhost -u root -p${MYSQL_PASSWD} mysql &> /dev/null
338 echo -e "\nmysql ready"
341 if [ ! -d ${INSTALLED_DIR} ]
343 mkdir -p ${INSTALLED_DIR}
346 if [ ! -f ${SDNC_HOME}/.installed ]
348 # for integration testing. In OOM, a separate job takes care of installing it.
349 if $SDNC_DB_INIT; then
350 echo "Installing SDN-C database"
351 ${SDNC_HOME}/bin/installSdncDb.sh
353 echo "Installing SDN-C keyStore\n"
354 ${SDNC_HOME}/bin/addSdncKeyStore.sh
355 echo "Installing A1-adapter trustStore\n"
356 ${SDNC_HOME}/bin/addA1TrustStore.sh
358 if [ -x ${SDNC_HOME}/svclogic/bin/install.sh ]
360 echo "Installing directed graphs"
361 ${SDNC_HOME}/svclogic/bin/install.sh
364 if $ENABLE_ODL_CLUSTER ; then enable_odl_cluster ; fi
366 if $SDNRWT ; then install_sdnrwt_features ; fi
368 if $SDNR_NORTHBOUND ; then install_sdnr_northbound_features ; fi
369 echo "Installed at `date`" > ${SDNC_HOME}/.installed
372 #cp /opt/opendaylight/current/certs/* /tmp
373 #cp /var/custom-certs/* /tmp
375 if [ -n "$OVERRIDE_FEATURES_BOOT" ] ; then
376 echo "Override features boot: $OVERRIDE_FEATURES_BOOT"
377 sed -i "/$FEATURESBOOTMARKER/c\featuresBoot = $OVERRIDE_FEATURES_BOOT" $ODL_FEATURES_BOOT_FILE
380 # Odl configuration done
381 ODL_REPOSITORIES_BOOT=$(sed -n "/$REPOSITORIESBOOTMARKER/p" $ODL_FEATURES_BOOT_FILE)
382 ODL_FEATURES_BOOT=$(sed -n "/$FEATURESBOOTMARKER/p" $ODL_FEATURES_BOOT_FILE)
383 export ODL_FEATURES_BOOT
385 # Create ODL data log directory (it nornally is created after karaf
386 # is started, but needs to exist before installCerts.py runs)
387 if [ -z "$ODL_CERT_DIR" ] ; then
388 echo "No certs provided. Skip installation."
390 echo "Start background cert installer"
391 mkdir -p /opt/opendaylight/data/log
392 nohup python3 ${SDNC_BIN}/installCerts.py &
395 echo "Startup opendaylight"
396 echo $ODL_REPOSITORIES_BOOT
397 echo $ODL_FEATURES_BOOT
398 exec ${ODL_HOME}/bin/karaf server