From af2195286efa40455e8d8198e86acf25b18d4f65 Mon Sep 17 00:00:00 2001 From: Eduardo Gonzalez Date: Wed, 18 Jan 2017 13:38:47 +0000 Subject: [PATCH] Refactor Designate and Panko bootstrap.yml Change-Id: I39b2800898183c59bf562935725dac6b17704f04 --- ansible/roles/designate/tasks/bootstrap.yml | 101 ++++++-------------- ansible/roles/panko/tasks/bootstrap.yml | 66 +++++-------- 2 files changed, 53 insertions(+), 114 deletions(-) diff --git a/ansible/roles/designate/tasks/bootstrap.yml b/ansible/roles/designate/tasks/bootstrap.yml index 09bc6ceafb..30d52840fe 100644 --- a/ansible/roles/designate/tasks/bootstrap.yml +++ b/ansible/roles/designate/tasks/bootstrap.yml @@ -1,79 +1,40 @@ --- -- name: Creating Designate database - command: docker exec -t kolla_toolbox /usr/bin/ansible localhost - -m mysql_db - -a "login_host='{{ database_address }}' - login_port='{{ database_port }}' - login_user='{{ database_user }}' - login_password='{{ database_password }}' - name='{{ designate_database_name }}'" +- name: Creating Designate databases + kolla_toolbox: + module_name: mysql_db + module_args: + login_host: "{{ database_address }}" + login_port: "{{ database_port }}" + login_user: "{{ database_user }}" + login_password: "{{ database_password }}" + name: "{{ item }}" register: database - changed_when: "{{ database.stdout.find('localhost | SUCCESS => ') != -1 and - (database.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}" - failed_when: database.stdout.split()[2] != 'SUCCESS' run_once: True delegate_to: "{{ groups['designate-central'][0] }}" + with_items: + - "{{ designate_database_name }}" + - "{{ designate_pool_manager_database_name }}" -- name: Reading json from variable - set_fact: - database_created: "{{ (database.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}" - -- name: Creating Designate Pool Manager database - command: docker exec -t kolla_toolbox /usr/bin/ansible localhost - -m mysql_db - -a "login_host='{{ database_address }}' - login_port='{{ database_port }}' - login_user='{{ database_user }}' - login_password='{{ database_password }}' - name='{{ designate_pool_manager_database_name }}'" - register: database_pool_manager - changed_when: "{{ database.stdout.find('localhost | SUCCESS => ') != -1 and - (database.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}" - failed_when: database.stdout.split()[2] != 'SUCCESS' - run_once: True - delegate_to: "{{ groups['designate-central'][0] }}" - -- name: Reading json from variable - set_fact: - database_pool_manager_created: "{{ (database_pool_manager.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}" - -- name: Creating Designate database user and setting permissions - command: docker exec -t kolla_toolbox /usr/bin/ansible localhost - -m mysql_user - -a "login_host='{{ database_address }}' - login_port='{{ database_port }}' - login_user='{{ database_user }}' - login_password='{{ database_password }}' - name='{{ designate_database_name }}' - password='{{ designate_database_password }}' - host='%' - priv='{{ designate_database_name }}.*:ALL' - append_privs='yes'" - register: database_user_create - changed_when: "{{ database_user_create.stdout.find('localhost | SUCCESS => ') != -1 and - (database_user_create.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}" - failed_when: database_user_create.stdout.split()[2] != 'SUCCESS' - run_once: True - delegate_to: "{{ groups['designate-central'][0] }}" - -- name: Creating Designate Pool Manager database user and setting permissions - command: docker exec -t kolla_toolbox /usr/bin/ansible localhost - -m mysql_user - -a "login_host='{{ database_address }}' - login_port='{{ database_port }}' - login_user='{{ database_user }}' - login_password='{{ database_password }}' - name='{{ designate_pool_manager_database_name }}' - password='{{ designate_pool_manager_database_password }}' - host='%' - priv='{{ designate_pool_manager_database_name }}.*:ALL' - append_privs='yes'" - register: database_pool_manager_user_create - changed_when: "{{ database_pool_manager_user_create.stdout.find('localhost | SUCCESS => ') != -1 and - (database_pool_manager_user_create.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}" - failed_when: database_pool_manager_user_create.stdout.split()[2] != 'SUCCESS' +- name: Creating Designate databases user and setting permissions + kolla_toolbox: + module_name: mysql_user + module_args: + login_host: "{{ database_address }}" + login_port: "{{ database_port }}" + login_user: "{{ database_user }}" + login_password: "{{ database_password }}" + name: "{{ item.database_name }}" + password: "{{ item.database_password }}" + host: "%" + priv: "{{ item.database_name }}.*:ALL" + append_privs: "yes" run_once: True delegate_to: "{{ groups['designate-central'][0] }}" + with_items: + - database_name: "{{ designate_database_name }}" + database_password: "{{ designate_database_password }}" + - database_name: "{{ designate_pool_manager_database_name }}" + database_password: "{{ designate_pool_manager_database_password }}" - include: bootstrap_service.yml - when: database_created + when: database.changed diff --git a/ansible/roles/panko/tasks/bootstrap.yml b/ansible/roles/panko/tasks/bootstrap.yml index 8412c333a2..7870011ba3 100644 --- a/ansible/roles/panko/tasks/bootstrap.yml +++ b/ansible/roles/panko/tasks/bootstrap.yml @@ -10,60 +10,38 @@ when: - panko_database_type == "mongodb" -- name: Checking Panko mysql database - command: docker exec -t kolla_toolbox /usr/bin/ansible localhost - -m mysql_db - -a "login_host='{{ panko_database_mysql_address }}' - login_port='{{ panko_database_port }}' - login_user='{{ panko_database_user }}' - login_password='{{ panko_database_password }}' - name='{{ panko_database_name }}'" - register: mysql_access - failed_when: False - changed_when: False - run_once: True - when: - - panko_database_type == "mysql" - -- name: Creating panko mysql database - command: docker exec -t kolla_toolbox /usr/bin/ansible localhost - -m mysql_db - -a "login_host='{{ panko_database_mysql_address }}' - login_port='{{ panko_database_port }}' - login_user='{{ database_user }}' - login_password='{{ database_password }}' - name='{{ panko_database_name }}'" +- name: Creating Panko mysql database + kolla_toolbox: + module_name: mysql_db + module_args: + login_host: "{{ panko_database_mysql_address }}" + login_port: "{{ panko_database_port }}" + login_user: "{{ database_user }}" + login_password: "{{ database_password }}" + name: "{{ panko_database_name }}" register: mysql_panko_database - changed_when: "{{ mysql_panko_database.stdout.find('localhost | SUCCESS => ') != -1 and - (mysql_panko_database.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}" - failed_when: mysql_panko_database.stdout.split()[2] != 'SUCCESS' run_once: True delegate_to: "{{ groups['panko-api'][0] }}" when: - panko_database_type == "mysql" - - "'FAILED' in mysql_access.stdout" -- name: Creating panko database user and setting permissions - command: docker exec -t kolla_toolbox /usr/bin/ansible localhost - -m mysql_user - -a "login_host='{{ panko_database_mysql_address }}' - login_port='{{ panko_database_port }}' - login_user='{{ database_user }}' - login_password='{{ database_password }}' - name='{{ panko_database_name }}' - password='{{ panko_database_password }}' - host='%' - priv='{{ panko_database_name }}.*:ALL' - append_privs='yes'" - register: database_user_create - changed_when: "{{ database_user_create.stdout.find('localhost | SUCCESS => ') != -1 and - (database_user_create.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}" - failed_when: database_user_create.stdout.split()[2] != 'SUCCESS' +- name: Creating Panko mysql database user and setting permissions + kolla_toolbox: + module_name: mysql_user + module_args: + login_host: "{{ panko_database_mysql_address }}" + login_port: "{{ panko_database_port }}" + login_user: "{{ database_user }}" + login_password: "{{ database_password }}" + name: "{{ panko_database_name }}" + password: "{{ panko_database_password }}" + host: "%" + priv: "{{ panko_database_name }}.*:ALL" + append_privs: "yes" run_once: True delegate_to: "{{ groups['panko-api'][0] }}" when: - panko_database_type == "mysql" - - "'FAILED' in mysql_access.stdout" - include: bootstrap_service.yml when: ((panko_database_type == "mongodb" and mongodb_panko_database.changed)