diff options
author | Francisco Redondo Marchena <francisco.marchena@codethink.co.uk> | 2015-04-14 09:14:39 +0000 |
---|---|---|
committer | Francisco Redondo Marchena <francisco.marchena@codethink.co.uk> | 2015-04-14 15:26:42 +0000 |
commit | b3b4b63b825b12501b6d9fc500d7cc2bfb0cd2eb (patch) | |
tree | 613da592853705d1d6aeffb264ad769c16217020 | |
parent | 473046efa912cf9d052914f2664c3a66491dd850 (diff) | |
download | definitions-b3b4b63b825b12501b6d9fc500d7cc2bfb0cd2eb.tar.gz |
cinder: Add configuration extension
Change-Id: Ia722cace623424f30a143786e0189f4dfe3c25a4
-rw-r--r-- | openstack-cinder.configure | 88 | ||||
-rw-r--r-- | systems/openstack-server.morph | 1 |
2 files changed, 89 insertions, 0 deletions
diff --git a/openstack-cinder.configure b/openstack-cinder.configure new file mode 100644 index 00000000..b6e3e3f2 --- /dev/null +++ b/openstack-cinder.configure @@ -0,0 +1,88 @@ +#!/bin/sh + +# Copyright (C) 2014-2015 Codethink Limited +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; version 2 of the License. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License along +# with this program. If not, see <http://www.gnu.org/licenses/>. + +set -e + +ROOT="$1" + +########################################################################## + +ln -sf "/usr/lib/systemd/system/openstack-cinder-setup.service" \ + "$ROOT/etc/systemd/system/multi-user.target.wants/openstack-cinder-setup.service" + +########################################################################## +# Check variables +########################################################################## + +if [ -z "$RABBITMQ_HOST" -a \ + -z "$RABBITMQ_PORT" -a \ + -z "$RABBITMQ_USER" -a \ + -z "$RABBITMQ_PASSWORD" -a \ + -z "$KEYSTONE_TEMPORARY_ADMIN_TOKEN" -a \ + -z "$CINDER_DB_USER" -a \ + -z "$CINDER_DB_PASSWORD" -a \ + -z "$CONTROLLER_HOST_ADDRESS" -a \ + -z "$CINDER_USER" -a \ + -z "$CINDER_PASSWORD" -a \ + -z "$CINDER_DEVICE" -a \ + -z "$MANAGEMENT_INTERFACE_IP_ADDRESS" ]; then + # No Cinder options defined, do nothing. + exit 0 +fi + +if [ -z "$RABBITMQ_HOST" -o \ + -z "$RABBITMQ_PORT" -o \ + -z "$RABBITMQ_USER" -o \ + -z "$RABBITMQ_PASSWORD" -o \ + -z "$KEYSTONE_TEMPORARY_ADMIN_TOKEN" -o \ + -z "$CINDER_DB_USER" -o \ + -z "$CINDER_DB_PASSWORD" -o \ + -z "$CONTROLLER_HOST_ADDRESS" -o \ + -z "$CINDER_USER" -o \ + -z "$CINDER_PASSWORD" -o \ + -z "$CINDER_DEVICE" -o \ + -z "$MANAGEMENT_INTERFACE_IP_ADDRESS" ]; then + echo Some options required for Cinder were defined, but not all. + exit 1 +fi + +########################################################################## +# Generate configuration file +########################################################################## + +OPENSTACK_DATA="$ROOT/etc/openstack" +mkdir -p "$OPENSTACK_DATA" + +python <<'EOF' >"$OPENSTACK_DATA/cinder.conf" +import os, sys, yaml + +cinder_configuration={ + 'RABBITMQ_HOST':os.environ['RABBITMQ_HOST'], + 'RABBITMQ_PORT':os.environ['RABBITMQ_PORT'], + 'RABBITMQ_USER':os.environ['RABBITMQ_USER'], + 'RABBITMQ_PASSWORD':os.environ['RABBITMQ_PASSWORD'], + 'KEYSTONE_TEMPORARY_ADMIN_TOKEN':os.environ['KEYSTONE_TEMPORARY_ADMIN_TOKEN'], + 'CINDER_DB_USER':os.environ['CINDER_DB_USER'], + 'CINDER_DB_PASSWORD':os.environ['CINDER_DB_PASSWORD'], + 'CONTROLLER_HOST_ADDRESS':os.environ['CONTROLLER_HOST_ADDRESS'], + 'CINDER_USER':os.environ['CINDER_USER'], + 'CINDER_PASSWORD':os.environ['CINDER_PASSWORD'], + 'CINDER_DEVICE':os.environ['CINDER_DEVICE'], + 'MANAGEMENT_INTERFACE_IP_ADDRESS':os.environ['MANAGEMENT_INTERFACE_IP_ADDRESS'], +} + +yaml.dump(cinder_configuration, sys.stdout, default_flow_style=False) +EOF diff --git a/systems/openstack-server.morph b/systems/openstack-server.morph index cec51aa3..1b53df06 100644 --- a/systems/openstack-server.morph +++ b/systems/openstack-server.morph @@ -65,3 +65,4 @@ configuration-extensions: - hosts - openstack-keystone - openstack-glance +- openstack-cinder |