xoxys.openvpn_client/tasks/setup.yml
Robert Kaussow efc4ede1dc
All checks were successful
continuous-integration/drone/push Build is passing
refactor: use generic ansible modules service and package
2021-06-05 15:30:43 +02:00

67 lines
1.8 KiB
YAML

---
- block:
- name: Install dependencies
package:
name: "{{ item }}"
state: present
loop: "{{ openvpn_client_packages_extra }}"
- name: Install required packages
package:
name: "{{ item }}"
state: present
loop:
- openvpn
- name: Write client config
template:
src: etc/openvpn/client.conf.j2
dest: "/etc/openvpn/{{ openvpn_client_name }}.conf"
mode: 0600
notify: __openvpn_restart
- name: Create certs folder
file:
path: /etc/openvpn/certs
state: directory
mode: 0750
- name: Copy cert files (if defined)
copy:
src: "{{ item.src }}"
dest: "{{ item.dest }}"
mode: "{{ item.mode }}"
loop:
- {
src: "{{ openvpn_client_ca_source | default('') }}",
dest: "/etc/openvpn/certs/{{ openvpn_client_ca_file }}",
mode: "0640",
}
- {
src: "{{ openvpn_client_cert_source | default('') }}",
dest: "/etc/openvpn/certs/{{ openvpn_client_cert_file }}",
mode: "0640",
}
- {
src: "{{ openvpn_client_key_source | default('') }}",
dest: "/etc/openvpn/certs/{{ openvpn_client_key_file }}",
mode: "0600",
}
- {
src: "{{ openvpn_client_ta_source | default('') }}",
dest: "/etc/openvpn/certs/{{ openvpn_client_ta_file }}",
mode: "0600",
}
loop_control:
label: "{{ item.dest }}"
when: item.src | length > 0
notify: __openvpn_restart
- name: Ensure openvpn service is up and running
service:
name: "openvpn@{{ openvpn_client_name }}"
state: "{{ openvpn_service_state }}"
enabled: yes
become: True
become_user: root