@bundy-lmw/hive-server 1.0.1 → 1.0.3

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.
Files changed (101) hide show
  1. package/dist/bootstrap.d.ts +3 -4
  2. package/dist/bootstrap.d.ts.map +1 -1
  3. package/dist/bootstrap.js +17 -24
  4. package/dist/bootstrap.js.map +1 -1
  5. package/dist/cli/commands/skill/index.d.ts +10 -0
  6. package/dist/cli/commands/skill/index.d.ts.map +1 -0
  7. package/dist/cli/commands/skill/index.js +174 -0
  8. package/dist/cli/commands/skill/index.js.map +1 -0
  9. package/dist/cli/commands/skill/installer.d.ts +75 -0
  10. package/dist/cli/commands/skill/installer.d.ts.map +1 -0
  11. package/dist/cli/commands/skill/installer.js +347 -0
  12. package/dist/cli/commands/skill/installer.js.map +1 -0
  13. package/dist/cli/index.d.ts.map +1 -1
  14. package/dist/cli/index.js +3 -0
  15. package/dist/cli/index.js.map +1 -1
  16. package/dist/gateway/http.d.ts +2 -1
  17. package/dist/gateway/http.d.ts.map +1 -1
  18. package/dist/gateway/http.js +17 -3
  19. package/dist/gateway/http.js.map +1 -1
  20. package/dist/gateway/ws/admin-handler.d.ts +24 -47
  21. package/dist/gateway/ws/admin-handler.d.ts.map +1 -1
  22. package/dist/gateway/ws/admin-handler.js +76 -465
  23. package/dist/gateway/ws/admin-handler.js.map +1 -1
  24. package/dist/gateway/ws/chat-handler.d.ts +42 -0
  25. package/dist/gateway/ws/chat-handler.d.ts.map +1 -0
  26. package/dist/gateway/ws/chat-handler.js +258 -0
  27. package/dist/gateway/ws/chat-handler.js.map +1 -0
  28. package/dist/gateway/ws/config-store.d.ts +16 -0
  29. package/dist/gateway/ws/config-store.d.ts.map +1 -0
  30. package/dist/gateway/ws/config-store.js +68 -0
  31. package/dist/gateway/ws/config-store.js.map +1 -0
  32. package/dist/gateway/ws/data-types.d.ts +3 -0
  33. package/dist/gateway/ws/data-types.d.ts.map +1 -1
  34. package/dist/gateway/ws/handler-context.d.ts +41 -0
  35. package/dist/gateway/ws/handler-context.d.ts.map +1 -0
  36. package/dist/gateway/ws/handler-context.js +8 -0
  37. package/dist/gateway/ws/handler-context.js.map +1 -0
  38. package/dist/gateway/ws/handlers/base.d.ts +14 -0
  39. package/dist/gateway/ws/handlers/base.d.ts.map +1 -0
  40. package/dist/gateway/ws/handlers/base.js +13 -0
  41. package/dist/gateway/ws/handlers/base.js.map +1 -0
  42. package/dist/gateway/ws/handlers/config-handler.d.ts +14 -0
  43. package/dist/gateway/ws/handlers/config-handler.d.ts.map +1 -0
  44. package/dist/gateway/ws/handlers/config-handler.js +53 -0
  45. package/dist/gateway/ws/handlers/config-handler.js.map +1 -0
  46. package/dist/gateway/ws/handlers/index.d.ts +10 -0
  47. package/dist/gateway/ws/handlers/index.d.ts.map +1 -0
  48. package/dist/gateway/ws/handlers/index.js +10 -0
  49. package/dist/gateway/ws/handlers/index.js.map +1 -0
  50. package/dist/gateway/ws/handlers/log-handler.d.ts +20 -0
  51. package/dist/gateway/ws/handlers/log-handler.d.ts.map +1 -0
  52. package/dist/gateway/ws/handlers/log-handler.js +65 -0
  53. package/dist/gateway/ws/handlers/log-handler.js.map +1 -0
  54. package/dist/gateway/ws/handlers/plugin-handler.d.ts +29 -0
  55. package/dist/gateway/ws/handlers/plugin-handler.d.ts.map +1 -0
  56. package/dist/gateway/ws/handlers/plugin-handler.js +197 -0
  57. package/dist/gateway/ws/handlers/plugin-handler.js.map +1 -0
  58. package/dist/gateway/ws/handlers/session-handler.d.ts +14 -0
  59. package/dist/gateway/ws/handlers/session-handler.d.ts.map +1 -0
  60. package/dist/gateway/ws/handlers/session-handler.js +36 -0
  61. package/dist/gateway/ws/handlers/session-handler.js.map +1 -0
  62. package/dist/gateway/ws/handlers/status-handler.d.ts +23 -0
  63. package/dist/gateway/ws/handlers/status-handler.d.ts.map +1 -0
  64. package/dist/gateway/ws/handlers/status-handler.js +136 -0
  65. package/dist/gateway/ws/handlers/status-handler.js.map +1 -0
  66. package/dist/gateway/ws/log-buffer.d.ts +1 -0
  67. package/dist/gateway/ws/log-buffer.d.ts.map +1 -1
  68. package/dist/gateway/ws/log-buffer.js +8 -0
  69. package/dist/gateway/ws/log-buffer.js.map +1 -1
  70. package/dist/gateway/ws/types.d.ts +1 -1
  71. package/dist/gateway/ws/types.d.ts.map +1 -1
  72. package/dist/gateway/ws/types.js.map +1 -1
  73. package/dist/graceful-shutdown.d.ts +13 -0
  74. package/dist/graceful-shutdown.d.ts.map +1 -0
  75. package/dist/graceful-shutdown.js +65 -0
  76. package/dist/graceful-shutdown.js.map +1 -0
  77. package/dist/logging/file-logger.d.ts +43 -0
  78. package/dist/logging/file-logger.d.ts.map +1 -0
  79. package/dist/logging/file-logger.js +134 -0
  80. package/dist/logging/file-logger.js.map +1 -0
  81. package/dist/logging/hive-logger.d.ts +26 -0
  82. package/dist/logging/hive-logger.d.ts.map +1 -0
  83. package/dist/logging/hive-logger.js +251 -0
  84. package/dist/logging/hive-logger.js.map +1 -0
  85. package/dist/main.d.ts +2 -0
  86. package/dist/main.d.ts.map +1 -1
  87. package/dist/main.js +68 -19
  88. package/dist/main.js.map +1 -1
  89. package/dist/plugin-manager/installer.d.ts +1 -1
  90. package/dist/plugin-manager/installer.d.ts.map +1 -1
  91. package/dist/plugin-manager/installer.js +84 -17
  92. package/dist/plugin-manager/installer.js.map +1 -1
  93. package/dist/plugin-manager/searcher.js +1 -1
  94. package/dist/plugin-manager/searcher.js.map +1 -1
  95. package/dist/plugin-manager/types.d.ts +1 -0
  96. package/dist/plugin-manager/types.d.ts.map +1 -1
  97. package/dist/plugins.d.ts +18 -0
  98. package/dist/plugins.d.ts.map +1 -1
  99. package/dist/plugins.js +50 -22
  100. package/dist/plugins.js.map +1 -1
  101. package/package.json +6 -3
