Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/radityaharya/tailscale-caddy-fly-proxy
An all-in-one Tailscale - Caddy - Fly - Grafana stack
https://github.com/radityaharya/tailscale-caddy-fly-proxy
adguardhome caddy flyio grafana tailscale
Last synced: about 2 months ago
JSON representation
An all-in-one Tailscale - Caddy - Fly - Grafana stack
- Host: GitHub
- URL: https://github.com/radityaharya/tailscale-caddy-fly-proxy
- Owner: radityaharya
- Created: 2024-09-15T07:38:34.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-09-17T15:28:14.000Z (4 months ago)
- Last Synced: 2024-10-12T22:41:55.822Z (3 months ago)
- Topics: adguardhome, caddy, flyio, grafana, tailscale
- Language: Dockerfile
- Homepage:
- Size: 17.6 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Tailscale Caddy Fly.io Proxy
This is a simple proxy that routes services that are in the [tailnet](https://tailscale.com/kb/1136/tailnet). It has built-in AdGuard Home, which is used as a DNS server, that you can use as your [tailscale's nameserver](https://tailscale.com/kb/1054/dns) or use it in [split DNS mode](https://tailscale.com/kb/1054/dns#restricted-nameservers).
## Getting Started
1. Clone this repository
```bash
git clone https://github.com/radityaharya/tailscale-caddy-fly-proxy.git
cd tailscale-caddy-fly-proxy
```2. Copy Caddyfile.example to Caddyfile
```bash
cp Caddyfile.example Caddyfile
```3. Edit Caddyfile to add your services
4. Create a new Fly.io app (select copy from existing configuration)
```bash
flyctl launch --ha-false
```5. Set the following environment variables
```bash
flyctl secrets set TAILSCALE_AUTHKEY=
```6. Deploy the app
```bash
flyctl deploy --ha=false
```7. Go to [Tailscale admin console](https://login.tailscale.com/admin/machines) and save your newly added machine's IP address
8. Setup AdGuard Home by going to `http://:3000` and set the dashboard listen address other than `80` as it will be used by Caddy, for example you can set it to `8053`
9. Go to Adguard home dashboard at `http://:8053`. Go to Filters > DNS Rewrites and add the following rewrites:
```
*.fly.local ->
```10. Go to Tailscale admin console > [DNS](https://login.tailscale.com/admin/dns) and add a custom nameserver with the following configuration:
```
Name:(You can skip this if you don't want to use split DNS, and use AdGuard Home as your nameserver)
Restrict to domain: trueDomains: fly.local
```11. You should be able to access your services defined in `Caddyfile`