2023-09-10 20:56:38 -04:00
# homeserver ansible playbook
This Ansible playbook allows me to set up and configure all my home lab servers completely automatically, with little to no intervention.
It is for personal use; do not rely on this for anything important.
Special thanks to [Wolfgang ](https://github.com/notthebee/ ) for the idea of automating the installation process.
This project was largely inspired by his own [infra ](https://github.com/notthebee/infra ) repo.
## services
The following services are managed completely automatically:
2023-12-09 21:36:36 -05:00
- [Gitea ](https://about.gitea.com/ )
- [Matrix Synapse ](https://github.com/matrix-org/synapse )
- [Syncthing ](https://syncthing.net/ )
- [Navidrome ](https://www.navidrome.org/ )
- [Paperless-ngx ](https://docs.paperless-ngx.com/ )
- [Exim ](https://www.exim.org/ ) mail (internal use only)
- [Caddy ](https://caddyserver.com/ ) reverse proxy
2024-06-16 15:27:33 -04:00
- [WireGuard ](https://www.wireguard.com/ ) VPN server.
2023-09-10 20:56:38 -04:00
## misc features
- Firewall setup (UFW)
- Python bootstrapping
- Setting up static IP in LAN
- External storage decryption/mounting
- Dotfile installation
## usage
The playbook assumes fresh Arch Linux ARM images installed on machines in your LAN, connected via Ethernet.
They should start off with default credentials (i.e. `alarm:alarm` , `root:root` ).
This repo takes care of everything else.
The intended topology is a bastion host facing the Internet, with reverse proxies forwarding traffic to a service host inside the firewall.
- Flash all your machines with Arch Linux ARM.
- Copy `inventory.example.yml` to `inventory.yml` .
- Write down the machines' DHCP addresses inside `inventory.yml` under the `fallback_host` field.
- Assign static LAN IP addresses for your machines in the inventory.
2023-09-10 21:00:15 -04:00
- Create ssh keys for all your hosts:
```
mkdir -p ~/.ssh/keys
ssh-keygen -t ed25519 -f ~/.ssh/keys/your_host_name
```
It is important for the hostnames to match your inventory hostnames.
2023-09-10 20:56:38 -04:00
- Set up your domain name and networks.
- Forward all needed ports to your bastion host's static IP.
- Set up a dynamic DNS subdomain, for example via [nsupdate ](https://www.nsupdate.info/ ).
- Create subdomains for Gitea, Matrix, and Navidrome. These should be forwarded to your dynamic DNS subdomain via CNAME records. Configure these subdomains in `group_vars` (see below.)
2023-08-21 17:19:29 -04:00
2023-08-26 22:02:29 -04:00
- Install required packages:
- sshpass
2023-09-09 11:45:54 -04:00
- python-passlib
2023-09-10 19:25:29 -04:00
- Look at `group_vars/all/50-vars.yml` , and set needed settings in `host_vars/<hostname>/vars.yml` , or `group_vars/all/90-overlay.yml` .
(Files in group vars with a larger number have more precedence.)
2023-08-21 17:19:29 -04:00
- Look at the following roles, and for each of them override their `defaults/vars.yml` in host or group vars:
- `networking/connection`
- `networking/nameserver`
2023-09-04 20:09:48 -04:00
- `caddy`
- `containers`
2023-08-21 17:19:29 -04:00
- `filesystems`
- `firewall`
2023-09-04 20:09:48 -04:00
- `syncthing`
- `website`
2023-08-21 17:19:29 -04:00
- Create vault for secrets:
```
2023-09-10 19:25:29 -04:00
ansible-vault create group_vars/all/80-vault.yml
ansible-vault edit group_vars/all/80-vault.yml
2023-08-21 17:19:29 -04:00
```
2023-09-10 19:25:29 -04:00
Copy-paste `group_vars/all/00-secret_template.yml` into this vault,
2023-08-21 17:19:29 -04:00
and modify as needed.
- Add secret files:
```
# Keyfile for LUKS disk encryption
dd if=/dev/random of=roles/filesystems/files/host1.secret bs=1024 count=2
ansible-vault encrypt roles/filesystems/files/host1.secret
# repeat the above for every host with encrypted external storage
```
2023-08-26 22:02:29 -04:00
- Run the playbook:
```
ansible-playbook run.yml --ask-vault-pass
```