1f75555cd1
This patch set allows for searching the trustee user in a specified domain rather than just the "default" domain. Change-Id: I53ee6816e02c25e577244015fe5aea0870e0fd32 Signed-off-by: Tin Lam <tin@irrational.io>
51 lines
1.9 KiB
Smarty
51 lines
1.9 KiB
Smarty
# Copyright 2017 The Openstack-Helm Authors.
|
|
#
|
|
# 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.
|
|
|
|
#!/bin/bash
|
|
|
|
set -ex
|
|
|
|
# Get IDs for filtering
|
|
OS_PROJECT_ID=$(openstack project show -f value -c id ${OS_PROJECT_NAME})
|
|
OS_USER_ID=$(openstack user show -f value -c id ${OS_USERNAME})
|
|
SERVICE_OS_TRUSTEE_ID=$(openstack user show -f value -c id --domain ${SERVICE_OS_TRUSTEE_DOMAIN} ${SERVICE_OS_TRUSTEE})
|
|
|
|
# Check if trust doesn't already exist
|
|
openstack trust list -f value -c "Project ID" \
|
|
-c "Trustee User ID" -c "Trustor User ID" | \
|
|
grep "^${OS_PROJECT_ID} ${SERVICE_OS_TRUSTEE_ID} ${OS_USER_ID}$" && \
|
|
exit 0
|
|
|
|
# If there are no roles specified...
|
|
if [ -z "${SERVICE_OS_ROLES}" ]; then
|
|
# ...Heat will try to delegate all of the roles that user has in the
|
|
# project. Let's fetch them all and use that.
|
|
readarray -t roles < <(openstack role assignment list -f value \
|
|
-c "Role" --user="${OS_USERNAME}" --project="${OS_PROJECT_ID}")
|
|
else
|
|
# Split roles into an array
|
|
IFS=',' read -r -a roles <<< "${SERVICE_OS_ROLES}"
|
|
fi
|
|
|
|
# Create trust between trustor and trustee
|
|
SERVICE_OS_TRUST_ID=$(openstack trust create -f value -c id \
|
|
--project="${OS_PROJECT_NAME}" \
|
|
${roles[@]/#/--role=} \
|
|
--trustee-domain="${SERVICE_OS_TRUSTEE_DOMAIN}" \
|
|
"${OS_USERNAME}" \
|
|
"${SERVICE_OS_TRUSTEE}")
|
|
|
|
# Display trust
|
|
openstack trust show "${SERVICE_OS_TRUST_ID}"
|