SMARCH-89: feat: added setup for connect wordpress with database dump
parent
b01ae836f5
commit
7f4b338477
@ -0,0 +1,77 @@
|
||||
---
|
||||
# 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.
|
||||
|
||||
|
||||
#############################################################
|
||||
# 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 }}-{{ cluster_name }}-{{ '%02d' | format(item|int) }}"
|
||||
groups:
|
||||
- "stage_{{ stage }}"
|
||||
- "upload_local_file"
|
||||
- "import_maria_database"
|
||||
with_sequence: start=1 end={{ cluster_size | default(1) }}
|
||||
changed_when: False
|
||||
|
||||
|
||||
#############################################################
|
||||
# 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: "'upload_local_file' in group_names and upload_file is defined"
|
||||
- role: import-maria-database
|
||||
when: "'import_maria_database' in group_names and target_database is defined and uploaded_file is defined"
|
||||
@ -1,40 +0,0 @@
|
||||
---
|
||||
|
||||
wordpress_mysql_root_password: "wordpress-mysql-root-password"
|
||||
wordpress_mysql_database: "wordpress-mysql"
|
||||
wordpress_mysql_username: "wordpress-mysql-admin"
|
||||
wordpress_mysql_password: "wordpress-mysql-admin"
|
||||
|
||||
wordpress_domain_external: "{{ http_s }}://{{ stage_server_url_host }}"
|
||||
|
||||
wordpress_client_id: "{{ cluster_name }}"
|
||||
wordpress_buergerportal_username: "wordpress-admin"
|
||||
wordpress_buergerportal_password: "wordpress-admin"
|
||||
|
||||
current_realm_users: [
|
||||
{
|
||||
"username": "{{ wordpress_buergerportal_username }}",
|
||||
"password": "{{ wordpress_buergerportal_password }}",
|
||||
}
|
||||
]
|
||||
|
||||
current_realm_clients: [
|
||||
{
|
||||
clientId: "{{ wordpress_client_id }}",
|
||||
name: '{{ wordpress_client_id }}',
|
||||
admin_url: '',
|
||||
root_url: '',
|
||||
redirect_uris: '
|
||||
[
|
||||
"https://{{ service_name }}.{{ domain }}/*",
|
||||
]',
|
||||
secret: '{{ cluster_name }}',
|
||||
web_origins: '
|
||||
[
|
||||
"https://{{ service_name }}.{{ domain }}/*",
|
||||
]',
|
||||
}
|
||||
]
|
||||
|
||||
wordpress_oidc_client_id: "{{ wordpress_client_id }}"
|
||||
wordpress_oidc_client_secret: "{{ cluster_name }}"
|
||||
@ -0,0 +1,3 @@
|
||||
---
|
||||
wordpress_image_name: "{{ shared_service_docker_registry_hostname }}/smardigo/wordpress"
|
||||
wordpress_image_version: '1.3.0'
|
||||
@ -0,0 +1,3 @@
|
||||
---
|
||||
upload_directory: /tmp
|
||||
|
||||
@ -0,0 +1 @@
|
||||
---
|
||||
@ -0,0 +1 @@
|
||||
---
|
||||
@ -0,0 +1,42 @@
|
||||
---
|
||||
|
||||
- name: "Send mattermost message"
|
||||
uri:
|
||||
url: "{{ mattermost_hook_smardigo }}"
|
||||
method: POST
|
||||
body: "{{ lookup('template','mattermost-deploy-start.json.j2') }}"
|
||||
body_format: json
|
||||
headers:
|
||||
Content-Type: "application/json"
|
||||
delegate_to: 127.0.0.1
|
||||
become: false
|
||||
when:
|
||||
- send_status_messages # TODO: Message Refactor :')
|
||||
|
||||
- name: "Destroy {{ target_database }}"
|
||||
community.mysql.mysql_db:
|
||||
name: "{{ target_database }}"
|
||||
state: absent
|
||||
config_file: "/etc/mysql/mariadb.conf.d/50-client.cnf"
|
||||
login_password: "{{ mysql_root_password }}"
|
||||
|
||||
- name: "Import database from {{ upload_directory }}/{{ uploaded_file }} to {{ target_database }}"
|
||||
community.mysql.mysql_db:
|
||||
name: "{{ target_database }}"
|
||||
state: import
|
||||
target: "/tmp/{{ uploaded_file }}"
|
||||
config_file: "/etc/mysql/mariadb.conf.d/50-client.cnf"
|
||||
login_password: "{{ mysql_root_password }}"
|
||||
|
||||
- name: "Send mattermost message"
|
||||
uri:
|
||||
url: "{{ mattermost_hook_smardigo }}"
|
||||
method: POST
|
||||
body: "{{ lookup('template','mattermost-deploy-end.json.j2') }}"
|
||||
body_format: json
|
||||
headers:
|
||||
Content-Type: "application/json"
|
||||
delegate_to: 127.0.0.1
|
||||
become: false
|
||||
when:
|
||||
- send_status_messages # TODO: Message Refactor :')
|
||||
@ -0,0 +1,2 @@
|
||||
---
|
||||
|
||||
@ -0,0 +1,3 @@
|
||||
---
|
||||
upload_directory: /tmp
|
||||
|
||||
@ -0,0 +1 @@
|
||||
---
|
||||
@ -0,0 +1 @@
|
||||
---
|
||||
@ -0,0 +1,33 @@
|
||||
---
|
||||
|
||||
- name: "Send mattermost message"
|
||||
uri:
|
||||
url: "{{ mattermost_hook_smardigo }}"
|
||||
method: POST
|
||||
body: "{{ lookup('template','mattermost-deploy-start.json.j2') }}"
|
||||
body_format: json
|
||||
headers:
|
||||
Content-Type: "application/json"
|
||||
delegate_to: 127.0.0.1
|
||||
become: false
|
||||
when:
|
||||
- send_status_messages # TODO: Message Refactor :')
|
||||
|
||||
- name: "Copy file to remote locations {{ upload_directory }}/{{ upload_file | basename }}"
|
||||
copy:
|
||||
src: "{{ upload_file }}"
|
||||
dest: "{{ upload_directory }}/{{ upload_file | basename }}"
|
||||
mode: 0644
|
||||
|
||||
- name: "Send mattermost message"
|
||||
uri:
|
||||
url: "{{ mattermost_hook_smardigo }}"
|
||||
method: POST
|
||||
body: "{{ lookup('template','mattermost-deploy-end.json.j2') }}"
|
||||
body_format: json
|
||||
headers:
|
||||
Content-Type: "application/json"
|
||||
delegate_to: 127.0.0.1
|
||||
become: false
|
||||
when:
|
||||
- send_status_messages # TODO: Message Refactor :')
|
||||
@ -0,0 +1,2 @@
|
||||
---
|
||||
|
||||
@ -1,10 +0,0 @@
|
||||
---
|
||||
|
||||
wordpress_image_name: "wordpress"
|
||||
wordpress_image_version: '5.7.2'
|
||||
|
||||
wordpress_mysql_image_name: "mysql"
|
||||
wordpress_mysql_image_version: "8.0.22"
|
||||
|
||||
wordpress_admin_username: "wordpress-admin"
|
||||
wordpress_admin_password: "wordpress-admin"
|
||||
Loading…
Reference in New Issue