For more information about the why and what, check Alex Haydock's original project template.
- config/etc/apk/worlddefines the packages
- the files in etc are the config files that get overlayed over the apk defaults
- genapkovl-pinewall.sh defines the services
- interfaces are in config/etc/network/interfaces
- config/etc/nftables.d/rules.nftsets up NAT and firewall rules
To build a bootable for a Raspberry PI:
docker build -t pinewall .
docker create --name pinewall pinewall
docker cp pinewall:/tmp/images/. .
docker rm pinewall
gunzip -c alpine-rpi-edge-aarch64.img.gz | sudo dd of=/dev/diskX bs=1m status=progress conv=fsync oflag=sync
For other architectures set profile_standard and arch in mkimg.pinewall_rpi.sh
- nftablespure firewall and NAT
- birdfor BGP with Kubernetes
- dnsmasqfor DHCP and DNS forwarding
- iperf3local "speedtest" server
