[DMAAP-BC] Update dbc-client script

Issue-ID: DMAAP-1561
Signed-off-by: ajay_dp001 <ajay.deep.singh@est.tech>
Change-Id: Ia261dd02f59ce3556481c848f4b8f25933202125
diff --git a/dbc-client/misc/dbc-client b/dbc-client/misc/dbc-client
index 461a069..7247e01 100644
--- a/dbc-client/misc/dbc-client
+++ b/dbc-client/misc/dbc-client
@@ -1,10 +1,11 @@
 #!/bin/sh
 #
-# ============LICENSE_START==========================================
+# ============LICENSE_START===============================================
 # org.onap.dmaap
-# ===================================================================
+# ========================================================================
 # Copyright © 2019 AT&T Intellectual Property. All rights reserved.
-# ===================================================================
+# Copyright (C) 2021 Nordix Foundation.
+# ========================================================================
 # 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
@@ -16,162 +17,96 @@
 # 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============================================
+# ============LICENSE_END=================================================
 # ECOMP is a trademark and service mark of AT&T Intellectual Property.
-#
-#
 
 umask 0022
-TZ=GMT0
-COMPONENT=dbc-client
-APP_ROOT=${APP_ROOT:-/opt/app/$COMPONENT}
-export TZ
-PATH=/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin
-export PATH
+set -uex -o pipefail
+export PATH=/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin
+
+# RESP_CACHE is (/opt/app/config/cache) empty-dir volume mount for K8s env
+RESP_CACHE=${RESP_CACHE:-''}
+RESP=${RESP:-'/dev/null'}
+APP_ROOT=${APP_ROOT:-/opt/app/dbc-client}
 CONFIGMAP_ROOT=${CONFIGMAP_ROOT:-/opt/app/config}
-CONTAINER_CONFIG=$CONFIGMAP_ROOT/conf/dbc-client.env
-REQUESTID=${REQUESTID:-dbc-client}
+
+PORT=${PORT:-8443}
 DBC=${DBC:-dmaap-bc}
 PROTO=${PROTO:-https}
