3 . $(dirname "$0")/setenv.bash
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
23 if [ $ret -ne 0 ]; then
24 printf "The command $1 returned with error code $ret \n" 1>&2
29 create_service_account() {
30 cmd=`echo kubectl create clusterrolebinding $1-admin-binding --clusterrole=cluster-admin --serviceaccount=$1:default`
32 check_return_code $cmd
36 cmd=`echo kubectl create namespace $1`
40 create_registry_key() {
41 cmd=`echo kubectl --namespace $1 create secret docker-registry $2 --docker-server=$3 --docker-username=$4 --docker-password=$5 --docker-email=$6`
43 check_return_code $cmd
46 configure_dcaegen2() {
47 if [ ! -s "$OPENSTACK_PRIVATE_KEY_PATH" ]
49 echo "ERROR: $OPENSTACK_PRIVATE_KEY_PATH does not exist or is empty. Cannot launch dcae gen2."
53 cmd=`echo kubectl --namespace $1-$2 create secret generic $2-openstack-ssh-private-key --from-file=key=${OPENSTACK_PRIVATE_KEY_PATH}`
55 check_return_code $cmd
57 if [ ! -s "$DCAEGEN2_CONFIG_INPUT_FILE_PATH" ]
59 echo "ERROR: $DCAEGEN2_CONFIG_INPUT_FILE_PATH does not exist or is empty. Cannot launch dcae gen2."
63 cmd=`echo kubectl --namespace $1-$2 create configmap $2-config-inputs --from-file=inputs.yaml=${DCAEGEN2_CONFIG_INPUT_FILE_PATH}`
65 check_return_code $cmd
69 HELM_VALUES_ADDITION=""
70 if [[ ! -z $HELM_VALUES_FILEPATH ]]; then
71 HELM_VALUES_ADDITION="--values=$HELM_VALUES_FILEPATH"
73 # Have to put a check for dcaegen2 because it requires external files to helm
74 # which should not be part of the Chart.
75 if [ "$2" = "dcaegen2" ];
77 configure_dcaegen2 $1 $2
81 echo "ERROR: dcaegen2 failed to configure: Pre-requisites not met. Skipping deploying it and continue"
86 # assign default auth token
87 if [[ -z $ONAP_DEFAULT_AUTH_TOKEN ]]; then
88 DEFAULT_SECRET=`kubectl get secrets -n $1 | grep default-token | awk '{ print $1}'`
89 ONAP_DEFAULT_AUTH_TOKEN=`kubectl get secrets $DEFAULT_SECRET -n $1 -o yaml | grep 'token:' | awk '{ print $2}' | base64 --decode`
92 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 check_return_code $cmd
99 HELM_VALUES_FILEPATH=""
108 SINGLE_COMPONENT=false
110 while getopts ":n:u:s:i:a:du:dp:l:v:" PARAM; do
120 HELM_VALUES_FILEPATH=${OPTARG}
129 SINGLE_COMPONENT=true
131 if [[ -z $APP ]]; then
149 if [[ -z $NS ]]; then
154 if [[ ! -z "$APP" ]]; then
159 if [ "$INSTANCE" -gt "$MAX_INSTANCE" ];then
160 printf "\n********** You choose to create ${INSTANCE}th instance of ONAP \n"
161 printf "\n********** Due to port allocation only ${MAX_INSTANCE} instances of ONAP is allowed per kubernetes deployment\n"
165 start=$((300+2*INSTANCE))
168 printf "\n********** Creating instance ${INSTANCE} of ONAP with port range ${start}00 and ${end}99\n"
171 printf "\n********** Creating ONAP: ${ONAP_APPS[*]}\n"
173 if [ "$SINGLE_COMPONENT" == "false" ]
175 printf "\nCreating namespace **********\n"
178 printf "\nCreating registry secret **********\n"
179 create_registry_key $NS ${NS}-docker-registry-key $ONAP_DOCKER_REGISTRY $DU $DP $ONAP_DOCKER_MAIL
181 printf "\nCreating service account **********\n"
182 create_service_account $NS
185 printf "\n\n********** Creating deployments for ${HELM_APPS[*]} ********** \n"
187 for i in ${HELM_APPS[@]}; do
189 printf "\nCreating deployments and services **********\n"
190 create_onap_helm $NS $i $start
195 printf "\n**** Done ****\n"