DEV-720 Recreate feature branch for new playbook
parent
96da6ef83f
commit
b9f753fa92
@ -0,0 +1,96 @@
|
||||
|
||||
---
|
||||
|
||||
# This playbook dumps all ip addresses from Hetzner Cloud saving it into local file.
|
||||
# A prefix "route" will be added, to easily use it within custom ovpn configuration.
|
||||
#
|
||||
# Parameters:
|
||||
# playbook inventory
|
||||
# stage := the name of the stage (e.g. dev, int, qa, prod)
|
||||
# Example:
|
||||
# STAGE=ext && ansible-playbook dump-hcloud-ips.yml -e "stage=${STAGE}" --vault-password-file=~/.ansible-vault-pass-${STAGE}
|
||||
|
||||
#############################################################
|
||||
# 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 }})"
|
||||
|
||||
# Add virtual server to load stage specific variables as context
|
||||
- name: "Add <{{ stage }}-virtual-host-to-read-groups-vars> to hosts"
|
||||
add_host:
|
||||
name: "{{ stage }}-virtual-host-to-read-groups-vars"
|
||||
groups:
|
||||
- "stage_{{ stage }}"
|
||||
changed_when: False
|
||||
|
||||
#############################################################
|
||||
# Dumping ip addresses from hcloud with given stage #
|
||||
#############################################################
|
||||
|
||||
- hosts: "{{ stage }}-virtual-host-to-read-groups-vars"
|
||||
serial: "{{ serial_number | default(1) }}"
|
||||
gather_facts: false
|
||||
connection: local
|
||||
|
||||
pre_tasks:
|
||||
- name: "Reading current server groups from hetzner"
|
||||
include_role:
|
||||
name: hcloud
|
||||
tasks_from: _read_server_infos
|
||||
with_items: [
|
||||
{
|
||||
name: "all",
|
||||
label_selector: "stage={{ stage }}",
|
||||
}
|
||||
]
|
||||
loop_control:
|
||||
loop_var: current_server_group
|
||||
|
||||
- name: "Reading info about current loadbalancers from hetzner"
|
||||
include_role:
|
||||
name: hcloud
|
||||
tasks_from: _read_load_balancer_infos
|
||||
with_items: [
|
||||
{
|
||||
name: "all",
|
||||
#label_selector: "stage={{ stage }}", # There are no useful labels at the moment. Todo: Create labels for load balancers like stage=dev
|
||||
}
|
||||
]
|
||||
loop_control:
|
||||
loop_var: current_load_balancer_group
|
||||
|
||||
tasks:
|
||||
- name: 'Save Hetzner Server ip adresses in ~/hcloud_ip_addresses.txt'
|
||||
blockinfile:
|
||||
marker: "## {mark} managed by ansible (hosts config for {{ stage }}) ##"
|
||||
path: '~/hcloud_ip_addresses.txt'
|
||||
state: present
|
||||
create: yes
|
||||
block: |
|
||||
{% for host in server_group_infos_all %}
|
||||
# {{ host.name }}
|
||||
route {{ host.ip }}
|
||||
{% endfor %}
|
||||
|
||||
- name: 'Save Hetzner loadbalancer ip adresses in ~/hcloud_ip_addresses.txt'
|
||||
blockinfile:
|
||||
marker: "## {mark} managed by ansible (load balancer config for {{ stage }}) ##"
|
||||
path: '~/hcloud_ip_addresses.txt'
|
||||
state: present
|
||||
create: yes
|
||||
block: |
|
||||
{% for host in load_balancer_group_infos_all %}
|
||||
# {{ host.name }}
|
||||
route {{ host.ip }}
|
||||
{% endfor %}
|
||||
@ -0,0 +1,31 @@
|
||||
---
|
||||
|
||||
- name: "Gathering current load_balancer infos from hetzner"
|
||||
hetzner.hcloud.hcloud_load_balancer_info:
|
||||
api_token: "{{ hetzner_authentication_ansible }}"
|
||||
#label_selector: "{{ current_load_balancer_group.label_selector }}"
|
||||
register: current_load_balancer_infos
|
||||
delegate_to: 127.0.0.1
|
||||
become: false
|
||||
tags:
|
||||
- update_config
|
||||
|
||||
- name: "Setting loadbalancer group as fact: load_balancer_group_infos_{{ current_load_balancer_group.name }}"
|
||||
set_fact:
|
||||
load_balancer_group_infos_{{ current_load_balancer_group.name }}: "{{ current_load_balancer_infos.hcloud_load_balancer_info | json_query(querystr) }}" # noqa var-naming
|
||||
vars:
|
||||
querystr: "[*].{id: id, name: name, ip: ipv4_address}"
|
||||
delegate_to: 127.0.0.1
|
||||
become: false
|
||||
tags:
|
||||
- update_config
|
||||
|
||||
- name: "Printing load_balancer infos {{ current_load_balancer_infos }}"
|
||||
debug:
|
||||
msg: "{{ current_load_balancer_infos }}"
|
||||
delegate_to: 127.0.0.1
|
||||
become: false
|
||||
tags:
|
||||
- update_config
|
||||
when:
|
||||
- debug
|
||||
Loading…
Reference in New Issue