0240c83e1a1c04fdb26db265e55e4c4866373ea2
[oom.git] / kubernetes / oneclick / createAll.bash
1 #!/bin/bash
2
3 . $(dirname "$0")/setenv.bash
4
5
6 usage() {
7   cat <<EOF
8 Usage: $0 [PARAMs]
9 -u                  : Display usage
10 -n [NAMESPACE]      : Kubernetes namespace (required)
11 -v [VALUES]         : HELM values filepath (usefull when deploying one component at a time)
12 -l [LOCATION]       : Location of oom project
13 -i [INSTANCE]       : ONAP deployment instance # (default: 1)
14 -a [APP]            : Specify a specific ONAP component (default: all)
15                       from the following choices:
16                       sdc, aai ,mso, message-router, robot, vid, aaf, uui
17                       sdnc, portal, policy, appc, multicloud, clamp, consul, vnfsdk
18 EOF
19 }
20
21 check_return_code(){
22   ret=$?
23   if [ $ret -ne 0 ]; then
24     printf "The command $1 returned with error code $ret \n" 1>&2
25     exit $ret
26   fi
27 }
28
29 create_service_account() {
30   cmd=`echo kubectl create clusterrolebinding $1-$2-admin-binding --clusterrole=cluster-admin --serviceaccount=$1-$2:default`
31   eval ${cmd}
32   check_return_code $cmd
33 }
34
35 create_namespace() {
36   cmd=`echo kubectl create namespace $1-$2`
37   eval ${cmd}
38   check_return_code $cmd
39 }
40
41 create_registry_key() {
42   cmd=`echo kubectl --namespace $1-$2 create secret docker-registry $3 --docker-server=$4 --docker-username=$5 --docker-password=$6 --docker-email=$7`
43   eval ${cmd}
44   check_return_code $cmd
45 }
46
47 configure_dcaegen2() {
48   if [ ! -s "$OPENSTACK_PRIVATE_KEY_PATH" ]
49   then
50     echo "ERROR: $OPENSTACK_PRIVATE_KEY_PATH does not exist or is empty.  Cannot launch dcae gen2."
51     return 1
52   fi
53
54   cmd=`echo kubectl --namespace $1-$2 create secret generic $2-openstack-ssh-private-key --from-file=key=${OPENSTACK_PRIVATE_KEY_PATH}`
55   eval ${cmd}
56   check_return_code $cmd
57
58   if [ ! -s "$DCAEGEN2_CONFIG_INPUT_FILE_PATH" ]
59   then
60     echo "ERROR: $DCAEGEN2_CONFIG_INPUT_FILE_PATH does not exist or is empty.  Cannot launch dcae gen2."
61     return 1
62   fi
63
64   cmd=`echo kubectl --namespace $1-$2 create configmap $2-config-inputs --from-file=inputs.yaml=${DCAEGEN2_CONFIG_INPUT_FILE_PATH}`
65   eval ${cmd}
66   check_return_code $cmd
67 }
68
69 create_onap_helm() {
70   HELM_VALUES_ADDITION=""
71   if [[ ! -z $HELM_VALUES_FILEPATH ]]; then
72     HELM_VALUES_ADDITION="--values=$HELM_VALUES_FILEPATH"
73   fi
74   # Have to put a check for dcaegen2 because it requires external files to helm
75   # which should not be part of the Chart.
76   if [ "$2" = "dcaegen2" ];
77   then
78     configure_dcaegen2 $1 $2
79     local result=$?
80     if [ $result -ne 0 ]
81     then
82       echo "ERROR: dcaegen2 failed to configure: Pre-requisites not met.  Skipping deploying it and continue"
83       return
84     fi
85   fi
86
87   # assign default auth token
88   if [[ -z $ONAP_DEFAULT_AUTH_TOKEN ]]; then
89     DEFAULT_SECRET=`kubectl get secrets -n kube-system | grep default-token |  awk '{ print $1}'`
90     ONAP_DEFAULT_AUTH_TOKEN=`kubectl get secrets $DEFAULT_SECRET -n kube-system -o yaml | grep  'token:'  | awk '{ print $2}' | base64 --decode`
91   fi
92
93   cmd=`echo helm install $LOCATION/$2/ --name $1-$2 --namespace $1 --set nsPrefix=$1,nodePortPrefix=$3,kubeMasterAuthToken=$ONAP_DEFAULT_AUTH_TOKEN ${HELM_VALUES_ADDITION}`
94   eval ${cmd}
95   check_return_code $cmd
96 }
97
98 #MAINs
99 NS=
100 HELM_VALUES_FILEPATH=""
101 LOCATION="../"
102 INCL_SVC=true
103 APP=
104 INSTANCE=1
105 MAX_INSTANCE=5
106 DU=$ONAP_DOCKER_USER
107 DP=$ONAP_DOCKER_PASS
108
109 while getopts ":n:u:s:i:a:du:dp:l:v:" PARAM; do
110   case $PARAM in
111     u)
112       usage
113       exit 1
114       ;;
115     n)
116       NS=${OPTARG}
117       ;;
118     v)
119       HELM_VALUES_FILEPATH=${OPTARG}
120       ;;
121     i)
122       INSTANCE=${OPTARG}
123       ;;
124     l)
125       LOCATION=${OPTARG}
126       ;;
127     a)
128       APP=${OPTARG}
129       if [[ -z $APP ]]; then
130         usage
131         exit 1
132       fi
133       ;;
134     du)
135       DU=${OPTARG}
136       ;;
137     dp)
138       DP=${OPTARG}
139       ;;
140     ?)
141       usage
142       exit
143       ;;
144   esac
145 done
146
147 if [[ -z $NS ]]; then
148   usage
149   exit 1
150 fi
151
152 if [[ ! -z "$APP" ]]; then
153   HELM_APPS=($APP)
154 fi
155
156
157 if [ "$INSTANCE" -gt "$MAX_INSTANCE" ];then
158   printf "\n********** You choose to create ${INSTANCE}th instance of ONAP \n"
159   printf "\n********** Due to port allocation only ${MAX_INSTANCE} instances of ONAP is allowed per kubernetes deployment\n"
160   exit 1
161 fi
162
163 start=$((300+2*INSTANCE))
164 end=$((start+1))
165
166 printf "\n********** Creating instance ${INSTANCE} of ONAP with port range ${start}00 and ${end}99\n"
167
168
169 printf "\n********** Creating ONAP: ${ONAP_APPS[*]}\n"
170
171
172 printf "\n\n********** Creating deployments for ${HELM_APPS[*]} ********** \n"
173
174 for i in ${HELM_APPS[@]}; do
175   printf "\nCreating namespace **********\n"
176   create_namespace $NS $i
177
178   printf "\nCreating service account **********\n"
179   create_service_account $NS $i
180
181   printf "\nCreating registry secret **********\n"
182   create_registry_key $NS $i ${NS}-docker-registry-key $ONAP_DOCKER_REGISTRY $DU $DP $ONAP_DOCKER_MAIL
183
184   printf "\nCreating deployments and services **********\n"
185   create_onap_helm $NS $i $start
186
187   printf "\n"
188 done
189
190 printf "\n**** Done ****\n"