feat: add TLS for node bridge
This commit is contained in:
@@ -28,8 +28,12 @@ If you are building an operator client (CLI, web UI, automations), use the
|
||||
## Transport
|
||||
|
||||
- TCP, one JSON object per line (JSONL).
|
||||
- Optional TLS (when `bridge.tls.enabled` is true).
|
||||
- Gateway owns the listener (default `18790`).
|
||||
|
||||
When TLS is enabled, discovery TXT records include `bridgeTls=1` plus
|
||||
`bridgeTlsSha256` so nodes can pin the certificate.
|
||||
|
||||
## Handshake + pairing
|
||||
|
||||
1) Client sends `hello` with node metadata + token (if already paired).
|
||||
|
||||
@@ -2732,12 +2732,29 @@ Bind modes:
|
||||
- `loopback`: `127.0.0.1` (local only)
|
||||
- `auto`: prefer tailnet IP if present, else `lan`
|
||||
|
||||
TLS:
|
||||
- `bridge.tls.enabled`: enable TLS for bridge connections (TLS-only when enabled).
|
||||
- `bridge.tls.autoGenerate`: generate a self-signed cert when no cert/key are present (default: true).
|
||||
- `bridge.tls.certPath` / `bridge.tls.keyPath`: PEM paths for the bridge certificate + private key.
|
||||
- `bridge.tls.caPath`: optional PEM CA bundle (custom roots or future mTLS).
|
||||
|
||||
When TLS is enabled, the Gateway advertises `bridgeTls=1` and `bridgeTlsSha256` in discovery TXT
|
||||
records so nodes can pin the certificate. Manual connections use trust-on-first-use if no
|
||||
fingerprint is stored yet.
|
||||
Auto-generated certs require `openssl` on PATH; if generation fails, the bridge will not start.
|
||||
|
||||
```json5
|
||||
{
|
||||
bridge: {
|
||||
enabled: true,
|
||||
port: 18790,
|
||||
bind: "tailnet"
|
||||
bind: "tailnet",
|
||||
tls: {
|
||||
enabled: true,
|
||||
// Uses ~/.clawdbot/bridge/tls/bridge-{cert,key}.pem when omitted.
|
||||
// certPath: "~/.clawdbot/bridge/tls/bridge-cert.pem",
|
||||
// keyPath: "~/.clawdbot/bridge/tls/bridge-key.pem"
|
||||
}
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
@@ -84,7 +84,7 @@ Schema:
|
||||
Notes:
|
||||
- `allowlist` entries are JSON-encoded argv arrays.
|
||||
- Choosing “Always Allow” in the prompt adds that command to the allowlist.
|
||||
- Allowlisted runs ignore `PATH` overrides; other env vars are merged with the app’s environment.
|
||||
- `system.run` environment overrides are filtered (drops `PATH`, `DYLD_*`, `LD_*`, `NODE_OPTIONS`, `PYTHON*`, `PERL*`, `RUBYOPT`) and then merged with the app’s environment.
|
||||
|
||||
## Deep links
|
||||
|
||||
|
||||
Reference in New Issue
Block a user