tobiko/devstack/plugin.sh
Federico Ressi c367511145 Update DevStack plugin after Keystone auth params improvement
This include some other imporvements, like for example tobiko.log file
configuration, and making plugin more configurable.

Change-Id: I7cc36845de419fa963548ed381f26152cc8267a8
2019-05-09 14:30:41 +00:00

151 lines
4.7 KiB
Bash

# Directory where this plugin.sh file is
TOBIKO_PLUGIN_DIR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
function install_tobiko {
echo_summary "Installing tobiko-plugin"
install_python3
setup_dev_lib tobiko
}
function configure_tobiko {
# Write configuration to a new temporary file
local tobiko_config=$(mktemp)
if [ -f "${TOBIKO_CONFIG}" ]; then
# Start from existing tobiko.conf file
cp "${TOBIKO_CONFIG}" "${tobiko_config}"
fi
configure_tobiko_default "${tobiko_config}"
configure_tobiko_keystone "${tobiko_config}"
configure_tobiko_nova "${tobiko_config}"
configure_tobiko_neutron "${tobiko_config}"
echo_summary "Apply changes to actual ${TOBIKO_CONFIG} file."
sudo mkdir -p $(dirname "${TOBIKO_CONFIG}")
sudo mv "${tobiko_config}" "${TOBIKO_CONFIG}"
sudo chmod ugo+r "${TOBIKO_CONFIG}"
echo "${TOBIKO_CONFIG} file content:"
echo --------------------------------
cat "${TOBIKO_CONFIG}"
echo --------------------------------
}
function configure_tobiko_default {
echo_summary "Write [DEFAULT] section to ${TOBIKO_CONFIG}"
local tobiko_config=$1
setup_logging "${tobiko_config}"
iniset ${tobiko_config} DEFAULT log_dir "${TOBIKO_LOG_DIR}"
iniset ${tobiko_config} DEFAULT log_file "${TOBIKO_LOG_FILE}"
iniset ${tobiko_config} DEFAULT debug "${TOBIKO_DEBUG}"
}
function configure_tobiko_keystone {
echo_summary "Write [keystone] section to ${TOBIKO_CONFIG}"
local tobiko_config=$1
local api_version=${IDENTITY_API_VERSION}
if [ "${api_version}" == '2']; then
local auth_url=${KEYSTONE_AUTH_URI/v2.0}
else
local auth_url=${KEYSTONE_AUTH_URI_V3:-${KEYSTONE_AUTH_URI/v3}}
fi
local project_id=$(get_or_create_project \
"${TOBIKO_KEYSTONE_PROJECT_NAME}" \
"${TOBIKO_KEYSTONE_PROJECT_DOMAIN_NAME}")
local user_id=$(get_or_create_user \
"${TOBIKO_KEYSTONE_USERNAME}" \
"${TOBIKO_KEYSTONE_PASSWORD}" \
"${TOBIKO_KEYSTONE_USER_DOMAIN_NAME}")
local user_project_role_id=$(get_or_add_user_project_role \
"${TOBIKO_KEYSTONE_USER_ROLE}" \
"${user_id}" \
"${project_id}")
local user_domain_role_id=$(get_or_add_user_domain_role \
"${TOBIKO_KEYSTONE_USER_ROLE}" \
"${user_id}" \
"${TOBIKO_KEYSTONE_USER_DOMAIN_NAME}")
iniset "${tobiko_config}" keystone api_version "${api_version}"
iniset "${tobiko_config}" keystone auth_url "${auth_url}"
iniset "${tobiko_config}" keystone username "${TOBIKO_KEYSTONE_USERNAME}"
iniset "${tobiko_config}" keystone password "${TOBIKO_KEYSTONE_PASSWORD}"
iniset "${tobiko_config}" keystone project_name "${TOBIKO_KEYSTONE_PROJECT_NAME}"
if [ "${api_version}" != '2' ]; then
iniset "${tobiko_config}" keystone domain_name "${TOBIKO_KEYSTONE_DOMAIN_NAME}"
iniset "${tobiko_config}" keystone user_domain_name \
"${TOBIKO_KEYSTONE_USER_DOMAIN_NAME}"
iniset "${tobiko_config}" keystone project_domain_name \
"${TOBIKO_KEYSTONE_PROJECT_DOMAIN_NAME}"
iniset "${tobiko_config}" keystone trust_id "${TOBIKO_KEYSTONE_TRUST_ID}"
fi
}
function configure_tobiko_nova {
echo_summary "Write [nova] section to ${TOBIKO_CONFIG}"
local tobiko_config=$1
# Write image ID
local image_name=${TOBIKO_NOVA_IMAGE:-}
if [ "${image_name}" != "" ]; then
local image_id=$(openstack image show -f value -c id "${image_name}")
else
local image_id=$(openstack image list --limit 1 -f value -c ID --public --status active)
fi
iniset "${tobiko_config}" nova image "${image_id}"
# Write flavor ID
local flavor_name=${TOBIKO_NOVA_FLAVOR:-}
if [ "${flavor_name}" != "" ]; then
local flavor_id=$(openstack flavor show -f value -c id "${flavor_name}")
else
local flavor_id=$(openstack flavor list --limit 1 -f value -c ID --public)
fi
iniset "${tobiko_config}" nova flavor "${flavor_id}"
# Write key_file
local key_file=${TOBIKO_NOVA_KEY_FILE:-}
if ! [ -r "${key_file}" ]; then
ssh-keygen -t rsa -q -P "" -f "${key_file}"
fi
iniset "${tobiko_config}" nova key_file "${key_file}"
}
function configure_tobiko_neutron {
echo_summary "Write [neutron] section to ${TOBIKO_CONFIG}"
local tobiko_config=$1
# Write floating network
local floating_network=${TOBIKO_NEUTRON_FLOATING_NETWORK}
if [ "${floating_network}" != "" ]; then
local floating_network=$(openstack network show -f value -c name "${floating_network}")
else
local networks=( $( openstack network list -f value -c Name --enable --external) )
local floating_network=${networks[0]}
fi
iniset "${tobiko_config}" neutron floating_network "${floating_network}"
}
if [[ "$1" == "stack" ]]; then
case "$2" in
install)
install_tobiko
;;
test-config)
configure_tobiko
;;
esac
fi