openstack-helm/heat/templates/bin/_trusts.sh.tpl
Jean-Philippe Evrard 05d0e2b4b8 Revert "Update OSH Author copyrights to OSF"
This reverts commit b1755c3993.

Change-Id: I215a172f2ff4220340292b95f5323847944baeb7
2018-08-28 17:25:13 +00:00

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}"