-PORT=${PORT:-8443}
-WAIT_TO_EXIT=${WAIT_TO_EXIT:-N}
-PEMDIR=${PEMDIR:-/opt/app/osaaf/local}
-CAPEM=${CAPEM:-ca.pem}
-CLIENTPEM=${CLIENTPEM:-client.pem}
-KEYPEM=${KEYPEM:-key.pem}
-CERTPWD=${CERTPWD:-'2U[iOZzMHI:.#tdCwlBqc;}S'}
+PARAM=${PARAM:-'useExisting=true'}
+REQUESTID=${REQUESTID:-dbc-client}
+URL=${URL:-"${PROTO}"://"${DBC}":"${PORT}"/webapi/}
+
+CA_PEM=${CA_PEM:-ca.pem}
+KEY_PEM=${KEY_PEM:-key.pem}
+CLIENT_PEM=${CLIENT_PEM:-client.pem}
+PEM_DIR=${PEM_DIR:-/opt/app/osaaf/local}
+CERT_PWD=${CERT_PWD:-'2U[iOZzMHI:.#tdCwlBqc;}S'}
+
+BA_PWD=${BA_PWD:-'demo123456!'}
 AUTH_METHOD=${AUTH_METHOD:-basicAuth}
 BA_IDENTITY=${BA_IDENTITY:-dmaap-bc@dmaap-bc.onap.org}
-BA_PWD=${BA_PWD:-'demo123456!'}
 
-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 $PEMDIR
-	pwd
-	ls -l
-	echo "AUTH_METHOD=$AUTH_METHOD"
-	if [ "$AUTH_METHOD"  =  "basicAuth" ]
-	then
-		echo "-u ${BA_IDENTITY}:${BA_PWD}" > $PEMDIR/curl.cred
-		CURLCRED="-K $PEMDIR/curl.cred"
-	elif [ -f $CAPEM  -a -f $CLIENTPEM -a -f $KEYPEM ]
-	then
-		printf "key \"$PEMDIR/$KEYPEM\"\ncacert \"$PEMDIR/$CAPEM\"\ncert \"$PEMDIR/${CLIENTPEM}:${CERTPWD}\"" > $PEMDIR/curl.cred
-		CURLCRED="-K $PEMDIR/curl.cred"
-	else
-		echo "Warning: PEM files for authorization not found!"
-		CURLCRED=""
-	fi
-	echo "CURLCRED=$CURLCRED"
-	cd $APP_ROOT
-	find . -type f -exec ls -l {} \;
-	find $CONFIGMAP_ROOT -type f -exec ls -l {} \;
-	if [ !  -f $CONTAINER_CONFIG ]
-	then
-		echo "WARNING: Expected env file $CONTAINER_CONFIG not found. Default behaviors in effect"
-	else
-		source $CONTAINER_CONFIG
-	fi
-
-	if [ "$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	
-	
-	set +x
+function xcurl() {
+  curl -X POST \
+    -s "$CURL_CRED" \
+    -w "%{http_code}" \
+    -H "X-ECOMP-RequestID: $REQUESTID" \
+    -H "Content-Type: application/json" "$@"
 }
 
-
-init() {
-	set -x
-	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=${RESP:-999}
-	while [ $rc != "200" ]
-	do
-		sleep 10
-		rc=`curl $CURLCRED -s -o /dev/null -I -w "%{http_code}" -X GET -H "X-ECOMP-RequestID: $REQUESTID" -H "Content-Type: application/json" ${PROTO}://${DBC}:${PORT}/webapi/dmaap`
-		echo "get dmaap response=${rc}"
-	done
-	set +x
+function init_config() {
+  if [ ! -d "$APP_ROOT" -a ! -d "$CONFIGMAP_ROOT" ]; then
+    echo "Expected either App root directory $APP_ROOT Or ConfigMap directory $CONFIGMAP_ROOT does not exist."
+    exit 1
+  fi
+  cd "$PEM_DIR"
+  if [ "$AUTH_METHOD" = "basicAuth" ]; then
+    echo "-u ${BA_IDENTITY}:${BA_PWD}" >"$PEM_DIR"/curl.cred
+    CURL_CRED="-K $PEM_DIR/curl.cred"
+  elif [ -f "$CA_PEM" -a -f "$CLIENT_PEM" -a -f "$KEY_PEM" ]; then
+    printf "key \"$PEM_DIR/$KEY_PEM\"\n cacert \"$PEM_DIR/$CA_PEM\"\n cert \"$PEM_DIR/${CLIENT_PEM}:${CERT_PWD}\"" >$PEM_DIR/curl.cred
+    CURL_CRED="-K $PEM_DIR/curl.cred"
+  else
+    echo "PEM files for authorization not found..!"
+  fi
 }
 
-dopost() {
-	set -x
-	RETRY_TIME=60
-
-	loop=true
-
-	while [ $loop = true ]
-	do
-		rc=`curl $CURLCRED -s -X POST -w "%{http_code}" -H "X-ECOMP-RequestID: $REQUESTID" -H "Content-Type: application/json" -d @${1} ${PROTO}://${DBC}:${PORT}/webapi/${2} -o /dev/null`
-		case $rc in
-		200 | 201 | 409 )
-			echo "response=$rc"
-			loop=false
-			;;
-		* )
-			echo "`date`: http response=$rc.  Will retry after $RETRY_TIME seconds"
-			sleep $RETRY_TIME
-			;;
-		esac
-	done
-	set +x
-
+function init_dbc_provisioning() {
+  cd "$CONFIGMAP_ROOT"
+  for dir in dmaap dcaeLocations mr_clusters topics mr_clients dr_nodes feeds dr_pubs dr_subs; do
+    if [ -d ${dir} ]; then
+      for file in $(ls ${dir}/*.json); do
+        do_http_post "$file" "$dir"
+      done
+    fi
+  done
 }
 
-doprov() {
-
-	set -x
-	cd $CONFIGMAP_ROOT
-	pwd
-	# order is important in this next list
-	for uri in dmaap dcaeLocations mr_clusters topics mr_clients dr_nodes feeds dr_pubs dr_subs
-	do
-		if [ -d ${uri} ]
-		then
-			for j in `ls ${uri}/*.json`
-			do
-				echo "POST $j to $uri"
-				dopost $j $uri
-			done
-		fi
-	done
-	set +x
+function do_http_post() {
+  RETRY_TIME=60
+  if [ -n "$RESP_CACHE" ]; then
+    RESP="$RESP_CACHE"/"$(echo "${1##*/}" | cut -d "." -f1)"-resp.json
+  fi
+  while true; do
+    if [ "$2" != "feeds" -a "$2" != "topics" ]; then
+      req_body=$(cat "${1}" | envsubst)
+      rc=$(xcurl -o "$RESP" -d "$req_body" "${URL}${2}")
+      if [ "$rc" = "200" -o "$rc" = "201" -o "$rc" = "409" ]; then
+        echo "Http Post request is successful with response code=$rc"
+        break
+      fi
+    else
+      rc=$(xcurl -o "$RESP" -d @"${1}" "${URL}${2}"/?"${PARAM}")
+      if [ "$rc" = "200" -o "$rc" = "201" -o "$rc" = "409" ]; then
+        echo "Http Post request for feed creation is successful with response code=$rc"
+        break
+      fi
+    fi
+    echo "$(date): Http Response code=$rc.  Will retry after $RETRY_TIME seconds.."
+    sleep "$RETRY_TIME"
+  done
 }
 
-delay() {
-	echo "DELAY=$DELAY"
-	if [ ! -z "$DELAY" ]
-	then
-		sleep $DELAY
-	fi
-}
-
-delay
-config
-init
-doprov
-
-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
+init_config
+init_dbc_provisioning
diff --git a/dbc-client/src/main/resources/Dockerfile b/dbc-client/src/main/resources/Dockerfile
index 9263e80..831d4f2 100644
--- a/dbc-client/src/main/resources/Dockerfile
+++ b/dbc-client/src/main/resources/Dockerfile
@@ -34,7 +34,7 @@
 RUN update-ca-certificates
 
 # Install curl & openssl
-RUN apk add --no-cache curl openssl
+RUN apk add --no-cache curl openssl gettext
 
 RUN mkdir -p /opt/app/osaaf/local && \
     chmod +x /opt/app/dbc-client/bin/* && \
diff --git a/pom.xml b/pom.xml
index 5c421b3..fccdb22 100644
--- a/pom.xml
+++ b/pom.xml
@@ -33,7 +33,7 @@
   </parent>
 
   <properties>
-    <revision>2.0.6-SNAPSHOT</revision>
+    <revision>2.0.7-SNAPSHOT</revision>
     <multiproject.basedir>${basedir}</multiproject.basedir>
     <docker.maven.plugin.version>1.0.0</docker.maven.plugin.version>
     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
diff --git a/version.properties b/version.properties
index 6f46efa..00f338b 100644
--- a/version.properties
+++ b/version.properties
@@ -27,7 +27,7 @@
 
 major=2
 minor=0
-patch=6
+patch=7
 base_version=${major}.${minor}.${patch}
 
 # Release must be completed with git revision # in Jenkins