Fixed some bugs
[holmes/rule-management.git] / rulemgt-standalone / src / main / assembly / bin / run.sh
1 #!/usr/bin/env bash
2
3 #
4 # Copyright 2017-2021 ZTE Corporation.
5 #
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
9 #
10 #     http://www.apache.org/licenses/LICENSE-2.0
11 #
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
17 #
18
19 DIRNAME=`dirname $0`
20 RUNHOME=`cd $DIRNAME/; pwd`
21 echo @RUNHOME@ $RUNHOME
22
23 echo @JAVA_HOME@ $JAVA_HOME
24 JAVA="$JAVA_HOME/bin/java"
25 echo @JAVA@ $JAVA
26 main_path=$RUNHOME/..
27 cd $main_path
28 JAVA_OPTS="-Xms256m -Xmx1g"
29 port=9201
30 #JAVA_OPTS="$JAVA_OPTS -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=*:$port,server=y,suspend=n"
31 echo @JAVA_OPTS@ $JAVA_OPTS
32
33 class_path="$main_path/lib/*"
34 echo @class_path@ $class_path
35
36 if [ -z ${JDBC_USERNAME} ]; then
37     export JDBC_USERNAME=holmes
38     echo "No user name is specified for the database. Use the default value \"$JDBC_USERNAME\"."
39 fi
40
41 if [ -z ${JDBC_PASSWORD} ]; then
42     export JDBC_PASSWORD=holmespwd
43     echo "No password is specified for the database. Use the default value \"$JDBC_PASSWORD\"."
44 fi
45
46 if [ -z ${DB_NAME} ]; then
47     export DB_NAME=holmes
48     echo "No database is name is specified. Use the default value \"$DB_NAME\"."
49 fi
50
51 # if deployed using helm, use the helm-generated configuration file.
52 if [ -d /opt/hrmconfig ]; then
53     cp /opt/hrmconfig/rulemgt.yml "$main_path/conf/rulemgt.yml"
54 else
55     sed -i "s|user:.*|user: $JDBC_USERNAME|" "$main_path/conf/rulemgt.yml"
56     sed -i "s|password:.*|password: $JDBC_PASSWORD|" "$main_path/conf/rulemgt.yml"
57     sed -i "s|url:.*|url: jdbc:postgresql://$URL_JDBC/$DB_NAME|" "$main_path/conf/rulemgt.yml"
58 fi
59
60 export SERVICE_IP=`hostname -i | awk '{print $1}'`
61 echo SERVICE_IP=${SERVICE_IP}
62
63 if [ ! -z ${HOST_IP} ]; then
64     export HOSTNAME=${HOST_IP}:9101
65 else
66     export HOSTNAME=${SERVICE_IP}:9101
67 fi
68
69 export DB_PORT=5432
70 if [ ! -z ${URL_JDBC} ] && [ `expr index $URL_JDBC :` != 0 ]; then
71     export DB_PORT="${URL_JDBC##*:}"
72 fi
73 echo DB_PORT=$DB_PORT
74
75 if [ -z ${ENABLE_ENCRYPT} ]; then
76     export ENABLE_ENCRYPT=true
77 fi
78 echo ENABLE_ENCRYPT=${ENABLE_ENCRYPT}
79
80 KEY_PATH="$main_path/conf/holmes.keystore"
81 KEY_PASSWORD="holmes"
82
83 if [ -f "/opt/app/osaaf/local/org.onap.holmes-rule-mgmt.p12" ]; then
84     KEY_PATH="/opt/app/osaaf/local/org.onap.holmes-rule-mgmt.p12"
85     KEY_PASSWORD=`head -n1 "/opt/app/osaaf/local/mycreds.prop" | cut -d= -f2`
86 fi
87
88 echo "KEY_PATH=$KEY_PATH"
89 echo "KEY_PASS=$KEY_PASSWORD"
90
91 #HTTPS Configurations
92 sed -i "s|keyStorePath:.*|keyStorePath: $KEY_PATH|" "$main_path/conf/rulemgt.yml"
93 sed -i "s|keyStorePassword:.*|keyStorePassword: $KEY_PASSWORD|" "$main_path/conf/rulemgt.yml"
94
95 if [ ${ENABLE_ENCRYPT} = true ]; then
96     sed -i "s|type:\s*https\?$|type: https|" "$main_path/conf/rulemgt.yml"
97     sed -i "s|#\?keyStorePath|keyStorePath|" "$main_path/conf/rulemgt.yml"
98     sed -i "s|#\?keyStorePassword|keyStorePassword|" "$main_path/conf/rulemgt.yml"
99     sed -i "s|#\?validateCerts|validateCerts|" "$main_path/conf/rulemgt.yml"
100     sed -i "s|#\?validatePeers|validatePeers|" "$main_path/conf/rulemgt.yml"
101 else
102     sed -i 's|type:\s*https\?$|type: http|' "$main_path/conf/rulemgt.yml"
103     sed -i "s|#\?keyStorePath|#keyStorePath|" "$main_path/conf/rulemgt.yml"
104     sed -i "s|#\?keyStorePassword|#keyStorePassword|" "$main_path/conf/rulemgt.yml"
105     sed -i "s|#\?validateCerts|#validateCerts|" "$main_path/conf/rulemgt.yml"
106     sed -i "s|#\?validatePeers|#validatePeers|" "$main_path/conf/rulemgt.yml"
107 fi
108
109
110 ${RUNHOME}/initDB.sh "$JDBC_USERNAME" "$JDBC_PASSWORD" "$DB_NAME" "$DB_PORT" "${URL_JDBC%:*}"
111
112
113 if [ -f "/opt/app/osaaf/local/org.onap.holmes-rule-mgmt.crt" ]; then
114     sed -i "s|/etc/ssl/certs/holmes-frontend-selfsigned.crt|/opt/app/osaaf/local/org.onap.holmes-rule-mgmt.crt|" "/etc/nginx/conf.d/nginx-https.conf"
115     sed -i "s|/etc/ssl/private/holmes-frontend.key|/opt/app/osaaf/local/org.onap.holmes-rule-mgmt.key|" "/etc/nginx/conf.d/nginx-https.conf"
116 fi
117
118 if [ "$MSB_IAG_SERVICE_PORT"x = "443"x ]; then
119     sed -i "s|http://msb-iag.onap|https://$MSB_IAG_SERVICE_HOST:$MSB_IAG_SERVICE_PORT|g" /etc/nginx/conf.d/nginx-http*.conf
120 else
121     sed -i "s|http://msb-iag.onap|http://$MSB_IAG_SERVICE_HOST:$MSB_IAG_SERVICE_PORT|g" /etc/nginx/conf.d/nginx-http*.conf
122 fi
123
124 if [ "${ENABLE_ENCRYPT}"x = "true"x ]; then
125     nginx -c /etc/nginx/conf.d/nginx-https.conf
126 else
127     nginx -c /etc/nginx/conf.d/nginx-http.conf
128 fi
129 echo nginx started.
130
131 "$JAVA" $JAVA_OPTS -classpath "$class_path" org.onap.holmes.rulemgt.RuleActiveApp server "$main_path/conf/rulemgt.yml"