openstack-ansible-os_designate/tasks/designate_post_install.yml

99 lines
3.3 KiB
YAML

---
# Copyright 2016, Tata Consultancy Services
#
# 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.
- name: Get project id for managed resources
delegate_to: "{{ designate_service_setup_host }}"
vars:
ansible_python_interpreter: >-
{{ (designate_service_setup_host == 'localhost') | ternary(ansible_playbook_python, ansible_python['executable']) }}
os_project_facts:
cloud: default
name: "{{ designate_managed_resource_project_name }}"
interface: internal
validate_certs: "{{ not (keystone_service_internaluri_insecure | bool) }}"
register: _get_managed_resource_project
until: _get_managed_resource_project is success
retries: 5
delay: 15
- name: Store project id for managed resources
set_fact:
designate_managed_resource_tenant_id: "{{ ansible_facts.openstack_projects[0].id }}"
- name: Copy designate config
config_template:
src: "{{ item.src }}"
dest: "{{ item.dest }}"
owner: "{{ item.owner|default(designate_system_user_name) }}"
group: "{{ item.group|default(designate_system_group_name) }}"
mode: "0644"
config_overrides: "{{ item.config_overrides }}"
config_type: "{{ item.config_type }}"
with_items:
- src: "designate.conf.j2"
dest: "/etc/designate/designate.conf"
config_overrides: "{{ designate_designate_conf_overrides }}"
config_type: "ini"
- src: "api-paste.ini.j2"
dest: "/etc/designate/api-paste.ini"
config_overrides: "{{ designate_api_paste_ini_overrides }}"
config_type: "ini"
- src: "policy.json.j2"
dest: "/etc/designate/policy.json-{{ designate_venv_tag }}"
config_overrides: "{{ designate_policy_overrides }}"
config_type: "json"
- src: "rootwrap.conf.j2"
dest: "/etc/designate/rootwrap.conf"
owner: "root"
group: "root"
config_overrides: "{{ designate_rootwrap_conf_overrides }}"
config_type: "ini"
notify: Restart designate services
- name: Create Designate pools.yaml file
copy:
content: "{{ designate_pools_yaml | to_nice_yaml }}"
dest: "/etc/designate/pools.yaml"
when: designate_pools_yaml is defined
- name: Create Designate rndc key file
template:
src: rndc.key.j2
dest: "{{ item.file }}"
owner: "{{ item.owner | default('root') }}"
group: "{{ item.group | default('root') }}"
mode: "{{ item.mode | default('0600') }}"
with_items: "{{ designate_rndc_keys }}"
when: designate_rndc_keys is defined
- name: Copy rootwrap filters
copy:
src: "{{ item }}"
dest: "/etc/designate/rootwrap.d/"
owner: "root"
group: "root"
with_fileglob:
- rootwrap.d/*
notify: Restart designate services
- name: Mask any conflicting units
systemd:
name: "{{ item }}"
state: stopped
enabled: false
masked: true
failed_when: false
with_items: "{{ designate_mask_conflicting_units }}"