@@ -0,0 +1,136 @@
1
+ /**
2
+ * StatusHandler — 服务状态域
3
+ *
4
+ * status.get / server.restart / server.getProviders / provider.list / provider.getModels
5
+ */
6
+ import { WsDomainHandler } from './base.js';
7
+ import { createSuccessResponse, createErrorResponse } from '../types.js';
8
+ import { readFileSync } from 'node:fs';
9
+ import { resolve } from 'node:path';
10
+ import { HIVE_HOME } from '../../../config.js';
11
+ export class StatusHandler extends WsDomainHandler {
12
+ startTime;
13
+ httpServer = null;
14
+ constructor(ctx, startTime) {
15
+ super(ctx);
16
+ this.startTime = startTime;
17
+ }
18
+ setHttpServer(httpServer) {
19
+ this.httpServer = httpServer;
20
+ }
21
+ register() {
22
+ return new Map([
23
+ ['status.get', this.handleStatusGet.bind(this)],
24
+ ['server.restart', this.handleServerRestart.bind(this)],
25
+ ['server.getProviders', this.handleGetProviders.bind(this)],
26
+ ['provider.list', this.handleProviderList.bind(this)],
27
+ ['provider.getModels', this.handleProviderGetModels.bind(this)],
28
+ ]);
29
+ }
30
+ handleStatusGet(_params, id) {
31
+ const server = this.ctx.getServer();
32
+ const provider = server?.agent?.currentProvider;
33
+ const providerReady = !!provider?.apiKey && provider.apiKey.length > 0;
34
+ const status = {
35
+ server: {
36
+ state: 'running',
37
+ port: this.getPort(),
38
+ uptime: Math.floor((Date.now() - this.startTime) / 1000),
39
+ version: this.getVersion(),
40
+ },
41
+ agent: {
42
+ initialized: !!server,
43
+ providerReady,
44
+ currentProvider: provider?.id ?? null,
45
+ activePlugins: [],
46
+ },
47
+ system: {
48
+ memory: {
49
+ rss: process.memoryUsage().rss,
50
+ heapUsed: process.memoryUsage().heapUsed,
51
+ heapTotal: process.memoryUsage().heapTotal,
52
+ },
53
+ nodeVersion: process.version,
54
+ platform: `${process.platform} ${process.arch}`,
55
+ },
56
+ };
57
+ return createSuccessResponse(id, status);
58
+ }
59
+ handleServerRestart(_params, id) {
60
+ const response = createSuccessResponse(id, { success: true });
61
+ this.ctx.broadcastEvent('server.shutting_down', { reason: 'restart' });
62
+ setTimeout(() => {
63
+ process.exit(0);
64
+ }, 300);
65
+ return response;
66
+ }
67
+ handleGetProviders(_params, id) {
68
+ const server = this.ctx.getServer();
69
+ if (!server) {
70
+ return createErrorResponse(id, 'INTERNAL', 'Server not initialized');
71
+ }
72
+ const providers = server.agent.listProviders();
73
+ return createSuccessResponse(id, providers);
74
+ }
75
+ async handleProviderList(_params, id) {
76
+ const server = this.ctx.getServer();
77
+ if (!server) {
78
+ return createErrorResponse(id, 'INTERNAL', 'Server not initialized');
79
+ }
80
+ try {
81
+ const providers = await server.agent.listAllProviders();
82
+ return createSuccessResponse(id, providers.map(p => ({
83
+ id: p.id,
84
+ name: p.name,
85
+ logo: p.logo,
86
+ type: p.type,
87
+ defaultModel: p.models.length > 0 ? p.models[0].id : undefined,
88
+ modelCount: p.models.length,
89
+ })));
90
+ }
91
+ catch (error) {
92
+ return createErrorResponse(id, 'INTERNAL', error instanceof Error ? error.message : 'Failed to list providers');
93
+ }
94
+ }
95
+ async handleProviderGetModels(params, id) {
96
+ const { providerId } = params;
97
+ if (!providerId) {
98
+ return createErrorResponse(id, 'VALIDATION', 'providerId is required');
99
+ }
100
+ const server = this.ctx.getServer();
101
+ if (!server) {
102
+ return createErrorResponse(id, 'INTERNAL', 'Server not initialized');
103
+ }
104
+ try {
105
+ const models = await server.agent.listProviderModels(providerId);
106
+ return createSuccessResponse(id, models.map(m => ({
107
+ id: m.id,
108
+ name: m.name,
109
+ family: m.family,
110
+ contextWindow: m.contextWindow,
111
+ maxOutputTokens: m.maxOutputTokens,
112
+ })));
113
+ }
114
+ catch (error) {
115
+ return createErrorResponse(id, 'INTERNAL', error instanceof Error ? error.message : 'Failed to get models');
116
+ }
117
+ }
118
+ getPort() {
119
+ if (this.httpServer) {
120
+ const addr = this.httpServer.address();
121
+ if (typeof addr === 'object' && addr)
122
+ return addr.port;
123
+ }
124
+ return 4450;
125
+ }
126
+ getVersion() {
127
+ try {
128
+ const pkg = JSON.parse(readFileSync(resolve(HIVE_HOME, 'package.json'), 'utf-8'));
129
+ return pkg.version ?? '0.0.0';
130
+ }
131
+ catch {
132
+ return '0.0.0';
133
+ }
134
+ }
135
+ }
136
+ //# sourceMappingURL=status-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"status-handler.js","sourceRoot":"","sources":["../../../../src/gateway/ws/handlers/status-handler.ts"],"names":[],"mappings":"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"}
@@ -18,6 +18,7 @@ export declare class LogBuffer {
18
18
  query?: string;
19
19
  limit?: number;
20
20
  offset?: number;
21
+ sinceId?: string;
21
22
  }): LogEntry[];
