add caddy role
This commit is contained in:
parent
d314955501
commit
c9456f3e1f
15 changed files with 367 additions and 0 deletions
33
roles/caddy/defaults/main.yml
Normal file
33
roles/caddy/defaults/main.yml
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
---
|
||||||
|
# defaults file for caddy-ansible
|
||||||
|
caddy_user: www-data
|
||||||
|
caddy_home: /home/caddy
|
||||||
|
caddy_packages: []
|
||||||
|
caddy_update: true
|
||||||
|
caddy_bin_dir: /usr/local/bin
|
||||||
|
caddy_conf_dir: /etc/caddy
|
||||||
|
caddy_github_token: ""
|
||||||
|
caddy_log_dir: /var/log/caddy
|
||||||
|
caddy_log_file: stdout
|
||||||
|
caddy_certs_dir: /etc/ssl/caddy
|
||||||
|
caddy_http2_enabled: "true"
|
||||||
|
# additional cli args to pass to caddy
|
||||||
|
caddy_additional_args: ""
|
||||||
|
caddy_systemd_network_dependency: true
|
||||||
|
caddy_systemd_capabilities_enabled: false
|
||||||
|
caddy_systemd_capabilities: "CAP_NET_BIND_SERVICE"
|
||||||
|
caddy_systemd_restart: "on-failure" # always, on-success, on-failure, on-abnormal, on-abort, on-watchdog
|
||||||
|
caddy_systemd_restart_startlimitinterval: "86400"
|
||||||
|
caddy_systemd_restart_startlimitburst: "5"
|
||||||
|
caddy_systemd_private_tmp: "true"
|
||||||
|
caddy_systemd_private_devices: "true"
|
||||||
|
# Disable this because the git module writes to ~/.ssh
|
||||||
|
caddy_systemd_protect_home: "false"
|
||||||
|
caddy_systemd_protect_system: "full"
|
||||||
|
caddy_systemd_nproc_limit: 0
|
||||||
|
caddy_setcap: true
|
||||||
|
caddy_config: |
|
||||||
|
http://localhost:2020
|
||||||
|
respond "Hello, world!"
|
||||||
|
caddy_environment_variables: {}
|
||||||
|
caddy_os: linux
|
12
roles/caddy/handlers/main.yml
Normal file
12
roles/caddy/handlers/main.yml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
- name: Restart caddy
|
||||||
|
systemd:
|
||||||
|
daemon_reload: true
|
||||||
|
name: caddy
|
||||||
|
state: restarted
|
||||||
|
|
||||||
|
- name: Reload caddy
|
||||||
|
systemd:
|
||||||
|
name: caddy
|
||||||
|
state: reloaded
|
21
roles/caddy/tasks/github-extract.yml
Normal file
21
roles/caddy/tasks/github-extract.yml
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
---
|
||||||
|
- name: Extract Caddy
|
||||||
|
unarchive:
|
||||||
|
src: "{{ caddy_home }}/caddy.tar.gz"
|
||||||
|
dest: "{{ caddy_home }}"
|
||||||
|
copy: false
|
||||||
|
mode: 0644
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
group: "{{ caddy_user_details.group }}"
|
||||||
|
when: caddy_binary_cache.changed
|
||||||
|
tags: skip_ansible_lint
|
||||||
|
|
||||||
|
- name: Extract Caddy
|
||||||
|
unarchive:
|
||||||
|
src: "{{ caddy_home }}/caddy.tar.gz"
|
||||||
|
dest: "{{ caddy_home }}"
|
||||||
|
creates: "{{ caddy_home }}/caddy"
|
||||||
|
copy: false
|
||||||
|
mode: 0644
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
group: "{{ caddy_user_details.group }}"
|
20
roles/caddy/tasks/github-url.yml
Normal file
20
roles/caddy/tasks/github-url.yml
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
---
|
||||||
|
- name: Get latest Caddy release details
|
||||||
|
uri:
|
||||||
|
url: https://api.github.com/repos/mholt/caddy/releases/latest
|
||||||
|
return_content: true
|
||||||
|
headers: '{{ caddy_github_headers }}'
|
||||||
|
register: latest_caddy_release
|
||||||
|
|
||||||
|
- name: Set Caddy tag
|
||||||
|
set_fact:
|
||||||
|
caddy_tag: "{{ (latest_caddy_release.content | from_json).get('tag_name') }}"
|
||||||
|
|
||||||
|
- name: Set Caddy version
|
||||||
|
set_fact:
|
||||||
|
caddy_version: "{{ caddy_tag | regex_replace('^v', '') }}"
|
||||||
|
|
||||||
|
- name: Set Caddy url
|
||||||
|
set_fact:
|
||||||
|
caddy_url: "https://github.com/caddyserver/caddy/releases/download/\
|
||||||
|
{{ caddy_tag }}/caddy_{{ caddy_version }}_{{ caddy_os }}_{{ go_arch }}.tar.gz"
|
134
roles/caddy/tasks/main.yml
Normal file
134
roles/caddy/tasks/main.yml
Normal file
|
@ -0,0 +1,134 @@
|
||||||
|
---
|
||||||
|
- include: preflight.yml
|
||||||
|
- include: packages-{{ ansible_pkg_mgr }}.yml
|
||||||
|
|
||||||
|
- name: Create Caddy user
|
||||||
|
user:
|
||||||
|
name: "{{ caddy_user }}"
|
||||||
|
system: true
|
||||||
|
createhome: true
|
||||||
|
home: "{{ caddy_home }}"
|
||||||
|
register: caddy_user_details
|
||||||
|
|
||||||
|
- name: Build headers to use when making requests to github
|
||||||
|
set_fact:
|
||||||
|
caddy_github_headers: "{{ caddy_github_headers | combine({'Authorization': 'token ' + caddy_github_token}) }}"
|
||||||
|
when: caddy_github_token | length > 0
|
||||||
|
|
||||||
|
- name: Get all Caddy releases
|
||||||
|
get_url:
|
||||||
|
url: https://api.github.com/repos/mholt/caddy/git/refs/tags
|
||||||
|
dest: "{{ caddy_home }}/releases.txt"
|
||||||
|
force: true
|
||||||
|
headers: '{{ caddy_github_headers }}'
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
group: "{{ caddy_user_details.group }}"
|
||||||
|
retries: 3
|
||||||
|
delay: 2
|
||||||
|
when: caddy_update
|
||||||
|
register: caddy_releases_cache
|
||||||
|
|
||||||
|
- name: Set Caddy features
|
||||||
|
copy:
|
||||||
|
content: "{{ ','.join(caddy_packages) }}"
|
||||||
|
dest: "{{ caddy_home }}/features.txt"
|
||||||
|
mode: 0640
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
group: "{{ caddy_user_details.group }}"
|
||||||
|
when: caddy_update
|
||||||
|
register: caddy_features_cache
|
||||||
|
|
||||||
|
- include: github-url.yml
|
||||||
|
when: caddy_use_github
|
||||||
|
|
||||||
|
- name: Download Caddy
|
||||||
|
get_url:
|
||||||
|
url: "{{ caddy_url }}"
|
||||||
|
dest: "{{ caddy_home }}/{{ 'caddy.tar.gz' if caddy_use_github else 'caddy' }}"
|
||||||
|
force: true
|
||||||
|
timeout: 300
|
||||||
|
mode: 0644
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
group: "{{ caddy_user_details.group }}"
|
||||||
|
retries: 3
|
||||||
|
delay: 2
|
||||||
|
when: caddy_releases_cache.changed or caddy_features_cache.changed
|
||||||
|
register: caddy_binary_cache
|
||||||
|
tags: skip_ansible_lint
|
||||||
|
|
||||||
|
- name: Download Caddy
|
||||||
|
get_url:
|
||||||
|
url: "{{ caddy_url }}"
|
||||||
|
dest: "{{ caddy_home }}/{{ 'caddy.tar.gz' if caddy_use_github else 'caddy' }}"
|
||||||
|
timeout: 300
|
||||||
|
mode: 0644
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
group: "{{ caddy_user_details.group }}"
|
||||||
|
retries: 3
|
||||||
|
delay: 2
|
||||||
|
register: caddy_download
|
||||||
|
tags: skip_ansible_lint
|
||||||
|
|
||||||
|
- include: github-extract.yml
|
||||||
|
when: caddy_use_github
|
||||||
|
|
||||||
|
- name: Copy Caddy Binary
|
||||||
|
copy:
|
||||||
|
src: "{{ caddy_home }}/caddy"
|
||||||
|
dest: "{{ caddy_bin }}"
|
||||||
|
mode: 0755
|
||||||
|
remote_src: true
|
||||||
|
notify:
|
||||||
|
- Restart caddy
|
||||||
|
|
||||||
|
- name: Create directories
|
||||||
|
file:
|
||||||
|
path: "{{ item }}"
|
||||||
|
state: directory
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
mode: 0770
|
||||||
|
with_items:
|
||||||
|
- "{{ caddy_conf_dir }}"
|
||||||
|
- "{{ caddy_certs_dir }}"
|
||||||
|
|
||||||
|
- name: Create log directory
|
||||||
|
file:
|
||||||
|
path: "{{ caddy_log_dir }}"
|
||||||
|
state: directory
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
mode: 0775
|
||||||
|
|
||||||
|
- name: Create Caddyfile
|
||||||
|
copy:
|
||||||
|
content: "{{ caddy_config }}"
|
||||||
|
dest: "{{ caddy_conf_dir }}/Caddyfile"
|
||||||
|
owner: "{{ caddy_user }}"
|
||||||
|
mode: 0640
|
||||||
|
notify:
|
||||||
|
- Reload caddy
|
||||||
|
|
||||||
|
- name: Template systemd service
|
||||||
|
template:
|
||||||
|
src: caddy.service
|
||||||
|
dest: /etc/systemd/system/caddy.service
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: 0644
|
||||||
|
notify:
|
||||||
|
- Restart caddy
|
||||||
|
|
||||||
|
- name: Set capability on the binary file to be able to bind to TCP port <1024
|
||||||
|
capabilities:
|
||||||
|
path: "{{ caddy_bin }}"
|
||||||
|
capability: cap_net_bind_service+eip
|
||||||
|
state: present
|
||||||
|
when: caddy_setcap
|
||||||
|
|
||||||
|
- name: Ensue caddy service is up-to-date before starting it
|
||||||
|
meta: flush_handlers
|
||||||
|
|
||||||
|
- name: Start Caddy service
|
||||||
|
systemd:
|
||||||
|
name: caddy
|
||||||
|
state: started
|
||||||
|
enabled: true
|
18
roles/caddy/tasks/packages-apt.yml
Normal file
18
roles/caddy/tasks/packages-apt.yml
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
- name: Update cache
|
||||||
|
apt:
|
||||||
|
update_cache: true
|
||||||
|
cache_valid_time: 43200 # 12 hours
|
||||||
|
|
||||||
|
# This is required because it provides the /bin/kill binary used in the service file
|
||||||
|
- name: Install procps
|
||||||
|
apt:
|
||||||
|
name: procps
|
||||||
|
state: present
|
||||||
|
|
||||||
|
- name: Install libcap
|
||||||
|
apt:
|
||||||
|
name: libcap2-bin
|
||||||
|
state: present
|
||||||
|
when: caddy_setcap
|
1
roles/caddy/tasks/packages-dnf.yml
Normal file
1
roles/caddy/tasks/packages-dnf.yml
Normal file
|
@ -0,0 +1 @@
|
||||||
|
---
|
1
roles/caddy/tasks/packages-pacman.yml
Normal file
1
roles/caddy/tasks/packages-pacman.yml
Normal file
|
@ -0,0 +1 @@
|
||||||
|
---
|
1
roles/caddy/tasks/packages-yum.yml
Normal file
1
roles/caddy/tasks/packages-yum.yml
Normal file
|
@ -0,0 +1 @@
|
||||||
|
---
|
17
roles/caddy/tasks/preflight.yml
Normal file
17
roles/caddy/tasks/preflight.yml
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
---
|
||||||
|
- name: Assert usage of systemd as an init system
|
||||||
|
assert:
|
||||||
|
that: ansible_service_mgr == 'systemd'
|
||||||
|
msg: "This module only works with systemd"
|
||||||
|
|
||||||
|
- name: Get systemd version
|
||||||
|
command: systemctl --version
|
||||||
|
changed_when: false
|
||||||
|
check_mode: false
|
||||||
|
register: __systemd_version
|
||||||
|
tags:
|
||||||
|
- skip_ansible_lint
|
||||||
|
|
||||||
|
- name: Set systemd version fact
|
||||||
|
set_fact:
|
||||||
|
caddy_systemd_version: "{{ __systemd_version.stdout_lines[0].split(' ')[-1] }}"
|
73
roles/caddy/templates/caddy.service
Normal file
73
roles/caddy/templates/caddy.service
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
{{ ansible_managed | comment(decoration="; ") }}
|
||||||
|
; source: https://github.com/mholt/caddy/blob/master/dist/init/linux-systemd/caddy.service
|
||||||
|
; version: 6be0386
|
||||||
|
; changes: Set variables via Ansible
|
||||||
|
|
||||||
|
[Unit]
|
||||||
|
Description=Caddy HTTP/2 web server
|
||||||
|
Documentation=https://caddyserver.com/docs
|
||||||
|
After=network-online.target
|
||||||
|
{% if caddy_systemd_network_dependency == true %}
|
||||||
|
Wants=network-online.target systemd-networkd-wait-online.service
|
||||||
|
{% endif %}
|
||||||
|
{% if caddy_systemd_version | int >= 230 %}
|
||||||
|
StartLimitIntervalSec={{ caddy_systemd_restart_startlimitinterval }}
|
||||||
|
StartLimitBurst={{ caddy_systemd_restart_startlimitburst }}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Restart={{ caddy_systemd_restart }}
|
||||||
|
{% if caddy_systemd_version | int < 230 %}
|
||||||
|
StartLimitInterval={{ caddy_systemd_restart_startlimitinterval }}
|
||||||
|
StartLimitBurst={{ caddy_systemd_restart_startlimitburst }}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
; User and group the process will run as.
|
||||||
|
User={{ caddy_user }}
|
||||||
|
Group={{ caddy_user }}
|
||||||
|
|
||||||
|
; Letsencrypt-issued certificates will be written to this directory.
|
||||||
|
Environment=CADDYPATH={{ caddy_certs_dir }}
|
||||||
|
|
||||||
|
ExecStart="{{ caddy_bin_dir }}/caddy" run --environ --config "{{ caddy_conf_dir }}/Caddyfile" {{ caddy_additional_args }}
|
||||||
|
ExecReload="{{ caddy_bin_dir }}/caddy" reload --config "{{ caddy_conf_dir }}/Caddyfile"
|
||||||
|
|
||||||
|
; Limit the number of file descriptors; see `man systemd.exec` for more limit settings.
|
||||||
|
LimitNOFILE=1048576
|
||||||
|
{% if caddy_systemd_nproc_limit > 0 %}
|
||||||
|
; Limit the number of caddy threads.
|
||||||
|
LimitNPROC={{ caddy_systemd_nproc_limit }}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
; Use private /tmp and /var/tmp, which are discarded after caddy stops.
|
||||||
|
PrivateTmp={{ caddy_systemd_private_tmp }}
|
||||||
|
; Use a minimal /dev
|
||||||
|
PrivateDevices={{ caddy_systemd_private_devices }}
|
||||||
|
; Hide /home, /root, and /run/user. Nobody will steal your SSH-keys.
|
||||||
|
ProtectHome={{ caddy_systemd_protect_home }}
|
||||||
|
; Make /usr, /boot, /etc and possibly some more folders read-only.
|
||||||
|
ProtectSystem={{ caddy_systemd_protect_system }}
|
||||||
|
; … except {{ caddy_certs_dir }}, because we want Letsencrypt-certificates there.
|
||||||
|
; This merely retains r/w access rights, it does not add any new. Must still be writable on the host!
|
||||||
|
ReadWriteDirectories={{ caddy_certs_dir }}
|
||||||
|
|
||||||
|
{% if caddy_systemd_capabilities_enabled %}
|
||||||
|
; The following additional security directives only work with systemd v229 or later.
|
||||||
|
; They further retrict privileges that can be gained by caddy.
|
||||||
|
; Note that you may have to add capabilities required by any plugins in use.
|
||||||
|
CapabilityBoundingSet={{ caddy_systemd_capabilities }}
|
||||||
|
AmbientCapabilities={{ caddy_systemd_capabilities }}
|
||||||
|
NoNewPrivileges=true
|
||||||
|
|
||||||
|
{% endif %}
|
||||||
|
{% if caddy_environment_variables|length %}
|
||||||
|
|
||||||
|
; Additional environment variables:
|
||||||
|
|
||||||
|
{% for key, value in caddy_environment_variables.items() %}
|
||||||
|
Environment={{ key }}={{ value }}
|
||||||
|
{% endfor %}
|
||||||
|
|
||||||
|
{% endif %}
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
21
roles/caddy/vars/main.yml
Normal file
21
roles/caddy/vars/main.yml
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
---
|
||||||
|
# vars file for caddy-ansible
|
||||||
|
caddy_github_headers: {}
|
||||||
|
|
||||||
|
go_arch_map:
|
||||||
|
i386: '386'
|
||||||
|
x86_64: 'amd64'
|
||||||
|
aarch64: 'arm64'
|
||||||
|
armv7l: 'arm7'
|
||||||
|
armv6l: 'arm6'
|
||||||
|
|
||||||
|
go_arch: "{{ go_arch_map[ansible_architecture] | default(ansible_architecture) }}"
|
||||||
|
|
||||||
|
caddy_bin: "{{ caddy_bin_dir }}/caddy"
|
||||||
|
|
||||||
|
caddy_url: "https://caddyserver.com/api/download?os={{ caddy_os }}&arch={{ go_arch }}\
|
||||||
|
{% for pkg in caddy_packages %}\
|
||||||
|
{% if loop.first %}&{% endif %}p={{ pkg | urlencode() }}{% if not loop.last %},{% endif %}\
|
||||||
|
{% endfor %}"
|
||||||
|
|
||||||
|
caddy_use_github: "{{ caddy_packages == [] }}"
|
8
tests/caddy/Vagrantfile
vendored
Normal file
8
tests/caddy/Vagrantfile
vendored
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
Vagrant.configure("2") do |config|
|
||||||
|
config.vm.define :node do |node|
|
||||||
|
node.vm.box = "generic/debian10"
|
||||||
|
node.vm.provision "ansible" do |ansible|
|
||||||
|
ansible.playbook = "./nodejs.yml"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
6
tests/caddy/caddy.yml
Normal file
6
tests/caddy/caddy.yml
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
---
|
||||||
|
- name: caddy test
|
||||||
|
hosts: localhost
|
||||||
|
become: yes
|
||||||
|
roles:
|
||||||
|
- caddy
|
1
tests/caddy/roles
Symbolic link
1
tests/caddy/roles
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../../roles/
|
Loading…
Reference in a new issue