Merge "Include extra conf file updates when updating SHA's"
This commit is contained in:
commit
9782bb58b2
@ -47,7 +47,7 @@
|
|||||||
dest: "/etc/aodh/api_paste.ini"
|
dest: "/etc/aodh/api_paste.ini"
|
||||||
config_overrides: "{{ aodh_api_paste_ini_overrides }}"
|
config_overrides: "{{ aodh_api_paste_ini_overrides }}"
|
||||||
config_type: "ini"
|
config_type: "ini"
|
||||||
- src: "policy.json"
|
- src: "policy.json.j2"
|
||||||
dest: "/etc/aodh/policy.json"
|
dest: "/etc/aodh/policy.json"
|
||||||
config_overrides: "{{ aodh_policy_overrides }}"
|
config_overrides: "{{ aodh_policy_overrides }}"
|
||||||
config_type: "json"
|
config_type: "json"
|
||||||
|
@ -43,7 +43,7 @@
|
|||||||
dest: "/etc/ceilometer/pipeline.yaml"
|
dest: "/etc/ceilometer/pipeline.yaml"
|
||||||
config_overrides: "{{ ceilometer_pipeline_yaml_overrides }}"
|
config_overrides: "{{ ceilometer_pipeline_yaml_overrides }}"
|
||||||
config_type: "yaml"
|
config_type: "yaml"
|
||||||
- src: "policy.json"
|
- src: "policy.json.j2"
|
||||||
dest: "/etc/ceilometer/policy.json"
|
dest: "/etc/ceilometer/policy.json"
|
||||||
config_overrides: "{{ ceilometer_policy_overrides }}"
|
config_overrides: "{{ ceilometer_policy_overrides }}"
|
||||||
config_type: "json"
|
config_type: "json"
|
||||||
|
@ -51,7 +51,7 @@
|
|||||||
owner: "{{ cinder_system_user_name }}"
|
owner: "{{ cinder_system_user_name }}"
|
||||||
group: "{{ cinder_system_group_name }}"
|
group: "{{ cinder_system_group_name }}"
|
||||||
with_items:
|
with_items:
|
||||||
- { src: "volume.filters", dest: "/etc/cinder/rootwrap.d/volume.filters" }
|
- { src: "rootwrap.d/volume.filters", dest: "/etc/cinder/rootwrap.d/volume.filters" }
|
||||||
notify:
|
notify:
|
||||||
- Restart cinder services
|
- Restart cinder services
|
||||||
tags:
|
tags:
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
ONLINE_BRANCH=${ONLINE_BRANCH:-"master"}
|
ONLINE_BRANCH=${ONLINE_BRANCH:-"master"}
|
||||||
SERVICE_FILE=${SERVICE_FILE:-"playbooks/defaults/repo_packages/openstack_services.yml"}
|
SERVICE_FILE=${SERVICE_FILE:-"playbooks/defaults/repo_packages/openstack_services.yml"}
|
||||||
|
OPENSTACK_SERVICE_LIST=${OPENSTACK_SERVICE_LIST:-"aodh ceilometer cinder glance heat keystone neutron nova"}
|
||||||
|
|
||||||
IFS=$'\n'
|
IFS=$'\n'
|
||||||
|
|
||||||
@ -51,20 +52,82 @@ shift
|
|||||||
done
|
done
|
||||||
|
|
||||||
# Iterate through the service file
|
# Iterate through the service file
|
||||||
for repo in $(grep 'git_repo\:' ${SERVICE_FILE});do
|
for repo in $(grep 'git_repo\:' ${SERVICE_FILE}); do
|
||||||
|
|
||||||
|
echo -e "\nInspecting ${repo}..."
|
||||||
|
|
||||||
# Set the repo name
|
# Set the repo name
|
||||||
repo_name=$(echo "${repo}" | sed 's/_git_repo\:.*//g')
|
repo_name=$(echo "${repo}" | sed 's/_git_repo\:.*//g')
|
||||||
|
|
||||||
|
# Set the repo address
|
||||||
|
repo_address=$(echo ${repo} | awk '{print $2}')
|
||||||
|
|
||||||
# Get the branch data
|
# Get the branch data
|
||||||
branch_data=$(git ls-remote "$(echo ${repo} | awk '{print $2}')" | grep "${ONLINE_BRANCH}$")
|
branch_data=$(git ls-remote ${repo_address} | grep "${ONLINE_BRANCH}$")
|
||||||
|
|
||||||
# If there is branch data continue
|
# If there is branch data continue
|
||||||
if [ ! -z "${branch_data}" ];then
|
if [ ! -z "${branch_data}" ];then
|
||||||
|
|
||||||
# Set the branch sha for the head of the branch
|
# Set the branch sha for the head of the branch
|
||||||
branch_sha=$(echo "${branch_data}" | awk '{print $1}')
|
branch_sha=$(echo "${branch_data}" | awk '{print $1}')
|
||||||
|
|
||||||
# Set the branch entry
|
# Set the branch entry
|
||||||
branch_entry="${branch_sha} # HEAD of \"$ONLINE_BRANCH\" as of $(date +%d.%m.%Y)"
|
branch_entry="${branch_sha} # HEAD of \"$ONLINE_BRANCH\" as of $(date +%d.%m.%Y)"
|
||||||
# Write the branch entry
|
|
||||||
|
# Write the branch entry into the repo_packages file
|
||||||
sed -i.bak "s|${repo_name}_git_install_branch:.*|${repo_name}_git_install_branch: $branch_entry|" ${SERVICE_FILE}
|
sed -i.bak "s|${repo_name}_git_install_branch:.*|${repo_name}_git_install_branch: $branch_entry|" ${SERVICE_FILE}
|
||||||
echo "processed $repo_name @ $branch_entry"
|
|
||||||
|
# If the repo is in the specified list, then action the additional updates
|
||||||
|
if [[ "${OPENSTACK_SERVICE_LIST}" =~ "${repo_name}" ]]; then
|
||||||
|
repo_tmp_path="/tmp/${repo_name}"
|
||||||
|
|
||||||
|
# Ensure that the temp path doesn't exist
|
||||||
|
rm -rf ${repo_tmp_path}
|
||||||
|
|
||||||
|
# Do a shallow clone of the repo to work with
|
||||||
|
git clone --quiet --depth=1 --origin ${branch_sha} ${repo_address} ${repo_tmp_path}
|
||||||
|
|
||||||
|
# Update the policy files
|
||||||
|
find ${repo_tmp_path}/etc -name "policy.json" -exec \
|
||||||
|
cp {} "playbooks/roles/os_${repo_name}/templates/policy.json.j2" \;
|
||||||
|
|
||||||
|
# Tweak the paste files
|
||||||
|
find ${repo_tmp_path}/etc -name "*-paste.ini" -exec \
|
||||||
|
sed -i.bak "s|hmac_keys = SECRET_KEY|hmac_keys = {{ ${repo_name}_profiler_hmac_key }}|" {} \;
|
||||||
|
|
||||||
|
# Update the paste files
|
||||||
|
find ${repo_tmp_path}/etc -name "*-paste.ini" -exec \
|
||||||
|
bash -c "name=\"{}\"; cp \${name} \"playbooks/roles/os_${repo_name}/templates/\$(basename \${name}).j2\"" \;
|
||||||
|
|
||||||
|
# Tweak the rootwrap conf files
|
||||||
|
find ${repo_tmp_path}/etc -name "rootwrap.conf" -exec \
|
||||||
|
sed -i.bak "s|exec_dirs=|exec_dirs={{ ${repo_name}_bin }},|" {} \;
|
||||||
|
|
||||||
|
# Update the rootwrap conf files
|
||||||
|
find ${repo_tmp_path}/etc -name "rootwrap.conf" -exec \
|
||||||
|
cp {} "playbooks/roles/os_${repo_name}/templates/rootwrap.conf.j2" \;
|
||||||
|
|
||||||
|
# Update the rootwrap filters
|
||||||
|
find ${repo_tmp_path}/etc -name "*.filters" -exec \
|
||||||
|
bash -c "name=\"{}\"; cp \${name} \"playbooks/roles/os_${repo_name}/files/rootwrap.d/\$(basename \${name})\"" \;
|
||||||
|
|
||||||
|
# Update the yaml files for Ceilometer
|
||||||
|
if [ "${repo_name}" = "ceilometer" ]; then
|
||||||
|
find ${repo_tmp_path}/etc -name "*.yaml" -exec \
|
||||||
|
bash -c "name=\"{}\"; cp \${name} \"playbooks/roles/os_${repo_name}/templates/\$(basename \${name}).j2\"" \;
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Update the yaml files for Heat
|
||||||
|
if [ "${repo_name}" = "heat" ]; then
|
||||||
|
find ${repo_tmp_path}/etc -name "*.yaml" -exec \
|
||||||
|
bash -c "name=\"{}\"; cp \${name} \"playbooks/roles/os_${repo_name}/templates/\$(echo \${name} | rev | cut -sd / -f -2 | rev).j2\"" \;
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Clean up the temporary files
|
||||||
|
rm -rf ${repo_tmp_path}
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
echo -e "Processed $repo_name @ $branch_entry\n"
|
||||||
|
|
||||||
done
|
done
|
||||||
|
Loading…
Reference in New Issue
Block a user