5 Commits

Author SHA1 Message Date
8d2689a15a feat(registrar): add TLS_MODE for Traefik TCP; fix tag newline; default ACME resolver
- Add TLS_MODE env to control TCP TLS behavior:
  - terminating (default): Traefik terminates TLS (tls=true + tls.certresolver)
  - passthrough: end-to-end TLS passthrough (tls.passthrough=true)
  - plaintext: plain TCP for internal/Tailscale (HostSNI(`*`) + priority=1)

- Introduce TRAEFIK_CERT_RESOLVER with default "alidns" for ACME issuance.
  (HTTP branch keeps optional tls.certresolver line commented for easy enablement.)

- Fix tag concatenation: use a real newline for NL so that to_json_array()
  parses tags line-by-line into a proper JSON array (prevents single-line tag blob).

- Improve TCP router/service tags and comments to make behavior explicit
  per mode, and keep HTTP branch consistent (middlewares + priority).

BREAKING CHANGE:
- TCP default changes from implicit plaintext to TLS-terminating via Traefik.
  If you relied on plaintext TCP previously, set `TLS_MODE=plaintext` (or
  use `TLS_MODE=passthrough` if your backend terminates TLS itself).
  Ensure Traefik has a working ACME resolver named in $TRAEFIK_CERT_RESOLVER
  (default "alidns") or override accordingly.
2025-10-03 17:30:18 +08:00
6bf070ab66 之前的注册脚本里把中间件写成了 security-headers@file(还出现过一个带逗号的 security-headers@file,)。而在你的 routes/global.yml 里真正定义的名字是 sec-headers@file。
目的就是对齐中间件名称,避免 Traefik 在装配 router 时引用了一个不存在的中间件,导致该条 router 报告 warning / 被降级,进而被其它“更泛”的路由(比如系统自带面板 8000/5666)抢走域名流量。
2025-10-02 23:12:21 +08:00
22b10cd112 添加 NL 防止换行有问题 2025-10-02 22:48:20 +08:00
862b5676c1 增强退出时候的优化等待 2025-10-02 19:17:13 +08:00
d34f04427a first commit 2025-10-02 19:04:38 +08:00