@cicctencent/agent-midway 0.1.1

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 (160) hide show
  1. package/README.md +280 -0
  2. package/dist/adapters/express.d.ts +8 -0
  3. package/dist/adapters/express.js +91 -0
  4. package/dist/adapters/index.d.ts +5 -0
  5. package/dist/adapters/index.js +21 -0
  6. package/dist/adapters/koa.d.ts +3 -0
  7. package/dist/adapters/koa.js +75 -0
  8. package/dist/adapters/midway.d.ts +5 -0
  9. package/dist/adapters/midway.js +11 -0
  10. package/dist/adapters/next.d.ts +12 -0
  11. package/dist/adapters/next.js +89 -0
  12. package/dist/adapters/shared.d.ts +4 -0
  13. package/dist/adapters/shared.js +31 -0
  14. package/dist/channel/dingtalk.d.ts +18 -0
  15. package/dist/channel/dingtalk.js +68 -0
  16. package/dist/channel/feishu.d.ts +20 -0
  17. package/dist/channel/feishu.js +96 -0
  18. package/dist/channel/index.d.ts +46 -0
  19. package/dist/channel/index.js +311 -0
  20. package/dist/channel/types.d.ts +77 -0
  21. package/dist/channel/types.js +7 -0
  22. package/dist/channel/wecom.d.ts +22 -0
  23. package/dist/channel/wecom.js +106 -0
  24. package/dist/component.d.ts +49 -0
  25. package/dist/component.js +129 -0
  26. package/dist/connector/calendar-adapter.d.ts +19 -0
  27. package/dist/connector/calendar-adapter.js +236 -0
  28. package/dist/connector/db-adapter.d.ts +28 -0
  29. package/dist/connector/db-adapter.js +193 -0
  30. package/dist/connector/email-adapter.d.ts +23 -0
  31. package/dist/connector/email-adapter.js +192 -0
  32. package/dist/connector/fs-adapter.d.ts +15 -0
  33. package/dist/connector/fs-adapter.js +199 -0
  34. package/dist/connector/http-adapter.d.ts +29 -0
  35. package/dist/connector/http-adapter.js +181 -0
  36. package/dist/connector/index.d.ts +24 -0
  37. package/dist/connector/index.js +454 -0
  38. package/dist/connector/mcp-adapter.d.ts +27 -0
  39. package/dist/connector/mcp-adapter.js +156 -0
  40. package/dist/connector/mq-adapter.d.ts +25 -0
  41. package/dist/connector/mq-adapter.js +181 -0
  42. package/dist/connector/types.d.ts +205 -0
  43. package/dist/connector/types.js +9 -0
  44. package/dist/controller/a2a.controller.d.ts +41 -0
  45. package/dist/controller/a2a.controller.js +150 -0
  46. package/dist/controller/agent-profile.controller.d.ts +97 -0
  47. package/dist/controller/agent-profile.controller.js +200 -0
  48. package/dist/controller/agent.controller.d.ts +199 -0
  49. package/dist/controller/agent.controller.js +414 -0
  50. package/dist/controller/application.controller.d.ts +113 -0
  51. package/dist/controller/application.controller.js +217 -0
  52. package/dist/controller/automation.controller.d.ts +113 -0
  53. package/dist/controller/automation.controller.js +246 -0
  54. package/dist/controller/channel.controller.d.ts +73 -0
  55. package/dist/controller/channel.controller.js +183 -0
  56. package/dist/controller/chat.controller.d.ts +188 -0
  57. package/dist/controller/chat.controller.js +375 -0
  58. package/dist/controller/connector.controller.d.ts +134 -0
  59. package/dist/controller/connector.controller.js +257 -0
  60. package/dist/controller/knowledge-base.controller.d.ts +157 -0
  61. package/dist/controller/knowledge-base.controller.js +278 -0
  62. package/dist/controller/mcp-server.controller.d.ts +115 -0
  63. package/dist/controller/mcp-server.controller.js +236 -0
  64. package/dist/controller/model-config.controller.d.ts +139 -0
  65. package/dist/controller/model-config.controller.js +274 -0
  66. package/dist/controller/observability.controller.d.ts +124 -0
  67. package/dist/controller/observability.controller.js +142 -0
  68. package/dist/controller/security.controller.d.ts +91 -0
  69. package/dist/controller/security.controller.js +172 -0
  70. package/dist/controller/settings.controller.d.ts +83 -0
  71. package/dist/controller/settings.controller.js +280 -0
  72. package/dist/core/ai-workstation.d.ts +17 -0
  73. package/dist/core/ai-workstation.js +129 -0
  74. package/dist/core/index.d.ts +4 -0
  75. package/dist/core/index.js +20 -0
  76. package/dist/core/service-container.d.ts +12 -0
  77. package/dist/core/service-container.js +54 -0
  78. package/dist/core/sse.d.ts +6 -0
  79. package/dist/core/sse.js +56 -0
  80. package/dist/core/types.d.ts +72 -0
  81. package/dist/core/types.js +2 -0
  82. package/dist/dto/agent.dto.d.ts +21 -0
  83. package/dist/dto/agent.dto.js +79 -0
  84. package/dist/dto/ai-config.dto.d.ts +67 -0
  85. package/dist/dto/ai-config.dto.js +249 -0
  86. package/dist/dto/chat.dto.d.ts +40 -0
  87. package/dist/dto/chat.dto.js +122 -0
  88. package/dist/index.d.ts +101 -0
  89. package/dist/index.js +195 -0
  90. package/dist/memory/db-store.d.ts +33 -0
  91. package/dist/memory/db-store.js +143 -0
  92. package/dist/memory/index.d.ts +187 -0
  93. package/dist/memory/index.js +443 -0
  94. package/dist/model/ai-agent-profile.entity.d.ts +32 -0
  95. package/dist/model/ai-agent-profile.entity.js +289 -0
  96. package/dist/model/ai-application.entity.d.ts +20 -0
  97. package/dist/model/ai-application.entity.js +166 -0
  98. package/dist/model/ai-chat-memory.entity.d.ts +16 -0
  99. package/dist/model/ai-chat-memory.entity.js +123 -0
  100. package/dist/model/ai-chat-message.entity.d.ts +16 -0
  101. package/dist/model/ai-chat-message.entity.js +122 -0
  102. package/dist/model/ai-chat-skill.entity.d.ts +19 -0
  103. package/dist/model/ai-chat-skill.entity.js +155 -0
  104. package/dist/model/ai-chat-thread.entity.d.ts +15 -0
  105. package/dist/model/ai-chat-thread.entity.js +113 -0
  106. package/dist/model/ai-chat-workspace.entity.d.ts +17 -0
  107. package/dist/model/ai-chat-workspace.entity.js +136 -0
  108. package/dist/model/ai-kb-document.entity.d.ts +16 -0
  109. package/dist/model/ai-kb-document.entity.js +122 -0
  110. package/dist/model/ai-knowledge-base.entity.d.ts +22 -0
  111. package/dist/model/ai-knowledge-base.entity.js +185 -0
  112. package/dist/model/ai-mcp-server.entity.d.ts +23 -0
  113. package/dist/model/ai-mcp-server.entity.js +198 -0
  114. package/dist/model/ai-model-config.entity.d.ts +24 -0
  115. package/dist/model/ai-model-config.entity.js +200 -0
  116. package/dist/service/a2a.service.d.ts +142 -0
  117. package/dist/service/a2a.service.js +537 -0
  118. package/dist/service/agent-profile.service.d.ts +34 -0
  119. package/dist/service/agent-profile.service.js +110 -0
  120. package/dist/service/agent-server.service.d.ts +91 -0
  121. package/dist/service/agent-server.service.js +634 -0
  122. package/dist/service/agent-task-queue.service.d.ts +98 -0
  123. package/dist/service/agent-task-queue.service.js +283 -0
  124. package/dist/service/ai-chat.service.d.ts +103 -0
  125. package/dist/service/ai-chat.service.js +431 -0
  126. package/dist/service/ai-skill.service.d.ts +116 -0
  127. package/dist/service/ai-skill.service.js +457 -0
  128. package/dist/service/application.service.d.ts +42 -0
  129. package/dist/service/application.service.js +139 -0
  130. package/dist/service/automation.service.d.ts +37 -0
  131. package/dist/service/automation.service.js +196 -0
  132. package/dist/service/connector.service.d.ts +136 -0
  133. package/dist/service/connector.service.js +524 -0
  134. package/dist/service/knowledge-base.service.d.ts +138 -0
  135. package/dist/service/knowledge-base.service.js +528 -0
  136. package/dist/service/mcp-server.service.d.ts +39 -0
  137. package/dist/service/mcp-server.service.js +143 -0
  138. package/dist/service/model-config.service.d.ts +57 -0
  139. package/dist/service/model-config.service.js +168 -0
  140. package/dist/service/observability.service.d.ts +145 -0
  141. package/dist/service/observability.service.js +281 -0
  142. package/dist/service/openai.service.d.ts +88 -0
  143. package/dist/service/openai.service.js +406 -0
  144. package/dist/service/prompt-builder.service.d.ts +50 -0
  145. package/dist/service/prompt-builder.service.js +246 -0
  146. package/dist/tools/code-exec.tool.d.ts +37 -0
  147. package/dist/tools/code-exec.tool.js +162 -0
  148. package/dist/tools/datetime.tool.d.ts +21 -0
  149. package/dist/tools/datetime.tool.js +379 -0
  150. package/dist/tools/http-request.tool.d.ts +43 -0
  151. package/dist/tools/http-request.tool.js +455 -0
  152. package/dist/tools/registry.d.ts +71 -0
  153. package/dist/tools/registry.js +77 -0
  154. package/dist/tools/text-process.tool.d.ts +7 -0
  155. package/dist/tools/text-process.tool.js +366 -0
  156. package/dist/tools/web-search.tool.d.ts +28 -0
  157. package/dist/tools/web-search.tool.js +304 -0
  158. package/dist/types.d.ts +70 -0
  159. package/dist/types.js +7 -0
  160. package/package.json +69 -0
