5d7c92e204
Add support to the keystone devstack plugin for setting enforce_scope in the keystone config and setting up tempest to test it. It may be better to move this to tempest proper at some point. See also: https://review.opendev.org/686073 https://review.opendev.org/698397 Change-Id: I1b71135547b7ce03afb5b44fbbab3f52d213a2ae
72 lines
2.6 KiB
Bash
72 lines
2.6 KiB
Bash
#!/usr/bin/env bash
|
|
# Copyright 2016 Massachusetts Open Cloud
|
|
#
|
|
# 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.
|
|
|
|
KEYSTONE_PLUGIN=$DEST/keystone/devstack
|
|
source $KEYSTONE_PLUGIN/lib/federation.sh
|
|
source $KEYSTONE_PLUGIN/lib/scope.sh
|
|
|
|
# For more information on Devstack plugins, including a more detailed
|
|
# explanation on when the different steps are executed please see:
|
|
# https://docs.openstack.org/devstack/latest/plugins.html
|
|
|
|
if [[ "$1" == "stack" && "$2" == "install" ]]; then
|
|
# This phase is executed after the projects have been installed
|
|
echo "Keystone plugin - Install phase"
|
|
if is_service_enabled keystone-saml2-federation; then
|
|
install_federation
|
|
fi
|
|
|
|
elif [[ "$1" == "stack" && "$2" == "post-config" ]]; then
|
|
# This phase is executed after the projects have been configured and
|
|
# before they are started
|
|
echo "Keystone plugin - Post-config phase"
|
|
if is_service_enabled keystone-saml2-federation; then
|
|
configure_federation
|
|
fi
|
|
|
|
elif [[ "$1" == "stack" && "$2" == "extra" ]]; then
|
|
# This phase is executed after the projects have been started
|
|
echo "Keystone plugin - Extra phase"
|
|
if is_service_enabled keystone-saml2-federation; then
|
|
register_federation
|
|
fi
|
|
elif [[ "$1" == "stack" && "$2" == "test-config" ]]; then
|
|
# This phase is executed after Tempest was configured
|
|
echo "Keystone plugin - Test-config phase"
|
|
if is_service_enabled keystone-saml2-federation; then
|
|
configure_tests_settings
|
|
fi
|
|
if [[ "$(trueorfalse False KEYSTONE_ENFORCE_SCOPE)" == "True" ]] ; then
|
|
# devstack and tempest assume enforce_scope is false, so need to wait
|
|
# until the final phase to turn it on
|
|
configure_enforce_scope
|
|
configure_protection_tests
|
|
fi
|
|
fi
|
|
|
|
if [[ "$1" == "unstack" ]]; then
|
|
# Called by unstack.sh and clean.sh
|
|
# Undo what was performed during the "post-config" and "extra" phases
|
|
:
|
|
fi
|
|
|
|
if [[ "$1" == "clean" ]]; then
|
|
# Called by clean.sh after the "unstack" phase
|
|
# Undo what was performed during the "install" phase
|
|
if is_service_enabled keystone-saml2-federation; then
|
|
uninstall_federation
|
|
fi
|
|
fi
|