blob: 7e4f03a0c1232f991f69be04dd8211bb5f241b06 [file] [log] [blame]
#!/bin/bash
################################################################################
# Copyright (c) 2019 AT&T Intellectual Property. #
# Copyright (c) 2019 Nokia. #
# #
# Licensed under the Apache License, Version 2.0 (the "License"); #
# you may not use this file except in compliance with the License. #
# You may obtain a copy of the License at #
# #
# http://www.apache.org/licenses/LICENSE-2.0 #
# #
# Unless required by applicable law or agreed to in writing, software #
# distributed under the License is distributed on an "AS IS" BASIS, #
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
# See the License for the specific language governing permissions and #
# limitations under the License. #
################################################################################
while [ -n "$1" ]; do # while loop starts
case "$1" in
-f) OVERRIDEYAML=$2
shift
;;
-c) LIST_OF_COMPONENTS=$2
shift
;;
*) echo "Option $1 not recognized" ;; # In case you typed a different option other than a,b,c
esac
shift
done
if [ -z "$OVERRIDEYAML" ];then
echo "****************************************************************************************************************"
echo " ERROR "
echo "****************************************************************************************************************"
echo "RIC deployment without deployment recipe is currently disabled. Please specify an recipe with the -f option."
echo "****************************************************************************************************************"
exit 1
fi
#Check for helm3
IS_HELM3=$(helm version -c --short|grep -e "^v3")
HELM_SEARCH_FLAG=""
if [ $IS_HELM3 ]
then
HELM_SEARCH_FLAG="repo"
fi
HAS_RIC_COMMON_PACKAGE=$(helm search ${HELM_SEARCH_FLAG} local/ric-common | grep ric-common)
if [ -z "$HAS_RIC_COMMON_PACKAGE" ];then
echo "****************************************************************************************************************"
echo " ERROR "
echo "****************************************************************************************************************"
echo "Can't locate the ric-common helm package in the local repo. Please make sure that it is properly installed."
echo "****************************************************************************************************************"
exit 1
fi
HAS_AUX_COMMON_PACKAGE=$(helm search ${HELM_SEARCH_FLAG} local/aux-common | grep aux-common)
if [ -z "$HAS_AUX_COMMON_PACKAGE" ];then
echo "****************************************************************************************************************"
echo " ERROR "
echo "****************************************************************************************************************"
echo "Can't locate the aux-common helm package in the local repo. Please make sure that it is properly installed."
echo "****************************************************************************************************************"
exit 1
fi
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null && pwd )"
COMMON_BLOCK=$(cat $OVERRIDEYAML | awk '/^common:/{getline; while ($0 ~ /^ +.*|^ *$/) {print $0; if (getline == 0) {break}}}')
NAMESPACE_BLOCK=$(cat $OVERRIDEYAML | awk '/^ namespace:/{getline; while ($0 ~ /^ .*|^ *$/) {print $0; if (getline == 0) {break}}}')
AUXNAMESPACE=$(echo "$NAMESPACE_BLOCK" | awk '/^ *aux:/{print $2}')
INFRANAMESPACE=$(echo "$NAMESPACE_BLOCK" | awk '/^ *infra:/{print $2}')
RELEASE_PREFIX=$(echo "$COMMON_BLOCK" | awk '/^ *releasePrefix:/{print $2}')
COMPONENTS=${LIST_OF_COMPONENTS:-"infrastructure dashboard ves message-router mrsub mc-stack portal aaf"}
NODENAME=$(kubectl get node | awk 'NR>1{print $1}')
LABELFOUND=false
for f in $NODENAME; do
LABEL=$(kubectl describe node $f | grep "local-storage=enable")
if [ ! -z "$LABEL" ]; then
LABELFOUND=true
echo "Found lable \"local-storage=enable\" at node $f"
fi
done
FOUND_STORAGECLASS=$(grep -w storageclass $OVERRIDEYAML)
if ! $LABELFOUND && [ -z "$FOUND_STORAGECLASS" ]; then
echo "***********************************************************************************************"
echo "* ERROR!!!!!!!!!!!!! *"
echo "***********************************************************************************************"
echo "* Nodes label \"local-storage=enable\" is not found in any of the cluster node. *"
echo "* Please pick a node and label it using the following command. *"
echo "* kubectl label --overwrite nodes <YOUR_NODE_NAME> local-storage=enable *"
echo "***********************************************************************************************"
exit 1
fi
if [ -z "$FOUND_STORAGECLASS" ] && $LABELFOUND; then
DATAPATH=$(cat $DIR/../helm/dashboard/values.yaml | grep datapath | awk '{ print $2}' )
if [ ! -z $OVERRIDEYAML ]; then
DATAPATHOVERRIDE=$(cat $OVERRIDEYAML | grep datapath | awk '{ print $2}' )
fi
if [ ! -z "$DATAPATHOVERRIDE" ]; then
DATAPATH=$DATAPATHOVERRIDE
fi
if [ ! -d "$DATAPATH" ]; then
mkdir -p $DATAPATH || { echo "Directory $DATAPATH does not exist and you don't have permission to create it. Please choose a different datapath." ; exit 1 ; }
fi
echo "***********************************************************************************************"
echo "* WARNING!!!!!!!!!!!!! *"
echo "***********************************************************************************************"
echo "* Dashboard will use local storage. Please make sure that directory *"
echo "* $DATAPATH *"
echo "* contains the proper files. *"
echo "***********************************************************************************************"
fi
LABELFOUND=false
for f in $NODENAME; do
LABEL=$(kubectl describe node $f | grep "portal-storage=enable")
if [ ! -z "$LABEL" ]; then
LABELFOUND=true
echo "Found lable \"portal-storage=enable\" at node $f"
fi
done
if ! $LABELFOUND; then
echo "***********************************************************************************************"
echo "* ERROR!!!!!!!!!!!!! *"
echo "***********************************************************************************************"
echo "* Nodes label \"portal-storage=enable\" is not found in any of the cluster node. *"
echo "* Please pick a node and label it using the following command. i *"
echo "* kubectl label --overwrite nodes <YOUR_NODE_NAME> portal-storage=enable *"
echo "***********************************************************************************************"
exit 1
fi
if ! kubectl get ns ${AUXNAMESPACE:-ricaux}> /dev/null 2>&1; then
kubectl create ns ${AUXNAMESPACE:-ricaux}
fi
if ! kubectl get ns ${INFRANAMESPACE:-ricinfra}> /dev/null 2>&1; then
kubectl create ns ${INFRANAMESPACE:-ricinfra}
fi
if ! kubectl get ns onap > /dev/null 2>&1; then
kubectl create ns onap
fi
echo Add cluster roles
cat >ricaux-role.yaml <<EOF
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: ricaux-system-default
rules:
- apiGroups: [""]
resources: ["pods"]
verbs: ["list"]
- apiGroups: ["batch"]
resources: ["jobs/status"]
verbs: ["get"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: ricaux-system-default
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: ricaux-system-default
subjects:
- kind: ServiceAccount
name: default
namespace: ${AUXNAMESPACE:-ricaux}
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: onap-system-default
rules:
- apiGroups: [""]
resources: ["pods"]
verbs: ["list"]
- apiGroups: ["apps"]
resources: ["replicasets/status"]
verbs: ["get"]
- apiGroups: ["batch"]
resources: ["jobs/status"]
verbs: ["get"]
- apiGroups: ["apps"]
resources: ["deployments", "statefulsets"]
verbs: ["get"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: onap-system-default
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: onap-system-default
subjects:
- kind: ServiceAccount
name: default
namespace: onap
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: ricaux-system-tiller
rules:
- apiGroups: [""]
resources: ["deployments"]
verbs: ["get", "list", "create", "delete"]
- apiGroups: ["apiextensions.k8s.io"]
resources: ["customresourcedefinitions"]
verbs: ["get", "list", "create", "delete"]
- apiGroups: ["rbac.authorization.k8s.io"]
resources: ["clusterroles", "clusterrolebindings"]
verbs: ["get", "list", "create", "delete"]
- apiGroups: [""]
resources: ["events"]
verbs: ["create", "patch"]
- apiGroups: [""]
resources: ["nodes"]
verbs: ["list", "watch", "get"]
- apiGroups: ["configuration.konghq.com"]
resources: ["kongconsumers"]
verbs: ["get", "list", "watch"]
- apiGroups: ["configuration.konghq.com"]
resources: ["kongcredentials"]
verbs: ["get", "list", "watch"]
- apiGroups: ["configuration.konghq.com"]
resources: ["kongingresses"]
verbs: ["get", "list", "watch"]
- apiGroups: ["configuration.konghq.com"]
resources: ["kongplugins"]
verbs: ["get", "list", "watch"]
- apiGroups: ["extensions"]
resources: ["ingresses/status"]
verbs: ["update"]
- apiGroups: ["networking.k8s.io"]
resources: ["ingresses/status"]
verbs: ["update"]
- apiGroups: ["networking.k8s.io"]
resources: ["ingresses"]
verbs: ["get", "list", "create", "delete", "watch"]
- apiGroups: ["danm.k8s.io"]
resources: ["clusternetworks"]
verbs: ["get", "list", "create", "delete"]
- apiGroups: ["storage.k8s.io"]
resources: ["storageclasses"]
verbs: ["get", "list", "create", "delete"]
- apiGroups: [""]
resources: ["persistentvolumes"]
verbs: ["get", "list", "create", "delete"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: ricaux-system-tiller
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: ricaux-system-tiller
subjects:
- kind: ServiceAccount
name: tiller
namespace: kube-system
EOF
kubectl apply -f ricaux-role.yaml
rm ricaux-role.yaml
kubectl create configmap -n ${AUXNAMESPACE:-ricaux} aux-recipe --from-file=recipe=$OVERRIDEYAML
echo "Clean up dockerdata-nfs directory"
rm -rf /dockerdata-nfs/*
echo "Deploying AUX components [$COMPONENTS]"
for component in $COMPONENTS; do
helm dep up $DIR/../helm/$component
# Handle helm2/helm3 arg
NAME_ARG=""
if [ -z $IS_HELM3 ]; then
NAME_ARG=" --name "
fi
case "$component" in
aaf)
NODENAME=$(kubectl get node | awk 'NR>1{print $1}')
LABELFOUND=false
for f in $NODENAME; do
LABEL=$(kubectl describe node $f | grep "aaf-storage=enable")
if [ ! -z "$LABEL" ]; then
LABELFOUND=true
echo "Found lable \"aaf-storage=enable\" at node $f"
fi
done
if ! $LABELFOUND; then
echo "***********************************************************************************************"
echo "* ERROR!!!!!!!!!!!!! *"
echo "***********************************************************************************************"
echo "* Nodes label \"aaf-storage=enable\" is not found in any of the cluster node. *"
echo "* Please pick a node and label it using the following command. *"
echo "* kubectl label --overwrite nodes <YOUR_NODE_NAME> aaf-storage=enable *"
echo "***********************************************************************************************"
else
helm install -f $OVERRIDEYAML --namespace "onap" ${NAME_ARG} "${RELEASE_PREFIX}-$component" $DIR/../helm/$component
fi
;;
*)
helm install -f $OVERRIDEYAML --namespace "${AUXNAMESPACE:-ricaux}" ${NAME_ARG} "${RELEASE_PREFIX}-$component" $DIR/../helm/$component
sleep 8
esac
done