54a4e496b9
We are having all machines in DNS and want to be able to change IP addresses in DNS. So we do not use ansible_host in our host_vars/machine.yml As os_keystone is the first Ansible role we use. We will make similar changes to other roles later on. Change-Id: Ic9f43cc3f6b62b5098e85afcf55f008c022517f6
72 lines
3.0 KiB
Django/Jinja
72 lines
3.0 KiB
Django/Jinja
#!/usr/bin/env bash
|
|
# Copyright 2016, Rackspace US, Inc.
|
|
#
|
|
# 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.
|
|
|
|
# {{ ansible_managed }}
|
|
|
|
# This script is being created with mode 0755 intentionally. This is so that the
|
|
# script can be executed by root to rotate the keys as needed. The script being
|
|
# executed will always change it's user context to the keystone user before
|
|
# execution and while the script may be world read/executable its contains only
|
|
# the necessary bits that are required to run the rotate and sync commands.
|
|
|
|
function autorotate {
|
|
# Ensure all credentials are encrypted with the newest primary key so the rotation doesn't fail.
|
|
{{ keystone_bin }}/keystone-manage credential_migrate \
|
|
--keystone-user "{{ keystone_system_user_name }}" \
|
|
--keystone-group "{{ keystone_system_group_name }}"
|
|
|
|
# Rotate the keys
|
|
{{ keystone_bin }}/keystone-manage credential_rotate \
|
|
--keystone-user "{{ keystone_system_user_name }}" \
|
|
--keystone-group "{{ keystone_system_group_name }}"
|
|
|
|
# Ensure all credentials are encrypted with the new primary key
|
|
{{ keystone_bin }}/keystone-manage credential_migrate \
|
|
--keystone-user "{{ keystone_system_user_name }}" \
|
|
--keystone-group "{{ keystone_system_group_name }}"
|
|
|
|
{% for host in groups['keystone_all'] %}
|
|
|
|
{% if inventory_hostname != host %}
|
|
{% if 'ansible_host' in hostvars[host] %}
|
|
{% set destination_host = hostvars[host]['ansible_host'] %}
|
|
{% else %}
|
|
{% set destination_host = inventory_hostname %}
|
|
{% endif %}
|
|
# Fernet sync job to "{{ host }}"
|
|
rsync -e 'ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no' \
|
|
-avz \
|
|
--delete \
|
|
{{ keystone_credential_key_repository }}/ \
|
|
{{ keystone_system_user_name }}@{{ destination_host }}:{{ keystone_credential_key_repository }}/
|
|
|
|
{%- endif %}
|
|
|
|
{%- endfor %}
|
|
|
|
}
|
|
|
|
if [ "$(id -u)" == "0" ];then
|
|
# Change the script context to always execute as the "{{ keystone_system_user_name }}" user.
|
|
su - "{{ keystone_system_user_name }}" -s "/bin/bash" -c bash << EOC
|
|
{{ keystone_credential_auto_rotation_script }}
|
|
EOC
|
|
elif [ "$(whoami)" == "{{ keystone_system_user_name }}" ];then
|
|
logger $(autorotate)
|
|
else
|
|
echo "Failed - you do not have permission to rotate, or you've executed the job as the wrong user."
|
|
exit 99
|
|
fi
|