@mastra/server 0.0.0-break-rename-vnext-legacy-20251002212351 → 0.0.0-bundle-recursion-20251030002519
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/CHANGELOG.md +341 -4
- package/dist/{chunk-SZUAJANR.js → chunk-2P4VRXBT.js} +90 -108
- package/dist/chunk-2P4VRXBT.js.map +1 -0
- package/dist/{chunk-PPYGWINI.cjs → chunk-2PLXW4ZX.cjs} +74 -74
- package/dist/{chunk-PPYGWINI.cjs.map → chunk-2PLXW4ZX.cjs.map} +1 -1
- package/dist/{chunk-52UP7DFT.cjs → chunk-2S4IMB6E.cjs} +4 -4
- package/dist/{chunk-52UP7DFT.cjs.map → chunk-2S4IMB6E.cjs.map} +1 -1
- package/dist/{chunk-HRG5HN4U.js → chunk-3PXWQX3J.js} +189 -130
- package/dist/chunk-3PXWQX3J.js.map +1 -0
- package/dist/{chunk-NLWACBE7.cjs → chunk-3SNGNFUJ.cjs} +4 -4
- package/dist/{chunk-NLWACBE7.cjs.map → chunk-3SNGNFUJ.cjs.map} +1 -1
- package/dist/{chunk-AX5SCBJL.js → chunk-4AKQUEI2.js} +86 -48
- package/dist/chunk-4AKQUEI2.js.map +1 -0
- package/dist/{chunk-FYZHFAFB.cjs → chunk-4APSL4XM.cjs} +191 -130
- package/dist/chunk-4APSL4XM.cjs.map +1 -0
- package/dist/{chunk-A3AL7EWJ.js → chunk-ABRFV4XP.js} +3 -3
- package/dist/{chunk-A3AL7EWJ.js.map → chunk-ABRFV4XP.js.map} +1 -1
- package/dist/{chunk-YWOK4F5A.js → chunk-AQCEVRZV.js} +3 -4
- package/dist/chunk-AQCEVRZV.js.map +1 -0
- package/dist/{chunk-XJOYGRTN.js → chunk-AW5BU3RQ.js} +7 -4
- package/dist/chunk-AW5BU3RQ.js.map +1 -0
- package/dist/{chunk-WUJLVNLU.js → chunk-BATEJLED.js} +3 -3
- package/dist/{chunk-WUJLVNLU.js.map → chunk-BATEJLED.js.map} +1 -1
- package/dist/{chunk-T3TIA3O6.cjs → chunk-EP3JQDPD.cjs} +4 -4
- package/dist/{chunk-T3TIA3O6.cjs.map → chunk-EP3JQDPD.cjs.map} +1 -1
- package/dist/{chunk-TTHEEIZ3.js → chunk-EVI5NLZG.js} +4 -4
- package/dist/{chunk-TTHEEIZ3.js.map → chunk-EVI5NLZG.js.map} +1 -1
- package/dist/{chunk-QDPOVUS4.js → chunk-FTBY7JHX.js} +2948 -1475
- package/dist/chunk-FTBY7JHX.js.map +1 -0
- package/dist/{chunk-LHGBI76Y.cjs → chunk-GDUKGVFI.cjs} +91 -109
- package/dist/chunk-GDUKGVFI.cjs.map +1 -0
- package/dist/{chunk-LF2ZLOFP.js → chunk-GQRJOUV7.js} +64 -34
- package/dist/chunk-GQRJOUV7.js.map +1 -0
- package/dist/{chunk-JOXMWFM6.cjs → chunk-HQYKLJHG.cjs} +2837 -1359
- package/dist/chunk-HQYKLJHG.cjs.map +1 -0
- package/dist/{chunk-VY4ENABS.cjs → chunk-KIHM7IDM.cjs} +13 -14
- package/dist/chunk-KIHM7IDM.cjs.map +1 -0
- package/dist/{chunk-SIGXR3JT.cjs → chunk-LPM6BBAX.cjs} +5 -5
- package/dist/{chunk-SIGXR3JT.cjs.map → chunk-LPM6BBAX.cjs.map} +1 -1
- package/dist/{chunk-GU4EWMZB.cjs → chunk-LZKJT7QP.cjs} +64 -34
- package/dist/chunk-LZKJT7QP.cjs.map +1 -0
- package/dist/{chunk-WHN4VX55.js → chunk-MYR4PVGN.js} +3 -3
- package/dist/{chunk-WHN4VX55.js.map → chunk-MYR4PVGN.js.map} +1 -1
- package/dist/{chunk-EMMSS5I5.cjs → chunk-O7I5CWRX.cjs} +10 -3
- package/dist/{chunk-EMMSS5I5.cjs.map → chunk-O7I5CWRX.cjs.map} +1 -1
- package/dist/{chunk-G3PMV62Z.js → chunk-PR4QN5HX.js} +10 -4
- package/dist/{chunk-G3PMV62Z.js.map → chunk-PR4QN5HX.js.map} +1 -1
- package/dist/{chunk-JRDEOHAJ.js → chunk-QQXMIP6C.js} +3 -3
- package/dist/{chunk-JRDEOHAJ.js.map → chunk-QQXMIP6C.js.map} +1 -1
- package/dist/chunk-QU6N55W6.cjs +256 -0
- package/dist/chunk-QU6N55W6.cjs.map +1 -0
- package/dist/{chunk-KM7EJKXV.js → chunk-RC5UZM7H.js} +4 -4
- package/dist/{chunk-KM7EJKXV.js.map → chunk-RC5UZM7H.js.map} +1 -1
- package/dist/{chunk-NG5IVLEZ.js → chunk-RQK4FQUD.js} +3 -3
- package/dist/{chunk-NG5IVLEZ.js.map → chunk-RQK4FQUD.js.map} +1 -1
- package/dist/chunk-SHWNNZBL.js +254 -0
- package/dist/chunk-SHWNNZBL.js.map +1 -0
- package/dist/{chunk-BKCWZLEL.cjs → chunk-SPRRK3P7.cjs} +8 -5
- package/dist/chunk-SPRRK3P7.cjs.map +1 -0
- package/dist/{chunk-6IJWRJZE.js → chunk-THWIEXQQ.js} +4 -4
- package/dist/{chunk-6IJWRJZE.js.map → chunk-THWIEXQQ.js.map} +1 -1
- package/dist/chunk-TOCYBDP2.js +46 -0
- package/dist/chunk-TOCYBDP2.js.map +1 -0
- package/dist/{chunk-OPI3FZYH.cjs → chunk-X3G3KC47.cjs} +6 -6
- package/dist/{chunk-OPI3FZYH.cjs.map → chunk-X3G3KC47.cjs.map} +1 -1
- package/dist/chunk-X6C7BUWN.cjs +48 -0
- package/dist/chunk-X6C7BUWN.cjs.map +1 -0
- package/dist/{chunk-SPLSYTYW.cjs → chunk-XN74I6VW.cjs} +4 -4
- package/dist/{chunk-SPLSYTYW.cjs.map → chunk-XN74I6VW.cjs.map} +1 -1
- package/dist/{chunk-4HS3I2TI.cjs → chunk-XUOE3PBE.cjs} +91 -51
- package/dist/chunk-XUOE3PBE.cjs.map +1 -0
- package/dist/{chunk-KNGXRN26.cjs → chunk-YAYIYIMS.cjs} +11 -11
- package/dist/{chunk-KNGXRN26.cjs.map → chunk-YAYIYIMS.cjs.map} +1 -1
- package/dist/{chunk-LJFAAEU7.cjs → chunk-YYXITBYY.cjs} +11 -11
- package/dist/{chunk-LJFAAEU7.cjs.map → chunk-YYXITBYY.cjs.map} +1 -1
- package/dist/{chunk-6GMFZ5LK.js → chunk-ZULZ2752.js} +3 -3
- package/dist/{chunk-6GMFZ5LK.js.map → chunk-ZULZ2752.js.map} +1 -1
- package/dist/{dist-R3L5J3LL.cjs → dist-4MVGNSRL.cjs} +20 -20
- package/dist/{dist-R3L5J3LL.cjs.map → dist-4MVGNSRL.cjs.map} +1 -1
- package/dist/{dist-OC4J73ML.cjs → dist-FZYCV3VB.cjs} +26 -26
- package/dist/{dist-OC4J73ML.cjs.map → dist-FZYCV3VB.cjs.map} +1 -1
- package/dist/{dist-N6P7NYGX.cjs → dist-G2BYZJOC.cjs} +28 -28
- package/dist/{dist-N6P7NYGX.cjs.map → dist-G2BYZJOC.cjs.map} +1 -1
- package/dist/dist-P4MXBQ3U.cjs +16 -0
- package/dist/{dist-EZZMMMNT.cjs.map → dist-P4MXBQ3U.cjs.map} +1 -1
- package/dist/{dist-LKU3RRT2.js → dist-PQZUVLPC.js} +3 -3
- package/dist/{dist-LKU3RRT2.js.map → dist-PQZUVLPC.js.map} +1 -1
- package/dist/{dist-ZHCN47XA.js → dist-R7WYX6LC.js} +3 -3
- package/dist/{dist-ZHCN47XA.js.map → dist-R7WYX6LC.js.map} +1 -1
- package/dist/{dist-QI7RYOYQ.cjs → dist-RFMYFILX.cjs} +30 -30
- package/dist/{dist-QI7RYOYQ.cjs.map → dist-RFMYFILX.cjs.map} +1 -1
- package/dist/{dist-JNIWWFE5.js → dist-X7XR3M3Z.js} +3 -3
- package/dist/{dist-JNIWWFE5.js.map → dist-X7XR3M3Z.js.map} +1 -1
- package/dist/{dist-COC6WFAX.js → dist-XVBSOGFK.js} +3 -3
- package/dist/{dist-COC6WFAX.js.map → dist-XVBSOGFK.js.map} +1 -1
- package/dist/dist-YREX2TJT.js +3 -0
- package/dist/{dist-26HWEQY6.js.map → dist-YREX2TJT.js.map} +1 -1
- package/dist/server/handlers/a2a.cjs +7 -7
- package/dist/server/handlers/a2a.js +1 -1
- package/dist/server/handlers/agent-builder.cjs +36 -16
- package/dist/server/handlers/agent-builder.d.ts +20 -4
- package/dist/server/handlers/agent-builder.d.ts.map +1 -1
- package/dist/server/handlers/agent-builder.js +1 -1
- package/dist/server/handlers/agents.cjs +26 -18
- package/dist/server/handlers/agents.d.ts +57 -47
- package/dist/server/handlers/agents.d.ts.map +1 -1
- package/dist/server/handlers/agents.js +1 -1
- package/dist/server/handlers/legacyWorkflows.cjs +11 -11
- package/dist/server/handlers/legacyWorkflows.js +1 -1
- package/dist/server/handlers/logs.cjs +4 -4
- package/dist/server/handlers/logs.js +1 -1
- package/dist/server/handlers/memory.cjs +16 -16
- package/dist/server/handlers/memory.d.ts +3 -2
- package/dist/server/handlers/memory.d.ts.map +1 -1
- package/dist/server/handlers/memory.js +1 -1
- package/dist/server/handlers/observability.cjs +5 -5
- package/dist/server/handlers/observability.js +1 -1
- package/dist/server/handlers/scores.cjs +7 -7
- package/dist/server/handlers/scores.d.ts +9 -108
- package/dist/server/handlers/scores.d.ts.map +1 -1
- package/dist/server/handlers/scores.js +1 -1
- package/dist/server/handlers/tools.cjs +6 -6
- package/dist/server/handlers/tools.js +1 -1
- package/dist/server/handlers/vector.cjs +7 -7
- package/dist/server/handlers/vector.js +1 -1
- package/dist/server/handlers/voice.cjs +5 -5
- package/dist/server/handlers/voice.js +1 -1
- package/dist/server/handlers/workflows.cjs +27 -19
- package/dist/server/handlers/workflows.d.ts +13 -7
- package/dist/server/handlers/workflows.d.ts.map +1 -1
- package/dist/server/handlers/workflows.js +1 -1
- package/dist/server/handlers.cjs +27 -32
- package/dist/server/handlers.d.ts +0 -1
- package/dist/server/handlers.d.ts.map +1 -1
- package/dist/server/handlers.js +12 -13
- package/dist/server/utils.d.ts.map +1 -1
- package/dist/token-375W3LEI.cjs +64 -0
- package/dist/token-375W3LEI.cjs.map +1 -0
- package/dist/token-C3IMNCC4.js +62 -0
- package/dist/token-C3IMNCC4.js.map +1 -0
- package/dist/token-util-CV3RRG6K.cjs +9 -0
- package/dist/token-util-CV3RRG6K.cjs.map +1 -0
- package/dist/token-util-E5QO2RCL.js +7 -0
- package/dist/token-util-E5QO2RCL.js.map +1 -0
- package/package.json +9 -9
- package/dist/chunk-4HS3I2TI.cjs.map +0 -1
- package/dist/chunk-4RRMWXQ2.js +0 -3522
- package/dist/chunk-4RRMWXQ2.js.map +0 -1
- package/dist/chunk-AX5SCBJL.js.map +0 -1
- package/dist/chunk-BKCWZLEL.cjs.map +0 -1
- package/dist/chunk-FALVL2VV.cjs +0 -3525
- package/dist/chunk-FALVL2VV.cjs.map +0 -1
- package/dist/chunk-FYZHFAFB.cjs.map +0 -1
- package/dist/chunk-GU4EWMZB.cjs.map +0 -1
- package/dist/chunk-HRG5HN4U.js.map +0 -1
- package/dist/chunk-HVBBFCDH.cjs +0 -2321
- package/dist/chunk-HVBBFCDH.cjs.map +0 -1
- package/dist/chunk-JOXMWFM6.cjs.map +0 -1
- package/dist/chunk-KV6VHX4V.js +0 -160
- package/dist/chunk-KV6VHX4V.js.map +0 -1
- package/dist/chunk-LF2ZLOFP.js.map +0 -1
- package/dist/chunk-LHGBI76Y.cjs.map +0 -1
- package/dist/chunk-N7F33WAD.js +0 -2290
- package/dist/chunk-N7F33WAD.js.map +0 -1
- package/dist/chunk-PWTXZZTR.cjs +0 -165
- package/dist/chunk-PWTXZZTR.cjs.map +0 -1
- package/dist/chunk-QDPOVUS4.js.map +0 -1
- package/dist/chunk-SZUAJANR.js.map +0 -1
- package/dist/chunk-VY4ENABS.cjs.map +0 -1
- package/dist/chunk-XJOYGRTN.js.map +0 -1
- package/dist/chunk-YWOK4F5A.js.map +0 -1
- package/dist/dist-26HWEQY6.js +0 -3
- package/dist/dist-3DRD6USP.cjs +0 -1411
- package/dist/dist-3DRD6USP.cjs.map +0 -1
- package/dist/dist-7GVM5ZCS.js +0 -845
- package/dist/dist-7GVM5ZCS.js.map +0 -1
- package/dist/dist-CCDXEZDR.js +0 -1408
- package/dist/dist-CCDXEZDR.js.map +0 -1
- package/dist/dist-EZZMMMNT.cjs +0 -16
- package/dist/dist-H64VX6DE.js +0 -3
- package/dist/dist-H64VX6DE.js.map +0 -1
- package/dist/dist-H7RR3EXL.js +0 -2006
- package/dist/dist-H7RR3EXL.js.map +0 -1
- package/dist/dist-L76NFIWM.cjs +0 -934
- package/dist/dist-L76NFIWM.cjs.map +0 -1
- package/dist/dist-MQUZENT7.js +0 -931
- package/dist/dist-MQUZENT7.js.map +0 -1
- package/dist/dist-S3ILRJUH.cjs +0 -2013
- package/dist/dist-S3ILRJUH.cjs.map +0 -1
- package/dist/dist-WKYB3LTJ.cjs +0 -16
- package/dist/dist-WKYB3LTJ.cjs.map +0 -1
- package/dist/dist-WY4WSW7C.cjs +0 -849
- package/dist/dist-WY4WSW7C.cjs.map +0 -1
- package/dist/server/handlers/telemetry.cjs +0 -20
- package/dist/server/handlers/telemetry.cjs.map +0 -1
- package/dist/server/handlers/telemetry.d.ts +0 -33
- package/dist/server/handlers/telemetry.d.ts.map +0 -1
- package/dist/server/handlers/telemetry.js +0 -3
- package/dist/server/handlers/telemetry.js.map +0 -1
|
@@ -3,12 +3,14 @@
|
|
|
3
3
|
var chunkG4PUALCE_cjs = require('./chunk-G4PUALCE.cjs');
|
|
4
4
|
var chunkRE4RPXT2_cjs = require('./chunk-RE4RPXT2.cjs');
|
|
5
5
|
var chunk7NADHFD2_cjs = require('./chunk-7NADHFD2.cjs');
|
|
6
|
-
var
|
|
6
|
+
var chunkO7I5CWRX_cjs = require('./chunk-O7I5CWRX.cjs');
|
|
7
|
+
var agent = require('@mastra/core/agent');
|
|
8
|
+
var di = require('@mastra/core/di');
|
|
7
9
|
var utils = require('@mastra/core/utils');
|
|
8
10
|
|
|
9
11
|
// src/server/handlers/memory.ts
|
|
10
12
|
var memory_exports = {};
|
|
11
|
-
|
|
13
|
+
chunkO7I5CWRX_cjs.__export(memory_exports, {
|
|
12
14
|
createThreadHandler: () => createThreadHandler,
|
|
13
15
|
deleteMessagesHandler: () => deleteMessagesHandler,
|
|
14
16
|
deleteThreadHandler: () => deleteThreadHandler,
|
|
@@ -30,13 +32,38 @@ async function getMemoryFromContext({
|
|
|
30
32
|
agentId,
|
|
31
33
|
runtimeContext
|
|
32
34
|
}) {
|
|
33
|
-
const
|
|
35
|
+
const logger = mastra.getLogger();
|
|
36
|
+
let agent;
|
|
37
|
+
if (agentId) {
|
|
38
|
+
try {
|
|
39
|
+
agent = mastra.getAgent(agentId);
|
|
40
|
+
} catch (error) {
|
|
41
|
+
logger.debug("Error getting agent from mastra, searching agents for agent", error);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
34
44
|
if (agentId && !agent) {
|
|
35
|
-
|
|
45
|
+
logger.debug("Agent not found, searching agents for agent", { agentId });
|
|
46
|
+
const agents = mastra.getAgents();
|
|
47
|
+
if (Object.keys(agents || {}).length) {
|
|
48
|
+
for (const [_, ag] of Object.entries(agents)) {
|
|
49
|
+
try {
|
|
50
|
+
const agents2 = await ag.listAgents();
|
|
51
|
+
if (agents2[agentId]) {
|
|
52
|
+
agent = agents2[agentId];
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
} catch (error) {
|
|
56
|
+
logger.debug("Error getting agent from agent", error);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
if (!agent) {
|
|
61
|
+
throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Agent not found" });
|
|
62
|
+
}
|
|
36
63
|
}
|
|
37
64
|
if (agent) {
|
|
38
65
|
return await agent?.getMemory({
|
|
39
|
-
runtimeContext
|
|
66
|
+
runtimeContext: runtimeContext ?? new di.RuntimeContext()
|
|
40
67
|
}) || mastra.getMemory();
|
|
41
68
|
}
|
|
42
69
|
return mastra.getMemory();
|
|
@@ -307,7 +334,8 @@ async function getMessagesHandler({
|
|
|
307
334
|
threadId,
|
|
308
335
|
...limit && { selectBy: { last: limit } }
|
|
309
336
|
});
|
|
310
|
-
|
|
337
|
+
const uiMessages = agent.convertMessages(result.messagesV2).to("AIV5.UI");
|
|
338
|
+
return { messages: result.messages, uiMessages, legacyMessages: result.uiMessages };
|
|
311
339
|
} catch (error) {
|
|
312
340
|
return chunkRE4RPXT2_cjs.handleError(error, "Error getting messages");
|
|
313
341
|
}
|
|
@@ -332,7 +360,7 @@ async function getWorkingMemoryHandler({
|
|
|
332
360
|
const workingMemoryTemplate = template?.format === "json" ? { ...template, content: JSON.stringify(utils.generateEmptyFromSchema(template.content)) } : template;
|
|
333
361
|
const workingMemory = await memory.getWorkingMemory({ threadId, resourceId, memoryConfig });
|
|
334
362
|
const config = memory.getMergedThreadConfig(memoryConfig || {});
|
|
335
|
-
const source = config.workingMemory?.scope
|
|
363
|
+
const source = config.workingMemory?.scope !== "thread" && resourceId ? "resource" : "thread";
|
|
336
364
|
return { workingMemory, source, workingMemoryTemplate, threadExists };
|
|
337
365
|
} catch (error) {
|
|
338
366
|
return chunkRE4RPXT2_cjs.handleError(error, "Error getting working memory");
|
|
@@ -404,7 +432,7 @@ async function searchMemoryHandler({
|
|
|
404
432
|
}
|
|
405
433
|
const config = memory.getMergedThreadConfig(memoryConfig || {});
|
|
406
434
|
const hasSemanticRecall = !!config?.semanticRecall;
|
|
407
|
-
const resourceScope = typeof config?.semanticRecall === "object"
|
|
435
|
+
const resourceScope = typeof config?.semanticRecall === "object" ? config?.semanticRecall?.scope !== "thread" : true;
|
|
408
436
|
if (threadId && !resourceScope) {
|
|
409
437
|
const thread = await memory.getThreadById({ threadId });
|
|
410
438
|
if (!thread) {
|
|
@@ -415,7 +443,6 @@ async function searchMemoryHandler({
|
|
|
415
443
|
}
|
|
416
444
|
}
|
|
417
445
|
const searchResults = [];
|
|
418
|
-
const messageMap = /* @__PURE__ */ new Map();
|
|
419
446
|
if (threadId && !resourceScope) {
|
|
420
447
|
const thread = await memory.getThreadById({ threadId });
|
|
421
448
|
if (!thread) {
|
|
@@ -423,117 +450,72 @@ async function searchMemoryHandler({
|
|
|
423
450
|
results: [],
|
|
424
451
|
count: 0,
|
|
425
452
|
query: searchQuery,
|
|
426
|
-
searchScope: "thread",
|
|
453
|
+
searchScope: resourceScope ? "resource" : "thread",
|
|
427
454
|
searchType: hasSemanticRecall ? "semantic" : "text"
|
|
428
455
|
};
|
|
429
456
|
}
|
|
430
457
|
}
|
|
431
|
-
if (!threadId
|
|
432
|
-
const
|
|
433
|
-
if (
|
|
458
|
+
if (!threadId) {
|
|
459
|
+
const threads2 = await memory.getThreadsByResourceId({ resourceId });
|
|
460
|
+
if (threads2.length === 0) {
|
|
434
461
|
return {
|
|
435
462
|
results: [],
|
|
436
463
|
count: 0,
|
|
437
464
|
query: searchQuery,
|
|
438
|
-
searchScope: "resource",
|
|
465
|
+
searchScope: resourceScope ? "resource" : "thread",
|
|
439
466
|
searchType: hasSemanticRecall ? "semantic" : "text"
|
|
440
467
|
};
|
|
441
468
|
}
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
results: [],
|
|
490
|
-
count: 0,
|
|
491
|
-
query: searchQuery,
|
|
492
|
-
searchScope: "thread",
|
|
493
|
-
searchType: hasSemanticRecall ? "semantic" : "text"
|
|
469
|
+
threadId = threads2[0].id;
|
|
470
|
+
}
|
|
471
|
+
const beforeRange = typeof config.semanticRecall === `boolean` ? 2 : typeof config.semanticRecall?.messageRange === `number` ? config.semanticRecall.messageRange : config.semanticRecall?.messageRange.before || 2;
|
|
472
|
+
const afterRange = typeof config.semanticRecall === `boolean` ? 2 : typeof config.semanticRecall?.messageRange === `number` ? config.semanticRecall.messageRange : config.semanticRecall?.messageRange.after || 2;
|
|
473
|
+
if (resourceScope && config.semanticRecall) {
|
|
474
|
+
config.semanticRecall = typeof config.semanticRecall === `boolean` ? (
|
|
475
|
+
// make message range 0 so we can highlight the matches in search, message range will include other messages, not the matching ones
|
|
476
|
+
// and we add prev/next messages in a special section on each message anyway
|
|
477
|
+
{ messageRange: 0, topK: 2, scope: "resource" }
|
|
478
|
+
) : { ...config.semanticRecall, messageRange: 0 };
|
|
479
|
+
}
|
|
480
|
+
const result = await memory.rememberMessages({
|
|
481
|
+
threadId,
|
|
482
|
+
resourceId,
|
|
483
|
+
vectorMessageSearch: searchQuery,
|
|
484
|
+
config
|
|
485
|
+
});
|
|
486
|
+
const threads = await memory.getThreadsByResourceId({ resourceId });
|
|
487
|
+
const threadMap = new Map(threads.map((t) => [t.id, t]));
|
|
488
|
+
for (const msg of result.messagesV2) {
|
|
489
|
+
const content = typeof msg.content.content === `string` ? msg.content.content : msg.content.parts?.map((p) => p.type === "text" ? p.text : "").join(" ") || "";
|
|
490
|
+
const msgThreadId = msg.threadId || threadId;
|
|
491
|
+
const thread = threadMap.get(msgThreadId);
|
|
492
|
+
const threadMessages = (await memory.query({ threadId: msgThreadId })).uiMessages;
|
|
493
|
+
const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
|
|
494
|
+
const searchResult = {
|
|
495
|
+
id: msg.id,
|
|
496
|
+
role: msg.role,
|
|
497
|
+
content,
|
|
498
|
+
createdAt: msg.createdAt,
|
|
499
|
+
threadId: msgThreadId,
|
|
500
|
+
threadTitle: thread?.title || msgThreadId
|
|
501
|
+
};
|
|
502
|
+
if (messageIndex !== -1) {
|
|
503
|
+
searchResult.context = {
|
|
504
|
+
before: threadMessages.slice(Math.max(0, messageIndex - beforeRange), messageIndex).map((m) => ({
|
|
505
|
+
id: m.id,
|
|
506
|
+
role: m.role,
|
|
507
|
+
content: m.content,
|
|
508
|
+
createdAt: m.createdAt || /* @__PURE__ */ new Date()
|
|
509
|
+
})),
|
|
510
|
+
after: threadMessages.slice(messageIndex + 1, messageIndex + afterRange + 1).map((m) => ({
|
|
511
|
+
id: m.id,
|
|
512
|
+
role: m.role,
|
|
513
|
+
content: m.content,
|
|
514
|
+
createdAt: m.createdAt || /* @__PURE__ */ new Date()
|
|
515
|
+
}))
|
|
494
516
|
};
|
|
495
517
|
}
|
|
496
|
-
|
|
497
|
-
threadId,
|
|
498
|
-
resourceId,
|
|
499
|
-
vectorMessageSearch: searchQuery,
|
|
500
|
-
config
|
|
501
|
-
});
|
|
502
|
-
const threadMessages = (await memory.query({ threadId })).uiMessages;
|
|
503
|
-
result.messagesV2.forEach((msg) => {
|
|
504
|
-
if (messageMap.has(msg.id)) return;
|
|
505
|
-
messageMap.set(msg.id, true);
|
|
506
|
-
const content = msg.content.content || msg.content.parts?.map((p) => p.type === "text" ? p.text : "").join(" ") || "";
|
|
507
|
-
if (!hasSemanticRecall && !content.toLowerCase().includes(searchQuery.toLowerCase())) {
|
|
508
|
-
return;
|
|
509
|
-
}
|
|
510
|
-
const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
|
|
511
|
-
const searchResult = {
|
|
512
|
-
id: msg.id,
|
|
513
|
-
role: msg.role,
|
|
514
|
-
content,
|
|
515
|
-
createdAt: msg.createdAt,
|
|
516
|
-
threadId,
|
|
517
|
-
threadTitle: thread?.title || threadId
|
|
518
|
-
};
|
|
519
|
-
if (messageIndex !== -1) {
|
|
520
|
-
searchResult.context = {
|
|
521
|
-
before: threadMessages.slice(Math.max(0, messageIndex - 2), messageIndex).map((m) => ({
|
|
522
|
-
id: m.id,
|
|
523
|
-
role: m.role,
|
|
524
|
-
content: m.content,
|
|
525
|
-
createdAt: m.createdAt || /* @__PURE__ */ new Date()
|
|
526
|
-
})),
|
|
527
|
-
after: threadMessages.slice(messageIndex + 1, messageIndex + 3).map((m) => ({
|
|
528
|
-
id: m.id,
|
|
529
|
-
role: m.role,
|
|
530
|
-
content: m.content,
|
|
531
|
-
createdAt: m.createdAt || /* @__PURE__ */ new Date()
|
|
532
|
-
}))
|
|
533
|
-
};
|
|
534
|
-
}
|
|
535
|
-
searchResults.push(searchResult);
|
|
536
|
-
});
|
|
518
|
+
searchResults.push(searchResult);
|
|
537
519
|
}
|
|
538
520
|
const sortedResults = searchResults.sort((a, b) => new Date(b.createdAt).getTime() - new Date(a.createdAt).getTime()).slice(0, limit);
|
|
539
521
|
return {
|
|
@@ -564,5 +546,5 @@ exports.saveMessagesHandler = saveMessagesHandler;
|
|
|
564
546
|
exports.searchMemoryHandler = searchMemoryHandler;
|
|
565
547
|
exports.updateThreadHandler = updateThreadHandler;
|
|
566
548
|
exports.updateWorkingMemoryHandler = updateWorkingMemoryHandler;
|
|
567
|
-
//# sourceMappingURL=chunk-
|
|
568
|
-
//# sourceMappingURL=chunk-
|
|
549
|
+
//# sourceMappingURL=chunk-GDUKGVFI.cjs.map
|
|
550
|
+
//# sourceMappingURL=chunk-GDUKGVFI.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/server/handlers/memory.ts"],"names":["__export","agents","HTTPException","RuntimeContext","handleError","validateBody","convertMessages","generateEmptyFromSchema","threads"],"mappings":"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","file":"chunk-GDUKGVFI.cjs","sourcesContent":["import { convertMessages } from '@mastra/core/agent';\nimport { RuntimeContext } from '@mastra/core/di';\nimport type { MastraMemory } from '@mastra/core/memory';\nimport type { StorageGetMessagesArg, ThreadSortOptions } from '@mastra/core/storage';\nimport { generateEmptyFromSchema } from '@mastra/core/utils';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\n\nimport { handleError } from './error';\nimport { validateBody } from './utils';\n\ninterface MemoryContext extends Context {\n agentId?: string;\n resourceId?: string;\n threadId?: string;\n runtimeContext?: RuntimeContext;\n}\n\nasync function getMemoryFromContext({\n mastra,\n agentId,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'runtimeContext'>): Promise<MastraMemory | null | undefined> {\n const logger = mastra.getLogger();\n let agent;\n if (agentId) {\n try {\n agent = mastra.getAgent(agentId);\n } catch (error) {\n logger.debug('Error getting agent from mastra, searching agents for agent', error);\n }\n }\n if (agentId && !agent) {\n logger.debug('Agent not found, searching agents for agent', { agentId });\n const agents = mastra.getAgents();\n if (Object.keys(agents || {}).length) {\n for (const [_, ag] of Object.entries(agents)) {\n try {\n const agents = await ag.listAgents();\n\n if (agents[agentId]) {\n agent = agents[agentId];\n break;\n }\n } catch (error) {\n logger.debug('Error getting agent from agent', error);\n }\n }\n }\n\n if (!agent) {\n throw new HTTPException(404, { message: 'Agent not found' });\n }\n }\n\n if (agent) {\n return (\n (await agent?.getMemory({\n runtimeContext: runtimeContext ?? new RuntimeContext(),\n })) || mastra.getMemory()\n );\n }\n\n return mastra.getMemory();\n}\n\n// Memory handlers\nexport async function getMemoryStatusHandler({\n mastra,\n agentId,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'runtimeContext'>) {\n try {\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n\n if (!memory) {\n return { result: false };\n }\n\n return { result: true };\n } catch (error) {\n return handleError(error, 'Error getting memory status');\n }\n}\n\nexport async function getMemoryConfigHandler({\n mastra,\n agentId,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'runtimeContext'>) {\n try {\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n // Get the merged configuration (defaults + custom)\n const config = memory.getMergedThreadConfig({});\n\n return { config };\n } catch (error) {\n return handleError(error, 'Error getting memory configuration');\n }\n}\n\nexport async function getThreadsHandler({\n mastra,\n agentId,\n resourceId,\n runtimeContext,\n orderBy,\n sortDirection,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'resourceId' | 'runtimeContext'> & ThreadSortOptions) {\n try {\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n validateBody({ resourceId });\n\n const threads = await memory.getThreadsByResourceId({\n resourceId: resourceId!,\n orderBy,\n sortDirection,\n });\n return threads;\n } catch (error) {\n return handleError(error, 'Error getting threads');\n }\n}\n\nexport async function getThreadsPaginatedHandler({\n mastra,\n agentId,\n resourceId,\n runtimeContext,\n page,\n perPage,\n orderBy,\n sortDirection,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'resourceId' | 'runtimeContext'> & {\n page: number;\n perPage: number;\n} & ThreadSortOptions) {\n try {\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n validateBody({ resourceId });\n\n const result = await memory.getThreadsByResourceIdPaginated({\n resourceId: resourceId!,\n page,\n perPage,\n orderBy,\n sortDirection,\n });\n return result;\n } catch (error) {\n return handleError(error, 'Error getting paginated threads');\n }\n}\n\nexport async function getThreadByIdHandler({\n mastra,\n agentId,\n threadId,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'threadId' | 'runtimeContext'>) {\n try {\n validateBody({ threadId });\n\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n const thread = await memory.getThreadById({ threadId: threadId! });\n if (!thread) {\n throw new HTTPException(404, { message: 'Thread not found' });\n }\n\n return thread;\n } catch (error) {\n return handleError(error, 'Error getting thread');\n }\n}\n\nexport async function saveMessagesHandler({\n mastra,\n agentId,\n body,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'runtimeContext'> & {\n body: {\n messages: Parameters<MastraMemory['saveMessages']>[0]['messages'];\n };\n}) {\n try {\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n if (!body?.messages) {\n throw new HTTPException(400, { message: 'Messages are required' });\n }\n\n if (!Array.isArray(body.messages)) {\n throw new HTTPException(400, { message: 'Messages should be an array' });\n }\n\n // Validate that all messages have threadId and resourceId\n const invalidMessages = body.messages.filter(message => !message.threadId || !message.resourceId);\n if (invalidMessages.length > 0) {\n throw new HTTPException(400, {\n message: `All messages must have threadId and resourceId fields. Found ${invalidMessages.length} invalid message(s).`,\n });\n }\n\n const processedMessages = body.messages.map(message => ({\n ...message,\n id: message.id || memory.generateId(),\n createdAt: message.createdAt ? new Date(message.createdAt) : new Date(),\n }));\n\n const result = await memory.saveMessages({ messages: processedMessages, memoryConfig: {} });\n return result;\n } catch (error) {\n return handleError(error, 'Error saving messages');\n }\n}\n\nexport async function createThreadHandler({\n mastra,\n agentId,\n body,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'runtimeContext'> & {\n body?: Omit<Parameters<MastraMemory['createThread']>[0], 'resourceId'> & { resourceId?: string };\n}) {\n try {\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n validateBody({ resourceId: body?.resourceId });\n\n const result = await memory.createThread({\n resourceId: body?.resourceId!,\n title: body?.title,\n metadata: body?.metadata,\n threadId: body?.threadId,\n });\n return result;\n } catch (error) {\n return handleError(error, 'Error saving thread to memory');\n }\n}\n\nexport async function updateThreadHandler({\n mastra,\n agentId,\n threadId,\n body,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'threadId' | 'runtimeContext'> & {\n body?: Parameters<MastraMemory['saveThread']>[0]['thread'];\n}) {\n try {\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n\n if (!body) {\n throw new HTTPException(400, { message: 'Body is required' });\n }\n\n const { title, metadata, resourceId } = body;\n const updatedAt = new Date();\n\n validateBody({ threadId });\n\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n const thread = await memory.getThreadById({ threadId: threadId! });\n if (!thread) {\n throw new HTTPException(404, { message: 'Thread not found' });\n }\n\n const updatedThread = {\n ...thread,\n title: title || thread.title,\n metadata: metadata || thread.metadata,\n resourceId: resourceId || thread.resourceId,\n createdAt: thread.createdAt,\n updatedAt,\n };\n\n const result = await memory.saveThread({ thread: updatedThread });\n return result;\n } catch (error) {\n return handleError(error, 'Error updating thread');\n }\n}\n\nexport async function deleteThreadHandler({\n mastra,\n agentId,\n threadId,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'threadId' | 'runtimeContext'>) {\n try {\n validateBody({ threadId });\n\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n const thread = await memory.getThreadById({ threadId: threadId! });\n if (!thread) {\n throw new HTTPException(404, { message: 'Thread not found' });\n }\n\n await memory.deleteThread(threadId!);\n return { result: 'Thread deleted' };\n } catch (error) {\n return handleError(error, 'Error deleting thread');\n }\n}\n\nexport async function getMessagesPaginatedHandler({\n mastra,\n threadId,\n resourceId,\n selectBy,\n format,\n}: StorageGetMessagesArg & Pick<MemoryContext, 'mastra'>) {\n try {\n validateBody({ threadId });\n\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(400, { message: 'Storage is not initialized' });\n }\n\n const thread = await storage.getThreadById({ threadId: threadId! });\n\n if (!thread) {\n throw new HTTPException(404, { message: 'Thread not found' });\n }\n\n const result = await storage.getMessagesPaginated({ threadId: threadId!, resourceId, selectBy, format });\n return result;\n } catch (error) {\n return handleError(error, 'Error getting messages');\n }\n}\n\nexport async function getMessagesHandler({\n mastra,\n agentId,\n threadId,\n limit,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'threadId' | 'runtimeContext'> & {\n limit?: number;\n}) {\n if (limit !== undefined && (!Number.isInteger(limit) || limit <= 0)) {\n throw new HTTPException(400, { message: 'Invalid limit: must be a positive integer' });\n }\n try {\n validateBody({ threadId });\n\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n const thread = await memory.getThreadById({ threadId: threadId! });\n if (!thread) {\n throw new HTTPException(404, { message: 'Thread not found' });\n }\n\n const result = await memory.query({\n threadId: threadId!,\n ...(limit && { selectBy: { last: limit } }),\n });\n const uiMessages = convertMessages(result.messagesV2).to('AIV5.UI');\n return { messages: result.messages, uiMessages, legacyMessages: result.uiMessages };\n } catch (error) {\n return handleError(error, 'Error getting messages');\n }\n}\n\n/**\n * Handler to get the working memory for a thread (optionally resource-scoped).\n * @returns workingMemory - the working memory for the thread\n * @returns source - thread or resource\n */\nexport async function getWorkingMemoryHandler({\n mastra,\n agentId,\n threadId,\n resourceId,\n runtimeContext,\n memoryConfig,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'threadId' | 'runtimeContext'> & {\n resourceId?: Parameters<MastraMemory['getWorkingMemory']>[0]['resourceId'];\n memoryConfig?: Parameters<MastraMemory['getWorkingMemory']>[0]['memoryConfig'];\n}) {\n try {\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n validateBody({ threadId });\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n const thread = await memory.getThreadById({ threadId: threadId! });\n const threadExists = !!thread;\n const template = await memory.getWorkingMemoryTemplate({ memoryConfig });\n const workingMemoryTemplate =\n template?.format === 'json'\n ? { ...template, content: JSON.stringify(generateEmptyFromSchema(template.content)) }\n : template;\n const workingMemory = await memory.getWorkingMemory({ threadId: threadId!, resourceId, memoryConfig });\n const config = memory.getMergedThreadConfig(memoryConfig || {});\n const source = config.workingMemory?.scope !== 'thread' && resourceId ? 'resource' : 'thread';\n return { workingMemory, source, workingMemoryTemplate, threadExists };\n } catch (error) {\n return handleError(error, 'Error getting working memory');\n }\n}\n\n/**\n * Handler to update the working memory for a thread (optionally resource-scoped).\n * @param threadId - the thread id\n * @param body - the body containing the working memory to update and the resource id (optional)\n */\nexport async function updateWorkingMemoryHandler({\n mastra,\n agentId,\n threadId,\n body,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'threadId' | 'runtimeContext'> & {\n body: Omit<Parameters<MastraMemory['updateWorkingMemory']>[0], 'threadId'>;\n}) {\n try {\n validateBody({ threadId });\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n const { resourceId, memoryConfig, workingMemory } = body;\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n const thread = await memory.getThreadById({ threadId: threadId! });\n if (!thread) {\n throw new HTTPException(404, { message: 'Thread not found' });\n }\n\n await memory.updateWorkingMemory({ threadId: threadId!, resourceId, workingMemory, memoryConfig });\n return { success: true };\n } catch (error) {\n return handleError(error, 'Error updating working memory');\n }\n}\n\ninterface SearchResult {\n id: string;\n role: string;\n content: any;\n createdAt: Date;\n threadId?: string;\n threadTitle?: string;\n score?: number;\n context?: {\n before?: SearchResult[];\n after?: SearchResult[];\n };\n}\n\ninterface SearchResponse {\n results: SearchResult[];\n count: number;\n query: string;\n searchScope?: string;\n searchType?: string;\n}\n\n/**\n * Handler to delete one or more messages.\n * @param messageIds - Can be a single ID, array of IDs, or objects with ID property\n */\nexport async function deleteMessagesHandler({\n mastra,\n agentId,\n messageIds,\n runtimeContext,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'runtimeContext'> & {\n messageIds: string | string[] | { id: string } | { id: string }[];\n}) {\n try {\n if (messageIds === undefined || messageIds === null) {\n throw new HTTPException(400, { message: 'messageIds is required' });\n }\n\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n // Delete the messages - let the memory method handle validation\n await memory.deleteMessages(messageIds as any);\n\n // Count messages for response\n let count = 1;\n if (Array.isArray(messageIds)) {\n count = messageIds.length;\n }\n\n return { success: true, message: `${count} message${count === 1 ? '' : 's'} deleted successfully` };\n } catch (error) {\n return handleError(error, 'Error deleting messages');\n }\n}\n\nexport async function searchMemoryHandler({\n mastra,\n agentId,\n searchQuery,\n resourceId,\n threadId,\n limit = 20,\n runtimeContext,\n memoryConfig,\n}: Pick<MemoryContext, 'mastra' | 'agentId' | 'runtimeContext'> & {\n searchQuery: string;\n resourceId: string;\n threadId?: string;\n limit?: number;\n memoryConfig?: any;\n}): Promise<SearchResponse | ReturnType<typeof handleError>> {\n try {\n validateBody({ searchQuery, resourceId });\n\n const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });\n if (!memory) {\n throw new HTTPException(400, { message: 'Memory is not initialized' });\n }\n\n // Get memory configuration first to check scope\n const config = memory.getMergedThreadConfig(memoryConfig || {});\n const hasSemanticRecall = !!config?.semanticRecall;\n const resourceScope =\n typeof config?.semanticRecall === 'object' ? config?.semanticRecall?.scope !== 'thread' : true;\n\n // Only validate thread ownership if we're in thread scope\n if (threadId && !resourceScope) {\n const thread = await memory.getThreadById({ threadId });\n if (!thread) {\n throw new HTTPException(404, { message: 'Thread not found' });\n }\n if (thread.resourceId !== resourceId) {\n throw new HTTPException(403, { message: 'Thread does not belong to the specified resource' });\n }\n }\n\n const searchResults: SearchResult[] = [];\n\n // If threadId is provided and scope is thread-based, check if the thread exists\n if (threadId && !resourceScope) {\n const thread = await memory.getThreadById({ threadId });\n if (!thread) {\n // Thread doesn't exist yet (new unsaved thread) - return empty results\n return {\n results: [],\n count: 0,\n query: searchQuery,\n searchScope: resourceScope ? 'resource' : 'thread',\n searchType: hasSemanticRecall ? 'semantic' : 'text',\n };\n }\n }\n\n // If no threadId provided, get one from the resource\n if (!threadId) {\n const threads = await memory.getThreadsByResourceId({ resourceId });\n\n if (threads.length === 0) {\n return {\n results: [],\n count: 0,\n query: searchQuery,\n searchScope: resourceScope ? 'resource' : 'thread',\n searchType: hasSemanticRecall ? 'semantic' : 'text',\n };\n }\n\n // Use first thread - Memory class will handle scope internally\n threadId = threads[0]!.id;\n }\n\n const beforeRange =\n typeof config.semanticRecall === `boolean`\n ? 2\n : typeof config.semanticRecall?.messageRange === `number`\n ? config.semanticRecall.messageRange\n : config.semanticRecall?.messageRange.before || 2;\n const afterRange =\n typeof config.semanticRecall === `boolean`\n ? 2\n : typeof config.semanticRecall?.messageRange === `number`\n ? config.semanticRecall.messageRange\n : config.semanticRecall?.messageRange.after || 2;\n\n if (resourceScope && config.semanticRecall) {\n config.semanticRecall =\n typeof config.semanticRecall === `boolean`\n ? // make message range 0 so we can highlight the matches in search, message range will include other messages, not the matching ones\n // and we add prev/next messages in a special section on each message anyway\n { messageRange: 0, topK: 2, scope: 'resource' }\n : { ...config.semanticRecall, messageRange: 0 };\n }\n\n // Single call to rememberMessages - just like the agent does\n // The Memory class handles scope (thread vs resource) internally\n const result = await memory.rememberMessages({\n threadId,\n resourceId,\n vectorMessageSearch: searchQuery,\n config,\n });\n\n // Get all threads to build context and show which thread each message is from\n const threads = await memory.getThreadsByResourceId({ resourceId });\n const threadMap = new Map(threads.map(t => [t.id, t]));\n\n // Process each message in the results\n for (const msg of result.messagesV2) {\n const content =\n typeof msg.content.content === `string`\n ? msg.content.content\n : msg.content.parts?.map((p: any) => (p.type === 'text' ? p.text : '')).join(' ') || '';\n\n const msgThreadId = msg.threadId || threadId;\n const thread = threadMap.get(msgThreadId);\n\n // Get thread messages for context\n const threadMessages = (await memory.query({ threadId: msgThreadId })).uiMessages;\n const messageIndex = threadMessages.findIndex(m => m.id === msg.id);\n\n const searchResult: SearchResult = {\n id: msg.id,\n role: msg.role,\n content,\n createdAt: msg.createdAt,\n threadId: msgThreadId,\n threadTitle: thread?.title || msgThreadId,\n };\n\n if (messageIndex !== -1) {\n searchResult.context = {\n before: threadMessages.slice(Math.max(0, messageIndex - beforeRange), messageIndex).map(m => ({\n id: m.id,\n role: m.role,\n content: m.content,\n createdAt: m.createdAt || new Date(),\n })),\n after: threadMessages.slice(messageIndex + 1, messageIndex + afterRange + 1).map(m => ({\n id: m.id,\n role: m.role,\n content: m.content,\n createdAt: m.createdAt || new Date(),\n })),\n };\n }\n\n searchResults.push(searchResult);\n }\n\n // Sort by date (newest first) and limit\n const sortedResults = searchResults\n .sort((a, b) => new Date(b.createdAt).getTime() - new Date(a.createdAt).getTime())\n .slice(0, limit);\n\n return {\n results: sortedResults,\n count: sortedResults.length,\n query: searchQuery,\n searchScope: resourceScope ? 'resource' : 'thread',\n searchType: hasSemanticRecall ? 'semantic' : 'text',\n };\n } catch (error) {\n return handleError(error, 'Error searching memory');\n }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
1
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/double-indexed-kv.js
|
|
2
2
|
var DoubleIndexedKV = class {
|
|
3
3
|
constructor() {
|
|
4
4
|
this.keyToValue = /* @__PURE__ */ new Map();
|
|
@@ -20,7 +20,7 @@ var DoubleIndexedKV = class {
|
|
|
20
20
|
}
|
|
21
21
|
};
|
|
22
22
|
|
|
23
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
23
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/registry.js
|
|
24
24
|
var Registry = class {
|
|
25
25
|
constructor(generateIdentifier) {
|
|
26
26
|
this.generateIdentifier = generateIdentifier;
|
|
@@ -46,7 +46,7 @@ var Registry = class {
|
|
|
46
46
|
}
|
|
47
47
|
};
|
|
48
48
|
|
|
49
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
49
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/class-registry.js
|
|
50
50
|
var ClassRegistry = class extends Registry {
|
|
51
51
|
constructor() {
|
|
52
52
|
super((c) => c.name);
|
|
@@ -67,7 +67,7 @@ var ClassRegistry = class extends Registry {
|
|
|
67
67
|
}
|
|
68
68
|
};
|
|
69
69
|
|
|
70
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
70
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/util.js
|
|
71
71
|
function valuesOfObj(record) {
|
|
72
72
|
if ("values" in Object) {
|
|
73
73
|
return Object.values(record);
|
|
@@ -110,7 +110,7 @@ function findArr(record, predicate) {
|
|
|
110
110
|
return void 0;
|
|
111
111
|
}
|
|
112
112
|
|
|
113
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
113
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/custom-transformer-registry.js
|
|
114
114
|
var CustomTransformerRegistry = class {
|
|
115
115
|
constructor() {
|
|
116
116
|
this.transfomers = {};
|
|
@@ -126,7 +126,7 @@ var CustomTransformerRegistry = class {
|
|
|
126
126
|
}
|
|
127
127
|
};
|
|
128
128
|
|
|
129
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
129
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/is.js
|
|
130
130
|
var getType = (payload) => Object.prototype.toString.call(payload).slice(8, -1);
|
|
131
131
|
var isUndefined = (payload) => typeof payload === "undefined";
|
|
132
132
|
var isNull = (payload) => payload === null;
|
|
@@ -157,14 +157,24 @@ var isInfinite = (payload) => payload === Infinity || payload === -Infinity;
|
|
|
157
157
|
var isTypedArray = (payload) => ArrayBuffer.isView(payload) && !(payload instanceof DataView);
|
|
158
158
|
var isURL = (payload) => payload instanceof URL;
|
|
159
159
|
|
|
160
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
161
|
-
var escapeKey = (key) => key.replace(/\./g, "\\.");
|
|
160
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/pathstringifier.js
|
|
161
|
+
var escapeKey = (key) => key.replace(/\\/g, "\\\\").replace(/\./g, "\\.");
|
|
162
162
|
var stringifyPath = (path) => path.map(String).map(escapeKey).join(".");
|
|
163
|
-
var parsePath = (string) => {
|
|
163
|
+
var parsePath = (string, legacyPaths) => {
|
|
164
164
|
const result = [];
|
|
165
165
|
let segment = "";
|
|
166
166
|
for (let i = 0; i < string.length; i++) {
|
|
167
167
|
let char = string.charAt(i);
|
|
168
|
+
if (!legacyPaths && char === "\\") {
|
|
169
|
+
const escaped = string.charAt(i + 1);
|
|
170
|
+
if (escaped === "\\") {
|
|
171
|
+
segment += "\\";
|
|
172
|
+
i++;
|
|
173
|
+
continue;
|
|
174
|
+
} else if (escaped !== ".") {
|
|
175
|
+
throw Error("invalid path");
|
|
176
|
+
}
|
|
177
|
+
}
|
|
168
178
|
const isEscapedDot = char === "\\" && string.charAt(i + 1) === ".";
|
|
169
179
|
if (isEscapedDot) {
|
|
170
180
|
segment += ".";
|
|
@@ -184,7 +194,7 @@ var parsePath = (string) => {
|
|
|
184
194
|
return result;
|
|
185
195
|
};
|
|
186
196
|
|
|
187
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
197
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/transformer.js
|
|
188
198
|
function simpleTransformation(isApplicable, annotation, transform, untransform) {
|
|
189
199
|
return {
|
|
190
200
|
isApplicable,
|
|
@@ -208,12 +218,15 @@ var simpleRules = [
|
|
|
208
218
|
name: v.name,
|
|
209
219
|
message: v.message
|
|
210
220
|
};
|
|
221
|
+
if ("cause" in v) {
|
|
222
|
+
baseError.cause = v.cause;
|
|
223
|
+
}
|
|
211
224
|
superJson.allowedErrorProps.forEach((prop) => {
|
|
212
225
|
baseError[prop] = v[prop];
|
|
213
226
|
});
|
|
214
227
|
return baseError;
|
|
215
228
|
}, (v, superJson) => {
|
|
216
|
-
const e = new Error(v.message);
|
|
229
|
+
const e = new Error(v.message, { cause: v.cause });
|
|
217
230
|
e.name = v.name;
|
|
218
231
|
e.stack = v.stack;
|
|
219
232
|
superJson.allowedErrorProps.forEach((prop) => {
|
|
@@ -382,7 +395,7 @@ var untransformValue = (json, type, superJson) => {
|
|
|
382
395
|
}
|
|
383
396
|
};
|
|
384
397
|
|
|
385
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
398
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/accessDeep.js
|
|
386
399
|
var getNthKey = (value, n) => {
|
|
387
400
|
if (n > value.size)
|
|
388
401
|
throw new Error("index out of bounds");
|
|
@@ -498,40 +511,49 @@ var setDeep = (object, path, mapper) => {
|
|
|
498
511
|
return object;
|
|
499
512
|
};
|
|
500
513
|
|
|
501
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
502
|
-
|
|
514
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/plainer.js
|
|
515
|
+
var enableLegacyPaths = (version) => version < 1;
|
|
516
|
+
function traverse(tree, walker2, version, origin = []) {
|
|
503
517
|
if (!tree) {
|
|
504
518
|
return;
|
|
505
519
|
}
|
|
520
|
+
const legacyPaths = enableLegacyPaths(version);
|
|
506
521
|
if (!isArray(tree)) {
|
|
507
|
-
forEach(tree, (subtree, key) => traverse(subtree, walker2,
|
|
522
|
+
forEach(tree, (subtree, key) => traverse(subtree, walker2, version, [
|
|
523
|
+
...origin,
|
|
524
|
+
...parsePath(key, legacyPaths)
|
|
525
|
+
]));
|
|
508
526
|
return;
|
|
509
527
|
}
|
|
510
528
|
const [nodeValue, children] = tree;
|
|
511
529
|
if (children) {
|
|
512
530
|
forEach(children, (child, key) => {
|
|
513
|
-
traverse(child, walker2,
|
|
531
|
+
traverse(child, walker2, version, [
|
|
532
|
+
...origin,
|
|
533
|
+
...parsePath(key, legacyPaths)
|
|
534
|
+
]);
|
|
514
535
|
});
|
|
515
536
|
}
|
|
516
537
|
walker2(nodeValue, origin);
|
|
517
538
|
}
|
|
518
|
-
function applyValueAnnotations(plain, annotations, superJson) {
|
|
539
|
+
function applyValueAnnotations(plain, annotations, version, superJson) {
|
|
519
540
|
traverse(annotations, (type, path) => {
|
|
520
541
|
plain = setDeep(plain, path, (v) => untransformValue(v, type, superJson));
|
|
521
|
-
});
|
|
542
|
+
}, version);
|
|
522
543
|
return plain;
|
|
523
544
|
}
|
|
524
|
-
function applyReferentialEqualityAnnotations(plain, annotations) {
|
|
545
|
+
function applyReferentialEqualityAnnotations(plain, annotations, version) {
|
|
546
|
+
const legacyPaths = enableLegacyPaths(version);
|
|
525
547
|
function apply(identicalPaths, path) {
|
|
526
|
-
const object = getDeep(plain, parsePath(path));
|
|
527
|
-
identicalPaths.map(parsePath).forEach((identicalObjectPath) => {
|
|
548
|
+
const object = getDeep(plain, parsePath(path, legacyPaths));
|
|
549
|
+
identicalPaths.map((path2) => parsePath(path2, legacyPaths)).forEach((identicalObjectPath) => {
|
|
528
550
|
plain = setDeep(plain, identicalObjectPath, () => object);
|
|
529
551
|
});
|
|
530
552
|
}
|
|
531
553
|
if (isArray(annotations)) {
|
|
532
554
|
const [root, other] = annotations;
|
|
533
555
|
root.forEach((identicalPath) => {
|
|
534
|
-
plain = setDeep(plain, parsePath(identicalPath), () => plain);
|
|
556
|
+
plain = setDeep(plain, parsePath(identicalPath, legacyPaths), () => plain);
|
|
535
557
|
});
|
|
536
558
|
if (other) {
|
|
537
559
|
forEach(other, apply);
|
|
@@ -541,7 +563,7 @@ function applyReferentialEqualityAnnotations(plain, annotations) {
|
|
|
541
563
|
}
|
|
542
564
|
return plain;
|
|
543
565
|
}
|
|
544
|
-
var isDeep = (object, superJson) => isPlainObject(object) || isArray(object) || isMap(object) || isSet(object) || isInstanceOfRegisteredClass(object, superJson);
|
|
566
|
+
var isDeep = (object, superJson) => isPlainObject(object) || isArray(object) || isMap(object) || isSet(object) || isError(object) || isInstanceOfRegisteredClass(object, superJson);
|
|
545
567
|
function addIdentity(object, path, identities) {
|
|
546
568
|
const existingSet = identities.get(object);
|
|
547
569
|
if (existingSet) {
|
|
@@ -617,7 +639,7 @@ var walker = (object, identities, superJson, dedupe, path = [], objectsInThisPat
|
|
|
617
639
|
const recursiveResult = walker(value, identities, superJson, dedupe, [...path, index], [...objectsInThisPath, object], seenObjects);
|
|
618
640
|
transformedValue[index] = recursiveResult.transformedValue;
|
|
619
641
|
if (isArray(recursiveResult.annotations)) {
|
|
620
|
-
innerAnnotations[index] = recursiveResult.annotations;
|
|
642
|
+
innerAnnotations[escapeKey(index)] = recursiveResult.annotations;
|
|
621
643
|
} else if (isPlainObject(recursiveResult.annotations)) {
|
|
622
644
|
forEach(recursiveResult.annotations, (tree, key) => {
|
|
623
645
|
innerAnnotations[escapeKey(index) + "." + key] = tree;
|
|
@@ -637,13 +659,17 @@ var walker = (object, identities, superJson, dedupe, path = [], objectsInThisPat
|
|
|
637
659
|
return result;
|
|
638
660
|
};
|
|
639
661
|
|
|
640
|
-
// ../../node_modules/.pnpm/is-what@
|
|
662
|
+
// ../../node_modules/.pnpm/is-what@5.5.0/node_modules/is-what/dist/getType.js
|
|
641
663
|
function getType2(payload) {
|
|
642
664
|
return Object.prototype.toString.call(payload).slice(8, -1);
|
|
643
665
|
}
|
|
666
|
+
|
|
667
|
+
// ../../node_modules/.pnpm/is-what@5.5.0/node_modules/is-what/dist/isArray.js
|
|
644
668
|
function isArray2(payload) {
|
|
645
669
|
return getType2(payload) === "Array";
|
|
646
670
|
}
|
|
671
|
+
|
|
672
|
+
// ../../node_modules/.pnpm/is-what@5.5.0/node_modules/is-what/dist/isPlainObject.js
|
|
647
673
|
function isPlainObject2(payload) {
|
|
648
674
|
if (getType2(payload) !== "Object")
|
|
649
675
|
return false;
|
|
@@ -651,7 +677,7 @@ function isPlainObject2(payload) {
|
|
|
651
677
|
return !!prototype && prototype.constructor === Object && prototype === Object.prototype;
|
|
652
678
|
}
|
|
653
679
|
|
|
654
|
-
// ../../node_modules/.pnpm/copy-anything@
|
|
680
|
+
// ../../node_modules/.pnpm/copy-anything@4.0.5/node_modules/copy-anything/dist/index.js
|
|
655
681
|
function assignProp(carry, key, newVal, originalObject, includeNonenumerable) {
|
|
656
682
|
const propType = {}.propertyIsEnumerable.call(originalObject, key) ? "enumerable" : "nonenumerable";
|
|
657
683
|
if (propType === "enumerable")
|
|
@@ -675,6 +701,8 @@ function copy(target, options = {}) {
|
|
|
675
701
|
const props = Object.getOwnPropertyNames(target);
|
|
676
702
|
const symbols = Object.getOwnPropertySymbols(target);
|
|
677
703
|
return [...props, ...symbols].reduce((carry, key) => {
|
|
704
|
+
if (key === "__proto__")
|
|
705
|
+
return carry;
|
|
678
706
|
if (isArray2(options.props) && !options.props.includes(key)) {
|
|
679
707
|
return carry;
|
|
680
708
|
}
|
|
@@ -685,7 +713,7 @@ function copy(target, options = {}) {
|
|
|
685
713
|
}, {});
|
|
686
714
|
}
|
|
687
715
|
|
|
688
|
-
// ../../node_modules/.pnpm/superjson@2.2.
|
|
716
|
+
// ../../node_modules/.pnpm/superjson@2.2.3/node_modules/superjson/dist/index.js
|
|
689
717
|
var SuperJSON = class {
|
|
690
718
|
/**
|
|
691
719
|
* @param dedupeReferentialEqualities If true, SuperJSON will make sure only one instance of referentially equal objects are serialized and the rest are replaced with `null`.
|
|
@@ -716,16 +744,18 @@ var SuperJSON = class {
|
|
|
716
744
|
referentialEqualities: equalityAnnotations
|
|
717
745
|
};
|
|
718
746
|
}
|
|
747
|
+
if (res.meta)
|
|
748
|
+
res.meta.v = 1;
|
|
719
749
|
return res;
|
|
720
750
|
}
|
|
721
|
-
deserialize(payload) {
|
|
751
|
+
deserialize(payload, options) {
|
|
722
752
|
const { json, meta } = payload;
|
|
723
|
-
let result = copy(json);
|
|
753
|
+
let result = options?.inPlace ? json : copy(json);
|
|
724
754
|
if (meta?.values) {
|
|
725
|
-
result = applyValueAnnotations(result, meta.values, this);
|
|
755
|
+
result = applyValueAnnotations(result, meta.values, meta.v ?? 0, this);
|
|
726
756
|
}
|
|
727
757
|
if (meta?.referentialEqualities) {
|
|
728
|
-
result = applyReferentialEqualityAnnotations(result, meta.referentialEqualities);
|
|
758
|
+
result = applyReferentialEqualityAnnotations(result, meta.referentialEqualities, meta.v ?? 0);
|
|
729
759
|
}
|
|
730
760
|
return result;
|
|
731
761
|
}
|
|
@@ -733,7 +763,7 @@ var SuperJSON = class {
|
|
|
733
763
|
return JSON.stringify(this.serialize(object));
|
|
734
764
|
}
|
|
735
765
|
parse(string) {
|
|
736
|
-
return this.deserialize(JSON.parse(string));
|
|
766
|
+
return this.deserialize(JSON.parse(string), { inPlace: true });
|
|
737
767
|
}
|
|
738
768
|
registerClass(v, options) {
|
|
739
769
|
this.classRegistry.register(v, options);
|
|
@@ -763,5 +793,5 @@ SuperJSON.allowErrorProps = SuperJSON.defaultInstance.allowErrorProps.bind(Super
|
|
|
763
793
|
var stringify = SuperJSON.stringify;
|
|
764
794
|
|
|
765
795
|
export { stringify };
|
|
766
|
-
//# sourceMappingURL=chunk-
|
|
767
|
-
//# sourceMappingURL=chunk-
|
|
796
|
+
//# sourceMappingURL=chunk-GQRJOUV7.js.map
|
|
797
|
+
//# sourceMappingURL=chunk-GQRJOUV7.js.map
|