kolla-ansible/ansible/roles/panko/tasks/bootstrap.yml

51 lines
2.0 KiB
YAML

---
- name: Creating Panko MongoDB database
command: docker exec -t mongodb mongo --host {{ mongodb_replication_set_name }}/{{ panko_database_mongodb_address }} --eval 'db = db.getSiblingDB("{{ panko_database_name }}"); db.createUser({user':' "{{ panko_database_user }}", pwd':' "{{ panko_database_password }}", roles':' [ "readWrite", "dbAdmin" ]})'
register: mongodb_panko_database
run_once: true
changed_when: mongodb_panko_database.stdout.find('already') == -1
failed_when: mongodb_panko_database.stdout.split()[4] != 'connecting'
delegate_to: "{{ groups['mongodb'][0] }}"
when:
- panko_database_type == "mongodb"
- name: Creating Panko mysql database
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: "{{ panko_database_name }}"
register: mysql_panko_database
run_once: True
delegate_to: "{{ groups['panko-api'][0] }}"
when:
- not use_preconfigured_databases | bool
- panko_database_type == "mysql"
- name: Creating Panko mysql database 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: "{{ panko_database_user }}"
password: "{{ panko_database_password }}"
host: "%"
priv: "{{ panko_database_name }}.*:ALL"
append_privs: "yes"
run_once: True
delegate_to: "{{ groups['panko-api'][0] }}"
when:
- not use_preconfigured_databases | bool
- panko_database_type == "mysql"
- include_tasks: bootstrap_service.yml
when: (panko_database_type == "mongodb" and mongodb_panko_database.changed)
or (panko_database_type == "mysql" and mysql_panko_database.changed)
or use_preconfigured_databases | bool