46d8fecdfa
Replace deploy tasks with teardown tasks that stop containers and remove stack directories. Remove Caddy routes and DNS records, with explicit Route53 deletion for the decommissioned subdomains. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
96 lines
2.6 KiB
YAML
96 lines
2.6 KiB
YAML
---
|
|
# dns.yml
|
|
- name: Add A Records for thesatelliteoflove.com and nerder.land
|
|
hosts: localhost
|
|
gather_facts: false
|
|
|
|
vars:
|
|
# Domains to manage DNS records for
|
|
domains:
|
|
- name: thesatelliteoflove.com
|
|
dns_records:
|
|
- name: "home"
|
|
ip: "152.53.36.98"
|
|
- name: "git"
|
|
ip: "152.53.36.98"
|
|
- name: "social"
|
|
ip: "152.53.36.98"
|
|
- name: "auth"
|
|
ip: "152.53.36.98"
|
|
- name: "audio"
|
|
ip: "152.53.36.98"
|
|
- name: "books"
|
|
ip: "152.53.36.98"
|
|
- name: "paper"
|
|
ip: "152.53.36.98"
|
|
- name: "snippets"
|
|
ip: "152.53.36.98"
|
|
- name: cal
|
|
ip: "152.53.36.98"
|
|
- name: loclog
|
|
ip: "152.53.36.98"
|
|
- name: watcher
|
|
ip: "152.53.36.98"
|
|
- name: models
|
|
ip: "152.53.36.98"
|
|
- name: bookmarks
|
|
ip: "152.53.36.98"
|
|
- name: gotify
|
|
ip: "152.53.36.98"
|
|
- name: gotify-assistant
|
|
ip: "152.53.36.98"
|
|
- name: pdg
|
|
ip: "152.53.36.98"
|
|
- name: nerder.land
|
|
dns_records:
|
|
- name: "forms"
|
|
ip: "152.53.36.98"
|
|
- name: "repair"
|
|
ip: "152.53.36.98"
|
|
|
|
# DNS records to remove for decommissioned services
|
|
removed_records:
|
|
- name: thesatelliteoflove.com
|
|
dns_records:
|
|
- name: "pin"
|
|
ip: "152.53.36.98"
|
|
- name: "code"
|
|
ip: "152.53.36.98"
|
|
- name: "phlog"
|
|
ip: "152.53.36.98"
|
|
- name: "tasks"
|
|
ip: "152.53.36.98"
|
|
- name: "post"
|
|
ip: "152.53.36.98"
|
|
- name: "files"
|
|
ip: "152.53.36.98"
|
|
- name: "kanboard"
|
|
ip: "152.53.36.98"
|
|
- name: "grocy"
|
|
ip: "152.53.36.98"
|
|
|
|
tasks:
|
|
- name: Remove A records for decommissioned services
|
|
amazon.aws.route53:
|
|
state: absent
|
|
zone: "{{ item.0.name }}"
|
|
record: "{{ item.1.name + '.' + item.0.name }}"
|
|
type: A
|
|
ttl: 300
|
|
value: "{{ item.1.ip }}"
|
|
loop: "{{ query('subelements', removed_records, 'dns_records') }}"
|
|
loop_control:
|
|
loop_var: item
|
|
|
|
- name: Add A records for subdomains of each domain
|
|
amazon.aws.route53:
|
|
state: present
|
|
zone: "{{ item.0.name }}"
|
|
record: "{{ item.0.name if item.1.name == '@' else item.1.name + '.' + item.0.name }}"
|
|
type: A
|
|
ttl: 300
|
|
value: "{{ item.1.ip }}"
|
|
loop: "{{ query('subelements', domains, 'dns_records') }}"
|
|
loop_control:
|
|
loop_var: item
|