blob: 1d6bcc0b0b90219483699febdbe7079f27cd2787 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
|
---
# file: roles/consul/tasks/main.yaml
- name: Inst - Update Repositories Cache
apt:
update_cache: true
when:
- ansible_os_family == 'Debian'
tags:
- consul-inst-package
- name: Inst - Dependencies
apt:
name: "{{ packages | flatten(levels=1) }}"
state: "present"
cache_valid_time: 3600
install_recommends: false
when:
- ansible_os_family == 'Debian'
tags:
- consul-inst-dependencies
- name: Conf - Add Consul Group
group:
name: "{{ consul_group }}"
state: "{{ consul_group_state }}"
tags:
- consul-conf-user
- name: Conf - Add Consul user
user:
name: "{{ consul_user }}"
group: "{{ consul_group }}"
state: "{{ consul_user_state }}"
system: true
tags:
- consul-conf-user
- name: Inst - Download Consul
get_url:
url: "{{ consul_zip_url }}"
dest: "{{ consul_inst_dir }}/{{ consul_pkg }}"
tags:
- consul-inst-package
- name: Inst - Clean Consul
file:
path: "{{ consul_inst_dir }}/consul"
state: "absent"
when:
- consul_force_update | bool
tags:
- consul-inst-package
- name: Inst - Unarchive Consul
unarchive:
src: "{{ consul_inst_dir }}/{{ consul_pkg }}"
dest: "{{ consul_inst_dir }}/"
remote_src: true
tags:
- consul-inst-package
- name: Inst - Consul
copy:
src: "{{ consul_inst_dir }}/consul"
dest: "{{ consul_bin_dir }}"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
force: true
mode: 0755
remote_src: true
tags:
- consul-inst-package
- name: Conf - Create Directories "{{ consul_data_dir }}"
file:
dest: "{{ consul_data_dir }}"
state: directory
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
tags:
- consul-conf
- name: Conf - Create Directories "{{ consul_ssl_dir }}"
file:
dest: "{{ consul_ssl_dir }}"
state: directory
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
tags:
- consul-conf
- name: Conf - Create Config Directory
file:
dest: "{{ consul_config_dir }}"
state: directory
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0755
tags:
- consul-conf
- name: Conf - Base Configuration
template:
src: base.hcl.j2
dest: "{{ consul_config_dir }}/base.hcl"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0644
tags:
- consul-conf
- name: Conf - Ports Configuration
template:
src: ports.hcl.j2
dest: "{{ consul_config_dir }}/ports.hcl"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0644
tags:
- consul-conf
- name: Conf - Telemetry Configuration
template:
src: telemetry.hcl.j2
dest: "{{ consul_config_dir }}/telemetry.hcl"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0644
tags:
- consul-conf
- name: Conf - Services Configuration
template:
src: services.json.j2
dest: "{{ consul_config_dir }}/services.json"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0644
when:
- consul_services
tags:
- consul-conf
- name: Conf - Copy Certificates And Keys
copy:
content: "{{ item.src }}"
dest: "{{ item.dest }}"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0600
no_log: true
loop: "{{ consul_certificates | flatten(levels=1) }}"
when:
- consul_certificates is defined
tags:
- consul-conf
- name: Conf - Stop Systemd-resolved
systemd:
daemon_reload: true
enabled: false
name: "systemd-resolved"
state: "{{ systemd_resolved_state }}"
when:
- consul_service_mgr == "systemd"
tags:
- consul-conf
- name: Conf - System.d Script
template:
src: "consul_systemd.service.j2"
dest: "/lib/systemd/system/consul.service"
owner: "root"
group: "root"
mode: 0644
notify:
- "Restart Consul"
- "Restart Nomad"
when:
- consul_service_mgr == "systemd"
tags:
- consul-conf
- name: Meta - Flush handlers
meta: flush_handlers
|