Tunnels¶
Pynchy's tunnel connectivity detection system. Use this page to make sure your Pynchy instance is reachable remotely — for the TUI client, deploy webhooks, and other HTTP-based access.
Tunnels are pluggable. The built-in plugin detects Tailscale, but alternative providers (Cloudflare Tunnel, WireGuard, etc.) can be added via plugins.
What Tunnels Do¶
Pynchy exposes an HTTP server (default port 8484) for the TUI client, deploy webhooks, and SSE event streaming. On a headless server, you need a way to reach that port from other machines.
The tunnel subsystem detects whether a tunnel is available — it doesn't create or manage tunnels itself. At startup, Pynchy checks every registered tunnel provider and warns if none are connected.
This is purely informational. If no tunnel is detected, Pynchy continues running normally. You might still have connectivity through other means (direct network access, port forwarding, etc.).
Startup Check¶
On boot, Pynchy:
- Discovers tunnel providers via plugins
- Checks each provider's availability (is the software installed?)
- Checks connectivity (is the tunnel actually connected?)
- Logs the result —
INFOif connected,WARNINGif not
If no tunnels are connected at all, you'll see:
Built-in: Tailscale¶
Detects Tailscale connectivity by running tailscale status --json and checking the BackendState field.
- Available when the
tailscaleCLI is installed - Connected when
BackendState == "Running" - Failures fall through to "not connected" — CLI not found, timeouts, and parse errors are all treated the same
Tunnel Provider Contract¶
Plugins implement the pynchy_tunnel hook and return an object with:
| Attribute / Method | Type | Description |
|---|---|---|
name | str | Tunnel identifier (e.g., "tailscale", "cloudflare") |
is_available() | () → bool | Whether the tunnel software is installed on the host |
is_connected() | () → bool | Whether the tunnel is currently connected |
status_summary() | () → str | Human-readable status string for logging |
Want to customize this? Write your own tunnel plugin — see the Plugin Authoring Guide. Have an idea but don't want to build it? Open a feature request.