blob: 73e27daa9e821f9f11e945af6e7c9e64640f6b3b [file] [log] [blame]
#!/bin/bash
# ============LICENSE_START=======================================================
# Copyright (C) 2019 The Nordix Foundation. 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.
#
# SPDX-License-Identifier: Apache-2.0
# ============LICENSE_END=========================================================
set -o errexit
set -o nounset
set -o pipefail
INSTALLER_ROOT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
export ANSIBLE_ROLES_PATH="$HOME/.ansible/roles:/usr/share/ansible/roles:/etc/ansible/roles:${ENGINE_PATH}/engine/playbooks/roles:${ENGINE_CACHE}/repos/bifrost/playbooks/roles"
export ANSIBLE_LIBRARY="$HOME/.ansible/plugins/modules:/usr/share/ansible/plugins/modules:${ENGINE_CACHE}/repos/bifrost/playbooks/library"
# configure target hosts
echo "-------------------------------------------------------------------------"
echo "Info: Configure target hosts"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_PATH}"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
-i "${ENGINE_PATH}/engine/inventory/inventory.ini" \
"${INSTALLER_ROOT_DIR}/playbooks/configure-targethosts.yml"
# configure kolla installer
echo "-------------------------------------------------------------------------"
echo "Info: Configure kolla installer"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_PATH}"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
-i "${ENGINE_PATH}/engine/inventory/inventory.ini" \
"${INSTALLER_ROOT_DIR}/playbooks/configure-installer.yml"
# TODO: we need to run scenario pre-deployment tasks here in order to configure
# bootstrap scenario
echo "-------------------------------------------------------------------------"
echo "Info: Execute scenario pre deployment tasks"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_PATH}"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
-i "${ENGINE_PATH}/engine/inventory/inventory.ini" \
"${INSTALLER_ROOT_DIR}/playbooks/pre-deployment.yml"
# kolla-ansible: bootstrap servers
echo "-------------------------------------------------------------------------"
echo "Info: Kolla-ansible bootstrap servers"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_CACHE}/repos/kolla-ansible/tools"
./kolla-ansible \
-i "${ENGINE_PATH}/engine/inventory/inventory.ini" \
--configdir "${ENGINE_CACHE}/config" \
--passwords "${ENGINE_CACHE}/config/passwords.yml" \
-e "@${ENGINE_CACHE}/config/kolla-ansible-extra-vars.yml" \
bootstrap-servers
# kolla-ansible: prechecks
echo "-------------------------------------------------------------------------"
echo "Info: Kolla-ansible prechecks"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_CACHE}/repos/kolla-ansible/tools"
./kolla-ansible \
-i "${ENGINE_PATH}/engine/inventory/inventory.ini" \
--configdir "${ENGINE_CACHE}/config" \
--passwords "${ENGINE_CACHE}/config/passwords.yml" \
-e "@${ENGINE_CACHE}/config/kolla-ansible-extra-vars.yml" \
prechecks
# kolla-ansible: deploy
echo "-------------------------------------------------------------------------"
echo "Info: Kolla-ansible deploy"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_CACHE}/repos/kolla-ansible/tools"
./kolla-ansible \
-i "${ENGINE_PATH}/engine/inventory/inventory.ini" \
--configdir "${ENGINE_CACHE}/config" \
--passwords "${ENGINE_CACHE}/config/passwords.yml" \
-e "@${ENGINE_CACHE}/config/kolla-ansible-extra-vars.yml" \
deploy
# kolla-ansible: post-deploy
echo "-------------------------------------------------------------------------"
echo "Info: Kolla-ansible post-deploy"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_CACHE}/repos/kolla-ansible/tools"
./kolla-ansible \
-i "${ENGINE_PATH}/engine/inventory/inventory.ini" \
--configdir "${ENGINE_CACHE}/config" \
--passwords "${ENGINE_CACHE}/config/passwords.yml" \
-e "@${ENGINE_CACHE}/config/kolla-ansible-extra-vars.yml" \
post-deploy
# NOTE: shellcheck SC1090 is disabled since openrc file is put in place during runtime
# shellcheck disable=SC1090
# source admin-openrc.sh for running post-deployment tasks
source "${ENGINE_CACHE}/config/admin-openrc.sh"
# run post-deployment tasks
echo "-------------------------------------------------------------------------"
echo "Info: Execute scenario and common post deployment tasks"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_PATH}"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
-i "${ENGINE_PATH}/engine/inventory/inventory.ini" \
"${INSTALLER_ROOT_DIR}/playbooks/post-deployment.yml"
# vim: set ts=2 sw=2 expandtab: