blob: 75b36bbc52fcb6b21a41f56b7fa1283554092465 [file] [log] [blame]
#!/bin/sh -x
# Copyright (c) 2021 AT&T. All rights reserved.
#
# 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.
# Pre-requisite
# 1. Chart packages available under local directory provided as input/argument
# 2. helm client installed with push plugin
# 3. ONAP chartmuseum service deployed
usage()
{
echo "Chart Base directory must be provided as input!!"
echo "Usage: registry-initialize.sh -d chartdirectory \
<-n namespace override> <-r helmrelease override>"
exit 1
}
if [ $# -eq 0 ]; then
usage
fi
# defaults
NAMESPACE=onap
RLS_NAME=onap
LOGIN=""
PASSWORD=""
while getopts ":d:n:r:" opt; do
case $opt in
d) BASEDIR="$OPTARG"
;;
n) NAMESPACE="$OPTARG"
;;
r) RLS_NAME="$OPTARG"
;;
\?) echo "Invalid option -$OPTARG" >&2
usage
;;
esac
done
if [ -z "$BASEDIR" ]; then
exit "Chart base directory provided $BASEDIR is empty"
fi
if [ "$(find $BASEDIR -maxdepth 1 -name '*tgz' -print -quit)" ]; then
echo "$BASEDIR valid"
else
exit "No chart package on $BASEDIR provided"
fi
LOGIN=$(kubectl -n "$NAMESPACE" get secret \
"${RLS_NAME}-chartmuseum-registrycred" \
-o jsonpath='{.data.login}' | base64 -d)
PASSWORD=$(kubectl -n "$NAMESPACE" get secret \
"${RLS_NAME}-chartmuseum-registrycred" \
-o jsonpath='{.data.password}' | base64 -d)
if [ -z "$LOGIN" ] || [ -z "$PASSWORD" ]; then
echo "Login/Password credential for target registry cannot be retrieved"
exit 1
fi
# Expose cluster port via port-forwarding
kubectl -n $NAMESPACE port-forward service/chart-museum 27017:80 &
if [ $? -ne 0 ]; then
echo "Error in portforwarding; registry cannot be added!!"
exit 1
fi
sleep 5
# Add chartmuseum repo as helm repo
# Credentials should match config defined in
# oom\kubernetes\platform\components\chartmuseum\values.yaml
helm repo add k8s-registry http://127.0.0.1:27017 --username "$LOGIN" \
--password "$PASSWORD"
if [ $? -ne 0 ]; then
echo "registry cannot be added!!"
pkill -f "port-forward service/chart-museum"
exit 1
fi
# Initial scope is pushing only dcae charts
# can be expanded to include all onap charts if required
for file in $BASEDIR/dcae*tgz; do
# use helm plugin to push charts
helm push $file k8s-registry
if [ $? -eq 0 ]; then
echo "$file uploaded to registry successfully"
else
echo "registry upload failed!!"
pkill -f "port-forward service/chart-museum"
helm repo remove k8s-registry
exit 1
fi
done
echo "All Helm charts successfully uploaded into internal repository"
# Remove the port-forwarding process
pkill -f "port-forward service/chart-museum"
# Remove helm registry from local
helm repo remove k8s-registry