@debian777/kairos-mcp 3.3.0 → 3.3.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.
- package/README.md +2 -2
- package/dist/.tsbuildinfo +1 -1
- package/dist/bootstrap.d.ts +2 -0
- package/dist/bootstrap.d.ts.map +1 -0
- package/dist/bootstrap.js +60 -0
- package/dist/bootstrap.js.map +1 -0
- package/dist/config.d.ts +13 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +18 -3
- package/dist/config.js.map +1 -1
- package/dist/embed-docs/mem/00000000-0000-0000-0000-000000002001.md +1 -1
- package/dist/embed-docs/mem/00000000-0000-0000-0000-000000002002.md +1 -1
- package/dist/http/http-api-dump.d.ts.map +1 -1
- package/dist/http/http-api-dump.js +1 -1
- package/dist/http/http-api-dump.js.map +1 -1
- package/dist/http/http-api-mint.d.ts.map +1 -1
- package/dist/http/http-api-mint.js +31 -4
- package/dist/http/http-api-mint.js.map +1 -1
- package/dist/http/http-api-next.d.ts.map +1 -1
- package/dist/http/http-api-next.js +2 -2
- package/dist/http/http-api-next.js.map +1 -1
- package/dist/http/http-api-snapshot.d.ts.map +1 -1
- package/dist/http/http-api-snapshot.js +0 -1
- package/dist/http/http-api-snapshot.js.map +1 -1
- package/dist/http/http-auth-callback.d.ts.map +1 -1
- package/dist/http/http-auth-callback.js +3 -2
- package/dist/http/http-auth-callback.js.map +1 -1
- package/dist/http/http-auth-middleware.d.ts +1 -0
- package/dist/http/http-auth-middleware.d.ts.map +1 -1
- package/dist/http/http-auth-middleware.js +2 -0
- package/dist/http/http-auth-middleware.js.map +1 -1
- package/dist/http/http-error-handlers.d.ts.map +1 -1
- package/dist/http/http-error-handlers.js +12 -1
- package/dist/http/http-error-handlers.js.map +1 -1
- package/dist/http/http-health-routes.d.ts.map +1 -1
- package/dist/http/http-health-routes.js +9 -6
- package/dist/http/http-health-routes.js.map +1 -1
- package/dist/http/http-mcp-handler.d.ts.map +1 -1
- package/dist/http/http-mcp-handler.js +44 -11
- package/dist/http/http-mcp-handler.js.map +1 -1
- package/dist/http/http-server-config.d.ts.map +1 -1
- package/dist/http/http-server-config.js +51 -1
- package/dist/http/http-server-config.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -10
- package/dist/index.js.map +1 -1
- package/dist/resources/docs-resources.js +1 -1
- package/dist/resources/docs-resources.js.map +1 -1
- package/dist/resources/prompt-resources.js +1 -1
- package/dist/resources/prompt-resources.js.map +1 -1
- package/dist/services/chain-utils.d.ts +0 -7
- package/dist/services/chain-utils.d.ts.map +1 -1
- package/dist/services/chain-utils.js +0 -6
- package/dist/services/chain-utils.js.map +1 -1
- package/dist/services/embedding/audit.d.ts +35 -0
- package/dist/services/embedding/audit.d.ts.map +1 -0
- package/dist/services/embedding/audit.js +146 -0
- package/dist/services/embedding/audit.js.map +1 -0
- package/dist/services/embedding/config.js +1 -1
- package/dist/services/embedding/config.js.map +1 -1
- package/dist/services/embedding/health.d.ts +5 -0
- package/dist/services/embedding/health.d.ts.map +1 -0
- package/dist/services/embedding/health.js +112 -0
- package/dist/services/embedding/health.js.map +1 -0
- package/dist/services/embedding/providers.d.ts.map +1 -1
- package/dist/services/embedding/providers.js +65 -1
- package/dist/services/embedding/providers.js.map +1 -1
- package/dist/services/embedding/service.d.ts +1 -0
- package/dist/services/embedding/service.d.ts.map +1 -1
- package/dist/services/embedding/service.js +94 -124
- package/dist/services/embedding/service.js.map +1 -1
- package/dist/services/memory/store-chain-default-handler.d.ts.map +1 -1
- package/dist/services/memory/store-chain-default-handler.js +7 -2
- package/dist/services/memory/store-chain-default-handler.js.map +1 -1
- package/dist/services/memory/store-chain-header-handler.d.ts.map +1 -1
- package/dist/services/memory/store-chain-header-handler.js +7 -2
- package/dist/services/memory/store-chain-header-handler.js.map +1 -1
- package/dist/services/memory/store-chain-helpers.js +1 -1
- package/dist/services/memory/store-chain-helpers.js.map +1 -1
- package/dist/services/memory/store-chain.js +1 -1
- package/dist/services/memory/store-chain.js.map +1 -1
- package/dist/services/memory/store-init.js +1 -1
- package/dist/services/memory/store-init.js.map +1 -1
- package/dist/services/memory/store-methods.js +1 -1
- package/dist/services/memory/store-methods.js.map +1 -1
- package/dist/services/memory/store.js +1 -1
- package/dist/services/memory/store.js.map +1 -1
- package/dist/services/memory-store.js +1 -1
- package/dist/services/memory-store.js.map +1 -1
- package/dist/services/metrics/anomaly-metrics.d.ts +3 -0
- package/dist/services/metrics/anomaly-metrics.d.ts.map +1 -0
- package/dist/services/metrics/anomaly-metrics.js +9 -0
- package/dist/services/metrics/anomaly-metrics.js.map +1 -0
- package/dist/services/proof-of-work-store.js +1 -1
- package/dist/services/proof-of-work-store.js.map +1 -1
- package/dist/services/qdrant/attest-propagation.d.ts.map +1 -1
- package/dist/services/qdrant/attest-propagation.js +5 -8
- package/dist/services/qdrant/attest-propagation.js.map +1 -1
- package/dist/services/qdrant/connection.js +1 -1
- package/dist/services/qdrant/connection.js.map +1 -1
- package/dist/services/qdrant/initialization.js +1 -1
- package/dist/services/qdrant/initialization.js.map +1 -1
- package/dist/services/qdrant/listing.js +1 -1
- package/dist/services/qdrant/listing.js.map +1 -1
- package/dist/services/qdrant/memory-retrieval.d.ts +21 -0
- package/dist/services/qdrant/memory-retrieval.d.ts.map +1 -1
- package/dist/services/qdrant/memory-retrieval.js +36 -18
- package/dist/services/qdrant/memory-retrieval.js.map +1 -1
- package/dist/services/qdrant/memory-store.js +1 -1
- package/dist/services/qdrant/memory-store.js.map +1 -1
- package/dist/services/qdrant/memory-updates.d.ts.map +1 -1
- package/dist/services/qdrant/memory-updates.js +35 -37
- package/dist/services/qdrant/memory-updates.js.map +1 -1
- package/dist/services/qdrant/quality.d.ts.map +1 -1
- package/dist/services/qdrant/quality.js +13 -27
- package/dist/services/qdrant/quality.js.map +1 -1
- package/dist/services/qdrant/resources.d.ts.map +1 -1
- package/dist/services/qdrant/resources.js +23 -8
- package/dist/services/qdrant/resources.js.map +1 -1
- package/dist/services/qdrant/search.js +1 -1
- package/dist/services/qdrant/search.js.map +1 -1
- package/dist/services/qdrant/service.js +1 -1
- package/dist/services/qdrant/service.js.map +1 -1
- package/dist/services/qdrant/utils.js +1 -1
- package/dist/services/qdrant/utils.js.map +1 -1
- package/dist/services/redis-cache.js +1 -1
- package/dist/services/redis-cache.js.map +1 -1
- package/dist/services/redis.d.ts +1 -0
- package/dist/services/redis.d.ts.map +1 -1
- package/dist/services/redis.js +20 -6
- package/dist/services/redis.js.map +1 -1
- package/dist/services/stats/model-stats.js +1 -1
- package/dist/services/stats/model-stats.js.map +1 -1
- package/dist/services/stats/protocol.js +1 -1
- package/dist/services/stats/protocol.js.map +1 -1
- package/dist/tools/kairos_attest.js +1 -1
- package/dist/tools/kairos_attest.js.map +1 -1
- package/dist/tools/kairos_mint.js +1 -1
- package/dist/tools/kairos_mint.js.map +1 -1
- package/dist/tools/kairos_search.d.ts.map +1 -1
- package/dist/tools/kairos_search.js +26 -13
- package/dist/tools/kairos_search.js.map +1 -1
- package/dist/ui/assets/{AccountPage-xcULo_Ht.js → AccountPage-kxmPtqQP.js} +1 -1
- package/dist/ui/assets/{ErrorAlert-Bp_BC2t_.js → ErrorAlert-ME7tEJ6X.js} +1 -1
- package/dist/ui/assets/{HomePage-YaKMlhFN.js → HomePage-DxiAsvs-.js} +1 -1
- package/dist/ui/assets/{KairosPage-DgO58pOn.js → KairosPage-BkqYs3-_.js} +1 -1
- package/dist/ui/assets/NotFoundPage-DyfbQ-6G.js +1 -0
- package/dist/ui/assets/{ProtocolDetailPage-D93cKbME.js → ProtocolDetailPage-DKaSVepL.js} +1 -1
- package/dist/ui/assets/{ProtocolEditPage-CCwQy6yl.js → ProtocolEditPage-D-aTavvx.js} +1 -1
- package/dist/ui/assets/{RenderedMarkdown-Dd_bDNwz.js → RenderedMarkdown-DjbuQlBl.js} +1 -1
- package/dist/ui/assets/{RunGuidedPage-CcTlI5HF.js → RunGuidedPage-BUD0MaGh.js} +1 -1
- package/dist/ui/assets/{RunsPage-BjSaeOq_.js → RunsPage-ctnsEF2U.js} +1 -1
- package/dist/ui/assets/{SkillBundlePage-D2cJwwA1.js → SkillBundlePage-CaWW5oGq.js} +1 -1
- package/dist/ui/assets/{index-BE1NYtLh.css → index-BAOM7Ima.css} +1 -1
- package/dist/ui/assets/{index-Dj9XLtnR.js → index-BrTmRWuA.js} +3 -3
- package/dist/ui/assets/{tiptap-BEg0BoNB.js → tiptap-kMFBDujG.js} +2 -2
- package/dist/ui/assets/{useProtocol-D_32bpf9.js → useProtocol-BruWpIzq.js} +1 -1
- package/dist/ui/assets/{useSpaces-DdE67BYD.js → useSpaces-BV6eUjY3.js} +1 -1
- package/dist/ui/assets/vendor-GiUVcjs7.js +33 -0
- package/dist/ui/index.html +4 -4
- package/dist/utils/qdrant-vector-management.js +1 -1
- package/dist/utils/qdrant-vector-management.js.map +1 -1
- package/dist/utils/structured-logger.d.ts +6 -1
- package/dist/utils/structured-logger.d.ts.map +1 -1
- package/dist/utils/structured-logger.js +103 -16
- package/dist/utils/structured-logger.js.map +1 -1
- package/dist/utils/tenant-context.d.ts +7 -0
- package/dist/utils/tenant-context.d.ts.map +1 -1
- package/dist/utils/tenant-context.js +20 -6
- package/dist/utils/tenant-context.js.map +1 -1
- package/package.json +10 -7
- package/dist/ui/assets/NotFoundPage-BnEJbefZ.js +0 -1
- package/dist/ui/assets/vendor-BxD5ItEO.js +0 -33
- package/dist/utils/logger.d.ts +0 -22
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/logger.js +0 -63
- package/dist/utils/logger.js.map +0 -1
|
@@ -58,6 +58,14 @@ export function setupHealthRoutes(app, memoryStore) {
|
|
|
58
58
|
else {
|
|
59
59
|
dependencies['cache'] = 'healthy (memory)';
|
|
60
60
|
}
|
|
61
|
+
const details = {
|
|
62
|
+
cacheBackend: USE_REDIS ? 'redis' : 'memory'
|
|
63
|
+
};
|
|
64
|
+
if (req.auth?.sub) {
|
|
65
|
+
details['embedding'] = teiHealth.message;
|
|
66
|
+
details['provider'] = embeddingCfg.provider || 'auto';
|
|
67
|
+
details['providerPref'] = embeddingCfg.providerPref || 'auto';
|
|
68
|
+
}
|
|
61
69
|
res.status(statusCode).json({
|
|
62
70
|
status: healthStatus,
|
|
63
71
|
service: 'KAIROS',
|
|
@@ -65,12 +73,7 @@ export function setupHealthRoutes(app, memoryStore) {
|
|
|
65
73
|
transport: 'http',
|
|
66
74
|
uptime: uptime,
|
|
67
75
|
dependencies,
|
|
68
|
-
details
|
|
69
|
-
embedding: teiHealth.message,
|
|
70
|
-
provider: embeddingCfg.provider || 'auto',
|
|
71
|
-
providerPref: embeddingCfg.providerPref || 'auto',
|
|
72
|
-
cacheBackend: USE_REDIS ? 'redis' : 'memory'
|
|
73
|
-
}
|
|
76
|
+
details
|
|
74
77
|
});
|
|
75
78
|
});
|
|
76
79
|
// GET / is handled by setupUiStatic: redirect to /ui
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-health-routes.js","sourceRoot":"","sources":["../../src/http/http-health-routes.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"http-health-routes.js","sourceRoot":"","sources":["../../src/http/http-health-routes.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-mcp-handler.d.ts","sourceRoot":"","sources":["../../src/http/http-mcp-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,OAAO,MAAM,SAAS,CAAC;AAC9B,OAAO,EAAE,6BAA6B,EAAE,MAAM,oDAAoD,CAAC;AAOnG,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAIrE,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,OAAO,CAAC,OAAO,CAAC;IACrB,SAAS,EAAE,6BAA6B,CAAC;CAC1C;AAED,eAAO,MAAM,eAAe,sCAA6C,CAAC;AAoC1E;;;;;;;GAOG;AACH,wBAAgB,cAAc,CAAC,GAAG,EAAE,OAAO,CAAC,OAAO,EAAE,WAAW,EAAE,iBAAiB,
|
|
1
|
+
{"version":3,"file":"http-mcp-handler.d.ts","sourceRoot":"","sources":["../../src/http/http-mcp-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,OAAO,MAAM,SAAS,CAAC;AAC9B,OAAO,EAAE,6BAA6B,EAAE,MAAM,oDAAoD,CAAC;AAOnG,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAIrE,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,OAAO,CAAC,OAAO,CAAC;IACrB,SAAS,EAAE,6BAA6B,CAAC;CAC1C;AAED,eAAO,MAAM,eAAe,sCAA6C,CAAC;AAoC1E;;;;;;;GAOG;AACH,wBAAgB,cAAc,CAAC,GAAG,EAAE,OAAO,CAAC,OAAO,EAAE,WAAW,EAAE,iBAAiB,QAwNlF"}
|
|
@@ -64,7 +64,7 @@ export function setupMcpRoutes(app, memoryStore) {
|
|
|
64
64
|
// Log incoming request with level control
|
|
65
65
|
const logLevel = LOG_LEVEL;
|
|
66
66
|
if (logLevel === 'debug' || method !== 'notifications/cancelled') {
|
|
67
|
-
structuredLogger.info(
|
|
67
|
+
structuredLogger.info({ event: 'mcp_request', mcp_method: method, mcp_tool_name: toolName, request_id: requestId }, 'Incoming MCP request');
|
|
68
68
|
}
|
|
69
69
|
// listOfferingsForUI (MCP Apps / UI discovery): not implemented by SDK. Handle here so the client
|
|
70
70
|
// gets a proper auth-related response when auth is required, instead of -32601 Method not found.
|
|
@@ -95,7 +95,12 @@ export function setupMcpRoutes(app, memoryStore) {
|
|
|
95
95
|
concurrentMcpRequests++;
|
|
96
96
|
if (concurrentMcpRequests > MAX_CONCURRENT) {
|
|
97
97
|
concurrentMcpRequests--;
|
|
98
|
-
structuredLogger.warn(
|
|
98
|
+
structuredLogger.warn({
|
|
99
|
+
event: 'mcp_request_rejected_concurrent_limit',
|
|
100
|
+
current_concurrent: concurrentMcpRequests + 1,
|
|
101
|
+
max_concurrent: MAX_CONCURRENT,
|
|
102
|
+
request_id: requestId
|
|
103
|
+
}, 'MCP request rejected: concurrent limit exceeded');
|
|
99
104
|
if (!res.headersSent) {
|
|
100
105
|
res.status(503).set('Retry-After', '5').json({
|
|
101
106
|
jsonrpc: '2.0',
|
|
@@ -119,7 +124,13 @@ export function setupMcpRoutes(app, memoryStore) {
|
|
|
119
124
|
const timeoutHandler = setTimeout(() => {
|
|
120
125
|
if (!requestCompleted) {
|
|
121
126
|
const duration = Date.now() - requestStart;
|
|
122
|
-
structuredLogger.
|
|
127
|
+
structuredLogger.warn({
|
|
128
|
+
event: 'mcp_request_timeout',
|
|
129
|
+
mcp_method: method,
|
|
130
|
+
mcp_tool_name: toolName,
|
|
131
|
+
request_id: requestId,
|
|
132
|
+
duration_ms: duration
|
|
133
|
+
}, 'MCP request timeout');
|
|
123
134
|
}
|
|
124
135
|
}, 25000); // Log at 25s (before typical 30s client timeout)
|
|
125
136
|
const deleteTimestamp = () => {
|
|
@@ -133,13 +144,19 @@ export function setupMcpRoutes(app, memoryStore) {
|
|
|
133
144
|
if (method === 'notifications/cancelled') {
|
|
134
145
|
const originalStart = requestTimestamps.get(requestId);
|
|
135
146
|
const actualDuration = originalStart ? Date.now() - originalStart : duration;
|
|
136
|
-
structuredLogger.warn(
|
|
147
|
+
structuredLogger.warn({ event: 'mcp_client_cancelled', duration_ms: actualDuration, request_id: requestId }, 'Client cancelled request - operation may continue in background');
|
|
137
148
|
}
|
|
138
149
|
else if (duration > 20000) {
|
|
139
|
-
structuredLogger.warn(
|
|
150
|
+
structuredLogger.warn({
|
|
151
|
+
event: 'mcp_request_closed',
|
|
152
|
+
duration_ms: duration,
|
|
153
|
+
mcp_method: method,
|
|
154
|
+
mcp_tool_name: toolName,
|
|
155
|
+
request_id: requestId
|
|
156
|
+
}, 'Request closed after threshold');
|
|
140
157
|
}
|
|
141
158
|
else if (logLevel === 'debug') {
|
|
142
|
-
structuredLogger.info(
|
|
159
|
+
structuredLogger.info({ event: 'mcp_request_closed', duration_ms: duration, request_id: requestId }, 'Request closed');
|
|
143
160
|
}
|
|
144
161
|
deleteTimestamp();
|
|
145
162
|
transport.close();
|
|
@@ -150,15 +167,25 @@ export function setupMcpRoutes(app, memoryStore) {
|
|
|
150
167
|
deleteTimestamp();
|
|
151
168
|
const duration = Date.now() - requestStart;
|
|
152
169
|
if (duration > 10000 && method !== 'notifications/cancelled') {
|
|
153
|
-
structuredLogger.info(
|
|
170
|
+
structuredLogger.info({
|
|
171
|
+
event: 'mcp_request_completed',
|
|
172
|
+
duration_ms: duration,
|
|
173
|
+
mcp_method: method,
|
|
174
|
+
mcp_tool_name: toolName,
|
|
175
|
+
request_id: requestId
|
|
176
|
+
}, 'Request completed');
|
|
154
177
|
}
|
|
155
178
|
else if (logLevel === 'debug') {
|
|
156
|
-
structuredLogger.info(
|
|
179
|
+
structuredLogger.info({ event: 'mcp_request_completed', duration_ms: duration, request_id: requestId }, 'Completed');
|
|
157
180
|
}
|
|
158
181
|
});
|
|
159
182
|
await server.connect(transport);
|
|
160
183
|
transport._requestContext = req;
|
|
161
|
-
const
|
|
184
|
+
const requestIdFromHttp = req.requestId;
|
|
185
|
+
const spaceCtx = {
|
|
186
|
+
...(req.spaceContext ?? getSpaceContext(req)),
|
|
187
|
+
requestId: requestIdFromHttp || requestId || ''
|
|
188
|
+
};
|
|
162
189
|
await runWithSpaceContextAsync(spaceCtx, async () => {
|
|
163
190
|
await mcpRequestStore.run({ req, transport }, async () => {
|
|
164
191
|
await transport.handleRequest(req, res, req.body);
|
|
@@ -169,10 +196,16 @@ export function setupMcpRoutes(app, memoryStore) {
|
|
|
169
196
|
}
|
|
170
197
|
catch (error) {
|
|
171
198
|
const duration = Date.now() - requestStart;
|
|
172
|
-
const errMsg = error instanceof Error ? error.message : String(error);
|
|
173
199
|
const errName = error instanceof Error ? error.constructor?.name ?? 'Error' : typeof error;
|
|
174
200
|
const errStack = error instanceof Error ? error.stack : undefined;
|
|
175
|
-
structuredLogger.error(
|
|
201
|
+
structuredLogger.error('MCP request failed', error, {
|
|
202
|
+
request_id: requestId,
|
|
203
|
+
mcp_method: method,
|
|
204
|
+
mcp_tool_name: toolName,
|
|
205
|
+
duration_ms: duration,
|
|
206
|
+
stack: errStack,
|
|
207
|
+
error_name: errName
|
|
208
|
+
});
|
|
176
209
|
if (!res.headersSent) {
|
|
177
210
|
const help = mcpErrorToHelp(error);
|
|
178
211
|
res.status(500).json({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-mcp-handler.js","sourceRoot":"","sources":["../../src/http/http-mcp-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAErD,OAAO,EAAE,6BAA6B,EAAE,MAAM,oDAAoD,CAAC;AACnG,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,+BAA+B,EAAE,MAAM,cAAc,CAAC;AACxF,OAAO,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAC;AAC7E,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACvF,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAG5C,MAAM,cAAc,GAAG,4BAA4B,CAAC,+BAA+B,CAAC,CAAC;AAOrF,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,iBAAiB,EAAqB,CAAC;AAE1E;;;GAGG;AACH,MAAM,iBAAiB,GAAG,IAAI,GAAG,EAAkB,CAAC;AACpD,MAAM,kBAAkB,GAAG,OAAO,CAAC;AACnC,WAAW,CAAC,GAAG,EAAE;IACf,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACvB,KAAK,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,iBAAiB,CAAC,OAAO,EAAE,EAAE,CAAC;QACtD,IAAI,GAAG,GAAG,KAAK,GAAG,kBAAkB;YAAE,iBAAiB,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACrE,CAAC;AACH,CAAC,EAAE,MAAM,CAAC,CAAC;AAEX,6FAA6F;AAC7F,IAAI,qBAAqB,GAAG,CAAC,CAAC;AAE9B,iFAAiF;AACjF,SAAS,cAAc,CAAC,KAAc;IACpC,MAAM,GAAG,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACnE,8EAA8E;IAC9E,IAAI,GAAG,CAAC,QAAQ,CAAC,kCAAkC,CAAC,EAAE,CAAC;QACrD,OAAO;YACL,OAAO,EAAE,8GAA8G;YACvH,UAAU,EAAE,qBAAqB;YACjC,UAAU,EAAE,sFAAsF;SACnG,CAAC;IACJ,CAAC;IACD,OAAO;QACL,OAAO,EAAE,gGAAgG;QACzG,UAAU,EAAE,cAAc;QAC1B,UAAU,EAAE,6DAA6D;KAC1E,CAAC;AACJ,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,cAAc,CAAC,GAAoB,EAAE,WAA8B;IAC/E,mDAAmD;IACnD,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;QAChC,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAChC,MAAM,SAAS,GAAG,GAAG,CAAC,IAAI,EAAE,EAAE,IAAI,SAAS,CAAC;QAC5C,MAAM,MAAM,GAAG,GAAG,CAAC,IAAI,EAAE,MAAM,IAAI,SAAS,CAAC;QAC7C,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,IAAI,SAAS,CAAC;QAErD,2FAA2F;QAC3F,IACI,MAAM,KAAK,yBAAyB;YACpC,MAAM,KAAK,oBAAoB;YAC/B,SAAS,KAAK,SAAS,EACzB,CAAC;YACC,iBAAiB,CAAC,GAAG,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;QACnD,CAAC;QAED,0CAA0C;QAC1C,MAAM,QAAQ,GAAG,SAAS,CAAC;QAC3B,IAAI,QAAQ,KAAK,OAAO,IAAI,MAAM,KAAK,yBAAyB,EAAE,CAAC;YAC/D,gBAAgB,CAAC,IAAI,
|
|
1
|
+
{"version":3,"file":"http-mcp-handler.js","sourceRoot":"","sources":["../../src/http/http-mcp-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-server-config.d.ts","sourceRoot":"","sources":["../../src/http/http-server-config.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"http-server-config.d.ts","sourceRoot":"","sources":["../../src/http/http-server-config.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;AAkD9B;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,OAAO,CAAC,OAAO,QAyBvD"}
|
|
@@ -1,6 +1,37 @@
|
|
|
1
1
|
import express from 'express';
|
|
2
|
+
import helmet from 'helmet';
|
|
3
|
+
import { rateLimit } from 'express-rate-limit';
|
|
4
|
+
import { AUTH_RATE_LIMIT_MAX, AUTH_RATE_LIMIT_WINDOW_MS, HTTP_JSON_BODY_LIMIT, HTTP_RATE_LIMIT_MAX, HTTP_RATE_LIMIT_WINDOW_MS, MCP_RATE_LIMIT_MAX, MCP_RATE_LIMIT_WINDOW_MS } from '../config.js';
|
|
2
5
|
import { httpLogger } from '../utils/structured-logger.js';
|
|
3
6
|
import { httpMetricsMiddleware } from './http-metrics-middleware.js';
|
|
7
|
+
/** Minimal CSP for API server (no HTML UI); satisfies security scanners while avoiding breakage. */
|
|
8
|
+
const HELMET_CSP = {
|
|
9
|
+
directives: {
|
|
10
|
+
defaultSrc: ["'self'"],
|
|
11
|
+
scriptSrc: ["'self'"],
|
|
12
|
+
styleSrc: ["'self'"],
|
|
13
|
+
imgSrc: ["'self'"],
|
|
14
|
+
connectSrc: ["'self'"],
|
|
15
|
+
fontSrc: ["'self'"],
|
|
16
|
+
objectSrc: ["'none'"],
|
|
17
|
+
mediaSrc: ["'self'"],
|
|
18
|
+
frameSrc: ["'none'"],
|
|
19
|
+
frameAncestors: ["'self'"]
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
function createRateLimiter(options) {
|
|
23
|
+
return rateLimit({
|
|
24
|
+
windowMs: options.windowMs,
|
|
25
|
+
limit: options.limit,
|
|
26
|
+
standardHeaders: 'draft-8',
|
|
27
|
+
legacyHeaders: false,
|
|
28
|
+
identifier: options.identifier,
|
|
29
|
+
message: {
|
|
30
|
+
error: 'RATE_LIMITED',
|
|
31
|
+
message: options.message
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}
|
|
4
35
|
/**
|
|
5
36
|
* Configure Express application with middleware
|
|
6
37
|
* @param app Express application instance
|
|
@@ -10,6 +41,25 @@ export function configureMiddleware(app) {
|
|
|
10
41
|
app.use(httpLogger);
|
|
11
42
|
// HTTP metrics middleware for Prometheus
|
|
12
43
|
app.use(httpMetricsMiddleware);
|
|
13
|
-
app.use(
|
|
44
|
+
app.use(helmet({ contentSecurityPolicy: HELMET_CSP }));
|
|
45
|
+
app.use('/auth', createRateLimiter({
|
|
46
|
+
identifier: 'auth',
|
|
47
|
+
windowMs: AUTH_RATE_LIMIT_WINDOW_MS,
|
|
48
|
+
limit: AUTH_RATE_LIMIT_MAX,
|
|
49
|
+
message: 'Too many authentication requests. Try again later.'
|
|
50
|
+
}));
|
|
51
|
+
app.use('/api', createRateLimiter({
|
|
52
|
+
identifier: 'api',
|
|
53
|
+
windowMs: HTTP_RATE_LIMIT_WINDOW_MS,
|
|
54
|
+
limit: HTTP_RATE_LIMIT_MAX,
|
|
55
|
+
message: 'Too many API requests. Try again later.'
|
|
56
|
+
}));
|
|
57
|
+
app.use('/mcp', createRateLimiter({
|
|
58
|
+
identifier: 'mcp',
|
|
59
|
+
windowMs: MCP_RATE_LIMIT_WINDOW_MS,
|
|
60
|
+
limit: MCP_RATE_LIMIT_MAX,
|
|
61
|
+
message: 'Too many MCP requests. Try again later.'
|
|
62
|
+
}));
|
|
63
|
+
app.use(express.json({ limit: HTTP_JSON_BODY_LIMIT }));
|
|
14
64
|
}
|
|
15
65
|
//# sourceMappingURL=http-server-config.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-server-config.js","sourceRoot":"","sources":["../../src/http/http-server-config.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;AAC9B,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AAErE;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,GAAoB;IACpD,4CAA4C;IAC5C,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACpB,yCAAyC;IACzC,GAAG,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;IAC/B,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"http-server-config.js","sourceRoot":"","sources":["../../src/http/http-server-config.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;AAC9B,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EACH,mBAAmB,EACnB,yBAAyB,EACzB,oBAAoB,EACpB,mBAAmB,EACnB,yBAAyB,EACzB,kBAAkB,EAClB,wBAAwB,EAC3B,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AAErE,oGAAoG;AACpG,MAAM,UAAU,GAAG;IACjB,UAAU,EAAE;QACV,UAAU,EAAE,CAAC,QAAQ,CAAC;QACtB,SAAS,EAAE,CAAC,QAAQ,CAAC;QACrB,QAAQ,EAAE,CAAC,QAAQ,CAAC;QACpB,MAAM,EAAE,CAAC,QAAQ,CAAC;QAClB,UAAU,EAAE,CAAC,QAAQ,CAAC;QACtB,OAAO,EAAE,CAAC,QAAQ,CAAC;QACnB,SAAS,EAAE,CAAC,QAAQ,CAAC;QACrB,QAAQ,EAAE,CAAC,QAAQ,CAAC;QACpB,QAAQ,EAAE,CAAC,QAAQ,CAAC;QACpB,cAAc,EAAE,CAAC,QAAQ,CAAC;KAC3B;CACO,CAAC;AAEX,SAAS,iBAAiB,CAAC,OAK1B;IACG,OAAO,SAAS,CAAC;QACb,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,eAAe,EAAE,SAAS;QAC1B,aAAa,EAAE,KAAK;QACpB,UAAU,EAAE,OAAO,CAAC,UAAU;QAC9B,OAAO,EAAE;YACL,KAAK,EAAE,cAAc;YACrB,OAAO,EAAE,OAAO,CAAC,OAAO;SAC3B;KACJ,CAAC,CAAC;AACP,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,GAAoB;IACpD,4CAA4C;IAC5C,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACpB,yCAAyC;IACzC,GAAG,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;IAC/B,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,qBAAqB,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;IACvD,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE,iBAAiB,CAAC;QAC/B,UAAU,EAAE,MAAM;QAClB,QAAQ,EAAE,yBAAyB;QACnC,KAAK,EAAE,mBAAmB;QAC1B,OAAO,EAAE,oDAAoD;KAChE,CAAC,CAAC,CAAC;IACJ,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC;QAC9B,UAAU,EAAE,KAAK;QACjB,QAAQ,EAAE,yBAAyB;QACnC,KAAK,EAAE,mBAAmB;QAC1B,OAAO,EAAE,yCAAyC;KACrD,CAAC,CAAC,CAAC;IACJ,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC;QAC9B,UAAU,EAAE,KAAK;QACjB,QAAQ,EAAE,wBAAwB;QAClC,KAAK,EAAE,kBAAkB;QACzB,OAAO,EAAE,yCAAyC;KACrD,CAAC,CAAC,CAAC;IACJ,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC"}
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAaH,OAAO,sCAAsC,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -5,7 +5,6 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import { structuredLogger } from './utils/structured-logger.js';
|
|
7
7
|
import { installGlobalErrorHandlers } from './utils/global-error-handlers.js';
|
|
8
|
-
import { logger } from './utils/logger.js';
|
|
9
8
|
import { MemoryQdrantStore } from './services/memory/store.js';
|
|
10
9
|
import { startServer } from './http/http-server.js';
|
|
11
10
|
import { injectMemResourcesAtBoot } from './resources/mem-resources-boot.js';
|
|
@@ -79,19 +78,11 @@ async function main() {
|
|
|
79
78
|
}
|
|
80
79
|
catch (err) {
|
|
81
80
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
82
|
-
// Prefer structured HTTP logger for fatal errors
|
|
83
81
|
try {
|
|
84
82
|
structuredLogger.error('Fatal error during KAIROS MCP startup', error);
|
|
85
83
|
}
|
|
86
84
|
catch {
|
|
87
|
-
// Ignore logging failures
|
|
88
|
-
}
|
|
89
|
-
// Fallback to generic logger (stdio-safe)
|
|
90
|
-
try {
|
|
91
|
-
logger.error('Fatal error during KAIROS MCP startup', error);
|
|
92
|
-
}
|
|
93
|
-
catch {
|
|
94
|
-
// Ignore logging failures from generic logger
|
|
85
|
+
// Ignore logging failures
|
|
95
86
|
}
|
|
96
87
|
// Ensure non-zero exit so supervisors can detect failure
|
|
97
88
|
process.exitCode = 1;
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,0BAA0B,EAAE,MAAM,kCAAkC,CAAC;AAC9E,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { getResource, getResources } from './embedded-mcp-resources.js';
|
|
2
|
-
import { logger } from '../utils/logger.js';
|
|
2
|
+
import { logger } from '../utils/structured-logger.js';
|
|
3
3
|
function mdOrFallback(uri, text, notFound = 'Document not found') {
|
|
4
4
|
return {
|
|
5
5
|
contents: [{ uri: uri.href, mimeType: 'text/markdown', text: text || `# ${notFound}` }]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"docs-resources.js","sourceRoot":"","sources":["../../src/resources/docs-resources.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,MAAM,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"docs-resources.js","sourceRoot":"","sources":["../../src/resources/docs-resources.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prompt-resources.js","sourceRoot":"","sources":["../../src/resources/prompt-resources.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACpE,OAAO,EAAE,MAAM,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"prompt-resources.js","sourceRoot":"","sources":["../../src/resources/prompt-resources.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACpE,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AAQvD,MAAM,eAAe,GAAmC;IACtD,mBAAmB,EAAE;QACnB,KAAK,EAAE,8BAA8B;QACrC,WAAW,EAAE,oDAAoD;QACjE,iBAAiB,EAAE,oDAAoD;KACxE;CACF,CAAC;AAEF;;GAEG;AACH,MAAM,UAAU,uBAAuB,CAAC,MAAW;IACjD,MAAM,CAAC,IAAI,CAAC,yDAAyD,CAAC,CAAC;IAEvE,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAE7B,KAAK,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QAClD,MAAM,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QAC5C,MAAM,KAAK,GACT,QAAQ,CAAC,KAAK,IAAI,GAAG,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;QAC/F,MAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,IAAI,WAAW,KAAK,EAAE,CAAC;QAC/D,MAAM,iBAAiB,GAAG,QAAQ,CAAC,iBAAiB,IAAI,WAAW,CAAC;QAEpE,MAAM,CAAC,cAAc,CACnB,GAAG,EACH;YACE,KAAK;YACL,WAAW;SACZ,EACD,KAAK,IAA8B,EAAE;YACnC,MAAM,UAAU,GAAG,SAAS,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC;YAC1C,MAAM,MAAM,GAAoB;gBAC9B,WAAW,EAAE,iBAAiB;gBAC9B,QAAQ,EAAE;oBACR;wBACE,IAAI,EAAE,MAAM;wBACZ,OAAO,EAAE;4BACP,IAAI,EAAE,MAAM;4BACZ,IAAI,EAAE,UAAU;yBACjB;qBACF;iBACF;aACF,CAAC;YAEF,OAAO,MAAM,CAAC;QAChB,CAAC,CACF,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -12,11 +12,4 @@ export declare function resolveFirstStep(memory: Memory, qdrantService?: any): P
|
|
|
12
12
|
export declare function resolveChainFirstStep(memory: Memory, qdrantService?: any): Promise<ResolvedChainStep | undefined>;
|
|
13
13
|
export declare function resolveChainNextStep(memory: Memory, qdrantService?: any): Promise<ResolvedChainStep | undefined>;
|
|
14
14
|
export declare function resolveChainPreviousStep(memory: Memory, qdrantService?: any): Promise<ResolvedChainStep | undefined>;
|
|
15
|
-
declare const _default: {
|
|
16
|
-
resolveFirstStep: typeof resolveFirstStep;
|
|
17
|
-
resolveChainFirstStep: typeof resolveChainFirstStep;
|
|
18
|
-
resolveChainNextStep: typeof resolveChainNextStep;
|
|
19
|
-
resolveChainPreviousStep: typeof resolveChainPreviousStep;
|
|
20
|
-
};
|
|
21
|
-
export default _default;
|
|
22
15
|
//# sourceMappingURL=chain-utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chain-utils.d.ts","sourceRoot":"","sources":["../../src/services/chain-utils.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAEjD,MAAM,WAAW,iBAAiB;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB;AAYD,wBAAsB,gBAAgB,CAClC,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,GAAG,GACpB,OAAO,CAAC;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GAAG,SAAS,CAAC,CAkBrD;AAED,wBAAsB,qBAAqB,CACvC,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,GAAG,GACpB,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CAexC;AAED,wBAAsB,oBAAoB,CACtC,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,GAAG,GACpB,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CAexC;AAED,wBAAsB,wBAAwB,CAC1C,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,GAAG,GACpB,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CAexC
|
|
1
|
+
{"version":3,"file":"chain-utils.d.ts","sourceRoot":"","sources":["../../src/services/chain-utils.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAEjD,MAAM,WAAW,iBAAiB;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB;AAYD,wBAAsB,gBAAgB,CAClC,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,GAAG,GACpB,OAAO,CAAC;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GAAG,SAAS,CAAC,CAkBrD;AAED,wBAAsB,qBAAqB,CACvC,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,GAAG,GACpB,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CAexC;AAED,wBAAsB,oBAAoB,CACtC,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,GAAG,GACpB,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CAexC;AAED,wBAAsB,wBAAwB,CAC1C,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,GAAG,GACpB,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CAexC"}
|
|
@@ -86,10 +86,4 @@ export async function resolveChainPreviousStep(memory, qdrantService) {
|
|
|
86
86
|
return { uuid: prev.uuid, label: prev.label, step: prev.step, count };
|
|
87
87
|
return undefined;
|
|
88
88
|
}
|
|
89
|
-
export default {
|
|
90
|
-
resolveFirstStep,
|
|
91
|
-
resolveChainFirstStep,
|
|
92
|
-
resolveChainNextStep,
|
|
93
|
-
resolveChainPreviousStep
|
|
94
|
-
};
|
|
95
89
|
//# sourceMappingURL=chain-utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chain-utils.js","sourceRoot":"","sources":["../../src/services/chain-utils.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"chain-utils.js","sourceRoot":"","sources":["../../src/services/chain-utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export interface EmbeddingAuditPayload {
|
|
2
|
+
tenantId: string;
|
|
3
|
+
requestId: string;
|
|
4
|
+
provider: string;
|
|
5
|
+
model: string;
|
|
6
|
+
inputCount: number;
|
|
7
|
+
inputCharLength: number;
|
|
8
|
+
outputDimension: number;
|
|
9
|
+
latencyMs: number;
|
|
10
|
+
}
|
|
11
|
+
export declare function logEmbeddingAuditSuccess(payload: EmbeddingAuditPayload): void;
|
|
12
|
+
export declare function logEmbeddingAuditError(payload: Omit<EmbeddingAuditPayload, 'outputDimension'> & {
|
|
13
|
+
outputDimension?: number;
|
|
14
|
+
errorMessage: string;
|
|
15
|
+
}): void;
|
|
16
|
+
export declare function detectEmbeddingAnomalies(params: {
|
|
17
|
+
tenantId: string;
|
|
18
|
+
requestId: string;
|
|
19
|
+
provider: string;
|
|
20
|
+
model: string;
|
|
21
|
+
latencyMs: number;
|
|
22
|
+
expectedDimension: number;
|
|
23
|
+
actualDimension: number;
|
|
24
|
+
sampleEmbedding: number[];
|
|
25
|
+
}): {
|
|
26
|
+
hasCritical: boolean;
|
|
27
|
+
};
|
|
28
|
+
export declare function logSearchAnomaly(params: {
|
|
29
|
+
tenantId: string;
|
|
30
|
+
requestId: string;
|
|
31
|
+
resultCount: number;
|
|
32
|
+
queryLength: number;
|
|
33
|
+
topScore: number | null;
|
|
34
|
+
}): void;
|
|
35
|
+
//# sourceMappingURL=audit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit.d.ts","sourceRoot":"","sources":["../../../src/services/embedding/audit.ts"],"names":[],"mappings":"AASA,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,eAAe,EAAE,MAAM,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;CACnB;AAyCD,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,qBAAqB,GAAG,IAAI,CAa7E;AAED,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,IAAI,CAAC,qBAAqB,EAAE,iBAAiB,CAAC,GAAG;IAC/F,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,EAAE,MAAM,CAAC;CACtB,GAAG,IAAI,CAcP;AAED,wBAAgB,wBAAwB,CAAC,MAAM,EAAE;IAC/C,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,eAAe,EAAE,MAAM,CAAC;IACxB,eAAe,EAAE,MAAM,EAAE,CAAC;CAC3B,GAAG;IAAE,WAAW,EAAE,OAAO,CAAA;CAAE,CAsD3B;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE;IACvC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;CACzB,GAAG,IAAI,CA8BP"}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { EMBEDDING_LATENCY_WARN_MS, EMBEDDING_NORM_MAX, EMBEDDING_NORM_MIN, SEARCH_SCORE_WARN_THRESHOLD } from '../../config.js';
|
|
2
|
+
import { anomalyEvents } from '../metrics/anomaly-metrics.js';
|
|
3
|
+
import { structuredLogger } from '../../utils/structured-logger.js';
|
|
4
|
+
function round(value) {
|
|
5
|
+
return Number(value.toFixed(4));
|
|
6
|
+
}
|
|
7
|
+
function vectorNorm(vector) {
|
|
8
|
+
if (vector.length === 0)
|
|
9
|
+
return 0;
|
|
10
|
+
let sumSquares = 0;
|
|
11
|
+
for (const value of vector)
|
|
12
|
+
sumSquares += value * value;
|
|
13
|
+
return Math.sqrt(sumSquares);
|
|
14
|
+
}
|
|
15
|
+
function recordAnomaly(params) {
|
|
16
|
+
anomalyEvents.inc({
|
|
17
|
+
type: params.type,
|
|
18
|
+
severity: params.severity,
|
|
19
|
+
tenant_id: params.tenantId
|
|
20
|
+
});
|
|
21
|
+
const bindings = {
|
|
22
|
+
category: 'audit.anomaly',
|
|
23
|
+
anomaly_type: params.type,
|
|
24
|
+
severity: params.severity,
|
|
25
|
+
tenant_id: params.tenantId,
|
|
26
|
+
request_id: params.requestId,
|
|
27
|
+
...params.details
|
|
28
|
+
};
|
|
29
|
+
if (params.severity === 'error') {
|
|
30
|
+
structuredLogger.error(params.message, undefined, bindings);
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
structuredLogger.warn(bindings, params.message);
|
|
34
|
+
}
|
|
35
|
+
export function logEmbeddingAuditSuccess(payload) {
|
|
36
|
+
structuredLogger.info({
|
|
37
|
+
category: 'audit.embedding',
|
|
38
|
+
status: 'success',
|
|
39
|
+
tenant_id: payload.tenantId,
|
|
40
|
+
request_id: payload.requestId,
|
|
41
|
+
provider: payload.provider,
|
|
42
|
+
model: payload.model,
|
|
43
|
+
input_count: payload.inputCount,
|
|
44
|
+
input_char_length: payload.inputCharLength,
|
|
45
|
+
output_dimension: payload.outputDimension,
|
|
46
|
+
latency_ms: payload.latencyMs
|
|
47
|
+
}, 'Embedding request completed');
|
|
48
|
+
}
|
|
49
|
+
export function logEmbeddingAuditError(payload) {
|
|
50
|
+
structuredLogger.error('Embedding request failed', undefined, {
|
|
51
|
+
category: 'audit.embedding',
|
|
52
|
+
status: 'error',
|
|
53
|
+
tenant_id: payload.tenantId,
|
|
54
|
+
request_id: payload.requestId,
|
|
55
|
+
provider: payload.provider,
|
|
56
|
+
model: payload.model,
|
|
57
|
+
input_count: payload.inputCount,
|
|
58
|
+
input_char_length: payload.inputCharLength,
|
|
59
|
+
output_dimension: payload.outputDimension ?? 0,
|
|
60
|
+
latency_ms: payload.latencyMs,
|
|
61
|
+
error_message: payload.errorMessage
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
export function detectEmbeddingAnomalies(params) {
|
|
65
|
+
let hasCritical = false;
|
|
66
|
+
if (params.latencyMs > EMBEDDING_LATENCY_WARN_MS) {
|
|
67
|
+
recordAnomaly({
|
|
68
|
+
tenantId: params.tenantId,
|
|
69
|
+
requestId: params.requestId,
|
|
70
|
+
type: 'embedding_high_latency',
|
|
71
|
+
severity: 'warn',
|
|
72
|
+
message: 'Embedding latency exceeded warning threshold',
|
|
73
|
+
details: {
|
|
74
|
+
provider: params.provider,
|
|
75
|
+
model: params.model,
|
|
76
|
+
latency_ms: params.latencyMs,
|
|
77
|
+
threshold_ms: EMBEDDING_LATENCY_WARN_MS
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
const norm = vectorNorm(params.sampleEmbedding);
|
|
82
|
+
if (norm < EMBEDDING_NORM_MIN || norm > EMBEDDING_NORM_MAX) {
|
|
83
|
+
recordAnomaly({
|
|
84
|
+
tenantId: params.tenantId,
|
|
85
|
+
requestId: params.requestId,
|
|
86
|
+
type: 'embedding_unusual_norm',
|
|
87
|
+
severity: 'warn',
|
|
88
|
+
message: 'Embedding vector norm is outside expected range',
|
|
89
|
+
details: {
|
|
90
|
+
provider: params.provider,
|
|
91
|
+
model: params.model,
|
|
92
|
+
norm: round(norm),
|
|
93
|
+
min_norm: EMBEDDING_NORM_MIN,
|
|
94
|
+
max_norm: EMBEDDING_NORM_MAX
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
if (params.actualDimension !== params.expectedDimension) {
|
|
99
|
+
hasCritical = true;
|
|
100
|
+
recordAnomaly({
|
|
101
|
+
tenantId: params.tenantId,
|
|
102
|
+
requestId: params.requestId,
|
|
103
|
+
type: 'embedding_dimension_mismatch',
|
|
104
|
+
severity: 'error',
|
|
105
|
+
message: 'Embedding dimension mismatch detected',
|
|
106
|
+
details: {
|
|
107
|
+
provider: params.provider,
|
|
108
|
+
model: params.model,
|
|
109
|
+
expected_dimension: params.expectedDimension,
|
|
110
|
+
actual_dimension: params.actualDimension
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
return { hasCritical };
|
|
115
|
+
}
|
|
116
|
+
export function logSearchAnomaly(params) {
|
|
117
|
+
if (params.resultCount === 0 && params.queryLength >= 8) {
|
|
118
|
+
recordAnomaly({
|
|
119
|
+
tenantId: params.tenantId,
|
|
120
|
+
requestId: params.requestId,
|
|
121
|
+
type: 'search_zero_results',
|
|
122
|
+
severity: 'warn',
|
|
123
|
+
message: 'Search returned zero results for a non-trivial query',
|
|
124
|
+
details: {
|
|
125
|
+
query_length: params.queryLength,
|
|
126
|
+
result_count: params.resultCount
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
if (typeof params.topScore === 'number' && params.queryLength >= 8 && params.topScore < SEARCH_SCORE_WARN_THRESHOLD) {
|
|
131
|
+
recordAnomaly({
|
|
132
|
+
tenantId: params.tenantId,
|
|
133
|
+
requestId: params.requestId,
|
|
134
|
+
type: 'search_low_score',
|
|
135
|
+
severity: 'warn',
|
|
136
|
+
message: 'Search top score is below warning threshold',
|
|
137
|
+
details: {
|
|
138
|
+
query_length: params.queryLength,
|
|
139
|
+
result_count: params.resultCount,
|
|
140
|
+
top_score: round(params.topScore),
|
|
141
|
+
threshold: SEARCH_SCORE_WARN_THRESHOLD
|
|
142
|
+
}
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
//# sourceMappingURL=audit.js.map
|