---
- 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
  failed_when:
    - "'already' not in mongodb_panko_database.stdout"
    - 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)