--- # Example call: # poetry run ansible-playbook create-db-import.yml --ask-vault-pass -e "cluster_name='maria' cluster_size='1' stage='dev' upload_file='dumps/import.sql' uploaded_file='import.sql' target_database=test01" # How this stuff works: # If `upload_file` is defined the upload role save the binary to `upload_directory` (default /tmp) # If `uploaded_file` and `target_database` are defined the import role imports from file basename `uploaded_file` to `target_database` # If both role conditions match the upload role trigger first. # Parameters: # playbook inventory # stage := the type of the stage (e.g. dev, int, qa, prod) # tenant_id := (unique key for the tenant, e.g. customer) # cluster_name := (business name for the cluster, e.g. product, department ) # cluster_size := (WIP node count for the cluster) (Currently max is 2 master/slave) # cluster_services := (services to setup, e.g. ['connect', 'wordpress', ...]) # upload_file := the local file to upload (e.g. dumps/wordpress_portal.sql) # uploaded_file := the dump file to import (e.g. wordpress_portal.sql) # smardigo message callback # scope_id := (scope id of the management process) # process_instance_id := (process instance id of the management process) # smardigo_management_action := (smardigo management action anme of the management process) ############################################################# # Creating inventory dynamically for given parameters ############################################################# - hosts: localhost connection: local gather_facts: false pre_tasks: - name: "Check if ansible version is at least 2.10.x" assert: that: - ansible_version.major >= 2 - ansible_version.minor >= 10 msg: "The ansible version has to be at least ({{ ansible_version.full }})" tasks: - name: Add hosts add_host: name: "{{ stage }}-maria-01" groups: - "stage_{{ stage }}" - "{{ item }}" cluster_service: "{{ item }}" changed_when: False with_items: "{{ cluster_service }}" when: item in ['connect_wordpress'] ############################################################# # Setup services for created inventory ############################################################# - hosts: "stage_{{ stage }}" serial: "{{ serial_number | default(1) }}" remote_user: root pre_tasks: - name: "Gathering current server infos from hetzner" hcloud_server_info: api_token: "{{ hetzner_authentication_token }}" register: hetzner_server_infos delegate_to: 127.0.0.1 - name: "Setting current server infos as fact: hetzner_server_infos_json" set_fact: hetzner_server_infos_json: "{{ hetzner_server_infos.hcloud_server_info }}" delegate_to: 127.0.0.1 - name: "Reading ip address for {{ inventory_hostname }}" set_fact: stage_server_ip: "{{ hetzner_server_infos_json | json_query(querystr) | first }}" vars: querystr: "[?name=='{{ inventory_hostname }}'].ipv4_address" delegate_to: 127.0.0.1 - name: "Printing ip address for {{ inventory_hostname }}" debug: msg: "{{ stage_server_ip }}" delegate_to: 127.0.0.1 when: - debug roles: - role: upload-local-file when: - "'connect_wordpress' in group_names" - "upload_file is defined" - role: import-maria-database when: - "'connect_wordpress' in group_names" - "target_database is defined" - "uploaded_file is defined" - role: import-maria-database vars: target_database: "{{ connect_wordpress_maria_database }}" when: - "'connect_wordpress' in group_names" - "uploaded_file is defined" ############################################################# # Sending smardigo management message to process ############################################################# - hosts: "stage_{{ stage }}" serial: "{{ serial_number | default(5) }}" connection: local gather_facts: false post_tasks: - name: "Sending smardigo management message <{{ smardigo_management_action }}> to <{{ scope_id }}/{{ process_instance_id }}>" uri: url: "{{ smardigo_management_url }}" method: POST body_format: json body: "{{ lookup('template','smardigo-management-message.json.j2') }}" headers: accept: "*/*" Content-Type: "application/json" Smardigo-User-Token: "{{ smardigo_management_token }}" status_code: [200] delegate_to: 127.0.0.1 retries: 5 delay: 5 when: - scope_id is defined - process_instance_id is defined - smardigo_management_action is defined