@@ -0,0 +1,281 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var ObservabilityService_1;
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.ObservabilityService = void 0;
11
+ const core_1 = require("@midwayjs/core");
12
+ const midwayjs_base_1 = require("@cicctencent/midwayjs-base");
13
+ /**
14
+ * 可观测性服务
15
+ * 提供链路追踪、指标记录、仪表板和系统健康监控
16
+ */
17
+ let ObservabilityService = ObservabilityService_1 = class ObservabilityService extends midwayjs_base_1.BaseService {
18
+ constructor() {
19
+ super(...arguments);
20
+ /** 追踪记录环形缓冲区 */
21
+ this.traceBuffer = [];
22
+ this.traceIndex = 0;
23
+ /** 指标记录环形缓冲区 */
24
+ this.metricBuffer = [];
25
+ this.metricIndex = 0;
26
+ /** 自增 ID 计数器 */
27
+ this.traceIdCounter = 0;
28
+ this.metricIdCounter = 0;
29
+ /** 服务启动时间 */
30
+ this.startTime = Date.now();
31
+ }
32
+ // ===================== 链路追踪 =====================
33
+ /**
34
+ * 记录链路追踪数据
35
+ */
36
+ recordTrace(trace) {
37
+ const record = {
38
+ ...trace,
39
+ id: `trace_${++this.traceIdCounter}`,
40
+ timestamp: trace.timestamp || new Date().toISOString(),
41
+ };
42
+ if (this.traceBuffer.length < ObservabilityService_1.MAX_TRACES) {
43
+ this.traceBuffer.push(record);
44
+ }
45
+ else {
46
+ this.traceBuffer[this.traceIndex] = record;
47
+ }
48
+ this.traceIndex =
49
+ (this.traceIndex + 1) % ObservabilityService_1.MAX_TRACES;
50
+ return record;
51
+ }
52
+ /**
53
+ * 查询追踪记录
54
+ */
55
+ getTraces(options = {}) {
56
+ let results = [...this.traceBuffer];
57
+ if (options.traceId) {
58
+ results = results.filter(t => t.traceId === options.traceId);
59
+ }
60
+ if (options.threadId !== undefined) {
61
+ results = results.filter(t => t.threadId === options.threadId);
62
+ }
63
+ if (options.action) {
64
+ results = results.filter(t => t.action === options.action);
65
+ }
66
+ if (options.status) {
67
+ results = results.filter(t => t.status === options.status);
68
+ }
69
+ if (options.startTime) {
70
+ results = results.filter(t => t.timestamp >= options.startTime);
71
+ }
72
+ if (options.endTime) {
73
+ results = results.filter(t => t.timestamp <= options.endTime);
74
+ }
75
+ // 按时间倒序
76
+ results.sort((a, b) => b.timestamp.localeCompare(a.timestamp));
77
+ const total = results.length;
78
+ const page = options.page || 1;
79
+ const pageSize = options.pageSize || 20;
80
+ const start = (page - 1) * pageSize;
81
+ const list = results.slice(start, start + pageSize);
82
+ return { list, total, page, pageSize };
83
+ }
84
+ /**
85
+ * 获取单个追踪详情
86
+ */
87
+ getTraceById(traceId) {
88
+ return this.traceBuffer.find(t => t.traceId === traceId) || null;
89
+ }
90
+ // ===================== 指标记录 =====================
91
+ /**
92
+ * 记录指标数据
93
+ */
94
+ recordMetric(metric) {
95
+ const record = {
96
+ ...metric,
97
+ id: `metric_${++this.metricIdCounter}`,
98
+ timestamp: metric.timestamp || new Date().toISOString(),
99
+ };
100
+ if (this.metricBuffer.length < ObservabilityService_1.MAX_METRICS) {
101
+ this.metricBuffer.push(record);
102
+ }
103
+ else {
104
+ this.metricBuffer[this.metricIndex] = record;
105
+ }
106
+ this.metricIndex =
107
+ (this.metricIndex + 1) % ObservabilityService_1.MAX_METRICS;
108
+ return record;
109
+ }
110
+ /**
111
+ * 查询指标
112
+ */
113
+ getMetrics(options = {}) {
114
+ let results = [...this.metricBuffer];
115
+ if (options.name) {
116
+ results = results.filter(m => m.name === options.name);
117
+ }
118
+ if (options.startTime) {
119
+ results = results.filter(m => m.timestamp >= options.startTime);
120
+ }
121
+ if (options.endTime) {
122
+ results = results.filter(m => m.timestamp <= options.endTime);
123
+ }
124
+ results.sort((a, b) => b.timestamp.localeCompare(a.timestamp));
125
+ const total = results.length;
126
+ const page = options.page || 1;
127
+ const pageSize = options.pageSize || 20;
128
+ const start = (page - 1) * pageSize;
129
+ const list = results.slice(start, start + pageSize);
130
+ return { list, total, page, pageSize };
131
+ }
132
+ // ===================== 仪表板 =====================
133
+ /**
134
+ * 获取仪表板数据
135
+ */
136
+ getDashboard() {
137
+ const traces = this.traceBuffer;
138
+ const totalRequests = traces.length;
139
+ const successCount = traces.filter(t => t.status === 'success').length;
140
+ const errorCount = traces.filter(t => t.status === 'error').length;
141
+ const timeoutCount = traces.filter(t => t.status === 'timeout').length;
142
+ const successRate = totalRequests > 0
143
+ ? Math.round((successCount / totalRequests) * 10000) / 100
144
+ : 100;
145
+ const totalDuration = traces.reduce((sum, t) => sum + t.duration, 0);
146
+ const avgDuration = totalRequests > 0 ? Math.round(totalDuration / totalRequests) : 0;
147
+ // 活跃线程数(最近 5 分钟有活动的 threadId)
148
+ const fiveMinAgo = new Date(Date.now() - 5 * 60 * 1000).toISOString();
149
+ const activeThreadIds = new Set();
150
+ for (const t of traces) {
151
+ if (t.threadId !== undefined && t.timestamp >= fiveMinAgo) {
152
+ activeThreadIds.add(t.threadId);
153
+ }
154
+ }
155
+ // 工具调用统计
156
+ const toolCallStats = {};
157
+ for (const t of traces) {
158
+ if (t.action === 'tool_call') {
159
+ const toolName = t.input?.tool || t.input?.name || 'unknown';
160
+ if (!toolCallStats[toolName]) {
161
+ toolCallStats[toolName] = {
162
+ total: 0,
163
+ success: 0,
164
+ error: 0,
165
+ };
166
+ }
167
+ toolCallStats[toolName].total++;
168
+ if (t.status === 'success') {
169
+ toolCallStats[toolName].success++;
170
+ }
171
+ else {
172
+ toolCallStats[toolName].error++;
173
+ }
174
+ }
175
+ }
176
+ // 最近的追踪记录
177
+ const recentTraces = [...traces]
178
+ .sort((a, b) => b.timestamp.localeCompare(a.timestamp))
179
+ .slice(0, 10);
180
+ return {
181
+ totalRequests,
182
+ successCount,
183
+ errorCount,
184
+ timeoutCount,
185
+ successRate,
186
+ avgDuration,
187
+ activeThreads: activeThreadIds.size,
188
+ toolCallStats,
189
+ recentTraces,
190
+ };
191
+ }
192
+ // ===================== 系统健康 =====================
193
+ /**
194
+ * 获取系统健康状态
195
+ */
196
+ getSystemHealth() {
197
+ const memUsage = process.memoryUsage();
198
+ const cpuUsage = process.cpuUsage();
199
+ // 判断健康状态
200
+ const heapUsedMB = memUsage.heapUsed / (1024 * 1024);
201
+ const heapTotalMB = memUsage.heapTotal / (1024 * 1024);
202
+ const heapUsageRatio = heapTotalMB > 0 ? heapUsedMB / heapTotalMB : 0;
203
+ let status = 'healthy';
204
+ if (heapUsageRatio > 0.9 || heapUsedMB > 1500) {
205
+ status = 'critical';
206
+ }
207
+ else if (heapUsageRatio > 0.7 || heapUsedMB > 800) {
208
+ status = 'warning';
209
+ }
210
+ return {
211
+ status,
212
+ uptime: Date.now() - this.startTime,
213
+ memory: {
214
+ rss: memUsage.rss,
215
+ heapUsed: memUsage.heapUsed,
216
+ heapTotal: memUsage.heapTotal,
217
+ external: memUsage.external,
218
+ },
219
+ cpu: {
220
+ user: cpuUsage.user,
221
+ system: cpuUsage.system,
222
+ },
223
+ activeConnections: this.traceBuffer.filter(t => Date.now() - new Date(t.timestamp).getTime() < 60 * 1000).length,
224
+ traceCount: this.traceBuffer.length,
225
+ metricCount: this.metricBuffer.length,
226
+ };
227
+ }
228
+ // ===================== 导出 =====================
229
+ /**
230
+ * 导出追踪数据
231
+ */
232
+ exportTraces(format = 'json') {
233
+ const traces = [...this.traceBuffer].sort((a, b) => a.timestamp.localeCompare(b.timestamp));
234
+ if (format === 'csv') {
235
+ const headers = [
236
+ 'id',
237
+ 'traceId',
238
+ 'threadId',
239
+ 'action',
240
+ 'status',
241
+ 'duration',
242
+ 'error',
243
+ 'timestamp',
244
+ 'userId',
245
+ 'applicationId',
246
+ ];
247
+ const rows = traces.map(t => [
248
+ t.id,
249
+ t.traceId,
250
+ t.threadId ?? '',
251
+ t.action,
252
+ t.status,
253
+ t.duration,
254
+ t.error ? `"${t.error.replace(/"/g, '""')}"` : '',
255
+ t.timestamp,
256
+ t.userId ?? '',
257
+ t.applicationId ?? '',
258
+ ].join(','));
259
+ return [headers.join(','), ...rows].join('\n');
260
+ }
261
+ return JSON.stringify(traces, null, 2);
262
+ }
263
+ // ===================== 清理 =====================
264
+ /**
265
+ * 清空所有数据
266
+ */
267
+ clear() {
268
+ this.traceBuffer = [];
269
+ this.traceIndex = 0;
270
+ this.metricBuffer = [];
271
+ this.metricIndex = 0;
272
+ }
273
+ };
274
+ exports.ObservabilityService = ObservabilityService;
275
+ /** 环形缓冲区最大容量 */
276
+ ObservabilityService.MAX_TRACES = 10000;
277
+ ObservabilityService.MAX_METRICS = 10000;
278
+ exports.ObservabilityService = ObservabilityService = ObservabilityService_1 = __decorate([
279
+ (0, core_1.Provide)(),
280
+ (0, core_1.Scope)(core_1.ScopeEnum.Singleton)
281
+ ], ObservabilityService);
@@ -0,0 +1,88 @@
1
+ import { Context } from '@midwayjs/koa';
2
+ /** OpenAI 兼容 API 的配置接口 */
3
+ export interface OpenAIConfig {
4
+ baseUrl: string;
5
+ apiKey: string;
6
+ model: string;
7
+ fallbackModels?: string[];
8
+ maxTokens: number;
9
+ temperature: number;
10
+ }
11
+ /**
12
+ * OpenAI 基础服务
13
+ * 封装 OpenAI API 调用,提供通用对话、流式输出、模型容错降级等基础能力
14
+ */
15
+ export declare class OpenAIService {
16
+ ctx: Context;
17
+ openaiConfig: OpenAIConfig;
18
+ protected client: any;
19
+ init(): Promise<void>;
20
+ isAvailable(): boolean;
21
+ /**
22
+ * 通用 AI 对话流式输出
23
+ * 支持多轮对话上下文,返回 SSE 事件流
24
+ */
25
+ chatStream(messages: Array<{
26
+ role: string;
27
+ content: string;
28
+ }>, systemPrompt?: string): AsyncGenerator<{
29
+ event: string;
30
+ data: any;
31
+ }>;
32
+ /**
33
+ * 通用 AI 对话完整调用(非流式)
34
+ */
35
+ chatCompletion(systemPrompt: string, userMessage: string, modelOverride?: string): Promise<{
36
+ content: string;
37
+ reasoningContent?: string;
38
+ }>;
39
+ /**
40
+ * 带工具调用的单轮流式对话
41
+ * 子类可传入自定义 tools 参数覆盖默认行为
42
+ */
43
+ streamToolRound(messages: any[], modelOverride?: string, tools?: any[]): AsyncGenerator<{
44
+ kind: 'reasoning' | 'content';
45
+ text: string;
46
+ } | {
47
+ kind: 'result';
48
+ message: {
49
+ role: 'assistant';
50
+ content: string;
51
+ tool_calls?: any[];
52
+ reasoning_content?: string;
53
+ };
54
+ }>;
55
+ /**
56
+ * 从消息列表中流式输出对话内容
57
+ */
58
+ streamCompletionFromMessages(messages: any[], modelOverride?: string): AsyncGenerator<{
59
+ kind: 'reasoning' | 'content';
60
+ text: string;
61
+ }>;
62
+ normalizeTextPayload(payload: any): string;
63
+ extractReasoningText(message: any): string;
64
+ extractContentText(message: any): string;
65
+ parseToolArguments(rawArgs?: string): Record<string, any>;
66
+ mergeToolCallDelta(target: any[], deltaToolCall: any): void;
67
+ normalizeToolCalls(toolCalls: any[]): {
68
+ id: any;
69
+ type: any;
70
+ function: {
71
+ name: any;
72
+ arguments: any;
73
+ };
74
+ }[];
75
+ isModelEngineError(error: any): boolean;
76
+ /**
77
+ * 判断是否为网络连接错误(ECONNRESET / ETIMEDOUT 等)
78
+ * 这类错误通常可以通过重试或降级恢复
79
+ */
80
+ isNetworkError(error: any): boolean;
81
+ /**
82
+ * 判断是否为可恢复错误(模型引擎错误 + 网络错误)
83
+ * 可恢复错误会触发降级/重试,而非直接抛出
84
+ */
85
+ isRecoverableError(error: any): boolean;
86
+ logModelError(scope: string, error: any): void;
87
+ getFallbackModels(): string[];
88
+ }