22
23
  /** 获取所有日志(用于调试) */
23
24
  getAll(): LogEntry[];
@@ -1 +1 @@
1
- {"version":3,"file":"log-buffer.d.ts","sourceRoot":"","sources":["../../../src/gateway/ws/log-buffer.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAEzD,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAQ;IAChC,OAAO,CAAC,OAAO,CAAI;gBAEP,OAAO,SAAS;IAI5B,WAAW;IACX,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,QAAQ;IAiB/D,aAAa;IACb,KAAK,CAAC,OAAO,CAAC,EAAE;QACd,KAAK,CAAC,EAAE,QAAQ,CAAA;QAChB,MAAM,CAAC,EAAE,MAAM,CAAA;QACf,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,MAAM,CAAC,EAAE,MAAM,CAAA;KAChB,GAAG,QAAQ,EAAE;IAoBd,mBAAmB;IACnB,MAAM,IAAI,QAAQ,EAAE;IAIpB,YAAY;IACZ,KAAK,IAAI,IAAI;IAIb,aAAa;IACb,IAAI,IAAI,IAAI,MAAM,CAEjB;CACF"}
1
+ {"version":3,"file":"log-buffer.d.ts","sourceRoot":"","sources":["../../../src/gateway/ws/log-buffer.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAEzD,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAQ;IAChC,OAAO,CAAC,OAAO,CAAI;gBAEP,OAAO,SAAS;IAI5B,WAAW;IACX,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,QAAQ;IAiB/D,aAAa;IACb,KAAK,CAAC,OAAO,CAAC,EAAE;QACd,KAAK,CAAC,EAAE,QAAQ,CAAA;QAChB,MAAM,CAAC,EAAE,MAAM,CAAA;QACf,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,MAAM,CAAC,EAAE,MAAM,CAAA;QACf,OAAO,CAAC,EAAE,MAAM,CAAA;KACjB,GAAG,QAAQ,EAAE;IA6Bd,mBAAmB;IACnB,MAAM,IAAI,QAAQ,EAAE;IAIpB,YAAY;IACZ,KAAK,IAAI,IAAI;IAIb,aAAa;IACb,IAAI,IAAI,IAAI,MAAM,CAEjB;CACF"}
@@ -28,6 +28,14 @@ export class LogBuffer {
28
28
  /** 查询历史日志 */
29
29
  query(options) {
30
30
  let result = this.buffer;
31
+ // sinceId: 返回该 ID 之后的所有日志(用于轮询增量拉取)
32
+ if (options?.sinceId) {
33
+ const idx = this.buffer.findIndex(e => e.id === options.sinceId);
34
+ if (idx >= 0) {
35
+ result = result.slice(idx + 1);
36
+ }
37
+ // sinceId 不存在时返回全部(可能是 counter 重置)
38
+ }
31
39
  if (options?.level) {
32
40
  result = result.filter(e => e.level === options.level);
33
41
  }
@@ -1 +1 @@
1
- {"version":3,"file":"log-buffer.js","sourceRoot":"","sources":["../../../src/gateway/ws/log-buffer.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH,MAAM,OAAO,SAAS;IACZ,MAAM,GAAe,EAAE,CAAA;IACd,OAAO,CAAQ;IACxB,OAAO,GAAG,CAAC,CAAA;IAEnB,YAAY,OAAO,GAAG,MAAM;QAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAED,WAAW;IACX,GAAG,CAAC,KAAe,EAAE,MAAc,EAAE,OAAe;QAClD,MAAM,KAAK,GAAa;YACtB,EAAE,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC;YAC1B,KAAK;YACL,MAAM;YACN,OAAO;YACP,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAA;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;QACrB,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACvB,OAAO,KAAK,CAAA;IACd,CAAC;IAED,aAAa;IACb,KAAK,CAAC,OAML;QACC,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAA;QAExB,IAAI,OAAO,EAAE,KAAK,EAAE,CAAC;YACnB,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK,CAAC,CAAA;QACxD,CAAC;QACD,IAAI,OAAO,EAAE,MAAM,EAAE,CAAC;YACpB,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAA;QAC1D,CAAC;QACD,IAAI,OAAO,EAAE,KAAK,EAAE,CAAC;YACnB,MAAM,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,CAAA;YACrC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;QAClE,CAAC;QAED,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,IAAI,CAAC,CAAA;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,IAAI,GAAG,EAAE,IAAI,CAAC,CAAA;QAEnD,OAAO,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAA;IAC3C,CAAC;IAED,mBAAmB;IACnB,MAAM;QACJ,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAA;IACzB,CAAC;IAED,YAAY;IACZ,KAAK;QACH,IAAI,CAAC,MAAM,GAAG,EAAE,CAAA;IAClB,CAAC;IAED,aAAa;IACb,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAA;IAC3B,CAAC;CACF"}
1
+ {"version":3,"file":"log-buffer.js","sourceRoot":"","sources":["../../../src/gateway/ws/log-buffer.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH,MAAM,OAAO,SAAS;IACZ,MAAM,GAAe,EAAE,CAAA;IACd,OAAO,CAAQ;IACxB,OAAO,GAAG,CAAC,CAAA;IAEnB,YAAY,OAAO,GAAG,MAAM;QAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAED,WAAW;IACX,GAAG,CAAC,KAAe,EAAE,MAAc,EAAE,OAAe;QAClD,MAAM,KAAK,GAAa;YACtB,EAAE,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC;YAC1B,KAAK;YACL,MAAM;YACN,OAAO;YACP,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAA;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;QACrB,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACvB,OAAO,KAAK,CAAA;IACd,CAAC;IAED,aAAa;IACb,KAAK,CAAC,OAOL;QACC,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAA;QAExB,oCAAoC;QACpC,IAAI,OAAO,EAAE,OAAO,EAAE,CAAC;YACrB,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,OAAO,CAAC,CAAA;YAChE,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC;gBACb,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;YAChC,CAAC;YACD,mCAAmC;QACrC,CAAC;QAED,IAAI,OAAO,EAAE,KAAK,EAAE,CAAC;YACnB,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK,CAAC,CAAA;QACxD,CAAC;QACD,IAAI,OAAO,EAAE,MAAM,EAAE,CAAC;YACpB,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAA;QAC1D,CAAC;QACD,IAAI,OAAO,EAAE,KAAK,EAAE,CAAC;YACnB,MAAM,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,CAAA;YACrC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;QAClE,CAAC;QAED,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,IAAI,CAAC,CAAA;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,IAAI,GAAG,EAAE,IAAI,CAAC,CAAA;QAEnD,OAAO,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAA;IAC3C,CAAC;IAED,mBAAmB;IACnB,MAAM;QACJ,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAA;IACzB,CAAC;IAED,YAAY;IACZ,KAAK;QACH,IAAI,CAAC,MAAM,GAAG,EAAE,CAAA;IAClB,CAAC;IAED,aAAa;IACb,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAA;IAC3B,CAAC;CACF"}
@@ -43,7 +43,7 @@ export interface WsError {
43
43
  message: string;
44
44
  }
45
45
  export type WsResponse = WsSuccessResponse | WsErrorResponse;
46
- export type ErrorCode = 'NOT_FOUND' | 'VALIDATION' | 'INTERNAL' | 'TIMEOUT' | 'UNAUTHORIZED';
46
+ export type ErrorCode = 'NOT_FOUND' | 'VALIDATION' | 'INTERNAL' | 'TIMEOUT' | 'UNAUTHORIZED' | 'AGENT_NOT_READY';
47
47
  export interface WsEvent extends WsMessage {
48
48
  type: 'event';
49
49
  /** 事件名 */
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/gateway/ws/types.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,MAAM,WAAW,SAAS;IACxB,mCAAmC;IACnC,EAAE,EAAE,MAAM,CAAA;IACV,WAAW;IACX,IAAI,EAAE,KAAK,GAAG,KAAK,GAAG,OAAO,CAAA;IAC7B,YAAY;IACZ,SAAS,EAAE,MAAM,CAAA;CAClB;AAMD,MAAM,WAAW,SAAU,SAAQ,SAAS;IAC1C,IAAI,EAAE,KAAK,CAAA;IACX,YAAY;IACZ,MAAM,EAAE,MAAM,CAAA;IACd,WAAW;IACX,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB;AAMD,MAAM,WAAW,iBAAkB,SAAQ,SAAS;IAClD,IAAI,EAAE,KAAK,CAAA;IACX,eAAe;IACf,EAAE,EAAE,MAAM,CAAA;IACV,OAAO,EAAE,IAAI,CAAA;IACb,WAAW;IACX,MAAM,EAAE,OAAO,CAAA;CAChB;AAED,MAAM,WAAW,eAAgB,SAAQ,SAAS;IAChD,IAAI,EAAE,KAAK,CAAA;IACX,eAAe;IACf,EAAE,EAAE,MAAM,CAAA;IACV,OAAO,EAAE,KAAK,CAAA;IACd,KAAK,EAAE,OAAO,CAAA;CACf;AAED,MAAM,WAAW,OAAO;IACtB,UAAU;IACV,IAAI,EAAE,SAAS,CAAA;IACf,gBAAgB;IAChB,OAAO,EAAE,MAAM,CAAA;CAChB;AAED,MAAM,MAAM,UAAU,GAAG,iBAAiB,GAAG,eAAe,CAAA;AAE5D,MAAM,MAAM,SAAS,GACjB,WAAW,GACX,YAAY,GACZ,UAAU,GACV,SAAS,GACT,cAAc,CAAA;AAMlB,MAAM,WAAW,OAAQ,SAAQ,SAAS;IACxC,IAAI,EAAE,OAAO,CAAA;IACb,UAAU;IACV,KAAK,EAAE,MAAM,CAAA;IACb,WAAW;IACX,IAAI,EAAE,OAAO,CAAA;CACd;AAED,iBAAiB;AACjB,MAAM,MAAM,eAAe,GACvB,sBAAsB,GACtB,KAAK,GACL,kBAAkB,GAClB,oBAAoB,GACpB,gBAAgB,CAAA;AAMpB,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,UAAU,GAAG,OAAO,CAAA;AAM3D,aAAa;AACb,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,GAAG,SAAS,CAQzE;AAED,aAAa;AACb,wBAAgB,qBAAqB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,GAAG,iBAAiB,CAQ3F;AAED,aAAa;AACb,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,GAAG,eAAe,CAQxG;AAED,aAAa;AACb,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAQjE;AAED,eAAe;AACf,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,GAAG,IAAI,CAW/D"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/gateway/ws/types.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,MAAM,WAAW,SAAS;IACxB,mCAAmC;IACnC,EAAE,EAAE,MAAM,CAAA;IACV,WAAW;IACX,IAAI,EAAE,KAAK,GAAG,KAAK,GAAG,OAAO,CAAA;IAC7B,YAAY;IACZ,SAAS,EAAE,MAAM,CAAA;CAClB;AAMD,MAAM,WAAW,SAAU,SAAQ,SAAS;IAC1C,IAAI,EAAE,KAAK,CAAA;IACX,YAAY;IACZ,MAAM,EAAE,MAAM,CAAA;IACd,WAAW;IACX,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB;AAMD,MAAM,WAAW,iBAAkB,SAAQ,SAAS;IAClD,IAAI,EAAE,KAAK,CAAA;IACX,eAAe;IACf,EAAE,EAAE,MAAM,CAAA;IACV,OAAO,EAAE,IAAI,CAAA;IACb,WAAW;IACX,MAAM,EAAE,OAAO,CAAA;CAChB;AAED,MAAM,WAAW,eAAgB,SAAQ,SAAS;IAChD,IAAI,EAAE,KAAK,CAAA;IACX,eAAe;IACf,EAAE,EAAE,MAAM,CAAA;IACV,OAAO,EAAE,KAAK,CAAA;IACd,KAAK,EAAE,OAAO,CAAA;CACf;AAED,MAAM,WAAW,OAAO;IACtB,UAAU;IACV,IAAI,EAAE,SAAS,CAAA;IACf,gBAAgB;IAChB,OAAO,EAAE,MAAM,CAAA;CAChB;AAED,MAAM,MAAM,UAAU,GAAG,iBAAiB,GAAG,eAAe,CAAA;AAE5D,MAAM,MAAM,SAAS,GACjB,WAAW,GACX,YAAY,GACZ,UAAU,GACV,SAAS,GACT,cAAc,GACd,iBAAiB,CAAA;AAMrB,MAAM,WAAW,OAAQ,SAAQ,SAAS;IACxC,IAAI,EAAE,OAAO,CAAA;IACb,UAAU;IACV,KAAK,EAAE,MAAM,CAAA;IACb,WAAW;IACX,IAAI,EAAE,OAAO,CAAA;CACd;AAED,iBAAiB;AACjB,MAAM,MAAM,eAAe,GACvB,sBAAsB,GACtB,KAAK,GACL,kBAAkB,GAClB,oBAAoB,GACpB,gBAAgB,CAAA;AAMpB,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,UAAU,GAAG,OAAO,CAAA;AAM3D,aAAa;AACb,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,GAAG,SAAS,CAQzE;AAED,aAAa;AACb,wBAAgB,qBAAqB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,GAAG,iBAAiB,CAQ3F;AAED,aAAa;AACb,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,GAAG,eAAe,CAQxG;AAED,aAAa;AACb,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAQjE;AAED,eAAe;AACf,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,GAAG,IAAI,CAW/D"}
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/gateway/ws/types.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AA0FH,+CAA+C;AAC/C,OAAO;AACP,+CAA+C;AAE/C,aAAa;AACb,MAAM,UAAU,aAAa,CAAC,MAAc,EAAE,MAAgB;IAC5D,OAAO;QACL,EAAE,EAAE,MAAM,CAAC,UAAU,EAAE;QACvB,IAAI,EAAE,KAAK;QACX,MAAM;QACN,MAAM;QACN,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAA;AACH,CAAC;AAED,aAAa;AACb,MAAM,UAAU,qBAAqB,CAAC,SAAiB,EAAE,MAAe;IACtE,OAAO;QACL,EAAE,EAAE,SAAS;QACb,IAAI,EAAE,KAAK;QACX,OAAO,EAAE,IAAI;QACb,MAAM;QACN,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAA;AACH,CAAC;AAED,aAAa;AACb,MAAM,UAAU,mBAAmB,CAAC,SAAiB,EAAE,IAAe,EAAE,OAAe;IACrF,OAAO;QACL,EAAE,EAAE,SAAS;QACb,IAAI,EAAE,KAAK;QACX,OAAO,EAAE,KAAK;QACd,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE;QACxB,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAA;AACH,CAAC;AAED,aAAa;AACb,MAAM,UAAU,WAAW,CAAC,KAAa,EAAE,IAAa;IACtD,OAAO;QACL,EAAE,EAAE,MAAM,CAAC,UAAU,EAAE;QACvB,IAAI,EAAE,OAAO;QACb,KAAK;QACL,IAAI;QACJ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAA;AACH,CAAC;AAED,eAAe;AACf,MAAM,UAAU,cAAc,CAAC,GAAW;IACxC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAC3B,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ;YAAE,OAAO,IAAI,CAAA;QAChD,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE;YAAE,OAAO,IAAI,CAAA;QACrC,IAAI,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAA;QAC5D,OAAO,GAAmB,CAAA;IAC5B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAA;IACb,CAAC;AAEH,CAAC"}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/gateway/ws/types.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AA2FH,+CAA+C;AAC/C,OAAO;AACP,+CAA+C;AAE/C,aAAa;AACb,MAAM,UAAU,aAAa,CAAC,MAAc,EAAE,MAAgB;IAC5D,OAAO;QACL,EAAE,EAAE,MAAM,CAAC,UAAU,EAAE;QACvB,IAAI,EAAE,KAAK;QACX,MAAM;QACN,MAAM;QACN,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAA;AACH,CAAC;AAED,aAAa;AACb,MAAM,UAAU,qBAAqB,CAAC,SAAiB,EAAE,MAAe;IACtE,OAAO;QACL,EAAE,EAAE,SAAS;QACb,IAAI,EAAE,KAAK;QACX,OAAO,EAAE,IAAI;QACb,MAAM;QACN,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAA;AACH,CAAC;AAED,aAAa;AACb,MAAM,UAAU,mBAAmB,CAAC,SAAiB,EAAE,IAAe,EAAE,OAAe;IACrF,OAAO;QACL,EAAE,EAAE,SAAS;QACb,IAAI,EAAE,KAAK;QACX,OAAO,EAAE,KAAK;QACd,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE;QACxB,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAA;AACH,CAAC;AAED,aAAa;AACb,MAAM,UAAU,WAAW,CAAC,KAAa,EAAE,IAAa;IACtD,OAAO;QACL,EAAE,EAAE,MAAM,CAAC,UAAU,EAAE;QACvB,IAAI,EAAE,OAAO;QACb,KAAK;QACL,IAAI;QACJ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAA;AACH,CAAC;AAED,eAAe;AACf,MAAM,UAAU,cAAc,CAAC,GAAW;IACxC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAC3B,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ;YAAE,OAAO,IAAI,CAAA;QAChD,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE;YAAE,OAAO,IAAI,CAAA;QACrC,IAAI,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAA;QAC5D,OAAO,GAAmB,CAAA;IAC5B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAA;IACb,CAAC;AAEH,CAAC"}
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Graceful Shutdown
3
+ *
4
+ * Registers process signal handlers for clean shutdown in sidecar mode.
5
+ * Works with Tauri's watch_server() which detects process exit and auto-restarts.
6
+ */
7
+ export interface GracefulShutdownOptions {
8
+ close: () => Promise<void>;
9
+ forceExitTimeout?: number;
10
+ memoryThresholdBytes?: number;
11
+ }
12
+ export declare function registerGracefulShutdown(options: GracefulShutdownOptions): () => void;
13
+ //# sourceMappingURL=graceful-shutdown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"graceful-shutdown.d.ts","sourceRoot":"","sources":["../src/graceful-shutdown.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,MAAM,WAAW,uBAAuB;IACtC,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAC1B,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,oBAAoB,CAAC,EAAE,MAAM,CAAA;CAC9B;AAED,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,uBAAuB,GAAG,MAAM,IAAI,CAqErF"}
@@ -0,0 +1,65 @@
1
+ /**
2
+ * Graceful Shutdown
3
+ *
4
+ * Registers process signal handlers for clean shutdown in sidecar mode.
5
+ * Works with Tauri's watch_server() which detects process exit and auto-restarts.
6
+ */
7
+ export function registerGracefulShutdown(options) {
8
+ const { close, forceExitTimeout = 10_000, memoryThresholdBytes = 512 * 1024 * 1024, } = options;
9
+ let shuttingDown = false;
10
+ async function shutdown(reason, exitCode) {
11
+ if (shuttingDown)
12
+ return;
13
+ shuttingDown = true;
14
+ console.log(`[shutdown] Triggered by: ${reason}`);
15
+ // Force-exit timer — ensures we don't hang forever
16
+ const timer = setTimeout(() => {
17
+ console.error(`[shutdown] Force exit after ${forceExitTimeout}ms timeout`);
18
+ process.exit(exitCode || 1);
19
+ }, forceExitTimeout);
20
+ timer.unref(); // Don't block process exit
21
+ try {
22
+ await close();
23
+ console.log('[shutdown] Graceful shutdown complete');
24
+ }
25
+ catch (err) {
26
+ console.error('[shutdown] Error during shutdown:', err);
27
+ }
28
+ process.exit(exitCode);
29
+ }
30
+ // Named function references for proper process.off() removal
31
+ function handleSigterm() { shutdown('SIGTERM', 0); }
32
+ function handleSigint() { shutdown('SIGINT', 0); }
33
+ function handleUncaughtException(err) {
34
+ console.error('[shutdown] Uncaught exception:', err);
35
+ shutdown('uncaughtException', 1);
36
+ }
37
+ function handleUnhandledRejection(reason) {
38
+ console.error('[shutdown] Unhandled rejection:', reason);
39
+ // Log only — don't crash the process
40
+ }
41
+ // Register handlers
42
+ process.on('SIGTERM', handleSigterm);
43
+ process.on('SIGINT', handleSigint);
44
+ process.on('uncaughtException', handleUncaughtException);
45
+ process.on('unhandledRejection', handleUnhandledRejection);
46
+ // Memory watchdog
47
+ const watcher = setInterval(() => {
48
+ const rss = process.memoryUsage().rss;
49
+ if (rss > memoryThresholdBytes) {
50
+ const mb = Math.round(rss / 1024 / 1024);
51
+ const threshold = Math.round(memoryThresholdBytes / 1024 / 1024);
52
+ console.warn(`[watchdog] Memory usage ${mb}MB exceeds threshold ${threshold}MB`);
53
+ }
54
+ }, 30_000);
55
+ watcher.unref();
56
+ // Return deregister function
57
+ return () => {
58
+ process.off('SIGTERM', handleSigterm);
59
+ process.off('SIGINT', handleSigint);
60
+ process.off('uncaughtException', handleUncaughtException);
61
+ process.off('unhandledRejection', handleUnhandledRejection);
62
+ clearInterval(watcher);
63
+ };
64
+ }
65
+ //# sourceMappingURL=graceful-shutdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"graceful-shutdown.js","sourceRoot":"","sources":["../src/graceful-shutdown.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAQH,MAAM,UAAU,wBAAwB,CAAC,OAAgC;IACvE,MAAM,EACJ,KAAK,EACL,gBAAgB,GAAG,MAAM,EACzB,oBAAoB,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,GACzC,GAAG,OAAO,CAAA;IAEX,IAAI,YAAY,GAAG,KAAK,CAAA;IAExB,KAAK,UAAU,QAAQ,CAAC,MAAc,EAAE,QAAgB;QACtD,IAAI,YAAY;YAAE,OAAM;QACxB,YAAY,GAAG,IAAI,CAAA;QAEnB,OAAO,CAAC,GAAG,CAAC,4BAA4B,MAAM,EAAE,CAAC,CAAA;QAEjD,mDAAmD;QACnD,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,OAAO,CAAC,KAAK,CAAC,+BAA+B,gBAAgB,YAAY,CAAC,CAAA;YAC1E,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAA;QAC7B,CAAC,EAAE,gBAAgB,CAAC,CAAA;QACpB,KAAK,CAAC,KAAK,EAAE,CAAA,CAAC,2BAA2B;QAEzC,IAAI,CAAC;YACH,MAAM,KAAK,EAAE,CAAA;YACb,OAAO,CAAC,GAAG,CAAC,uCAAuC,CAAC,CAAA;QACtD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,mCAAmC,EAAE,GAAG,CAAC,CAAA;QACzD,CAAC;QAED,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACxB,CAAC;IAED,6DAA6D;IAC7D,SAAS,aAAa,KAAK,QAAQ,CAAC,SAAS,EAAE,CAAC,CAAC,CAAA,CAAC,CAAC;IACnD,SAAS,YAAY,KAAK,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAA,CAAC,CAAC;IACjD,SAAS,uBAAuB,CAAC,GAAU;QACzC,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,GAAG,CAAC,CAAA;QACpD,QAAQ,CAAC,mBAAmB,EAAE,CAAC,CAAC,CAAA;IAClC,CAAC;IACD,SAAS,wBAAwB,CAAC,MAAe;QAC/C,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,MAAM,CAAC,CAAA;QACxD,qCAAqC;IACvC,CAAC;IAED,oBAAoB;IACpB,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;IACpC,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;IAClC,OAAO,CAAC,EAAE,CAAC,mBAAmB,EAAE,uBAAuB,CAAC,CAAA;IACxD,OAAO,CAAC,EAAE,CAAC,oBAAoB,EAAE,wBAAwB,CAAC,CAAA;IAE1D,kBAAkB;IAClB,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE;QAC/B,MAAM,GAAG,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,GAAG,CAAA;QACrC,IAAI,GAAG,GAAG,oBAAoB,EAAE,CAAC;YAC/B,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,CAAC,CAAA;YACxC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,oBAAoB,GAAG,IAAI,GAAG,IAAI,CAAC,CAAA;YAChE,OAAO,CAAC,IAAI,CAAC,2BAA2B,EAAE,wBAAwB,SAAS,IAAI,CAAC,CAAA;QAClF,CAAC;IACH,CAAC,EAAE,MAAM,CAAC,CAAA;IACV,OAAO,CAAC,KAAK,EAAE,CAAA;IAEf,6BAA6B;IAC7B,OAAO,GAAG,EAAE;QACV,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;QACrC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QACnC,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,uBAAuB,CAAC,CAAA;QACzD,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,wBAAwB,CAAC,CAAA;QAC3D,aAAa,CAAC,OAAO,CAAC,CAAA;IACxB,CAAC,CAAA;AACH,CAAC"}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * FileLogger — 日志文件持久化
3
+ *
4
+ * 按天切割日志文件,支持文件大小限制切割和过期清理。
5
+ */
6
+ import type { LogEntry } from '../gateway/ws/data-types.js';
7
+ export interface FileLoggerOptions {
8
+ /** 日志目录路径(默认: ./logs) */
9
+ dir?: string;
10
+ /** 日志保留天数(默认: 7) */
11
+ retentionDays?: number;
12
+ /** 单文件最大字节数(默认: 50MB) */
13
+ maxFileSize?: number;
14
+ }
15
+ export declare class FileLogger {
16
+ private dir;
17
+ private retentionDays;
18
+ private maxFileSize;
19
+ private currentStream;
20
+ private currentDate;
21
+ private fileIndex;
22
+ private currentFilePath;
23
+ constructor(options?: FileLoggerOptions);
24
+ /** 写入一条日志 */
25
+ addLog(entry: LogEntry): void;
26
+ /** 关闭文件流(异步,确保数据刷新到磁盘) */
27
+ dispose(): Promise<void>;
28
+ private ensureDir;
29
+ /** 检查日期是否切换,必要时轮转 */
30
+ private ensureDate;
31
+ private getToday;
32
+ /** 格式化日志行 */
33
+ private formatLine;
34
+ /** 切换到新的日志文件 */
35
+ private rotateStream;
36
+ /** 生成文件路径 */
37
+ private getFilePath;
38
+ /** 检查当前文件大小,超过限制时切割 */
39
+ private checkFileSize;
40
+ /** 清理过期日志文件 */
41
+ private cleanupExpired;
42
+ }
43
+ //# sourceMappingURL=file-logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-logger.d.ts","sourceRoot":"","sources":["../../src/logging/file-logger.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAA;AAE3D,MAAM,WAAW,iBAAiB;IAChC,yBAAyB;IACzB,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,oBAAoB;IACpB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,yBAAyB;IACzB,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB;AAMD,qBAAa,UAAU;IACrB,OAAO,CAAC,GAAG,CAAQ;IACnB,OAAO,CAAC,aAAa,CAAQ;IAC7B,OAAO,CAAC,WAAW,CAAQ;IAC3B,OAAO,CAAC,aAAa,CAAoD;IACzE,OAAO,CAAC,WAAW,CAAa;IAChC,OAAO,CAAC,SAAS,CAAI;IACrB,OAAO,CAAC,eAAe,CAAK;gBAEhB,OAAO,GAAE,iBAAsB;IAU3C,aAAa;IACb,MAAM,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAO7B,0BAA0B;IACpB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAa9B,OAAO,CAAC,SAAS;IAMjB,qBAAqB;IACrB,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,QAAQ;IAIhB,aAAa;IACb,OAAO,CAAC,UAAU;IAMlB,gBAAgB;IAChB,OAAO,CAAC,YAAY;IAcpB,aAAa;IACb,OAAO,CAAC,WAAW;IAOnB,uBAAuB;IACvB,OAAO,CAAC,aAAa;IAkBrB,eAAe;IACf,OAAO,CAAC,cAAc;CAuBvB"}
@@ -0,0 +1,134 @@
1
+ /**
2
+ * FileLogger — 日志文件持久化
3
+ *
4
+ * 按天切割日志文件,支持文件大小限制切割和过期清理。
5
+ */
6
+ import { createWriteStream, existsSync, mkdirSync, readdirSync, statSync, unlinkSync } from 'node:fs';
7
+ import { join } from 'node:path';
8
+ const DEFAULT_DIR = 'logs';
9
+ const DEFAULT_RETENTION_DAYS = 7;
10
+ const MAX_FILE_SIZE = 50 * 1024 * 1024; // 50MB
11
+ export class FileLogger {
12
+ dir;
13
+ retentionDays;
14
+ maxFileSize;
15
+ currentStream = null;
16
+ currentDate = '';
17
+ fileIndex = 0;
18
+ currentFilePath = '';
19
+ constructor(options = {}) {
20
+ this.dir = options.dir ?? DEFAULT_DIR;
21
+ this.retentionDays = options.retentionDays ?? DEFAULT_RETENTION_DAYS;
22
+ this.maxFileSize = options.maxFileSize ?? MAX_FILE_SIZE;
23
+ this.ensureDir();
24
+ this.cleanupExpired();
25
+ this.rotateStream();
26
+ }
27
+ /** 写入一条日志 */
28
+ addLog(entry) {
29
+ this.ensureDate();
30
+ this.checkFileSize();
31
+ const line = this.formatLine(entry);
32
+ this.currentStream?.write(line + '\n');
33
+ }
34
+ /** 关闭文件流(异步,确保数据刷新到磁盘) */
35
+ async dispose() {
36
+ if (this.currentStream) {
37
+ await new Promise((resolve) => {
38
+ this.currentStream.end(() => resolve());
39
+ });
40
+ this.currentStream = null;
41
+ }
42
+ }
43
+ // ============================================
44
+ // 私有方法
45
+ // ============================================
46
+ ensureDir() {
47
+ if (!existsSync(this.dir)) {
48
+ mkdirSync(this.dir, { recursive: true });
49
+ }
50
+ }
51
+ /** 检查日期是否切换,必要时轮转 */
52
+ ensureDate() {
53
+ const today = this.getToday();
54
+ if (today !== this.currentDate) {
55
+ this.rotateStream();
56
+ }
57
+ }
58
+ getToday() {
59
+ return new Date().toISOString().slice(0, 10);
60
+ }
61
+ /** 格式化日志行 */
62
+ formatLine(entry) {
63
+ const ts = new Date(entry.timestamp).toISOString().replace('T', ' ').slice(0, 23);
64
+ const level = entry.level.toUpperCase().padEnd(5);
65
+ return `${ts} [${level}] [${entry.source}] ${entry.message}`;
66
+ }
67
+ /** 切换到新的日志文件 */
68
+ rotateStream() {
69
+ if (this.currentStream) {
70
+ this.currentStream.end();
71
+ }
72
+ this.currentDate = this.getToday();
73
+ this.fileIndex = 0;
74
+ this.currentFilePath = this.getFilePath();
75
+ this.currentStream = createWriteStream(this.currentFilePath, { flags: 'a' });
76
+ this.currentStream.on('error', () => {
77
+ // 防止 uncaught exception(如文件被删除后异步写入报错)
78
+ });
79
+ }
80
+ /** 生成文件路径 */
81
+ getFilePath() {
82
+ if (this.fileIndex === 0) {
83
+ return join(this.dir, `hive-${this.currentDate}.log`);
84
+ }
85
+ return join(this.dir, `hive-${this.currentDate}.${this.fileIndex}.log`);
86
+ }
87
+ /** 检查当前文件大小,超过限制时切割 */
88
+ checkFileSize() {
89
+ if (!this.currentFilePath)
90
+ return;
91
+ try {
92
+ const stat = statSync(this.currentFilePath);
93
+ if (stat.size >= this.maxFileSize) {
94
+ this.fileIndex++;
95
+ this.currentStream?.end();
96
+ this.currentFilePath = this.getFilePath();
97
+ this.currentStream = createWriteStream(this.currentFilePath, { flags: 'a' });
98
+ this.currentStream.on('error', () => {
99
+ // 防止 uncaught exception
100
+ });
101
+ }
102
+ }
103
+ catch {
104
+ // 文件可能尚未写入磁盘,忽略
105
+ }
106
+ }
107
+ /** 清理过期日志文件 */
108
+ cleanupExpired() {
109
+ if (!existsSync(this.dir))
110
+ return;
111
+ try {
112
+ const files = readdirSync(this.dir);
113
+ const cutoff = Date.now() - this.retentionDays * 24 * 60 * 60 * 1000;
114
+ for (const file of files) {
115
+ if (!file.endsWith('.log'))
116
+ continue;
117
+ try {
118
+ const filePath = join(this.dir, file);
119
+ const stat = statSync(filePath);
120
+ if (stat.mtimeMs < cutoff) {
121
+ unlinkSync(filePath);
122
+ }
123
+ }
124
+ catch {
125
+ // 忽略单个文件错误
126
+ }
127
+ }
128
+ }
129
+ catch {
130
+ // 忽略目录读取错误
131
+ }
132
+ }
133
+ }
134
+ //# sourceMappingURL=file-logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-logger.js","sourceRoot":"","sources":["../../src/logging/file-logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Hive Logger — pino 封装
3
+ *
4
+ * 统一日志入口:
5
+ * - console 输出(带颜色 + 时间戳)
6
+ * - logBuffer 内存缓冲(供 log.tail API 使用)
7
+ * - 文件持久化(日切割 + 大小切割 + 过期清理)
8
+ */
9
+ import pino from 'pino';
10
+ import type { LogEntry } from '../gateway/ws/data-types.js';
11
+ import type { LogBuffer } from '../gateway/ws/log-buffer.js';
12
+ export interface HiveLoggerOptions {
13
+ dir: string;
14
+ retentionDays?: number;
15
+ maxFileSize?: number;
16
+ logLevel?: string;
17
+ }
18
+ export interface HiveLogger {
19
+ logger: pino.Logger;
20
+ overrideConsole(): () => void;
21
+ dispose(): Promise<void>;
22
+ listLogDates(): string[];
23
+ getLogsByDate(date: string, limit?: number, offset?: number): LogEntry[];
24
+ }
25
+ export declare function createHiveLogger(logBuffer: LogBuffer, broadcastLog: (entry: LogEntry) => void, options: HiveLoggerOptions): HiveLogger;
26
+ //# sourceMappingURL=hive-logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hive-logger.d.ts","sourceRoot":"","sources":["../../src/logging/hive-logger.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAKH,OAAO,IAAI,MAAM,MAAM,CAAA;AACvB,OAAO,KAAK,EAAE,QAAQ,EAAY,MAAM,6BAA6B,CAAA;AACrE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAA;AAM5D,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,MAAM,CAAA;IACX,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB;AAED,MAAM,WAAW,UAAU;IACzB,MAAM,EAAE,IAAI,CAAC,MAAM,CAAA;IACnB,eAAe,IAAI,MAAM,IAAI,CAAA;IAC7B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;IACxB,YAAY,IAAI,MAAM,EAAE,CAAA;IACxB,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,QAAQ,EAAE,CAAA;CACzE;AA6BD,wBAAgB,gBAAgB,CAC9B,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,CAAC,KAAK,EAAE,QAAQ,KAAK,IAAI,EACvC,OAAO,EAAE,iBAAiB,GACzB,UAAU,CA4OZ"}