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

48 lines
1.9 KiB
YAML

---
- name: Creating Panko MongoDB database
command: docker exec -t mongodb mongo --host {{ 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: "{{ 'already' not in mongodb_panko_database.stdout }}"
failed_when: "{{ mongodb_panko_database.rc != 0 or 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: "{{ 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
run_once: True
delegate_to: "{{ groups['panko-api'][0] }}"
when:
- panko_database_type == "mysql"
- 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"
- include: bootstrap_service.yml
when: (panko_database_type == "mongodb" and mongodb_panko_database.changed)
or (panko_database_type == "mysql" and mysql_panko_database.changed)