mirror of
				https://github.com/kevinveenbirkenbach/computer-playbook.git
				synced 2025-10-31 10:19:09 +00:00 
			
		
		
		
	This update introduces apex (@) A and optional AAAA records for all base SLD domains. The tasks were moved into a new 02_apex.yml file and are looped using SYS_SVC_DNS_BASE_DOMAINS. CAA record loops were updated accordingly. See details: https://chatgpt.com/share/68c385c3-1804-800f-8c78-8614bc853f77
		
			
				
	
	
		
			27 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # sys-svc-dns
 | ||
| 
 | ||
| Bootstrap and maintain **DNS prerequisites** for your web stack on Cloudflare.
 | ||
| 
 | ||
| This role validates credentials and (by default) ensures:
 | ||
| - **A (and optional AAAA) records** on the **apex** (`@`) for all **base SLD domains**
 | ||
| - **Wildcard A/AAAA records** (`*.parent`) for parent hosts via `sys-dns-wildcards`
 | ||
| - *(Optional)* **CAA** records for Let’s Encrypt (kept as a commented block you can re-enable)
 | ||
| 
 | ||
| Runs **once per play** and is safe to include in stacks that roll out many domains.
 | ||
| 
 | ||
| ---
 | ||
| 
 | ||
| ## What it does
 | ||
| 
 | ||
| 1. **Validate `CLOUDFLARE_API_TOKEN`** is present (early fail if missing).
 | ||
| 2. **Ensure apex A/AAAA exist** for every **base SLD** in `SYS_SVC_DNS_BASE_DOMAINS`:
 | ||
|    - Writes `@  A` → `networks.internet.ip4`
 | ||
|    - Writes `@ AAAA` → `networks.internet.ip6` (only if global and present)
 | ||
| 3. *(Optional)* **CAA records** for all base SLDs (commented in the tasks; enable if you want CAA managed here).
 | ||
| 4. **Ensure wildcard parent DNS exists** (`*.parent` derived from children):
 | ||
|    - Delegates to [`sys-dns-wildcards`](../sys-dns-wildcards/README.md)
 | ||
|    - Creates `A` (and `AAAA` if enabled) wildcard records on the Cloudflare zone, optionally proxied. 
 | ||
| 
 | ||
| > Parent hosts example:  
 | ||
| > `c.wiki.example.com` → **parent** `wiki.example.com` (plus `example.com` apex)
 |