You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
100 lines
2.5 KiB
YAML
100 lines
2.5 KiB
YAML
---
|
|
|
|
### tags:
|
|
### update_dns
|
|
### update_networks
|
|
|
|
- name: "Checking present state for server {{ inventory_hostname }}"
|
|
hetzner.hcloud.hcloud_server:
|
|
api_token: "{{ hetzner_authentication_token }}"
|
|
name: "{{ inventory_hostname }}"
|
|
server_type: "{{ hetzner_server_type }}"
|
|
image: "{{ hetzner_server_image }}"
|
|
ssh_keys: "{{ hetzner_ssh_keys }}"
|
|
labels: "{{ hetzner_server_labels }}"
|
|
location: nbg1
|
|
state: present
|
|
delegate_to: 127.0.0.1
|
|
become: false
|
|
|
|
- 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
|
|
become: false
|
|
tags:
|
|
- update_dns
|
|
- update_networks
|
|
|
|
- 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
|
|
become: false
|
|
tags:
|
|
- update_dns
|
|
- update_networks
|
|
|
|
- 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
|
|
become: false
|
|
tags:
|
|
- update_dns
|
|
- update_networks
|
|
|
|
- name: "Printing ip address for {{ inventory_hostname }}"
|
|
debug:
|
|
msg: "{{ stage_server_ip }}"
|
|
delegate_to: 127.0.0.1
|
|
become: false
|
|
tags:
|
|
- update_dns
|
|
- update_networks
|
|
when:
|
|
- debug
|
|
|
|
- name: "Checking present state for firewalls"
|
|
include_tasks: configure-firewall.yml
|
|
vars:
|
|
current_firewall_name: '{{ current_firewall }}'
|
|
with_items:
|
|
- 'default'
|
|
- 'kibana'
|
|
- 'monitoring'
|
|
loop_control:
|
|
loop_var: current_firewall
|
|
tags:
|
|
- update_networks
|
|
|
|
- name: "Checking present state for networks"
|
|
include_tasks: configure-network.yml
|
|
vars:
|
|
current_network_name: '{{ current_network.name }}'
|
|
current_network_labels: 'stage={{ stage }}'
|
|
current_server_label_selector: '{{ current_network.label_selector }}'
|
|
with_items: [
|
|
{
|
|
"name": "{{ stage }}",
|
|
"label_selector": "stage={{ stage }}",
|
|
}
|
|
]
|
|
loop_control:
|
|
loop_var: current_network
|
|
tags:
|
|
- update_networks
|
|
|
|
- name: "Checking present state of dns for {{ inventory_hostname }}"
|
|
include_role:
|
|
name: _digitalocean
|
|
tasks_from: domain
|
|
vars:
|
|
record_data: "{{ stage_server_ip }}"
|
|
record_name: "{{ inventory_hostname }}"
|
|
tags:
|
|
- update_dns
|