Traefik: - Enable access logs → /var/log/traefik/access.log (needed for CrowdSec) - Add global security headers middleware: HSTS, X-Frame-Options, CSP, nosniff, XSS filter, referrer policy, permissions policy - Add rate limiting: default 100/s, API 30/s, admin 10/s (strict) - Add Authelia ForwardAuth middleware for SSO integration CrowdSec (new service): - Analyzes Traefik access logs + auth.log in real time - Community IP reputation blocklist (crowdsecurity/traefik + http-cve) - Firewall bouncer: bans malicious IPs at kernel level (iptables) Authelia (new service, auth.csrx.ru): - 2FA/SSO portal with TOTP (Google Authenticator) - Protects: traefik.csrx.ru, sync.csrx.ru, /god-mode/ in Plane - Session: 12h expiry, 30m inactivity, Redis backend - argon2id password hashing Container security: - Add security_opt: no-new-privileges to traefik, vaultwarden, forgejo, grafana, authelia CI/CD security: - Remove hardcoded server IP 87.249.49.32 from workflow - Use SSH_KNOWN_HOSTS secret instead of ssh-keyscan (prevents MITM) - Added SSH_KNOWN_HOSTS secret to Forgejo Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
172 lines
5 KiB
YAML
172 lines
5 KiB
YAML
---
|
|
- name: Deploy .env file
|
|
ansible.builtin.template:
|
|
src: env.j2
|
|
dest: "{{ services_root }}/.env"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0600"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy docker-compose.yml
|
|
ansible.builtin.template:
|
|
src: docker-compose.yml.j2
|
|
dest: "{{ services_root }}/docker-compose.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Traefik static config
|
|
ansible.builtin.template:
|
|
src: traefik/traefik.yml.j2
|
|
dest: "{{ services_root }}/traefik/traefik.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Traefik dynamic routes
|
|
ansible.builtin.template:
|
|
src: traefik/dynamic/routes.yml.j2
|
|
dest: "{{ services_root }}/traefik/dynamic/routes.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy act_runner config
|
|
ansible.builtin.template:
|
|
src: act_runner_config.yaml.j2
|
|
dest: "{{ services_root }}/act_runner/config.yaml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Prometheus config
|
|
ansible.builtin.template:
|
|
src: prometheus/prometheus.yml.j2
|
|
dest: "{{ services_root }}/prometheus/prometheus.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Grafana datasource provisioning
|
|
ansible.builtin.template:
|
|
src: grafana/provisioning/datasources/prometheus.yml.j2
|
|
dest: "{{ services_root }}/grafana/provisioning/datasources/prometheus.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Grafana dashboard provisioning config
|
|
ansible.builtin.template:
|
|
src: grafana/provisioning/dashboards/dashboards.yml.j2
|
|
dest: "{{ services_root }}/grafana/provisioning/dashboards/dashboards.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Node Exporter Full dashboard JSON
|
|
ansible.builtin.copy:
|
|
src: grafana/dashboards/node-exporter-full.json
|
|
dest: "{{ services_root }}/grafana/provisioning/dashboards/json/node-exporter-full.json"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy cAdvisor dashboard JSON
|
|
ansible.builtin.copy:
|
|
src: grafana/dashboards/cadvisor.json
|
|
dest: "{{ services_root }}/grafana/provisioning/dashboards/json/cadvisor.json"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Prometheus alert rules
|
|
ansible.builtin.template:
|
|
src: prometheus/rules/alerts.yml.j2
|
|
dest: "{{ services_root }}/prometheus/rules/alerts.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy AlertManager config
|
|
ansible.builtin.template:
|
|
src: prometheus/alertmanager.yml.j2
|
|
dest: "{{ services_root }}/prometheus/alertmanager.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0640"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Loki config
|
|
ansible.builtin.template:
|
|
src: loki/loki.yml.j2
|
|
dest: "{{ services_root }}/loki/loki.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Promtail config
|
|
ansible.builtin.template:
|
|
src: loki/promtail.yml.j2
|
|
dest: "{{ services_root }}/loki/promtail.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Grafana Loki datasource
|
|
ansible.builtin.template:
|
|
src: grafana/provisioning/datasources/loki.yml.j2
|
|
dest: "{{ services_root }}/grafana/provisioning/datasources/loki.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy CrowdSec acquisition config
|
|
ansible.builtin.template:
|
|
src: crowdsec/acquis.yaml.j2
|
|
dest: "{{ services_root }}/crowdsec/acquis.yaml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0644"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Authelia configuration
|
|
ansible.builtin.template:
|
|
src: authelia/configuration.yml.j2
|
|
dest: "{{ services_root }}/authelia/configuration.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0600"
|
|
notify: Restart stack
|
|
|
|
- name: Deploy Authelia users database
|
|
ansible.builtin.template:
|
|
src: authelia/users.yml.j2
|
|
dest: "{{ services_root }}/authelia/users.yml"
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0600"
|
|
notify: Restart stack
|
|
|
|
- name: Create acme.json for Let's Encrypt certificates
|
|
ansible.builtin.file:
|
|
path: "{{ services_root }}/traefik/acme.json"
|
|
state: touch
|
|
owner: "{{ deploy_user }}"
|
|
group: "{{ deploy_group }}"
|
|
mode: "0600"
|
|
modification_time: preserve
|
|
access_time: preserve
|