blob: 0a656ee22ec87f7e3b94880073d1653c1b5f7724 [file] [log] [blame]
#!/bin/bash
. $(dirname "$0")/setenv.bash
usage() {
cat <<EOF
Usage: $0 [PARAMs]
-u : Display usage
-n [NAMESPACE] : Kubernetes namespace (required)
-v [VALUES] : HELM values filepath (usefull when deploying one component at a time)
-l [LOCATION] : Location of oom project
-i [INSTANCE] : ONAP deployment instance # (default: 1)
-a [APP] : Specify a specific ONAP component (default: all)
from the following choices:
sdc, aai ,mso, message-router, robot, vid, aaf, uui
sdnc, portal, policy, appc, multicloud, clamp, consul, vnfsdk
EOF
}
check_return_code(){
ret=$?
if [ $ret -ne 0 ]; then
printf "The command $1 returned with error code $ret \n" 1>&2
exit $ret
fi
}
create_service_account() {
cmd=`echo kubectl create clusterrolebinding $1-$2-admin-binding --clusterrole=cluster-admin --serviceaccount=$1-$2:default`
eval ${cmd}
check_return_code $cmd
}
create_namespace() {
cmd=`echo kubectl create namespace $1-$2`
eval ${cmd}
check_return_code $cmd
}
create_registry_key() {
cmd=`echo kubectl --namespace $1-$2 create secret docker-registry $3 --docker-server=$4 --docker-username=$5 --docker-password=$6 --docker-email=$7`
eval ${cmd}
check_return_code $cmd
}
configure_dcaegen2() {
if [ ! -s "$OPENSTACK_PRIVATE_KEY_PATH" ]
then
echo "ERROR: $OPENSTACK_PRIVATE_KEY_PATH does not exist or is empty. Cannot launch dcae gen2."
return 1
fi
cmd=`echo kubectl --namespace $1-$2 create secret generic $2-openstack-ssh-private-key --from-file=key=${OPENSTACK_PRIVATE_KEY_PATH}`
eval ${cmd}
check_return_code $cmd
if [ ! -s "$DCAEGEN2_CONFIG_INPUT_FILE_PATH" ]
then
echo "ERROR: $DCAEGEN2_CONFIG_INPUT_FILE_PATH does not exist or is empty. Cannot launch dcae gen2."
return 1
fi
cmd=`echo kubectl --namespace $1-$2 create configmap $2-config-inputs --from-file=inputs.yaml=${DCAEGEN2_CONFIG_INPUT_FILE_PATH}`
eval ${cmd}
check_return_code $cmd
}
create_onap_helm() {
HELM_VALUES_ADDITION=""
if [[ ! -z $HELM_VALUES_FILEPATH ]]; then
HELM_VALUES_ADDITION="--values=$HELM_VALUES_FILEPATH"
fi
# Have to put a check for dcaegen2 because it requires external files to helm
# which should not be part of the Chart.
if [ "$2" = "dcaegen2" ];
then
configure_dcaegen2 $1 $2
local result=$?
if [ $result -ne 0 ]
then
echo "ERROR: dcaegen2 failed to configure: Pre-requisites not met. Skipping deploying it and continue"
return
fi
fi
# assign default auth token
if [[ -z $ONAP_DEFAULT_AUTH_TOKEN ]]; then
DEFAULT_SECRET=`kubectl get secrets -n kube-system | grep default-token | awk '{ print $1}'`
ONAP_DEFAULT_AUTH_TOKEN=`kubectl get secrets $DEFAULT_SECRET -n kube-system -o yaml | grep 'token:' | awk '{ print $2}' | base64 -d`
fi
cmd=`echo helm install $LOCATION/$2/ --name $1-$2 --namespace $1 --set nsPrefix=$1,nodePortPrefix=$3,kubeMasterAuthToken=$ONAP_DEFAULT_AUTH_TOKEN ${HELM_VALUES_ADDITION}`
eval ${cmd}
check_return_code $cmd
}
#MAINs
NS=
HELM_VALUES_FILEPATH=""
LOCATION="../"
INCL_SVC=true
APP=
INSTANCE=1
MAX_INSTANCE=5
DU=$ONAP_DOCKER_USER
DP=$ONAP_DOCKER_PASS
while getopts ":n:u:s:i:a:du:dp:l:v:" PARAM; do
case $PARAM in
u)
usage
exit 1
;;
n)
NS=${OPTARG}
;;
v)
HELM_VALUES_FILEPATH=${OPTARG}
;;
i)
INSTANCE=${OPTARG}
;;
l)
LOCATION=${OPTARG}
;;
a)
APP=${OPTARG}
if [[ -z $APP ]]; then
usage
exit 1
fi
;;
du)
DU=${OPTARG}
;;
dp)
DP=${OPTARG}
;;
?)
usage
exit
;;
esac
done
if [[ -z $NS ]]; then
usage
exit 1
fi
if [[ ! -z "$APP" ]]; then
HELM_APPS=($APP)
fi
if [ "$INSTANCE" -gt "$MAX_INSTANCE" ];then
printf "\n********** You choose to create ${INSTANCE}th instance of ONAP \n"
printf "\n********** Due to port allocation only ${MAX_INSTANCE} instances of ONAP is allowed per kubernetes deployment\n"
exit 1
fi
start=$((300+2*INSTANCE))
end=$((start+1))
printf "\n********** Creating instance ${INSTANCE} of ONAP with port range ${start}00 and ${end}99\n"
printf "\n********** Creating ONAP: ${ONAP_APPS[*]}\n"
printf "\n\n********** Creating deployments for ${HELM_APPS[*]} ********** \n"
for i in ${HELM_APPS[@]}; do
printf "\nCreating namespace **********\n"
create_namespace $NS $i
printf "\nCreating service account **********\n"
create_service_account $NS $i
printf "\nCreating registry secret **********\n"
create_registry_key $NS $i ${NS}-docker-registry-key $ONAP_DOCKER_REGISTRY $DU $DP $ONAP_DOCKER_MAIL
printf "\nCreating deployments and services **********\n"
create_onap_helm $NS $i $start
printf "\n"
done
printf "\n**** Done ****\n"