2012-11-19 16:00:01 -05:00
|
|
|
# lib/horizon
|
|
|
|
# Functions to control the configuration and operation of the horizon service
|
|
|
|
|
|
|
|
# Dependencies:
|
2013-10-24 11:27:02 +01:00
|
|
|
#
|
|
|
|
# - ``functions`` file
|
|
|
|
# - ``apache`` file
|
|
|
|
# - ``SERVICE_{TENANT_NAME|PASSWORD}`` must be defined
|
2012-11-19 16:00:01 -05:00
|
|
|
|
|
|
|
# ``stack.sh`` calls the entry points in this order:
|
|
|
|
#
|
2013-10-24 11:27:02 +01:00
|
|
|
# - install_horizon
|
|
|
|
# - configure_horizon
|
|
|
|
# - init_horizon
|
|
|
|
# - start_horizon
|
|
|
|
# - stop_horizon
|
|
|
|
# - cleanup_horizon
|
2012-11-19 16:00:01 -05:00
|
|
|
|
|
|
|
# Save trace setting
|
|
|
|
XTRACE=$(set +o | grep xtrace)
|
|
|
|
set +o xtrace
|
|
|
|
|
|
|
|
|
|
|
|
# Defaults
|
|
|
|
# --------
|
|
|
|
|
|
|
|
# Set up default directories
|
2014-11-14 09:31:02 -05:00
|
|
|
GITDIR["django_openstack_auth"]=$DEST/django_openstack_auth
|
|
|
|
|
2012-11-19 16:00:01 -05:00
|
|
|
HORIZON_DIR=$DEST/horizon
|
|
|
|
|
2013-03-27 19:47:11 +09:00
|
|
|
# local_settings.py is used to customize Dashboard settings.
|
|
|
|
# The example file in Horizon repo is used by default.
|
|
|
|
HORIZON_SETTINGS=${HORIZON_SETTINGS:-$HORIZON_DIR/openstack_dashboard/local/local_settings.py.example}
|
|
|
|
|
2014-01-29 16:22:11 -06:00
|
|
|
# Tell Tempest this project is present
|
|
|
|
TEMPEST_SERVICES+=,horizon
|
|
|
|
|
2013-04-08 15:38:03 -05:00
|
|
|
|
|
|
|
# Functions
|
|
|
|
# ---------
|
|
|
|
|
2013-03-07 16:10:10 +04:00
|
|
|
# utility method of setting python option
|
2014-02-21 15:35:08 +11:00
|
|
|
function _horizon_config_set {
|
2013-03-07 16:10:10 +04:00
|
|
|
local file=$1
|
|
|
|
local section=$2
|
|
|
|
local option=$3
|
|
|
|
local value=$4
|
|
|
|
|
2014-03-17 00:07:52 -04:00
|
|
|
if [ -z "$section" ]; then
|
|
|
|
sed -e "/^$option/d" -i $local_settings
|
|
|
|
echo -e "\n$option=$value" >> $file
|
|
|
|
elif grep -q "^$section" $file; then
|
2014-07-25 12:50:14 -05:00
|
|
|
local line=$(sed -ne "/^$section/,/^}/ { /^ *'$option':/ p; }" $file)
|
2013-03-07 16:10:10 +04:00
|
|
|
if [ -n "$line" ]; then
|
|
|
|
sed -i -e "/^$section/,/^}/ s/^\( *'$option'\) *:.*$/\1: $value,/" $file
|
|
|
|
else
|
2013-07-16 04:18:47 -07:00
|
|
|
sed -i -e "/^$section/a\ '$option': $value," $file
|
2013-03-07 16:10:10 +04:00
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo -e "\n\n$section = {\n '$option': $value,\n}" >> $file
|
|
|
|
fi
|
|
|
|
}
|
2012-11-19 16:00:01 -05:00
|
|
|
|
2013-04-11 11:13:09 +10:00
|
|
|
|
2013-06-03 16:47:36 -05:00
|
|
|
|
2012-11-19 16:00:01 -05:00
|
|
|
# Entry Points
|
|
|
|
# ------------
|
|
|
|
|
|
|
|
# cleanup_horizon() - Remove residual data files, anything left over from previous
|
|
|
|
# runs that a clean run would need to clean up
|
2014-02-21 15:35:08 +11:00
|
|
|
function cleanup_horizon {
|
2013-06-03 16:47:36 -05:00
|
|
|
if [[ is_fedora && $DISTRO =~ (rhel6) ]]; then
|
|
|
|
# If ``/usr/bin/node`` points into ``$DEST``
|
|
|
|
# we installed it via ``install_nodejs``
|
|
|
|
if [[ $(readlink -f /usr/bin/node) =~ ($DEST) ]]; then
|
|
|
|
sudo rm /usr/bin/node
|
|
|
|
fi
|
|
|
|
fi
|
2014-06-06 16:36:52 -05:00
|
|
|
|
|
|
|
local horizon_conf=$(apache_site_config_for horizon)
|
|
|
|
sudo rm -f $horizon_conf
|
2012-11-19 16:00:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
# configure_horizon() - Set config files, create data dirs, etc
|
2014-02-21 15:35:08 +11:00
|
|
|
function configure_horizon {
|
2012-11-19 16:00:01 -05:00
|
|
|
setup_develop $HORIZON_DIR
|
2014-10-15 17:26:59 +09:00
|
|
|
|
|
|
|
# Compile message catalogs.
|
|
|
|
# Horizon is installed as develop mode, so we can compile here.
|
|
|
|
# Message catalog compilation is handled by Django admin script,
|
|
|
|
# so compiling them after the installation avoids Django installation twice.
|
2014-11-14 09:31:02 -05:00
|
|
|
(cd $HORIZON_DIR; ./run_tests.sh -N --compilemessages)
|
2012-11-19 16:00:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
# init_horizon() - Initialize databases, etc.
|
2014-02-21 15:35:08 +11:00
|
|
|
function init_horizon {
|
2012-11-19 16:00:01 -05:00
|
|
|
# ``local_settings.py`` is used to override horizon default settings.
|
2014-07-25 12:50:14 -05:00
|
|
|
local local_settings=$HORIZON_DIR/openstack_dashboard/local/local_settings.py
|
2013-03-27 19:47:11 +09:00
|
|
|
cp $HORIZON_SETTINGS $local_settings
|
2012-11-19 16:00:01 -05:00
|
|
|
|
2014-09-11 17:50:08 -06:00
|
|
|
_horizon_config_set $local_settings "" COMPRESS_OFFLINE True
|
|
|
|
|
2014-03-17 00:07:52 -04:00
|
|
|
_horizon_config_set $local_settings "" OPENSTACK_HOST \"${KEYSTONE_SERVICE_HOST}\"
|
2014-06-04 19:15:11 +09:00
|
|
|
_horizon_config_set $local_settings "" OPENSTACK_KEYSTONE_URL "\"${KEYSTONE_SERVICE_PROTOCOL}://${KEYSTONE_SERVICE_HOST}:${KEYSTONE_SERVICE_PORT}/v2.0\""
|
2014-08-24 18:54:51 -05:00
|
|
|
if [[ -n "$KEYSTONE_TOKEN_HASH_ALGORITHM" ]]; then
|
|
|
|
_horizon_config_set $local_settings "" OPENSTACK_TOKEN_HASH_ALGORITHM \""$KEYSTONE_TOKEN_HASH_ALGORITHM"\"
|
|
|
|
fi
|
2014-03-17 00:07:52 -04:00
|
|
|
|
|
|
|
if [ -f $SSL_BUNDLE_FILE ]; then
|
|
|
|
_horizon_config_set $local_settings "" OPENSTACK_SSL_CACERT \"${SSL_BUNDLE_FILE}\"
|
|
|
|
fi
|
|
|
|
|
2012-11-19 16:00:01 -05:00
|
|
|
# Create an empty directory that apache uses as docroot
|
|
|
|
sudo mkdir -p $HORIZON_DIR/.blackhole
|
|
|
|
|
Fix the way Apache site configuration files are used, to improve OS portability
On Ubuntu 14.04, the site configuration file must have a .conf suffix for a2ensite and a2dissite to
recognise it. a2ensite and a2dissite ignore the .conf suffix used as parameter. The default sites'
files are 000-default.conf and default-ssl.conf.
On Ubuntu 12.04, the site configuration file may have any format, as long as it is in
/etc/apache2/sites-available/. a2ensite and a2dissite need the entire file name to work. The default
sites' files are default and default-ssl.
On Fedora, any file in /etc/httpd/conf.d/ whose name ends with .conf is enabled.
On RHEL and CentOS, things should hopefully work as in Fedora.
This change puts all distribution-related site configuration file name differences in lib/apache and
the other services gets the file name for its sites using the new exported function
apache_site_config_for <sitename>.
It also makes Fedora disabled sites use the .conf.disabled suffix instead of removing the .conf from
the file name.
The table below summarizes what should happen on each distribution:
+----------------------+--------------------+--------------------------+--------------------------+
| Distribution | File name | Site enabling command | Site disabling command |
+----------------------+--------------------+--------------------------+--------------------------+
| Ubuntu 12.04 | site | a2ensite site | a2dissite site |
| Ubuntu 14.04 | site.conf | a2ensite site | a2dissite site |
| Fedora, RHEL, CentOS | site.conf.disabled | mv site.conf{.disabled,} | mv site.conf{,.disabled} |
+----------------------+--------------------+--------------------------+--------------------------+
Change-Id: Ia2ba3cb7caccb6e9b65380f9d51d9d21180b894e
Closes-bug: #1313765
2014-05-27 20:58:22 +00:00
|
|
|
local horizon_conf=$(apache_site_config_for horizon)
|
2014-06-03 16:53:03 +02:00
|
|
|
|
|
|
|
# Configure apache to run horizon
|
|
|
|
sudo sh -c "sed -e \"
|
|
|
|
s,%USER%,$APACHE_USER,g;
|
|
|
|
s,%GROUP%,$APACHE_GROUP,g;
|
|
|
|
s,%HORIZON_DIR%,$HORIZON_DIR,g;
|
|
|
|
s,%APACHE_NAME%,$APACHE_NAME,g;
|
|
|
|
s,%DEST%,$DEST,g;
|
|
|
|
\" $FILES/apache-horizon.template >$horizon_conf"
|
|
|
|
|
2012-12-04 12:36:34 +01:00
|
|
|
if is_ubuntu; then
|
2014-03-27 12:48:43 +00:00
|
|
|
disable_apache_site 000-default
|
2013-06-21 18:18:02 +08:00
|
|
|
sudo touch $horizon_conf
|
2012-12-06 09:56:32 +01:00
|
|
|
elif is_fedora; then
|
|
|
|
sudo sed '/^Listen/s/^.*$/Listen 0.0.0.0:80/' -i /etc/httpd/conf/httpd.conf
|
2013-10-01 01:08:20 +01:00
|
|
|
elif is_suse; then
|
|
|
|
: # nothing to do
|
2012-11-19 16:00:01 -05:00
|
|
|
else
|
2013-10-01 01:10:16 +01:00
|
|
|
exit_distro_not_supported "horizon apache configuration"
|
2012-11-19 16:00:01 -05:00
|
|
|
fi
|
2014-06-03 16:53:03 +02:00
|
|
|
enable_apache_site horizon
|
2012-11-19 16:00:01 -05:00
|
|
|
|
2013-05-08 22:19:59 +02:00
|
|
|
# Remove old log files that could mess with how devstack detects whether Horizon
|
|
|
|
# has been successfully started (see start_horizon() and functions::screen_it())
|
2014-09-09 13:46:02 +01:00
|
|
|
# and run_process
|
2013-05-08 22:19:59 +02:00
|
|
|
sudo rm -f /var/log/$APACHE_NAME/horizon_*
|
|
|
|
|
2014-11-18 12:11:26 -06:00
|
|
|
# Setup alias for django-admin which could be different depending on distro
|
|
|
|
local django_admin
|
|
|
|
if type -p django-admin > /dev/null; then
|
|
|
|
django_admin=django-admin
|
|
|
|
else
|
|
|
|
django_admin=django-admin.py
|
|
|
|
fi
|
|
|
|
|
|
|
|
DJANGO_SETTINGS_MODULE=openstack_dashboard.settings $django_admin collectstatic --noinput
|
|
|
|
DJANGO_SETTINGS_MODULE=openstack_dashboard.settings $django_admin compress --force
|
2014-09-11 17:50:08 -06:00
|
|
|
|
2012-11-19 16:00:01 -05:00
|
|
|
}
|
|
|
|
|
2014-03-12 16:58:12 +08:00
|
|
|
# install_django_openstack_auth() - Collect source and prepare
|
|
|
|
function install_django_openstack_auth {
|
2014-11-14 09:31:02 -05:00
|
|
|
if use_library_from_git "django_openstack_auth"; then
|
|
|
|
local dir=${GITDIR["django_openstack_auth"]}
|
|
|
|
git_clone_by_name "django_openstack_auth"
|
|
|
|
# Compile message catalogs before installation
|
|
|
|
_prepare_message_catalog_compilation
|
|
|
|
(cd $dir; python setup.py compile_catalog)
|
|
|
|
setup_dev_lib "django_openstack_auth"
|
|
|
|
fi
|
|
|
|
# if we aren't using this library from git, then we just let it
|
|
|
|
# get dragged in by the horizon setup.
|
2014-03-12 16:58:12 +08:00
|
|
|
}
|
|
|
|
|
2012-11-19 16:00:01 -05:00
|
|
|
# install_horizon() - Collect source and prepare
|
2014-02-21 15:35:08 +11:00
|
|
|
function install_horizon {
|
2012-11-19 16:00:01 -05:00
|
|
|
# Apache installation, because we mark it NOPRIME
|
2013-06-21 18:18:02 +08:00
|
|
|
install_apache_wsgi
|
2012-11-19 16:00:01 -05:00
|
|
|
|
|
|
|
git_clone $HORIZON_REPO $HORIZON_DIR $HORIZON_BRANCH $HORIZON_TAG
|
|
|
|
}
|
|
|
|
|
|
|
|
# start_horizon() - Start running processes, including screen
|
2014-02-21 15:35:08 +11:00
|
|
|
function start_horizon {
|
2013-06-21 18:18:02 +08:00
|
|
|
restart_apache_server
|
2014-09-09 13:46:02 +01:00
|
|
|
tail_log horizon /var/log/$APACHE_NAME/horizon_error.log
|
2012-11-19 16:00:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
# stop_horizon() - Stop running processes (non-screen)
|
2014-02-21 15:35:08 +11:00
|
|
|
function stop_horizon {
|
2013-06-21 18:18:02 +08:00
|
|
|
stop_apache_server
|
2012-11-19 16:00:01 -05:00
|
|
|
}
|
|
|
|
|
2014-10-15 17:26:59 +09:00
|
|
|
# NOTE: It can be moved to common functions, but it is only used by compilation
|
|
|
|
# of django_openstack_auth catalogs at the moment.
|
|
|
|
function _prepare_message_catalog_compilation {
|
|
|
|
local babel_package=$(grep ^Babel $REQUIREMENTS_DIR/global-requirements.txt)
|
|
|
|
pip_install "$babel_package"
|
|
|
|
}
|
|
|
|
|
2013-06-03 16:47:36 -05:00
|
|
|
|
2012-11-19 16:00:01 -05:00
|
|
|
# Restore xtrace
|
|
|
|
$XTRACE
|
2013-03-29 14:34:53 -04:00
|
|
|
|
2013-10-24 11:27:02 +01:00
|
|
|
# Tell emacs to use shell-script-mode
|
|
|
|
## Local variables:
|
|
|
|
## mode: shell-script
|
|
|
|
## End:
|