@simonyea/holysheep-cli 1.7.109 → 1.7.110

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@simonyea/holysheep-cli",
3
- "version": "1.7.109",
3
+ "version": "1.7.110",
4
4
  "description": "Claude Code/Cursor/Cline API relay for China — ¥1=$1, WeChat/Alipay payment, no credit card, no VPN. One command setup for all AI coding tools.",
5
5
  "keywords": [
6
6
  "openai-china",
@@ -197,18 +197,31 @@ function createConnectTunnel(proxyUrl, target, headers) {
197
197
  }
198
198
 
199
199
  function pipeWithCleanup(a, b) {
200
- // TCP keepalive: 30秒探测一次,快速发现死连接
200
+ // TCP keepalive: 15秒探测
201
201
  for (const sock of [a, b]) {
202
- if (typeof sock.setKeepAlive === 'function') sock.setKeepAlive(true, 30000)
203
- if (typeof sock.setTimeout === 'function') {
204
- // 90秒无数据流动则判定为死连接
205
- sock.setTimeout(90000, () => sock.destroy(new Error('idle timeout')))
206
- }
202
+ if (typeof sock.setKeepAlive === 'function') sock.setKeepAlive(true, 15000)
207
203
  }
208
204
 
205
+ // 智能 stall 检测:有数据在流突然停了 → 15秒判死
206
+ // 空闲隧道等新请求 → 不超时
207
+ let lastActivity = Date.now()
208
+ let hasData = false
209
+ const onData = () => { lastActivity = Date.now(); hasData = true }
210
+ a.on('data', onData)
211
+ b.on('data', onData)
212
+
213
+ const stallCheck = setInterval(() => {
214
+ if (hasData && Date.now() - lastActivity > 15000) {
215
+ clearInterval(stallCheck)
216
+ a.destroy(new Error('stream stalled'))
217
+ b.destroy(new Error('stream stalled'))
218
+ }
219
+ }, 5000)
220
+
209
221
  a.pipe(b)
210
222
  b.pipe(a)
211
223
  const close = () => {
224
+ clearInterval(stallCheck)
212
225
  a.destroy()
213
226
  b.destroy()
214
227
  }