blob: 15f2fd27ad30ffd294e380fed117eb8ad90dd5b8 [file] [log] [blame]
#!/bin/bash
#
# ============LICENSE_START==========================================
# org.onap.dmaap
# ===================================================================
# Copyright © 2018 AT&T Intellectual Property. All rights reserved.
# ===================================================================
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ============LICENSE_END============================================
# ECOMP is a trademark and service mark of AT&T Intellectual Property.
#
#
umask 0022
TZ=GMT0
COMPONENT=dmaapbc
APP_ROOT=/opt/app/$COMPONENT
USER=dbc
GROUP=onap
export TZ
PATH=/usr/local/openjdk-11/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
export PATH
CLASSPATH=`echo $APP_ROOT/etc $APP_ROOT/lib/*.jar | tr ' ' ':'`
export CLASSPATH
CONFIGMAP_ROOT=${CONFIGMAP_ROOT:-/opt/app/config}
CONFIGMAP_PROPS=${CONFIGMAP_PROPS:-$CONFIGMAP_ROOT/conf/dmaapbc.properties}
CONTAINER_CONFIG=$CONFIGMAP_ROOT/conf/buscontroller.env
MAIN=org.onap.dmaap.dbcapi.server.Main
authcheck() {
set -x
ID=`id -n -u`
GRP=`id -n -g`
if [ "$ID" != "$USER" ]
then
echo $COMPONENT must be started as user $USER not $ID
exit 1
fi
if [ "$GRP" != "$GROUP" ]
then
echo $COMPONENT must be started as group $GROUP not $GRP
exit 1
fi
set +x
}
pids() {
set -x
ps -ef | grep java | grep $MAIN | sed -e 's/[^ ]* *//' -e 's/ .*//'
set +x
}
config() {
echo "ENTER config"
set -x
if [ ! -d $APP_ROOT ]
then
echo "Expected app root directory $APP_ROOT does not exist"
exit 1
fi
cd $APP_ROOT
if [ ! -f $CONTAINER_CONFIG ]
then
echo "WARNING: Expected env file $CONTAINER_CONFIG not found. Default behaviors in effect"
find $CONTAINER_ROOT -type f
else
. $CONTAINER_CONFIG
fi
if [ "$DMAAPBC_WAIT_TO_EXIT" != "Y" ]
then
echo "Creating $APP_ROOT/ok_to_exit so no waiting..."
> $APP_ROOT/ok_to_exit
else
echo "Not creating $APP_ROOT/ok_to_exit"
fi
#. misc/havecert.tmpl > etc/havecert
#chmod +x etc/havecert
echo Check for certificate
TZ=GMT0
cd /opt/app/dmaapbc;
KEYSTORE=${DMAAPBC_KSTOREFILE:-etc/keystore}
echo "KEYSTORE=$KEYSTORE"
d=`dirname $KEYSTORE`
ls -l $d
if [ -f ${KEYSTORE} ]
then
echo "Goodness: Found ${KEYSTORE}"
else
EMSG="`date '+%F %T,000'` WARN Certificate file $KEYSTORE is missing"
echo $EMSG
echo $EMSG >>${DMAAPBC_LOGS:-logs}/dmaapbc.log
fi
# These files might be better provided in kubernetes configmaps
# so if they are there, use them
if [ -f $CONFIGMAP_PROPS ]
then
PROPS=$CONFIGMAP_PROPS
else
PROPS=etc/dmaapbc.properties
. misc/dmaapbc.properties.tmpl > $PROPS
fi
if [ ! -f config/PolicyEngineApi.properties ]
then
. misc/PolicyEngineApi.properties.tmpl > config/PolicyEngineApi.properties
fi
set +x
}
start() {
echo "ENTER start"
set -x
authcheck
cd $APP_ROOT
pwd
if [ -f "$KEYSTORE" ]
then
echo >/dev/null
else
echo No certificate file available. Cannot start
exit 0
fi
PIDS=`pids`
if [ "$PIDS" != "" ]
then
echo $COMPONENT already running
exit 0
fi
rm -f $APP_ROOT/etc/SHUTDOWN
# JVM flags
#old line from Dockerfile...keep for reference only
FLAGS="-cp etc:lib/* -Dlog4j.configuration=etc/log4j.properties -DConfigFile=$PROPS -Dlogback.configurationFile=etc/logback.xml -Dhttps.protocols=TLSv1.2 -Dhttps.cipherSuites=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256"
#nohup java $FLAGS $MAIN </dev/null >/dev/null 2>&1 &
nohup java $FLAGS $MAIN </dev/null &
sleep 5
PIDS=`pids`
set +x
}
stop() {
echo "ENTER stop"
authcheck
touch $APP_ROOT/etc/SHUTDOWN
PIDS=`pids`
if [ "$PIDS" != "" ]
then
sleep 5
kill -9 $PIDS
sleep 5
echo $COMPONENT stopped
else
echo $COMPONENT not running
fi
}
status() {
echo "ENTER status"
PIDS=`pids`
if [ "$PIDS" != "" ]
then
echo $COMPONENT running
else
echo $COMPONENT not running
fi
}
init() {
echo "ENTER init"
if [ ! -d $CONFIGMAP_ROOT ]
then
echo $CONFIGMAP_ROOT does not exist
return
fi
#loop on get /dmaap until we get a good response to indicate other provisioning can continue
rc=999
while [ $rc != "200" ]
do
sleep 10
rc=`curl -s -o /dev/null -I -w "%{http_code}" -X GET -H "Content-Type: application/json" http://dmaap-bc:8080/webapi/dmaap`
echo "get dmaap response=${rc}"
done
cd $CONFIGMAP_ROOT
pwd
# order is important in this next list
for uri in dmaap dcaeLocations mr_clusters topics feeds
do
if [ -d ${uri} ]
then
for j in `ls ${uri}/*.json`
do
echo "POST $j to $uri"
rc=`curl -v -X POST -w "%{http_code}" -H "Content-Type: application/json" -d @${j} http://dmaap-bc:8080/webapi/${uri}`
echo "response=$rc"
done
fi
done
}
set -x
case "$1" in
'deploy')
config
start
#init
wait
;;
'start')
start
;;
'stop')
stop
;;
'restart')
stop
sleep 20
start
;;
'status')
status
;;
*)
echo "Usage: $0 { start | stop | restart }"
exit 1
;;
esac
ls -l $APP_ROOT/logs/ONAP
echo "------------ tail -100 error.log ---------------"
tail -100 $APP_ROOT/logs/ONAP/error.log
echo "------------ tail -100 server.log ---------------"
tail -100 $APP_ROOT/logs/ONAP/server.log
echo "------------ tail -100 application.log ---------------"
tail -100 $APP_ROOT/logs/ONAP/application.log
echo "Check $APP_ROOT/ok_to_exit"
while [ ! -f $APP_ROOT/ok_to_exit ]
do
echo "$APP_ROOT/ok_to_exit does not exist. Sticking around for debugging..."
sleep 10
done
exit 0