/home/zuul/src/opendev.org/openstack/openstack-ansible-os_designate/tasks/designate_post_install.yml
---
# 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: "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: Implement policy.json if there are overrides configured
  copy:
    content: "{{ designate_policy_overrides | to_nice_json }}"
    dest: "/etc/designate/policy.json-{{ designate_venv_tag }}"
  when:
    - designate_policy_overrides != {}

- 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