blob: 4da5763caefb9834c6aefcd3347931f63965afc4 [file] [log] [blame]
Victor Morales89ce3212017-06-16 18:32:48 -05001#!/bin/bash
2
3set -o xtrace
4
5source /var/onap/functions
6
7hbase_version=1.2.3
Victor Morales8e08c872017-08-21 16:15:57 -05008aai_src_folder=$git_src_folder/aai
Victor Morales51e61ce2017-10-12 10:56:35 -07009aai_repos=("aai-common" "aai-config" "aai-data" "aai-service" "babel" "champ" \
10"data-router" "esr-gui" "esr-server" "gizmo" "logging-service" "model-loader" \
11"resources" "rest-client" "router-core" "search-data-service" "test-config" \
12"traversal" "sparky-fe" "sparky-be")
Victor Morales455bece2017-07-31 18:40:39 -050013
14# install_hadoop() - Function that installs Hadoop
15function install_hadoop {
16 local release=titan
17 local version=1.0.0
18 local filename=$release-$version-hadoop1
19 local dest_folder=/opt/hadoop/current
20
21 if [ ! -d $dest_folder ]; then
22 curl http://s3.thinkaurelius.com/downloads/$release/$filename.zip -o /tmp/${filename}.zip
23 install_package unzip
24 mkdir -p $dest_folder
25 unzip /tmp/${filename}.zip -d $dest_folder
26 pushd $dest_folder/${filename}
Victor Morales158c18c2017-08-06 11:23:15 -050027 # Change commitlog_directory and data_file_directories values (https://stackoverflow.com/a/26856246/1707651)
28 sed -i "s|db/cassandra/data|/tmp/data|g" conf/cassandra/cassandra.yaml
29 sed -i "s|db/cassandra/commitlog|/tmp/commitlog|g" conf/cassandra/cassandra.yaml
30
31 install_java
Victor Morales455bece2017-07-31 18:40:39 -050032 ./bin/titan.sh start
33 popd
34 fi
35}
36
37# install_haproxy() - Function that install HAProxy
38function install_haproxy {
Victor Morales7ae05a42017-08-22 14:39:00 -050039 if is_package_installed haproxy; then
40 return
41 fi
42 install_package software-properties-common
43 add-apt-repository -y ppa:vbernat/haproxy-1.7
Victor Morales455bece2017-07-31 18:40:39 -050044 install_package haproxy
Victor Morales7ae05a42017-08-22 14:39:00 -050045 cp /var/onap/files/haproxy.cfg /etc/haproxy/
Victor Morales455bece2017-07-31 18:40:39 -050046 cp /var/onap/files/aai.pem /etc/ssl/private/
47 chmod 640 /etc/ssl/private/aai.pem
48 chown root:ssl-cert /etc/ssl/private/aai.pem
49 mkdir /usr/local/etc/haproxy
Victor Morales7ae05a42017-08-22 14:39:00 -050050 #echo "127.0.0.1 localhost aai-traversal.api.simpledemo.openecomp.org aai-resources.api.simpledemo.openecomp.org" >> /etc/hosts
Victor Morales455bece2017-07-31 18:40:39 -050051
52 service haproxy restart
53}
Victor Morales89ce3212017-06-16 18:32:48 -050054
Victor Moralesdd074802017-07-26 16:06:35 -050055# clone_all_aai_repos() - Function that clones AAI source repo.
56function clone_all_aai_repos {
Victor Morales455bece2017-07-31 18:40:39 -050057 for dirc in ${aai_repos[@]}; do
Victor Morales8e08c872017-08-21 16:15:57 -050058 clone_repo aai/$dirc $aai_src_folder/$dirc
Victor Moralesdd074802017-07-26 16:06:35 -050059 done
60}
61
Victor Morales455bece2017-07-31 18:40:39 -050062# compile_aai_repos() - Function that compiles AAI source repo.
63function compile_aai_repos {
64 local repos=("aai-common" "resources" "logging-service" "traversal")
65 if [[ "$compile_repo" == "True" ]]; then
Victor Morales158c18c2017-08-06 11:23:15 -050066 repos=("${aai_repos[@]}")
Victor Morales455bece2017-07-31 18:40:39 -050067 fi
Victor Moralesdd074802017-07-26 16:06:35 -050068
Victor Morales455bece2017-07-31 18:40:39 -050069 for dirc in ${repos[@]}; do
Victor Morales8e08c872017-08-21 16:15:57 -050070 compile_src $aai_src_folder/$dirc
Victor Moralesdd074802017-07-26 16:06:35 -050071 done
72}
73
Victor Morales455bece2017-07-31 18:40:39 -050074# setup_titan() - Function that configures AAI services to connect to Hadoop Titan
75function setup_titan {
Victor Morales7ae05a42017-08-22 14:39:00 -050076 local subdirectory="bundleconfig-local/etc/appprops"
Victor Morales455bece2017-07-31 18:40:39 -050077 install_python_package crudini
78
Victor Morales7ae05a42017-08-22 14:39:00 -050079 for dirc in resources/aai-resources traversal/aai-traversal; do
Victor Morales455bece2017-07-31 18:40:39 -050080 for file in titan-cached.properties titan-realtime.properties; do
Victor Morales7ae05a42017-08-22 14:39:00 -050081 crudini --set "$aai_src_folder/$dirc/$subdirectory/$file" "" "storage.backend" "cassandra"
82 crudini --set "$aai_src_folder/$dirc/$subdirectory/$file" "" "storage.hostname" "localhost"
Victor Morales455bece2017-07-31 18:40:39 -050083 done
84 done
85
Victor Morales7ae05a42017-08-22 14:39:00 -050086 # Add the schema to the local isntance
87 compile_src $aai_src_folder/resources/aai-resources/
88 uninstall_packages default-jre openjdk-7-jdk openjdk-7-jre openjdk-7-jre-headless
Victor Morales8e08c872017-08-21 16:15:57 -050089 pushd $aai_src_folder
Victor Morales8e08c872017-08-21 16:15:57 -050090 java -DAJSC_HOME=$aai_src_folder/resources/aai-resources -DBUNDLECONFIG_DIR="bundleconfig-local" -cp aai-common/aai-core/target/aai-core-1.1.0-SNAPSHOT.jar:resources/aai-resources/target/aai-resources.jar:resources/aai-resources/target/userjars/* org.openecomp.aai.dbgen.GenTester
Victor Morales455bece2017-07-31 18:40:39 -050091 popd
92}
93
94# start_aai_microservices() - Function that starts AAI microservices
95function start_aai_microservices {
Victor Morales7ae05a42017-08-22 14:39:00 -050096 install_maven
97 export MAVEN_OPTS="-Xms1024m -Xmx5120m -XX:PermSize=2024m -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=9446,server=y,suspend=n"
Victor Morales455bece2017-07-31 18:40:39 -050098 for svc in resources traversal; do
Victor Morales8e08c872017-08-21 16:15:57 -050099 pushd $aai_src_folder/resources
Victor Morales455bece2017-07-31 18:40:39 -0500100 mvn -P runAjsc
101 popd
102 done
103}
104
Victor Morales158c18c2017-08-06 11:23:15 -0500105# _pull_hbase_image() - Pull HBase container image from a Docker Registry Hub
106function _pull_hbase_image {
Victor Moralesdd074802017-07-26 16:06:35 -0500107 docker_openecomp_login
Victor Morales89ce3212017-06-16 18:32:48 -0500108 docker pull $nexus_docker_repo/aaidocker/aai-hbase-${hbase_version}
109}
110
111# install_hbase() - Install HBase Service
112function install_hbase {
113 docker rm -f hbase
Victor Morales158c18c2017-08-06 11:23:15 -0500114 _pull_hbase_image
Victor Morales89ce3212017-06-16 18:32:48 -0500115 docker run -d --net=host --name="hbase" $nexus_docker_repo/aaidocker/aai-hbase-${hbase_version}
116}
117
118# install_ajsc() - Install ASJC Java service container
119function install_ajsc_aai {
120 cat <<EOL > /etc/ajsc-aai.conf
121AAI_REPO_PATH=r/aai
122AAI_CHEF_ENV=simpledemo
123AAI_CHEF_LOC=/var/chef/aai-data/environments
124docker_gitbranch=master
125EOL
126 docker rm -f aai-service
Victor Moralesdd074802017-07-26 16:06:35 -0500127 if [[ "$build_image" == "True" ]]; then
Victor Morales8e08c872017-08-21 16:15:57 -0500128 build_docker_image $aai_src_folder/aai-service/ajsc-aai
Victor Moralesdd074802017-07-26 16:06:35 -0500129 else
130 pull_openecomp_image ajsc-aai
131 fi
132
Victor Morales89ce3212017-06-16 18:32:48 -0500133 docker run --env-file /etc/ajsc-aai.conf --name=aai-service --net=host -v /etc/ssl/certs/ca-certificates.crt:/etc/ssl/certs/ca-certificates.crt -it -d $nexus_docker_repo/openecomp/ajsc-aai:$docker_version
134}
135
136# install_model_loader() Install Model Loader
137function install_model_loader {
Victor Morales89ce3212017-06-16 18:32:48 -0500138 cat <<EOL > /etc/model-loader.conf
139DISTR_CLIENT_ASDC_ADDRESS=${SDC_ADDRESS:-c2.vm1.sdc.simpledemo.openecomp.org:8443}
140DISTR_CLIENT_CONSUMER_GROUP=${UEB_CONSUMER_GROUP:-SDCGroup}
141DISTR_CLIENT_CONSUMER_ID=${UEB_CONSUMER_GROUP_ID:-UEB}
142DISTR_CLIENT_ENVIRONMENT_NAME=${dmaap_topic}
143DISTR_CLIENT_PASSWORD=${SDC_PASSWORD:-OBF:1ks51l8d1o3i1pcc1r2r1e211r391kls1pyj1z7u1njf1lx51go21hnj1y0k1mli1sop1k8o1j651vu91mxw1vun1mze1vv11j8x1k5i1sp11mjc1y161hlr1gm41m111nkj1z781pw31kku1r4p1e391r571pbm1o741l4x1ksp}
144DISTR_CLIENT_USER=${SDC_USER:-aai}
145
146APP_SERVER_BASE_URL=${APP_SERVER_URL:-https://c1.vm1.aai.simpledemo.openecomp.org:8443}
147APP_SERVER_AUTH_USER=${APP_USER:-ModelLoader}
148APP_SERVER_KEYSTORE_PASSWORD=OBF:1i9a1u2a1unz1lr61wn51wn11lss1unz1u301i6o
149APP_SERVER_AUTH_PASSWORD=${APP_PASSWORD:-OBF:1qvu1v2h1sov1sar1wfw1j7j1wg21saj1sov1v1x1qxw}
150EOL
151
Victor Moralesdd074802017-07-26 16:06:35 -0500152 ARGS=""
153
Victor Morales89ce3212017-06-16 18:32:48 -0500154 docker rm -f model-loader-service
155 if [[ "$build_image" == "True" ]]; then
Victor Morales8e08c872017-08-21 16:15:57 -0500156 build_docker_image $aai_src_folder/model-loader/
Victor Moralesdd074802017-07-26 16:06:35 -0500157 ARGS+="--env-file /etc/model-loader.conf model-loader"
Victor Morales89ce3212017-06-16 18:32:48 -0500158 else
159 pull_openecomp_image model-loader
Victor Moralesdd074802017-07-26 16:06:35 -0500160 ARGS+="--name=model-loader-service -it -d --env-file /etc/model-loader.conf $nexus_docker_repo/openecomp/model-loader:$docker_version"
Victor Morales89ce3212017-06-16 18:32:48 -0500161 fi
Victor Moralesdd074802017-07-26 16:06:35 -0500162 docker run ${ARGS}
Victor Morales89ce3212017-06-16 18:32:48 -0500163}
164
Victor Morales158c18c2017-08-06 11:23:15 -0500165# _wait_for_sdc() - Function that determines if SDC is up and running
166function _wait_for_sdc {
Victor Morales89ce3212017-06-16 18:32:48 -0500167 if [[ -s "/opt/config/sdc_ip_addr.txt" ]]; then
168 SDC_IP_ADDR=$(cat /opt/config/sdc_ip_addr.txt)
169 else
170 SDC_IP_ADDR="10.0.3.1"
171 fi
172
173 # Run Health Check against SDC and verify that all five components are up
174 RES=$(curl http://$SDC_IP_ADDR:8181/sdc1/rest/healthCheck | grep -c "OK")
175 while [[ $RES -lt 5 ]]; do
176 RES=$(curl http://$SDC_IP_ADDR:8181/sdc1/rest/healthCheck | grep -c "OK")
177 done
178}
179
180# init_aai() - Function that initialize AAI services
181function init_aai {
Victor Morales455bece2017-07-31 18:40:39 -0500182 install_hadoop
183 install_haproxy
Victor Morales89ce3212017-06-16 18:32:48 -0500184
Idan Amit1690e082017-08-20 08:58:14 +0300185 if [[ "$clone_repo" == "True" ]]; then
186 clone_all_aai_repos
187 if [[ "$compile_repo" == "True" ]]; then
188 compile_aai_repos
189 fi
190 fi
Victor Morales455bece2017-07-31 18:40:39 -0500191
192 setup_titan
Victor Morales14613122017-08-22 19:51:35 -0500193 #start_aai_microservices
Victor Morales455bece2017-07-31 18:40:39 -0500194
195 mkdir -p /opt/openecomp/aai/logs
196 mkdir -p /opt/openecomp/aai/data
Victor Moralesdd074802017-07-26 16:06:35 -0500197
Victor Morales89ce3212017-06-16 18:32:48 -0500198 install_hbase
199
200 # Wait 3 minutes before instantiating the A&AI container
201 sleep 180
202
203 install_ajsc_aai
Victor Morales158c18c2017-08-06 11:23:15 -0500204 _wait_for_sdc
Victor Morales6a919972017-09-28 18:29:54 -0700205 if [[ "$skip_install" == "False" ]]; then
206 install_model_loader
207 fi
Victor Morales89ce3212017-06-16 18:32:48 -0500208}