@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.
- package/dist/bootstrap.d.ts +3 -4
- package/dist/bootstrap.d.ts.map +1 -1
- package/dist/bootstrap.js +17 -24
- package/dist/bootstrap.js.map +1 -1
- package/dist/cli/commands/skill/index.d.ts +10 -0
- package/dist/cli/commands/skill/index.d.ts.map +1 -0
- package/dist/cli/commands/skill/index.js +174 -0
- package/dist/cli/commands/skill/index.js.map +1 -0
- package/dist/cli/commands/skill/installer.d.ts +75 -0
- package/dist/cli/commands/skill/installer.d.ts.map +1 -0
- package/dist/cli/commands/skill/installer.js +347 -0
- package/dist/cli/commands/skill/installer.js.map +1 -0
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +3 -0
- package/dist/cli/index.js.map +1 -1
- package/dist/gateway/http.d.ts +2 -1
- package/dist/gateway/http.d.ts.map +1 -1
- package/dist/gateway/http.js +17 -3
- package/dist/gateway/http.js.map +1 -1
- package/dist/gateway/ws/admin-handler.d.ts +24 -47
- package/dist/gateway/ws/admin-handler.d.ts.map +1 -1
- package/dist/gateway/ws/admin-handler.js +76 -465
- package/dist/gateway/ws/admin-handler.js.map +1 -1
- package/dist/gateway/ws/chat-handler.d.ts +42 -0
- package/dist/gateway/ws/chat-handler.d.ts.map +1 -0
- package/dist/gateway/ws/chat-handler.js +258 -0
- package/dist/gateway/ws/chat-handler.js.map +1 -0
- package/dist/gateway/ws/config-store.d.ts +16 -0
- package/dist/gateway/ws/config-store.d.ts.map +1 -0
- package/dist/gateway/ws/config-store.js +68 -0
- package/dist/gateway/ws/config-store.js.map +1 -0
- package/dist/gateway/ws/data-types.d.ts +3 -0
- package/dist/gateway/ws/data-types.d.ts.map +1 -1
- package/dist/gateway/ws/handler-context.d.ts +41 -0
- package/dist/gateway/ws/handler-context.d.ts.map +1 -0
- package/dist/gateway/ws/handler-context.js +8 -0
- package/dist/gateway/ws/handler-context.js.map +1 -0
- package/dist/gateway/ws/handlers/base.d.ts +14 -0
- package/dist/gateway/ws/handlers/base.d.ts.map +1 -0
- package/dist/gateway/ws/handlers/base.js +13 -0
- package/dist/gateway/ws/handlers/base.js.map +1 -0
- package/dist/gateway/ws/handlers/config-handler.d.ts +14 -0
- package/dist/gateway/ws/handlers/config-handler.d.ts.map +1 -0
- package/dist/gateway/ws/handlers/config-handler.js +53 -0
- package/dist/gateway/ws/handlers/config-handler.js.map +1 -0
- package/dist/gateway/ws/handlers/index.d.ts +10 -0
- package/dist/gateway/ws/handlers/index.d.ts.map +1 -0
- package/dist/gateway/ws/handlers/index.js +10 -0
- package/dist/gateway/ws/handlers/index.js.map +1 -0
- package/dist/gateway/ws/handlers/log-handler.d.ts +20 -0
- package/dist/gateway/ws/handlers/log-handler.d.ts.map +1 -0
- package/dist/gateway/ws/handlers/log-handler.js +65 -0
- package/dist/gateway/ws/handlers/log-handler.js.map +1 -0
- package/dist/gateway/ws/handlers/plugin-handler.d.ts +29 -0
- package/dist/gateway/ws/handlers/plugin-handler.d.ts.map +1 -0
- package/dist/gateway/ws/handlers/plugin-handler.js +197 -0
- package/dist/gateway/ws/handlers/plugin-handler.js.map +1 -0
- package/dist/gateway/ws/handlers/session-handler.d.ts +14 -0
- package/dist/gateway/ws/handlers/session-handler.d.ts.map +1 -0
- package/dist/gateway/ws/handlers/session-handler.js +36 -0
- package/dist/gateway/ws/handlers/session-handler.js.map +1 -0
- package/dist/gateway/ws/handlers/status-handler.d.ts +23 -0
- package/dist/gateway/ws/handlers/status-handler.d.ts.map +1 -0
- package/dist/gateway/ws/handlers/status-handler.js +136 -0
- package/dist/gateway/ws/handlers/status-handler.js.map +1 -0
- package/dist/gateway/ws/log-buffer.d.ts +1 -0
- package/dist/gateway/ws/log-buffer.d.ts.map +1 -1
- package/dist/gateway/ws/log-buffer.js +8 -0
- package/dist/gateway/ws/log-buffer.js.map +1 -1
- package/dist/gateway/ws/types.d.ts +1 -1
- package/dist/gateway/ws/types.d.ts.map +1 -1
- package/dist/gateway/ws/types.js.map +1 -1
- package/dist/graceful-shutdown.d.ts +13 -0
- package/dist/graceful-shutdown.d.ts.map +1 -0
- package/dist/graceful-shutdown.js +65 -0
- package/dist/graceful-shutdown.js.map +1 -0
- package/dist/logging/file-logger.d.ts +43 -0
- package/dist/logging/file-logger.d.ts.map +1 -0
- package/dist/logging/file-logger.js +134 -0
- package/dist/logging/file-logger.js.map +1 -0
- package/dist/logging/hive-logger.d.ts +26 -0
- package/dist/logging/hive-logger.d.ts.map +1 -0
- package/dist/logging/hive-logger.js +251 -0
- package/dist/logging/hive-logger.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.d.ts.map +1 -1
- package/dist/main.js +68 -19
- package/dist/main.js.map +1 -1
- package/dist/plugin-manager/installer.d.ts +1 -1
- package/dist/plugin-manager/installer.d.ts.map +1 -1
- package/dist/plugin-manager/installer.js +84 -17
- package/dist/plugin-manager/installer.js.map +1 -1
- package/dist/plugin-manager/searcher.js +1 -1
- package/dist/plugin-manager/searcher.js.map +1 -1
- package/dist/plugin-manager/types.d.ts +1 -0
- package/dist/plugin-manager/types.d.ts.map +1 -1
- package/dist/plugins.d.ts +18 -0
- package/dist/plugins.d.ts.map +1 -1
- package/dist/plugins.js +50 -22
- package/dist/plugins.js.map +1 -1
- 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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"}
|
|
@@ -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;
|
|
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,
|
|
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;
|
|
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;
|
|
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":"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"}
|
|
@@ -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"}
|