Fixes based on review comments in Guilin
[sdnc/oam.git] / installation / sdnc / src / main / scripts / startODL.sh
1 #!/bin/bash
2
3 ###
4 # ============LICENSE_START=======================================================
5 # SDN-C
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
14 #
15 #      http://www.apache.org/licenses/LICENSE-2.0
16 #
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=========================================================
23 ###
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
26
27 # Functions
28
29 # Test if repository exists, like this mvn:org.onap.ccsdk.features.sdnr.wt/sdnr-wt-devicemanager-oran-feature/0.7.2/xml/features
30 # $1 repository
31 function isRepoExisting() {
32   REPO=$(echo $1 | sed -E "s#mvn:(.*)/xml/features\$#\1#")
33   OIFS="$IFS"
34   IFS='/' parts=($REPO)
35   IFS="$OIFS"
36   path="$ODL_HOME/system/"${parts[0]//./\/}"/"${parts[1]}"/"${parts[2]}
37   [ -d "$path" ]
38 }
39
40 # Add features repository to karaf featuresRepositories configuration
41 # $1 repositories to be added
42 function addRepository() {
43   CFG=$ODL_FEATURES_BOOT_FILE
44   ORIG=$CFG.orig
45   if isRepoExisting "$1" ; then
46     echo "Add repository: $1"
47     sed -i "\|featuresRepositories|s|$|, $1|" $CFG
48   else
49     echo "Repo does not exist: $1"
50   fi
51 }
52
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
58   ORIG=$CFG.orig
59   if [ -n "$2" ] ; then
60     echo "Add repository: $2"
61     mv $CFG $ORIG
62     cat $ORIG | sed -e "\|featuresRepositories|s|$|,$2|" > $CFG
63   fi
64   echo "Add boot feature: $1"
65   mv $CFG $ORIG
66   cat $ORIG | sed -e "\|featuresBoot *=|s|$|,$1|" > $CFG
67 }
68
69 # Append features to karaf boot feature configuration
70 # $1 search pattern
71 # $2 replacement
72 function replaceFeatureBoot() {
73   CFG=$ODL_HOME/etc/org.apache.karaf.features.cfg
74   ORIG=$CFG.orig
75   echo "Replace boot feature $1 with: $2"
76   sed -i "/featuresBoot/ s/$1/$2/g" $CFG
77 }
78
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
83 }
84
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"
91   n=0
92   until [ $n -ge 5 ] ; do
93     $INITCMD && break
94     n=$[$n+1]
95     sleep 15
96   done
97   return $?
98 }
99
100 function install_sdnrwt_features() {
101   # Repository setup provided via sdnc dockerfile
102   if $SDNRWT; then
103     addRepository $SDNRDM_BASE_REPO
104     addRepository $SDNRDM_ONF_REPO
105
106     if $SDNRONLY; then
107       cleanupFeatureBoot
108     fi
109     if $SDNRDM; then
110       addToFeatureBoot "$SDNRDM_BOOTFEATURES"
111     else
112       addToFeatureBoot "$SDNRWT_BOOTFEATURES"
113     fi
114   fi
115 }
116
117 function install_sdnr_northbound_features() {
118   addToFeatureBoot "$SDNR_NORTHBOUND_BOOTFEATURES" 
119 }
120
121 # Reconfigure ODL from default single node configuration to cluster
122
123 function enable_odl_cluster() {
124   if [ -z $SDNC_REPLICAS ]; then
125      echo "SDNC_REPLICAS is not configured in Env field"
126      exit
127   fi
128
129   # ODL NETCONF setup
130   echo "Installing Opendaylight cluster features for mdsal and netconf"
131   
132   #Be sure to remove feature odl-netconf-connector-all from list
133   replaceFeatureBoot "odl-netconf-connector-all,"
134
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
141
142   # ODL Cluster or Geo cluster configuration
143   
144   echo "Update cluster information statically"
145   fqdn=$(hostname -f)
146   echo "Get current fqdn ${fqdn}"
147
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')`
151   member_offset=1
152
153   if $GEO_ENABLED; then
154     echo "This is a Geo cluster"
155
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"
158      return
159     fi
160
161     if $IS_PRIMARY_CLUSTER; then
162        PRIMARY_NODE=${MY_ODL_CLUSTER}
163        SECONDARY_NODE=${PEER_ODL_CLUSTER}
164     else
165        PRIMARY_NODE=${PEER_ODL_CLUSTER}
166        SECONDARY_NODE=${MY_ODL_CLUSTER}
167        member_offset=4
168     fi
169
170     node_list="${PRIMARY_NODE} ${SECONDARY_NODE}"
171
172     ${SDNC_BIN}/configure_geo_cluster.sh $((node_index+member_offset)) ${node_list}
173   else
174     echo "This is a local cluster"
175     node_list=""
176     if $OOM_ENABLED; then
177        # Extract node name minus the index
178        # Example sdnr from "sdnr-2.logo.ost.das.r32.com"
179        node_name=($(echo ${fqdn} | sed 's/-[0-9].*$//g'))
180        for ((i=0;i<${SDNC_REPLICAS};i++));
181        do
182          node_list="${node_list} ${node_name}-$i.${SERVICE_NAME}-cluster.${NAMESPACE}"
183        done
184        ${ODL_HOME}/bin/configure_cluster.sh $((node_index+1)) ${node_list}
185     else 
186        for ((i=0;i<${SDNC_REPLICAS};i++));
187        do
188          #assemble node list by replacing node-index in hostname with "i"
189          node_name=`(echo ${fqdn} | sed -r "s/-[0-9]/-$i/g")`
190          node_list="${node_list} ${node_name}"
191        done
192        ${ODL_HOME}/bin/configure_cluster.sh $((node_index+1)) ${node_list}
193     fi
194   fi
195 }
196
197
198 # Install SDN-C platform components if not already installed and start container
199
200 # -----------------------
201 # Main script starts here
202
203 ODL_HOME=${ODL_HOME:-/opt/opendaylight/current}
204 ODL_FEATURES_BOOT_FILE=$ODL_HOME/etc/org.apache.karaf.features.cfg
205 #
206 ODL_REMOVEIDMDB=${ODL_REMOVEIDMDB:-false}
207
208 ODL_ADMIN_USERNAME=${ODL_ADMIN_USERNAME:-admin}
209 if $ODL_REMOVEIDMDB ; then
210    echo "Remove odl idmdb"
211    rm $ODL_HOME/data/idmlight.db.mv.db
212    ODL_ADMIN_PASSWORD=${ODL_ADMIN_PASSWORD:-admin}
213 else
214    ODL_ADMIN_PASSWORD=${ODL_ADMIN_PASSWORD:-Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U}
215 fi
216 ODL_ADMIN_PASSWORD=${ODL_ADMIN_PASSWORD:-Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U}
217 SDNC_HOME=${SDNC_HOME:-/opt/onap/sdnc}
218 SDNC_BIN=${SDNC_BIN:-/opt/onap/sdnc/bin}
219 SDNC_DB_INIT=${SDNC_DB_INIT:-false}
220 CCSDK_HOME=${CCSDK_HOME:-/opt/onap/ccsdk}
221 JDEBUG=${JDEBUG:-false}
222 MYSQL_PASSWD=${MYSQL_PASSWD:-openECOMP1.0}
223 ENABLE_ODL_CLUSTER=${ENABLE_ODL_CLUSTER:-false}
224 GEO_ENABLED=${GEO_ENABLED:-false}
225 SDNC_AAF_ENABLED=${SDNC_AAF_ENABLED:-false}
226 OOM_ENABLED=${OOM_ENABLED:-false}
227 IS_PRIMARY_CLUSTER=${IS_PRIMARY_CLUSTER:-false}
228 MY_ODL_CLUSTER=${MY_ODL_CLUSTER:-127.0.0.1}
229 INSTALLED_DIR=${INSTALLED_FILE:-/opt/opendaylight/current/daexim}
230 SDNRWT=${SDNRWT:-false}
231 SDNRWT_BOOTFEATURES=${SDNRWT_BOOTFEATURES:-sdnr-wt-feature-aggregator}
232 SDNRDM=${SDNRDM:-false}
233 # Add devicemanager base and specific repositories
234 SDNRDM_BASE_REPO=${SDNRDM_BASE_REPO:-mvn:org.onap.ccsdk.features.sdnr.wt/sdnr-wt-feature-aggregator-devicemanager-base/$CCSDKFEATUREVERSION/xml/features}
235 SDNRDM_ONF_REPO=${SDNRDM_ONF_REPO:-mvn:org.onap.ccsdk.features.sdnr.wt/sdnr-wt-devicemanager-onf-feature/$CCSDKFEATUREVERSION/xml/features}
236 # Add devicemanager features
237 SDNRDM_SDM_LIST=${SDNRDM_SDM_LIST:-sdnr-wt-devicemanager-onf-feature}
238 SDNRDM_BOOTFEATURES=${SDNRDM_BOOTFEATURES:-sdnr-wt-feature-aggregator-devicemanager-base, ${SDNRDM_SDM_LIST}}
239 SDNRINIT=${SDNRINIT:-false}
240 SDNRONLY=${SDNRONLY:-false}
241 SDNRDBURL=${SDNRDBURL:-http://sdnrdb:9200}
242 SDNRDBCOMMAND=${SDNRDBCOMMAND:--c init -db $SDNRDBURL -dbu $SDNRDBUSERNAME -dbp $SDNRDBPASSWORD $SDNRDBPARAMETER}
243
244 SDNR_NORTHBOUND=${SDNR_NORTHBOUND:-false}
245 SDNR_NORTHBOUND_BOOTFEATURES=${SDNR_NORTHBOUND_BOOTFEATURES:-sdnr-northbound-all}
246 export ODL_ADMIN_PASSWORD ODL_ADMIN_USERNAME
247
248 if $JDEBUG ; then
249     echo "Activate remote debugging"
250     #JSTADTPOLICYFILE="$ODL_HOME/etc/tools.policy"
251     #echo -e "grant codebase \"file:${JAVA_HOME}/lib/tools.jar\" {\n  permission java.security.AllPermission;\n };" > $JSTADTPOLICYFILE
252     #sleep 1
253     #$JAVA_HOME/bin/jstatd -p 1089 -J-Djava.security.policy=$JSTADTPOLICYFILE &
254     EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.port=1090"
255     EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.rmi.port=1090"
256     EXTRA_JAVA_OPTS+=" -Djava.rmi.server.hostname=$HOSTNAME"
257     EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.local.only=false"
258     EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.ssl=false"
259     EXTRA_JAVA_OPTS+=" -Dcom.sun.management.jmxremote.authenticate=false"
260     export EXTRA_JAVA_OPTS
261 fi
262
263
264 echo "Settings:"
265 echo "  SDNC_BIN=$SDNC_BIN"
266 echo "  SDNC_HOME=$SDNC_HOME"
267 echo "  SDNC_DB_INIT=$SDNC_DB_INIT"
268 echo "  ODL_CERT_DIR=$ODL_CERT_DIR"
269 echo "  CCSDKFEATUREVERSION=$CCSDKFEATUREVERSION"
270 echo "  ENABLE_ODL_CLUSTER=$ENABLE_ODL_CLUSTER"
271 echo "  ODL_REMOVEIDMDB=$ODL_REMOVEIDMDB"
272 echo "  SDNC_REPLICAS=$SDNC_REPLICAS"
273 echo "  SDNRWT=$SDNRWT"
274 echo "  SDNRDM=$SDNRDM"
275 echo "  SDNRONLY=$SDNRONLY"
276 echo "  SDNRINIT=$SDNRINIT"
277 echo "  SDNRDBURL=$SDNRDBURL"
278 echo "  SDNRDBUSERNAME=$SDNRDBUSERNAME"
279 echo "  GEO_ENABLED=$GEO_ENABLED"
280 echo "  IS_PRIMARY_CLUSTER=$IS_PRIMARY_CLUSTER"
281 echo "  MY_ODL_CLUSTER=$MY_ODL_CLUSTER"
282 echo "  PEER_ODL_CLUSTER=$PEER_ODL_CLUSTER"
283 echo "  SDNR_NORTHBOUND=$SDNR_NORTHBOUND"
284 echo "  AAF_ENABLED=$SDNC_AAF_ENABLED"
285
286 if $SDNC_AAF_ENABLED; then
287         export SDNC_AAF_STORE_DIR=/opt/app/osaaf/local
288         export SDNC_AAF_CONFIG_DIR=/opt/app/osaaf/local
289         export SDNC_KEYPASS=`cat /opt/app/osaaf/local/.pass`
290         export SDNC_KEYSTORE=org.onap.sdnc.p12
291         sed -i '/cadi_prop_files/d' $ODL_HOME/etc/system.properties
292         echo "cadi_prop_files=$SDNC_AAF_CONFIG_DIR/org.onap.sdnc.props" >> $ODL_HOME/etc/system.properties
293
294         sed -i '/org.ops4j.pax.web.ssl.keystore/d' $ODL_HOME/etc/custom.properties
295         sed -i '/org.ops4j.pax.web.ssl.password/d' $ODL_HOME/etc/custom.properties
296         sed -i '/org.ops4j.pax.web.ssl.keypassword/d' $ODL_HOME/etc/custom.properties
297         echo org.ops4j.pax.web.ssl.keystore=$SDNC_AAF_STORE_DIR/$SDNC_KEYSTORE >> $ODL_HOME/etc/custom.properties
298         echo org.ops4j.pax.web.ssl.password=$SDNC_KEYPASS >> $ODL_HOME/etc/custom.properties
299         echo org.ops4j.pax.web.ssl.keypassword=$SDNC_KEYPASS >> $ODL_HOME/etc/custom.properties
300 fi
301
302 if $SDNRINIT ; then
303   #One time intialization action
304   initialize_sdnr
305   init_result=$?
306   echo "Result of init script: $init_result"
307   if $SDNRWT ; then
308     echo "Proceed to initialize sdnr"
309   else
310     exit $init_result
311   fi
312 fi
313
314 if $OOM_ENABLED; then
315 #
316 # Wait for database
317 #
318   echo "Waiting for mysql"
319   until mysql -h dbhost -u root -p${MYSQL_PASSWD} mysql &> /dev/null
320   do
321     printf "."
322     sleep 1
323   done
324   echo -e "\nmysql ready"
325 fi
326
327 if [ ! -d ${INSTALLED_DIR} ]
328 then
329     mkdir -p ${INSTALLED_DIR}
330 fi
331
332 if [ ! -f ${SDNC_HOME}/.installed ]
333 then
334   if $OOM_ENABLED; then
335     # for integration testing. In OOM, a separate job takes care of installing it.
336     if $SDNC_DB_INIT; then
337       echo "Installing SDN-C database"
338       ${SDNC_HOME}/bin/installSdncDb.sh
339     fi
340     echo "Installing SDN-C keyStore"
341     ${SDNC_HOME}/bin/addSdncKeyStore.sh
342     echo "Installing A1-adapter trustStore"
343     ${SDNC_HOME}/bin/addA1TrustStore.sh
344
345     #${CCSDK_HOME}/bin/installOdlHostKey.sh
346
347     if [ -x ${SDNC_HOME}/svclogic/bin/install.sh ]
348     then
349       echo "Installing directed graphs"
350       ${SDNC_HOME}/svclogic/bin/install.sh
351     fi
352   fi
353
354   if $ENABLE_ODL_CLUSTER ; then enable_odl_cluster ; fi
355
356   if $SDNRWT ; then install_sdnrwt_features ; fi
357
358   if $SDNR_NORTHBOUND ; then install_sdnr_northbound_features ; fi
359   echo "Installed at `date`" > ${SDNC_HOME}/.installed
360 fi
361
362 #cp /opt/opendaylight/current/certs/* /tmp
363 #cp /var/custom-certs/* /tmp
364
365 if [ -n "$OVERRIDE_FEATURES_BOOT" ] ; then
366   echo "Override features boot: $OVERRIDE_FEATURES_BOOT"
367   sed -i "/$FEATURESBOOTMARKER/c\featuresBoot = $OVERRIDE_FEATURES_BOOT" $ODL_FEATURES_BOOT_FILE
368 fi
369
370 # Odl configuration done
371 ODL_REPOSITORIES_BOOT=$(sed -n "/$REPOSITORIESBOOTMARKER/p" $ODL_FEATURES_BOOT_FILE)
372 ODL_FEATURES_BOOT=$(sed -n "/$FEATURESBOOTMARKER/p" $ODL_FEATURES_BOOT_FILE)
373 export ODL_FEATURES_BOOT
374
375 # Create ODL data log directory (it nornally is created after karaf
376 # is started, but needs to exist before installCerts.py runs)
377 if [ -z "$ODL_CERT_DIR" ] ; then
378   echo "No certs provided. Skip installation."
379 else
380   echo "Start background cert installer"
381   mkdir -p /opt/opendaylight/data/log
382   nohup python3 ${SDNC_BIN}/installCerts.py &
383 fi
384
385 echo "Startup opendaylight"
386 echo $ODL_REPOSITORIES_BOOT
387 echo $ODL_FEATURES_BOOT
388 exec ${ODL_HOME}/bin/karaf server