@mastra/server 1.0.4-alpha.2 → 1.1.0-alpha.0
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 +6765 -0
- package/LICENSE.md +11 -42
- package/README.md +45 -137
- package/a2a/store.d.ts +1 -0
- package/auth.d.ts +1 -0
- package/dist/chunk-24SISJRB.js +250 -0
- package/dist/chunk-24SISJRB.js.map +1 -0
- package/dist/chunk-2HAVULC2.cjs +204 -0
- package/dist/chunk-2HAVULC2.cjs.map +1 -0
- package/dist/chunk-2HOMKKY4.cjs +352 -0
- package/dist/chunk-2HOMKKY4.cjs.map +1 -0
- package/dist/chunk-37DO73XV.cjs +33207 -0
- package/dist/chunk-37DO73XV.cjs.map +1 -0
- package/dist/chunk-3AZY5AWI.js +689 -0
- package/dist/chunk-3AZY5AWI.js.map +1 -0
- package/dist/chunk-3OIJLD3O.js +333 -0
- package/dist/chunk-3OIJLD3O.js.map +1 -0
- package/dist/chunk-3QUACCLU.js +1372 -0
- package/dist/chunk-3QUACCLU.js.map +1 -0
- package/dist/chunk-3W67K7YE.js +13 -0
- package/dist/chunk-3W67K7YE.js.map +1 -0
- package/dist/chunk-4HFYR562.cjs +82 -0
- package/dist/chunk-4HFYR562.cjs.map +1 -0
- package/dist/chunk-4JAEBN6N.js +1201 -0
- package/dist/chunk-4JAEBN6N.js.map +1 -0
- package/dist/chunk-4LVJBXI2.cjs +324 -0
- package/dist/chunk-4LVJBXI2.cjs.map +1 -0
- package/dist/{chunk-FV45V6WC.cjs → chunk-64ITUOXI.cjs} +3 -7
- package/dist/chunk-64ITUOXI.cjs.map +1 -0
- package/dist/chunk-6G2RQWKA.cjs +252 -0
- package/dist/chunk-6G2RQWKA.cjs.map +1 -0
- package/dist/chunk-6KC345IN.cjs +708 -0
- package/dist/chunk-6KC345IN.cjs.map +1 -0
- package/dist/{chunk-TRDNDNGQ.js → chunk-6QWQZI4Q.js} +4 -7
- package/dist/chunk-6QWQZI4Q.js.map +1 -0
- package/dist/chunk-7D3UAMQM.cjs +82 -0
- package/dist/chunk-7D3UAMQM.cjs.map +1 -0
- package/dist/chunk-7XIMPDJV.js +442 -0
- package/dist/chunk-7XIMPDJV.js.map +1 -0
- package/dist/chunk-A2K5ZL47.cjs +195 -0
- package/dist/chunk-A2K5ZL47.cjs.map +1 -0
- package/dist/chunk-AAHPYUEC.cjs +211 -0
- package/dist/chunk-AAHPYUEC.cjs.map +1 -0
- package/dist/chunk-AN42MFD5.cjs +1231 -0
- package/dist/chunk-AN42MFD5.cjs.map +1 -0
- package/dist/chunk-AQI6GLTN.cjs +2777 -0
- package/dist/chunk-AQI6GLTN.cjs.map +1 -0
- package/dist/chunk-AV3VZ6S3.cjs +190 -0
- package/dist/chunk-AV3VZ6S3.cjs.map +1 -0
- package/dist/chunk-C4NZAUUW.js +33168 -0
- package/dist/chunk-C4NZAUUW.js.map +1 -0
- package/dist/chunk-D5VCL56B.js +317 -0
- package/dist/chunk-D5VCL56B.js.map +1 -0
- package/dist/chunk-DD7LYNHB.js +596 -0
- package/dist/chunk-DD7LYNHB.js.map +1 -0
- package/dist/chunk-DHDVJ5II.js +334 -0
- package/dist/chunk-DHDVJ5II.js.map +1 -0
- package/dist/chunk-ED6NQBHF.js +190 -0
- package/dist/chunk-ED6NQBHF.js.map +1 -0
- package/dist/chunk-EKFYZUPC.cjs +1404 -0
- package/dist/chunk-EKFYZUPC.cjs.map +1 -0
- package/dist/chunk-EV5H2JQU.js +45 -0
- package/dist/chunk-EV5H2JQU.js.map +1 -0
- package/dist/chunk-F2WTCJ5C.js +1153 -0
- package/dist/chunk-F2WTCJ5C.js.map +1 -0
- package/dist/chunk-FCPLBTHB.js +195 -0
- package/dist/chunk-FCPLBTHB.js.map +1 -0
- package/dist/chunk-FQX5SQO7.js +212 -0
- package/dist/chunk-FQX5SQO7.js.map +1 -0
- package/dist/chunk-FRRHYZR6.cjs +88 -0
- package/dist/chunk-FRRHYZR6.cjs.map +1 -0
- package/dist/chunk-GUG6KRAJ.js +666 -0
- package/dist/chunk-GUG6KRAJ.js.map +1 -0
- package/dist/chunk-GXUBQJ74.js +184 -0
- package/dist/chunk-GXUBQJ74.js.map +1 -0
- package/dist/chunk-H66LLFDL.js +970 -0
- package/dist/chunk-H66LLFDL.js.map +1 -0
- package/dist/chunk-HDGF45K7.cjs +128 -0
- package/dist/chunk-HDGF45K7.cjs.map +1 -0
- package/dist/chunk-HT4LP3BO.js +75 -0
- package/dist/chunk-HT4LP3BO.js.map +1 -0
- package/dist/chunk-HZINLMHL.cjs +252 -0
- package/dist/chunk-HZINLMHL.cjs.map +1 -0
- package/dist/chunk-IS3HHGL4.js +250 -0
- package/dist/chunk-IS3HHGL4.js.map +1 -0
- package/dist/chunk-JLFFAYTC.cjs +252 -0
- package/dist/chunk-JLFFAYTC.cjs.map +1 -0
- package/dist/chunk-JRM3DWRM.cjs +322 -0
- package/dist/chunk-JRM3DWRM.cjs.map +1 -0
- package/dist/chunk-K2SXZLA3.cjs +1049 -0
- package/dist/chunk-K2SXZLA3.cjs.map +1 -0
- package/dist/chunk-K4HSW5ZF.js +77 -0
- package/dist/chunk-K4HSW5ZF.js.map +1 -0
- package/dist/chunk-LFNP3ACE.js +1009 -0
- package/dist/chunk-LFNP3ACE.js.map +1 -0
- package/dist/chunk-LFTVDHOD.js +200 -0
- package/dist/chunk-LFTVDHOD.js.map +1 -0
- package/dist/chunk-LJ6YRVDI.cjs +15 -0
- package/dist/chunk-LJ6YRVDI.cjs.map +1 -0
- package/dist/chunk-LOA7RQYO.js +2774 -0
- package/dist/chunk-LOA7RQYO.js.map +1 -0
- package/dist/chunk-MCYD5LW7.cjs +90 -0
- package/dist/chunk-MCYD5LW7.cjs.map +1 -0
- package/dist/chunk-MZRJNOYJ.cjs +1195 -0
- package/dist/chunk-MZRJNOYJ.cjs.map +1 -0
- package/dist/chunk-O7I5CWRX.cjs +44 -0
- package/dist/chunk-O7I5CWRX.cjs.map +1 -0
- package/dist/chunk-ONN5EA7E.js +26 -0
- package/dist/chunk-ONN5EA7E.js.map +1 -0
- package/dist/chunk-OS7SAIRA.js +250 -0
- package/dist/chunk-OS7SAIRA.js.map +1 -0
- package/dist/chunk-PR4QN5HX.js +39 -0
- package/dist/chunk-PR4QN5HX.js.map +1 -0
- package/dist/chunk-PWXUI3OG.cjs +252 -0
- package/dist/chunk-PWXUI3OG.cjs.map +1 -0
- package/dist/chunk-QOVLJFLX.cjs +680 -0
- package/dist/chunk-QOVLJFLX.cjs.map +1 -0
- package/dist/chunk-QXDNFBJQ.js +220 -0
- package/dist/chunk-QXDNFBJQ.js.map +1 -0
- package/dist/chunk-RIX6WEJ2.js +83 -0
- package/dist/chunk-RIX6WEJ2.js.map +1 -0
- package/dist/chunk-RW66MHXI.js +246 -0
- package/dist/chunk-RW66MHXI.js.map +1 -0
- package/dist/chunk-S4SLHUJ7.cjs +253 -0
- package/dist/chunk-S4SLHUJ7.cjs.map +1 -0
- package/dist/chunk-SONAXR2M.cjs +450 -0
- package/dist/chunk-SONAXR2M.cjs.map +1 -0
- package/dist/chunk-SUKFO7UM.cjs +29 -0
- package/dist/chunk-SUKFO7UM.cjs.map +1 -0
- package/dist/chunk-T5KH32UA.cjs +47 -0
- package/dist/chunk-T5KH32UA.cjs.map +1 -0
- package/dist/chunk-TCWPL26W.js +119 -0
- package/dist/chunk-TCWPL26W.js.map +1 -0
- package/dist/chunk-TGDBGIDA.cjs +623 -0
- package/dist/chunk-TGDBGIDA.cjs.map +1 -0
- package/dist/chunk-USR6JK77.js +62 -0
- package/dist/chunk-USR6JK77.js.map +1 -0
- package/dist/chunk-VNHOYZ56.cjs +219 -0
- package/dist/chunk-VNHOYZ56.cjs.map +1 -0
- package/dist/chunk-VX3VN7FN.cjs +992 -0
- package/dist/chunk-VX3VN7FN.cjs.map +1 -0
- package/dist/chunk-WHC6S3VY.cjs +345 -0
- package/dist/chunk-WHC6S3VY.cjs.map +1 -0
- package/dist/chunk-XKLJYRAA.js +77 -0
- package/dist/chunk-XKLJYRAA.js.map +1 -0
- package/dist/chunk-XUSAKRLX.js +312 -0
- package/dist/chunk-XUSAKRLX.js.map +1 -0
- package/dist/chunk-ZKMVCV4G.cjs +71 -0
- package/dist/chunk-ZKMVCV4G.cjs.map +1 -0
- package/dist/dist-7NTDEVLP.cjs +928 -0
- package/dist/dist-7NTDEVLP.cjs.map +1 -0
- package/dist/dist-B5GMANA6.js +1147 -0
- package/dist/dist-B5GMANA6.js.map +1 -0
- package/dist/dist-EDO7GEGI.js +3 -0
- package/dist/dist-EDO7GEGI.js.map +1 -0
- package/dist/dist-OF24ZMHH.cjs +764 -0
- package/dist/dist-OF24ZMHH.cjs.map +1 -0
- package/dist/dist-P6YSNLL3.cjs +1150 -0
- package/dist/dist-P6YSNLL3.cjs.map +1 -0
- package/dist/dist-SMBO5KVB.js +937 -0
- package/dist/dist-SMBO5KVB.js.map +1 -0
- package/dist/dist-THPMW5QR.js +761 -0
- package/dist/dist-THPMW5QR.js.map +1 -0
- package/dist/dist-VZTG56X2.cjs +940 -0
- package/dist/dist-VZTG56X2.cjs.map +1 -0
- package/dist/dist-ZLC23RVC.cjs +16 -0
- package/dist/dist-ZLC23RVC.cjs.map +1 -0
- package/dist/dist-ZOZ6MHJH.js +925 -0
- package/dist/dist-ZOZ6MHJH.js.map +1 -0
- package/dist/docs/README.md +31 -0
- package/dist/docs/SKILL.md +32 -0
- package/dist/docs/SOURCE_MAP.json +6 -0
- package/dist/docs/server/01-custom-adapters.md +380 -0
- package/dist/docs/server/02-reference.md +833 -0
- package/dist/index.cjs +6 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/server/a2a/protocol.d.ts +8 -0
- package/dist/server/a2a/protocol.d.ts.map +1 -0
- package/dist/server/a2a/store.cjs +25 -0
- package/dist/server/a2a/store.cjs.map +1 -0
- package/dist/server/a2a/store.d.ts +14 -0
- package/dist/server/a2a/store.d.ts.map +1 -0
- package/dist/server/a2a/store.js +23 -0
- package/dist/server/a2a/store.js.map +1 -0
- package/dist/server/a2a/tasks.d.ts +20 -0
- package/dist/server/a2a/tasks.d.ts.map +1 -0
- package/dist/server/auth/defaults.d.ts +3 -0
- package/dist/server/auth/defaults.d.ts.map +1 -0
- package/dist/server/auth/helpers.d.ts +21 -0
- package/dist/server/auth/helpers.d.ts.map +1 -0
- package/dist/server/auth/index.cjs +48 -0
- package/dist/server/auth/index.cjs.map +1 -0
- package/dist/server/auth/index.d.ts +3 -0
- package/dist/server/auth/index.d.ts.map +1 -0
- package/dist/server/auth/index.js +3 -0
- package/dist/server/auth/index.js.map +1 -0
- package/dist/server/auth/path-pattern.d.ts +43 -0
- package/dist/server/auth/path-pattern.d.ts.map +1 -0
- package/dist/server/constants.d.ts +51 -0
- package/dist/server/constants.d.ts.map +1 -0
- package/dist/server/handlers/a2a.cjs +40 -0
- package/dist/server/handlers/a2a.cjs.map +1 -0
- package/dist/server/handlers/a2a.d.ts +550 -0
- package/dist/server/handlers/a2a.d.ts.map +1 -0
- package/dist/server/handlers/a2a.js +3 -0
- package/dist/server/handlers/a2a.js.map +1 -0
- package/dist/server/handlers/agent-builder.cjs +68 -0
- package/dist/server/handlers/agent-builder.cjs.map +1 -0
- package/dist/server/handlers/agent-builder.d.ts +632 -0
- package/dist/server/handlers/agent-builder.d.ts.map +1 -0
- package/dist/server/handlers/agent-builder.js +3 -0
- package/dist/server/handlers/agent-builder.js.map +1 -0
- package/dist/server/handlers/agent-versions.cjs +60 -0
- package/dist/server/handlers/agent-versions.cjs.map +1 -0
- package/dist/server/handlers/agent-versions.d.ts +479 -0
- package/dist/server/handlers/agent-versions.d.ts.map +1 -0
- package/dist/server/handlers/agent-versions.js +3 -0
- package/dist/server/handlers/agent-versions.js.map +1 -0
- package/dist/server/handlers/agents.cjs +111 -13
- package/dist/server/handlers/agents.cjs.map +1 -0
- package/dist/server/handlers/agents.d.ts +3440 -6
- package/dist/server/handlers/agents.d.ts.map +1 -0
- package/dist/server/handlers/agents.js +3 -1
- package/dist/server/handlers/agents.js.map +1 -0
- package/dist/server/handlers/error.cjs +8 -2
- package/dist/server/handlers/error.cjs.map +1 -0
- package/dist/server/handlers/error.d.ts +14 -1
- package/dist/server/handlers/error.d.ts.map +1 -0
- package/dist/server/handlers/error.js +3 -1
- package/dist/server/handlers/error.js.map +1 -0
- package/dist/server/handlers/logs.cjs +9 -7
- package/dist/server/handlers/logs.cjs.map +1 -0
- package/dist/server/handlers/logs.d.ts +142 -3
- package/dist/server/handlers/logs.d.ts.map +1 -0
- package/dist/server/handlers/logs.js +3 -1
- package/dist/server/handlers/logs.js.map +1 -0
- package/dist/server/handlers/mcp.cjs +40 -0
- package/dist/server/handlers/mcp.cjs.map +1 -0
- package/dist/server/handlers/mcp.d.ts +132 -0
- package/dist/server/handlers/mcp.d.ts.map +1 -0
- package/dist/server/handlers/mcp.js +3 -0
- package/dist/server/handlers/mcp.js.map +1 -0
- package/dist/server/handlers/memory.cjs +83 -17
- package/dist/server/handlers/memory.cjs.map +1 -0
- package/dist/server/handlers/memory.d.ts +1089 -8
- package/dist/server/handlers/memory.d.ts.map +1 -0
- package/dist/server/handlers/memory.js +3 -1
- package/dist/server/handlers/memory.js.map +1 -0
- package/dist/server/handlers/observability.cjs +24 -0
- package/dist/server/handlers/observability.cjs.map +1 -0
- package/dist/server/handlers/observability.d.ts +154 -0
- package/dist/server/handlers/observability.d.ts.map +1 -0
- package/dist/server/handlers/observability.js +3 -0
- package/dist/server/handlers/observability.js.map +1 -0
- package/dist/server/handlers/processors.cjs +20 -0
- package/dist/server/handlers/processors.cjs.map +1 -0
- package/dist/server/handlers/processors.d.ts +181 -0
- package/dist/server/handlers/processors.d.ts.map +1 -0
- package/dist/server/handlers/processors.js +3 -0
- package/dist/server/handlers/processors.js.map +1 -0
- package/dist/server/handlers/scores.cjs +32 -0
- package/dist/server/handlers/scores.cjs.map +1 -0
- package/dist/server/handlers/scores.d.ts +121 -0
- package/dist/server/handlers/scores.d.ts.map +1 -0
- package/dist/server/handlers/scores.js +3 -0
- package/dist/server/handlers/scores.js.map +1 -0
- package/dist/server/handlers/stored-agents.cjs +28 -0
- package/dist/server/handlers/stored-agents.cjs.map +1 -0
- package/dist/server/handlers/stored-agents.d.ts +317 -0
- package/dist/server/handlers/stored-agents.d.ts.map +1 -0
- package/dist/server/handlers/stored-agents.js +3 -0
- package/dist/server/handlers/stored-agents.js.map +1 -0
- package/dist/server/handlers/system.cjs +12 -0
- package/dist/server/handlers/system.cjs.map +1 -0
- package/dist/server/handlers/system.d.ts +7 -0
- package/dist/server/handlers/system.d.ts.map +1 -0
- package/dist/server/handlers/system.js +3 -0
- package/dist/server/handlers/system.js.map +1 -0
- package/dist/server/handlers/test-utils.cjs +15 -0
- package/dist/server/handlers/test-utils.cjs.map +1 -0
- package/dist/server/handlers/test-utils.d.ts +6 -0
- package/dist/server/handlers/test-utils.d.ts.map +1 -0
- package/dist/server/handlers/test-utils.js +13 -0
- package/dist/server/handlers/test-utils.js.map +1 -0
- package/dist/server/handlers/tools.cjs +15 -9
- package/dist/server/handlers/tools.cjs.map +1 -0
- package/dist/server/handlers/tools.d.ts +71 -4
- package/dist/server/handlers/tools.d.ts.map +1 -0
- package/dist/server/handlers/tools.js +3 -1
- package/dist/server/handlers/tools.js.map +1 -0
- package/dist/server/handlers/utils.cjs +32 -2
- package/dist/server/handlers/utils.cjs.map +1 -0
- package/dist/server/handlers/utils.d.ts +39 -1
- package/dist/server/handlers/utils.d.ts.map +1 -0
- package/dist/server/handlers/utils.js +3 -1
- package/dist/server/handlers/utils.js.map +1 -0
- package/dist/server/handlers/vector.cjs +33 -7
- package/dist/server/handlers/vector.cjs.map +1 -0
- package/dist/server/handlers/vector.d.ts +135 -6
- package/dist/server/handlers/vector.d.ts.map +1 -0
- package/dist/server/handlers/vector.js +3 -1
- package/dist/server/handlers/vector.js.map +1 -0
- package/dist/server/handlers/voice.cjs +25 -7
- package/dist/server/handlers/voice.cjs.map +1 -0
- package/dist/server/handlers/voice.d.ts +82 -3
- package/dist/server/handlers/voice.d.ts.map +1 -0
- package/dist/server/handlers/voice.js +3 -1
- package/dist/server/handlers/voice.js.map +1 -0
- package/dist/server/handlers/workflows.cjs +75 -21
- package/dist/server/handlers/workflows.cjs.map +1 -0
- package/dist/server/handlers/workflows.d.ts +996 -10
- package/dist/server/handlers/workflows.d.ts.map +1 -0
- package/dist/server/handlers/workflows.js +3 -1
- package/dist/server/handlers/workflows.js.map +1 -0
- package/dist/server/handlers/workspace.cjs +80 -0
- package/dist/server/handlers/workspace.cjs.map +1 -0
- package/dist/server/handlers/workspace.d.ts +591 -0
- package/dist/server/handlers/workspace.d.ts.map +1 -0
- package/dist/server/handlers/workspace.js +3 -0
- package/dist/server/handlers/workspace.js.map +1 -0
- package/dist/server/handlers.cjs +41 -24
- package/dist/server/handlers.cjs.map +1 -0
- package/dist/server/handlers.d.ts +13 -9
- package/dist/server/handlers.d.ts.map +1 -0
- package/dist/server/handlers.js +14 -9
- package/dist/server/handlers.js.map +1 -0
- package/dist/server/http-exception.d.ts +82 -0
- package/dist/server/http-exception.d.ts.map +1 -0
- package/dist/server/schemas/a2a.d.ts +786 -0
- package/dist/server/schemas/a2a.d.ts.map +1 -0
- package/dist/server/schemas/agent-builder.d.ts +225 -0
- package/dist/server/schemas/agent-builder.d.ts.map +1 -0
- package/dist/server/schemas/agent-versions.d.ts +1646 -0
- package/dist/server/schemas/agent-versions.d.ts.map +1 -0
- package/dist/server/schemas/agents.d.ts +1815 -0
- package/dist/server/schemas/agents.d.ts.map +1 -0
- package/dist/server/schemas/common.d.ts +179 -0
- package/dist/server/schemas/common.d.ts.map +1 -0
- package/dist/server/schemas/logs.d.ts +124 -0
- package/dist/server/schemas/logs.d.ts.map +1 -0
- package/dist/server/schemas/mcp.d.ts +299 -0
- package/dist/server/schemas/mcp.d.ts.map +1 -0
- package/dist/server/schemas/memory.d.ts +1216 -0
- package/dist/server/schemas/memory.d.ts.map +1 -0
- package/dist/server/schemas/processors.d.ts +519 -0
- package/dist/server/schemas/processors.d.ts.map +1 -0
- package/dist/server/schemas/scores.d.ts +259 -0
- package/dist/server/schemas/scores.d.ts.map +1 -0
- package/dist/server/schemas/stored-agents.d.ts +850 -0
- package/dist/server/schemas/stored-agents.d.ts.map +1 -0
- package/dist/server/schemas/system.d.ts +36 -0
- package/dist/server/schemas/system.d.ts.map +1 -0
- package/dist/server/schemas/vectors.d.ts +107 -0
- package/dist/server/schemas/vectors.d.ts.map +1 -0
- package/dist/server/schemas/workflows.d.ts +863 -0
- package/dist/server/schemas/workflows.d.ts.map +1 -0
- package/dist/server/schemas/workspace.d.ts +1107 -0
- package/dist/server/schemas/workspace.d.ts.map +1 -0
- package/dist/server/server-adapter/index.cjs +661 -0
- package/dist/server/server-adapter/index.cjs.map +1 -0
- package/dist/server/server-adapter/index.d.ts +163 -0
- package/dist/server/server-adapter/index.d.ts.map +1 -0
- package/dist/server/server-adapter/index.js +630 -0
- package/dist/server/server-adapter/index.js.map +1 -0
- package/dist/server/server-adapter/openapi-utils.d.ts +69 -0
- package/dist/server/server-adapter/openapi-utils.d.ts.map +1 -0
- package/dist/server/server-adapter/redact.d.ts +26 -0
- package/dist/server/server-adapter/redact.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/a2a.d.ts +3 -0
- package/dist/server/server-adapter/routes/a2a.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/agent-builder.d.ts +3 -0
- package/dist/server/server-adapter/routes/agent-builder.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/agents.d.ts +3 -0
- package/dist/server/server-adapter/routes/agents.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/index.d.ts +52 -0
- package/dist/server/server-adapter/routes/index.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/legacy.d.ts +7 -0
- package/dist/server/server-adapter/routes/legacy.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/logs.d.ts +3 -0
- package/dist/server/server-adapter/routes/logs.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/mcp.d.ts +9 -0
- package/dist/server/server-adapter/routes/mcp.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/memory.d.ts +3 -0
- package/dist/server/server-adapter/routes/memory.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/observability.d.ts +3 -0
- package/dist/server/server-adapter/routes/observability.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/processors.d.ts +3 -0
- package/dist/server/server-adapter/routes/processors.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/route-builder.d.ts +112 -0
- package/dist/server/server-adapter/routes/route-builder.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/scorers.d.ts +3 -0
- package/dist/server/server-adapter/routes/scorers.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/stored-agents.d.ts +8 -0
- package/dist/server/server-adapter/routes/stored-agents.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/stream-types.d.ts +10 -0
- package/dist/server/server-adapter/routes/stream-types.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/system.d.ts +12 -0
- package/dist/server/server-adapter/routes/system.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/tools.d.ts +3 -0
- package/dist/server/server-adapter/routes/tools.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/vectors.d.ts +3 -0
- package/dist/server/server-adapter/routes/vectors.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/workflows.d.ts +3 -0
- package/dist/server/server-adapter/routes/workflows.d.ts.map +1 -0
- package/dist/server/server-adapter/routes/workspace.d.ts +8 -0
- package/dist/server/server-adapter/routes/workspace.d.ts.map +1 -0
- package/dist/server/types.d.ts +10 -0
- package/dist/server/types.d.ts.map +1 -0
- package/dist/server/utils.d.ts +58 -0
- package/dist/server/utils.d.ts.map +1 -0
- package/dist/token-6GSAFR2W-ABXTQD64-MC4IMVOB.cjs +63 -0
- package/dist/token-6GSAFR2W-ABXTQD64-MC4IMVOB.cjs.map +1 -0
- package/dist/token-6GSAFR2W-ABXTQD64-Z6U2TA2C.js +61 -0
- package/dist/token-6GSAFR2W-ABXTQD64-Z6U2TA2C.js.map +1 -0
- package/dist/token-6GSAFR2W-F2L44NEJ-B3QIV63M.cjs +63 -0
- package/dist/token-6GSAFR2W-F2L44NEJ-B3QIV63M.cjs.map +1 -0
- package/dist/token-6GSAFR2W-F2L44NEJ-GFZ37A2V.js +61 -0
- package/dist/token-6GSAFR2W-F2L44NEJ-GFZ37A2V.js.map +1 -0
- package/dist/token-6GSAFR2W-WGTMOPEU-6HSZQUFZ.cjs +63 -0
- package/dist/token-6GSAFR2W-WGTMOPEU-6HSZQUFZ.cjs.map +1 -0
- package/dist/token-6GSAFR2W-WGTMOPEU-JKP67ZX4.js +61 -0
- package/dist/token-6GSAFR2W-WGTMOPEU-JKP67ZX4.js.map +1 -0
- package/dist/token-util-NEHG7TUY-4YJ4EPCL-MBTAVIJ3.js +8 -0
- package/dist/token-util-NEHG7TUY-4YJ4EPCL-MBTAVIJ3.js.map +1 -0
- package/dist/token-util-NEHG7TUY-4YJ4EPCL-SQ4NADRW.cjs +10 -0
- package/dist/token-util-NEHG7TUY-4YJ4EPCL-SQ4NADRW.cjs.map +1 -0
- package/dist/token-util-NEHG7TUY-TV2H7N56-GGCGMPDG.js +8 -0
- package/dist/token-util-NEHG7TUY-TV2H7N56-GGCGMPDG.js.map +1 -0
- package/dist/token-util-NEHG7TUY-TV2H7N56-R7OENTCJ.cjs +10 -0
- package/dist/token-util-NEHG7TUY-TV2H7N56-R7OENTCJ.cjs.map +1 -0
- package/dist/token-util-NEHG7TUY-XQP3QSPX-BL5O5N7R.cjs +10 -0
- package/dist/token-util-NEHG7TUY-XQP3QSPX-BL5O5N7R.cjs.map +1 -0
- package/dist/token-util-NEHG7TUY-XQP3QSPX-YCJRRNXO.js +8 -0
- package/dist/token-util-NEHG7TUY-XQP3QSPX-YCJRRNXO.js.map +1 -0
- package/handlers/server/handlers.d.ts +1 -0
- package/handlers.d.ts +1 -0
- package/package.json +74 -20
- package/server-adapter.d.ts +1 -0
- package/dist/_tsup-dts-rollup.d.cts +0 -573
- package/dist/_tsup-dts-rollup.d.ts +0 -573
- package/dist/chunk-2FJURXCL.cjs +0 -213
- package/dist/chunk-3AHQ5RGN.js +0 -11
- package/dist/chunk-3EJZQ6TQ.js +0 -49
- package/dist/chunk-3RVHWGWO.js +0 -95
- package/dist/chunk-4JINXASC.js +0 -120
- package/dist/chunk-67WTHYAV.js +0 -156
- package/dist/chunk-A7DF4ETD.cjs +0 -100
- package/dist/chunk-B64YROKU.cjs +0 -317
- package/dist/chunk-CWSDZEZG.cjs +0 -139
- package/dist/chunk-DVPP5S6I.js +0 -135
- package/dist/chunk-JLDXUWK7.cjs +0 -126
- package/dist/chunk-L7XE5QTW.js +0 -16
- package/dist/chunk-M56ECCHK.cjs +0 -128
- package/dist/chunk-OPP7H5TW.js +0 -305
- package/dist/chunk-PDC4ZBQW.cjs +0 -126
- package/dist/chunk-QH6XWSXP.cjs +0 -5579
- package/dist/chunk-QN4KF3BH.cjs +0 -18
- package/dist/chunk-RBQASTUP.js +0 -203
- package/dist/chunk-SKBVVI24.cjs +0 -54
- package/dist/chunk-UV4WTEH4.js +0 -120
- package/dist/chunk-VK6FX47H.js +0 -5576
- package/dist/chunk-YANVFOYA.js +0 -120
- package/dist/chunk-Z46X3YCB.cjs +0 -164
- package/dist/chunk-ZLBRQFDD.cjs +0 -13
- package/dist/index.d.cts +0 -1
- package/dist/server/handlers/agents.d.cts +0 -6
- package/dist/server/handlers/error.d.cts +0 -1
- package/dist/server/handlers/logs.d.cts +0 -3
- package/dist/server/handlers/memory.d.cts +0 -8
- package/dist/server/handlers/network.cjs +0 -22
- package/dist/server/handlers/network.d.cts +0 -4
- package/dist/server/handlers/network.d.ts +0 -4
- package/dist/server/handlers/network.js +0 -1
- package/dist/server/handlers/telemetry.cjs +0 -14
- package/dist/server/handlers/telemetry.d.cts +0 -2
- package/dist/server/handlers/telemetry.d.ts +0 -2
- package/dist/server/handlers/telemetry.js +0 -1
- package/dist/server/handlers/tools.d.cts +0 -4
- package/dist/server/handlers/utils.d.cts +0 -1
- package/dist/server/handlers/vector.d.cts +0 -6
- package/dist/server/handlers/voice.d.cts +0 -3
- package/dist/server/handlers/workflows.d.cts +0 -10
- package/dist/server/handlers.d.cts +0 -9
|
@@ -0,0 +1,1201 @@
|
|
|
1
|
+
import { getEffectiveResourceId, getEffectiveThreadId, validateBody, validateThreadOwnership } from './chunk-USR6JK77.js';
|
|
2
|
+
import { createPagePaginationSchema, paginationInfoSchema, successResponseSchema } from './chunk-HT4LP3BO.js';
|
|
3
|
+
import { handleError } from './chunk-ONN5EA7E.js';
|
|
4
|
+
import { createRoute } from './chunk-D5VCL56B.js';
|
|
5
|
+
import { HTTPException } from './chunk-6QWQZI4Q.js';
|
|
6
|
+
import { __export } from './chunk-PR4QN5HX.js';
|
|
7
|
+
import { generateEmptyFromSchema } from '@mastra/core/utils';
|
|
8
|
+
import z from 'zod';
|
|
9
|
+
|
|
10
|
+
// src/server/handlers/memory.ts
|
|
11
|
+
var memory_exports = {};
|
|
12
|
+
__export(memory_exports, {
|
|
13
|
+
CLONE_THREAD_ROUTE: () => CLONE_THREAD_ROUTE,
|
|
14
|
+
CREATE_THREAD_NETWORK_ROUTE: () => CREATE_THREAD_NETWORK_ROUTE,
|
|
15
|
+
CREATE_THREAD_ROUTE: () => CREATE_THREAD_ROUTE,
|
|
16
|
+
DELETE_MESSAGES_NETWORK_ROUTE: () => DELETE_MESSAGES_NETWORK_ROUTE,
|
|
17
|
+
DELETE_MESSAGES_ROUTE: () => DELETE_MESSAGES_ROUTE,
|
|
18
|
+
DELETE_THREAD_NETWORK_ROUTE: () => DELETE_THREAD_NETWORK_ROUTE,
|
|
19
|
+
DELETE_THREAD_ROUTE: () => DELETE_THREAD_ROUTE,
|
|
20
|
+
GET_MEMORY_CONFIG_ROUTE: () => GET_MEMORY_CONFIG_ROUTE,
|
|
21
|
+
GET_MEMORY_STATUS_NETWORK_ROUTE: () => GET_MEMORY_STATUS_NETWORK_ROUTE,
|
|
22
|
+
GET_MEMORY_STATUS_ROUTE: () => GET_MEMORY_STATUS_ROUTE,
|
|
23
|
+
GET_THREAD_BY_ID_NETWORK_ROUTE: () => GET_THREAD_BY_ID_NETWORK_ROUTE,
|
|
24
|
+
GET_THREAD_BY_ID_ROUTE: () => GET_THREAD_BY_ID_ROUTE,
|
|
25
|
+
GET_WORKING_MEMORY_ROUTE: () => GET_WORKING_MEMORY_ROUTE,
|
|
26
|
+
LIST_MESSAGES_NETWORK_ROUTE: () => LIST_MESSAGES_NETWORK_ROUTE,
|
|
27
|
+
LIST_MESSAGES_ROUTE: () => LIST_MESSAGES_ROUTE,
|
|
28
|
+
LIST_THREADS_NETWORK_ROUTE: () => LIST_THREADS_NETWORK_ROUTE,
|
|
29
|
+
LIST_THREADS_ROUTE: () => LIST_THREADS_ROUTE,
|
|
30
|
+
SAVE_MESSAGES_NETWORK_ROUTE: () => SAVE_MESSAGES_NETWORK_ROUTE,
|
|
31
|
+
SAVE_MESSAGES_ROUTE: () => SAVE_MESSAGES_ROUTE,
|
|
32
|
+
SEARCH_MEMORY_ROUTE: () => SEARCH_MEMORY_ROUTE,
|
|
33
|
+
UPDATE_THREAD_NETWORK_ROUTE: () => UPDATE_THREAD_NETWORK_ROUTE,
|
|
34
|
+
UPDATE_THREAD_ROUTE: () => UPDATE_THREAD_ROUTE,
|
|
35
|
+
UPDATE_WORKING_MEMORY_ROUTE: () => UPDATE_WORKING_MEMORY_ROUTE,
|
|
36
|
+
getTextContent: () => getTextContent
|
|
37
|
+
});
|
|
38
|
+
var threadIdPathParams = z.object({
|
|
39
|
+
threadId: z.string().describe("Unique identifier for the conversation thread")
|
|
40
|
+
});
|
|
41
|
+
var agentIdQuerySchema = z.object({
|
|
42
|
+
agentId: z.string()
|
|
43
|
+
});
|
|
44
|
+
var optionalAgentIdQuerySchema = z.object({
|
|
45
|
+
agentId: z.string().optional()
|
|
46
|
+
});
|
|
47
|
+
var storageOrderBySchema = z.preprocess(
|
|
48
|
+
(val) => {
|
|
49
|
+
if (typeof val === "string") {
|
|
50
|
+
try {
|
|
51
|
+
return JSON.parse(val);
|
|
52
|
+
} catch {
|
|
53
|
+
return void 0;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return val;
|
|
57
|
+
},
|
|
58
|
+
z.object({
|
|
59
|
+
field: z.enum(["createdAt", "updatedAt"]).optional(),
|
|
60
|
+
direction: z.enum(["ASC", "DESC"]).optional()
|
|
61
|
+
}).optional()
|
|
62
|
+
);
|
|
63
|
+
var messageOrderBySchema = z.preprocess(
|
|
64
|
+
(val) => {
|
|
65
|
+
if (typeof val === "string") {
|
|
66
|
+
try {
|
|
67
|
+
return JSON.parse(val);
|
|
68
|
+
} catch {
|
|
69
|
+
return void 0;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return val;
|
|
73
|
+
},
|
|
74
|
+
z.object({
|
|
75
|
+
field: z.enum(["createdAt"]).optional(),
|
|
76
|
+
direction: z.enum(["ASC", "DESC"]).optional()
|
|
77
|
+
}).optional()
|
|
78
|
+
);
|
|
79
|
+
var includeSchema = z.preprocess(
|
|
80
|
+
(val) => {
|
|
81
|
+
if (typeof val === "string") {
|
|
82
|
+
try {
|
|
83
|
+
return JSON.parse(val);
|
|
84
|
+
} catch {
|
|
85
|
+
return val;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return val;
|
|
89
|
+
},
|
|
90
|
+
z.array(
|
|
91
|
+
z.object({
|
|
92
|
+
id: z.string(),
|
|
93
|
+
threadId: z.string().optional(),
|
|
94
|
+
withPreviousMessages: z.number().optional(),
|
|
95
|
+
withNextMessages: z.number().optional()
|
|
96
|
+
})
|
|
97
|
+
).optional()
|
|
98
|
+
);
|
|
99
|
+
var filterSchema = z.preprocess(
|
|
100
|
+
(val) => {
|
|
101
|
+
if (typeof val === "string") {
|
|
102
|
+
try {
|
|
103
|
+
return JSON.parse(val);
|
|
104
|
+
} catch {
|
|
105
|
+
return val;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return val;
|
|
109
|
+
},
|
|
110
|
+
z.object({
|
|
111
|
+
dateRange: z.object({
|
|
112
|
+
start: z.coerce.date().optional(),
|
|
113
|
+
end: z.coerce.date().optional()
|
|
114
|
+
}).optional(),
|
|
115
|
+
roles: z.array(z.string()).optional()
|
|
116
|
+
}).optional()
|
|
117
|
+
);
|
|
118
|
+
var memoryConfigSchema = z.preprocess((val) => {
|
|
119
|
+
if (typeof val === "string") {
|
|
120
|
+
try {
|
|
121
|
+
return JSON.parse(val);
|
|
122
|
+
} catch {
|
|
123
|
+
return val;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
return val;
|
|
127
|
+
}, z.record(z.string(), z.unknown()).optional());
|
|
128
|
+
var threadSchema = z.object({
|
|
129
|
+
id: z.string(),
|
|
130
|
+
title: z.string().optional(),
|
|
131
|
+
resourceId: z.string(),
|
|
132
|
+
createdAt: z.date(),
|
|
133
|
+
updatedAt: z.date(),
|
|
134
|
+
metadata: z.record(z.string(), z.unknown()).optional()
|
|
135
|
+
});
|
|
136
|
+
var messageSchema = z.any();
|
|
137
|
+
var getMemoryStatusQuerySchema = agentIdQuerySchema;
|
|
138
|
+
var getMemoryConfigQuerySchema = agentIdQuerySchema;
|
|
139
|
+
var listThreadsQuerySchema = createPagePaginationSchema(100).extend({
|
|
140
|
+
agentId: z.string().optional(),
|
|
141
|
+
resourceId: z.string().optional(),
|
|
142
|
+
metadata: z.preprocess(
|
|
143
|
+
(val) => {
|
|
144
|
+
if (typeof val === "string") {
|
|
145
|
+
try {
|
|
146
|
+
return JSON.parse(val);
|
|
147
|
+
} catch {
|
|
148
|
+
return val;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
return val;
|
|
152
|
+
},
|
|
153
|
+
z.optional(z.record(z.string(), z.any()))
|
|
154
|
+
),
|
|
155
|
+
orderBy: storageOrderBySchema
|
|
156
|
+
});
|
|
157
|
+
var getThreadByIdQuerySchema = optionalAgentIdQuerySchema.extend({
|
|
158
|
+
resourceId: z.string().optional()
|
|
159
|
+
});
|
|
160
|
+
var listMessagesQuerySchema = createPagePaginationSchema(40).extend({
|
|
161
|
+
agentId: z.string().optional(),
|
|
162
|
+
resourceId: z.string().optional(),
|
|
163
|
+
orderBy: messageOrderBySchema,
|
|
164
|
+
include: includeSchema,
|
|
165
|
+
filter: filterSchema
|
|
166
|
+
});
|
|
167
|
+
var getWorkingMemoryQuerySchema = z.object({
|
|
168
|
+
agentId: z.string(),
|
|
169
|
+
resourceId: z.string().optional(),
|
|
170
|
+
memoryConfig: memoryConfigSchema
|
|
171
|
+
});
|
|
172
|
+
var deleteThreadQuerySchema = agentIdQuerySchema.extend({
|
|
173
|
+
resourceId: z.string().optional()
|
|
174
|
+
});
|
|
175
|
+
var deleteMessagesQuerySchema = agentIdQuerySchema.extend({
|
|
176
|
+
resourceId: z.string().optional()
|
|
177
|
+
});
|
|
178
|
+
var getMemoryStatusNetworkQuerySchema = agentIdQuerySchema;
|
|
179
|
+
var listThreadsNetworkQuerySchema = createPagePaginationSchema(100).extend({
|
|
180
|
+
agentId: z.string().optional(),
|
|
181
|
+
resourceId: z.string().optional(),
|
|
182
|
+
metadata: z.preprocess(
|
|
183
|
+
(val) => {
|
|
184
|
+
if (typeof val === "string") {
|
|
185
|
+
try {
|
|
186
|
+
return JSON.parse(val);
|
|
187
|
+
} catch {
|
|
188
|
+
return val;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
return val;
|
|
192
|
+
},
|
|
193
|
+
z.optional(z.record(z.string(), z.any()))
|
|
194
|
+
),
|
|
195
|
+
orderBy: storageOrderBySchema
|
|
196
|
+
});
|
|
197
|
+
var getThreadByIdNetworkQuerySchema = optionalAgentIdQuerySchema.extend({
|
|
198
|
+
resourceId: z.string().optional()
|
|
199
|
+
});
|
|
200
|
+
var listMessagesNetworkQuerySchema = createPagePaginationSchema(40).extend({
|
|
201
|
+
agentId: z.string().optional(),
|
|
202
|
+
resourceId: z.string().optional(),
|
|
203
|
+
orderBy: messageOrderBySchema,
|
|
204
|
+
include: includeSchema,
|
|
205
|
+
filter: filterSchema
|
|
206
|
+
});
|
|
207
|
+
var saveMessagesNetworkQuerySchema = agentIdQuerySchema;
|
|
208
|
+
var createThreadNetworkQuerySchema = agentIdQuerySchema;
|
|
209
|
+
var updateThreadNetworkQuerySchema = agentIdQuerySchema;
|
|
210
|
+
var deleteThreadNetworkQuerySchema = agentIdQuerySchema.extend({
|
|
211
|
+
resourceId: z.string().optional()
|
|
212
|
+
});
|
|
213
|
+
var deleteMessagesNetworkQuerySchema = agentIdQuerySchema.extend({
|
|
214
|
+
resourceId: z.string().optional()
|
|
215
|
+
});
|
|
216
|
+
var memoryStatusResponseSchema = z.object({
|
|
217
|
+
result: z.boolean()
|
|
218
|
+
});
|
|
219
|
+
var memoryConfigResponseSchema = z.object({
|
|
220
|
+
config: z.object({
|
|
221
|
+
lastMessages: z.union([z.number(), z.literal(false)]).optional(),
|
|
222
|
+
semanticRecall: z.union([z.boolean(), z.any()]).optional(),
|
|
223
|
+
workingMemory: z.any().optional()
|
|
224
|
+
})
|
|
225
|
+
});
|
|
226
|
+
var listThreadsResponseSchema = paginationInfoSchema.extend({
|
|
227
|
+
threads: z.array(threadSchema)
|
|
228
|
+
});
|
|
229
|
+
var getThreadByIdResponseSchema = threadSchema;
|
|
230
|
+
var listMessagesResponseSchema = z.object({
|
|
231
|
+
messages: z.array(messageSchema),
|
|
232
|
+
uiMessages: z.unknown()
|
|
233
|
+
// Converted messages in UI format
|
|
234
|
+
});
|
|
235
|
+
var getWorkingMemoryResponseSchema = z.object({
|
|
236
|
+
workingMemory: z.unknown(),
|
|
237
|
+
// Can be string or structured object depending on template
|
|
238
|
+
source: z.enum(["thread", "resource"]),
|
|
239
|
+
workingMemoryTemplate: z.unknown(),
|
|
240
|
+
// Template structure varies
|
|
241
|
+
threadExists: z.boolean()
|
|
242
|
+
});
|
|
243
|
+
var saveMessagesBodySchema = z.object({
|
|
244
|
+
messages: z.array(messageSchema)
|
|
245
|
+
});
|
|
246
|
+
var createThreadBodySchema = z.object({
|
|
247
|
+
resourceId: z.string(),
|
|
248
|
+
title: z.string().optional(),
|
|
249
|
+
metadata: z.record(z.string(), z.unknown()).optional(),
|
|
250
|
+
threadId: z.string().optional()
|
|
251
|
+
});
|
|
252
|
+
var updateThreadBodySchema = z.object({
|
|
253
|
+
title: z.string().optional(),
|
|
254
|
+
metadata: z.record(z.string(), z.unknown()).optional(),
|
|
255
|
+
resourceId: z.string().optional()
|
|
256
|
+
});
|
|
257
|
+
var updateWorkingMemoryBodySchema = z.object({
|
|
258
|
+
workingMemory: z.string(),
|
|
259
|
+
resourceId: z.string().optional(),
|
|
260
|
+
memoryConfig: z.record(z.string(), z.unknown()).optional()
|
|
261
|
+
});
|
|
262
|
+
var deleteMessagesBodySchema = z.object({
|
|
263
|
+
messageIds: z.union([
|
|
264
|
+
z.string(),
|
|
265
|
+
z.array(z.string()),
|
|
266
|
+
z.object({ id: z.string() }),
|
|
267
|
+
z.array(z.object({ id: z.string() }))
|
|
268
|
+
])
|
|
269
|
+
});
|
|
270
|
+
var searchMemoryQuerySchema = z.object({
|
|
271
|
+
agentId: z.string(),
|
|
272
|
+
searchQuery: z.string(),
|
|
273
|
+
resourceId: z.string(),
|
|
274
|
+
threadId: z.string().optional(),
|
|
275
|
+
limit: z.coerce.number().optional().default(20),
|
|
276
|
+
memoryConfig: memoryConfigSchema
|
|
277
|
+
});
|
|
278
|
+
var saveMessagesResponseSchema = z.object({
|
|
279
|
+
messages: z.array(messageSchema)
|
|
280
|
+
});
|
|
281
|
+
var deleteThreadResponseSchema = z.object({
|
|
282
|
+
result: z.string()
|
|
283
|
+
});
|
|
284
|
+
var updateWorkingMemoryResponseSchema = successResponseSchema;
|
|
285
|
+
var deleteMessagesResponseSchema = successResponseSchema.extend({
|
|
286
|
+
message: z.string()
|
|
287
|
+
});
|
|
288
|
+
var searchMemoryResponseSchema = z.object({
|
|
289
|
+
results: z.array(z.unknown()),
|
|
290
|
+
count: z.number(),
|
|
291
|
+
query: z.string(),
|
|
292
|
+
searchScope: z.string().optional(),
|
|
293
|
+
searchType: z.string().optional()
|
|
294
|
+
});
|
|
295
|
+
var cloneThreadBodySchema = z.object({
|
|
296
|
+
newThreadId: z.string().optional(),
|
|
297
|
+
resourceId: z.string().optional(),
|
|
298
|
+
title: z.string().optional(),
|
|
299
|
+
metadata: z.record(z.string(), z.unknown()).optional(),
|
|
300
|
+
options: z.object({
|
|
301
|
+
messageLimit: z.number().optional(),
|
|
302
|
+
messageFilter: z.object({
|
|
303
|
+
startDate: z.coerce.date().optional(),
|
|
304
|
+
endDate: z.coerce.date().optional(),
|
|
305
|
+
messageIds: z.array(z.string()).optional()
|
|
306
|
+
}).optional()
|
|
307
|
+
}).optional()
|
|
308
|
+
});
|
|
309
|
+
var cloneThreadResponseSchema = z.object({
|
|
310
|
+
thread: threadSchema,
|
|
311
|
+
clonedMessages: z.array(messageSchema)
|
|
312
|
+
});
|
|
313
|
+
|
|
314
|
+
// src/server/handlers/memory.ts
|
|
315
|
+
function getTextContent(message) {
|
|
316
|
+
if (typeof message.content === "string") {
|
|
317
|
+
return message.content;
|
|
318
|
+
}
|
|
319
|
+
if (message.content && typeof message.content === "object" && "parts" in message.content) {
|
|
320
|
+
const textPart = message.content.parts.find((p) => p.type === "text");
|
|
321
|
+
return textPart?.text || "";
|
|
322
|
+
}
|
|
323
|
+
return "";
|
|
324
|
+
}
|
|
325
|
+
async function getMemoryFromContext({
|
|
326
|
+
mastra,
|
|
327
|
+
agentId,
|
|
328
|
+
requestContext
|
|
329
|
+
}) {
|
|
330
|
+
const logger = mastra.getLogger();
|
|
331
|
+
let agent;
|
|
332
|
+
if (agentId) {
|
|
333
|
+
try {
|
|
334
|
+
agent = mastra.getAgentById(agentId);
|
|
335
|
+
} catch (error) {
|
|
336
|
+
logger.debug("Error getting agent from mastra, searching agents for agent", error);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
if (agentId && !agent) {
|
|
340
|
+
logger.debug("Agent not found in registered agents, trying stored agents", { agentId });
|
|
341
|
+
try {
|
|
342
|
+
const storedAgent = await mastra.getStoredAgentById(agentId);
|
|
343
|
+
if (storedAgent) {
|
|
344
|
+
agent = storedAgent;
|
|
345
|
+
}
|
|
346
|
+
} catch (error) {
|
|
347
|
+
logger.debug("Error getting stored agent", error);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
if (agentId && !agent) {
|
|
351
|
+
logger.debug("Stored agent not found, searching sub-agents", { agentId });
|
|
352
|
+
const agents = mastra.listAgents();
|
|
353
|
+
if (Object.keys(agents || {}).length) {
|
|
354
|
+
for (const [_, ag] of Object.entries(agents)) {
|
|
355
|
+
try {
|
|
356
|
+
const subAgents = await ag.listAgents({ requestContext });
|
|
357
|
+
if (subAgents[agentId]) {
|
|
358
|
+
agent = subAgents[agentId];
|
|
359
|
+
break;
|
|
360
|
+
}
|
|
361
|
+
} catch (error) {
|
|
362
|
+
logger.debug("Error getting agent from agent", error);
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
if (!agent) {
|
|
367
|
+
throw new HTTPException(404, { message: "Agent not found" });
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
if (agent) {
|
|
371
|
+
return await agent?.getMemory({
|
|
372
|
+
requestContext
|
|
373
|
+
});
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
function getStorageFromContext({ mastra }) {
|
|
377
|
+
return mastra.getStorage();
|
|
378
|
+
}
|
|
379
|
+
var GET_MEMORY_STATUS_ROUTE = createRoute({
|
|
380
|
+
method: "GET",
|
|
381
|
+
path: "/memory/status",
|
|
382
|
+
responseType: "json",
|
|
383
|
+
queryParamSchema: getMemoryStatusQuerySchema,
|
|
384
|
+
responseSchema: memoryStatusResponseSchema,
|
|
385
|
+
summary: "Get memory status",
|
|
386
|
+
description: "Returns the current status of the memory system including configuration and health information",
|
|
387
|
+
tags: ["Memory"],
|
|
388
|
+
requiresAuth: true,
|
|
389
|
+
handler: async ({ mastra, agentId, requestContext }) => {
|
|
390
|
+
try {
|
|
391
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
392
|
+
if (memory) {
|
|
393
|
+
return { result: true };
|
|
394
|
+
}
|
|
395
|
+
if (!agentId) {
|
|
396
|
+
const storage = getStorageFromContext({ mastra });
|
|
397
|
+
if (storage) {
|
|
398
|
+
return { result: true };
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
return { result: false };
|
|
402
|
+
} catch (error) {
|
|
403
|
+
return handleError(error, "Error getting memory status");
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
});
|
|
407
|
+
var GET_MEMORY_CONFIG_ROUTE = createRoute({
|
|
408
|
+
method: "GET",
|
|
409
|
+
path: "/memory/config",
|
|
410
|
+
responseType: "json",
|
|
411
|
+
queryParamSchema: getMemoryConfigQuerySchema,
|
|
412
|
+
responseSchema: memoryConfigResponseSchema,
|
|
413
|
+
summary: "Get memory configuration",
|
|
414
|
+
description: "Returns the memory configuration for a specific agent or the system default",
|
|
415
|
+
tags: ["Memory"],
|
|
416
|
+
requiresAuth: true,
|
|
417
|
+
handler: async ({ mastra, agentId, requestContext }) => {
|
|
418
|
+
try {
|
|
419
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
420
|
+
if (!memory) {
|
|
421
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
422
|
+
}
|
|
423
|
+
const config = memory.getMergedThreadConfig({});
|
|
424
|
+
return { config };
|
|
425
|
+
} catch (error) {
|
|
426
|
+
return handleError(error, "Error getting memory configuration");
|
|
427
|
+
}
|
|
428
|
+
}
|
|
429
|
+
});
|
|
430
|
+
var LIST_THREADS_ROUTE = createRoute({
|
|
431
|
+
method: "GET",
|
|
432
|
+
path: "/memory/threads",
|
|
433
|
+
responseType: "json",
|
|
434
|
+
queryParamSchema: listThreadsQuerySchema,
|
|
435
|
+
responseSchema: listThreadsResponseSchema,
|
|
436
|
+
summary: "List memory threads",
|
|
437
|
+
description: "Returns a paginated list of conversation threads with optional filtering by resource ID and/or metadata",
|
|
438
|
+
tags: ["Memory"],
|
|
439
|
+
requiresAuth: true,
|
|
440
|
+
handler: async ({ mastra, agentId, resourceId, metadata, requestContext, page, perPage, orderBy }) => {
|
|
441
|
+
try {
|
|
442
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
443
|
+
const filter = effectiveResourceId || metadata ? {} : void 0;
|
|
444
|
+
if (effectiveResourceId) {
|
|
445
|
+
filter.resourceId = effectiveResourceId;
|
|
446
|
+
}
|
|
447
|
+
if (metadata) {
|
|
448
|
+
filter.metadata = metadata;
|
|
449
|
+
}
|
|
450
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
451
|
+
if (memory) {
|
|
452
|
+
const result = await memory.listThreads({
|
|
453
|
+
filter,
|
|
454
|
+
page,
|
|
455
|
+
perPage,
|
|
456
|
+
orderBy
|
|
457
|
+
});
|
|
458
|
+
return result;
|
|
459
|
+
}
|
|
460
|
+
if (!agentId) {
|
|
461
|
+
const storage = getStorageFromContext({ mastra });
|
|
462
|
+
if (storage) {
|
|
463
|
+
const memoryStore = await storage.getStore("memory");
|
|
464
|
+
if (memoryStore) {
|
|
465
|
+
const result = await memoryStore.listThreads({
|
|
466
|
+
filter,
|
|
467
|
+
page,
|
|
468
|
+
perPage,
|
|
469
|
+
orderBy
|
|
470
|
+
});
|
|
471
|
+
return result;
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
}
|
|
475
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
476
|
+
} catch (error) {
|
|
477
|
+
return handleError(error, "Error listing threads");
|
|
478
|
+
}
|
|
479
|
+
}
|
|
480
|
+
});
|
|
481
|
+
var GET_THREAD_BY_ID_ROUTE = createRoute({
|
|
482
|
+
method: "GET",
|
|
483
|
+
path: "/memory/threads/:threadId",
|
|
484
|
+
responseType: "json",
|
|
485
|
+
pathParamSchema: threadIdPathParams,
|
|
486
|
+
queryParamSchema: getThreadByIdQuerySchema,
|
|
487
|
+
responseSchema: getThreadByIdResponseSchema,
|
|
488
|
+
summary: "Get thread by ID",
|
|
489
|
+
description: "Returns details for a specific conversation thread",
|
|
490
|
+
tags: ["Memory"],
|
|
491
|
+
requiresAuth: true,
|
|
492
|
+
handler: async ({ mastra, agentId, threadId, resourceId, requestContext }) => {
|
|
493
|
+
try {
|
|
494
|
+
const effectiveThreadId = getEffectiveThreadId(requestContext, threadId);
|
|
495
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
496
|
+
validateBody({ threadId: effectiveThreadId });
|
|
497
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
498
|
+
if (memory) {
|
|
499
|
+
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
500
|
+
if (!thread) {
|
|
501
|
+
throw new HTTPException(404, { message: "Thread not found" });
|
|
502
|
+
}
|
|
503
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
504
|
+
return thread;
|
|
505
|
+
}
|
|
506
|
+
if (!agentId) {
|
|
507
|
+
const storage = getStorageFromContext({ mastra });
|
|
508
|
+
if (storage) {
|
|
509
|
+
const memoryStore = await storage.getStore("memory");
|
|
510
|
+
if (memoryStore) {
|
|
511
|
+
const thread = await memoryStore.getThreadById({ threadId: effectiveThreadId });
|
|
512
|
+
if (!thread) {
|
|
513
|
+
throw new HTTPException(404, { message: "Thread not found" });
|
|
514
|
+
}
|
|
515
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
516
|
+
return thread;
|
|
517
|
+
}
|
|
518
|
+
}
|
|
519
|
+
}
|
|
520
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
521
|
+
} catch (error) {
|
|
522
|
+
return handleError(error, "Error getting thread");
|
|
523
|
+
}
|
|
524
|
+
}
|
|
525
|
+
});
|
|
526
|
+
var LIST_MESSAGES_ROUTE = createRoute({
|
|
527
|
+
method: "GET",
|
|
528
|
+
path: "/memory/threads/:threadId/messages",
|
|
529
|
+
responseType: "json",
|
|
530
|
+
pathParamSchema: threadIdPathParams,
|
|
531
|
+
queryParamSchema: listMessagesQuerySchema,
|
|
532
|
+
responseSchema: listMessagesResponseSchema,
|
|
533
|
+
summary: "List thread messages",
|
|
534
|
+
description: "Returns a paginated list of messages in a conversation thread",
|
|
535
|
+
tags: ["Memory"],
|
|
536
|
+
requiresAuth: true,
|
|
537
|
+
handler: async ({
|
|
538
|
+
mastra,
|
|
539
|
+
agentId,
|
|
540
|
+
threadId,
|
|
541
|
+
resourceId,
|
|
542
|
+
perPage,
|
|
543
|
+
page,
|
|
544
|
+
orderBy,
|
|
545
|
+
include,
|
|
546
|
+
filter,
|
|
547
|
+
requestContext
|
|
548
|
+
}) => {
|
|
549
|
+
try {
|
|
550
|
+
const effectiveThreadId = getEffectiveThreadId(requestContext, threadId);
|
|
551
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
552
|
+
validateBody({ threadId: effectiveThreadId });
|
|
553
|
+
if (!effectiveThreadId) {
|
|
554
|
+
throw new HTTPException(400, { message: "No threadId found" });
|
|
555
|
+
}
|
|
556
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
557
|
+
if (memory) {
|
|
558
|
+
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
559
|
+
if (!thread) {
|
|
560
|
+
throw new HTTPException(404, { message: "Thread not found" });
|
|
561
|
+
}
|
|
562
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
563
|
+
const result = await memory.recall({
|
|
564
|
+
threadId: effectiveThreadId,
|
|
565
|
+
resourceId: effectiveResourceId,
|
|
566
|
+
perPage,
|
|
567
|
+
page,
|
|
568
|
+
orderBy,
|
|
569
|
+
include,
|
|
570
|
+
filter
|
|
571
|
+
});
|
|
572
|
+
return result;
|
|
573
|
+
}
|
|
574
|
+
if (!agentId) {
|
|
575
|
+
const storage = getStorageFromContext({ mastra });
|
|
576
|
+
if (storage) {
|
|
577
|
+
const memoryStore = await storage.getStore("memory");
|
|
578
|
+
if (memoryStore) {
|
|
579
|
+
const thread = await memoryStore.getThreadById({ threadId: effectiveThreadId });
|
|
580
|
+
if (!thread) {
|
|
581
|
+
throw new HTTPException(404, { message: "Thread not found" });
|
|
582
|
+
}
|
|
583
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
584
|
+
const result = await memoryStore.listMessages({
|
|
585
|
+
threadId: effectiveThreadId,
|
|
586
|
+
resourceId: effectiveResourceId,
|
|
587
|
+
perPage,
|
|
588
|
+
page,
|
|
589
|
+
orderBy,
|
|
590
|
+
include,
|
|
591
|
+
filter
|
|
592
|
+
});
|
|
593
|
+
return result;
|
|
594
|
+
}
|
|
595
|
+
}
|
|
596
|
+
}
|
|
597
|
+
return { messages: [], uiMessages: [] };
|
|
598
|
+
} catch (error) {
|
|
599
|
+
return handleError(error, "Error getting messages");
|
|
600
|
+
}
|
|
601
|
+
}
|
|
602
|
+
});
|
|
603
|
+
var GET_WORKING_MEMORY_ROUTE = createRoute({
|
|
604
|
+
method: "GET",
|
|
605
|
+
path: "/memory/threads/:threadId/working-memory",
|
|
606
|
+
responseType: "json",
|
|
607
|
+
pathParamSchema: threadIdPathParams,
|
|
608
|
+
queryParamSchema: getWorkingMemoryQuerySchema,
|
|
609
|
+
responseSchema: getWorkingMemoryResponseSchema,
|
|
610
|
+
summary: "Get working memory",
|
|
611
|
+
description: "Returns the working memory state for a thread",
|
|
612
|
+
tags: ["Memory"],
|
|
613
|
+
requiresAuth: true,
|
|
614
|
+
handler: async ({ mastra, agentId, threadId, resourceId, requestContext, memoryConfig }) => {
|
|
615
|
+
try {
|
|
616
|
+
const effectiveThreadId = getEffectiveThreadId(requestContext, threadId);
|
|
617
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
618
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
619
|
+
validateBody({ threadId: effectiveThreadId });
|
|
620
|
+
if (!memory) {
|
|
621
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
622
|
+
}
|
|
623
|
+
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
624
|
+
if (thread) {
|
|
625
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
626
|
+
}
|
|
627
|
+
const threadExists = !!thread;
|
|
628
|
+
const template = await memory.getWorkingMemoryTemplate({ memoryConfig });
|
|
629
|
+
const workingMemoryTemplate = template?.format === "json" ? { ...template, content: JSON.stringify(generateEmptyFromSchema(template.content)) } : template;
|
|
630
|
+
const workingMemory = await memory.getWorkingMemory({
|
|
631
|
+
threadId: effectiveThreadId,
|
|
632
|
+
resourceId: effectiveResourceId,
|
|
633
|
+
memoryConfig
|
|
634
|
+
});
|
|
635
|
+
const config = memory.getMergedThreadConfig(memoryConfig || {});
|
|
636
|
+
const source = config.workingMemory?.scope !== "thread" && effectiveResourceId ? "resource" : "thread";
|
|
637
|
+
return { workingMemory, source, workingMemoryTemplate, threadExists };
|
|
638
|
+
} catch (error) {
|
|
639
|
+
return handleError(error, "Error getting working memory");
|
|
640
|
+
}
|
|
641
|
+
}
|
|
642
|
+
});
|
|
643
|
+
var SAVE_MESSAGES_ROUTE = createRoute({
|
|
644
|
+
method: "POST",
|
|
645
|
+
path: "/memory/save-messages",
|
|
646
|
+
responseType: "json",
|
|
647
|
+
queryParamSchema: agentIdQuerySchema,
|
|
648
|
+
bodySchema: saveMessagesBodySchema,
|
|
649
|
+
responseSchema: saveMessagesResponseSchema,
|
|
650
|
+
summary: "Save messages",
|
|
651
|
+
description: "Saves new messages to memory",
|
|
652
|
+
tags: ["Memory"],
|
|
653
|
+
requiresAuth: true,
|
|
654
|
+
handler: async ({ mastra, agentId, messages, requestContext }) => {
|
|
655
|
+
try {
|
|
656
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, void 0);
|
|
657
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
658
|
+
if (!memory) {
|
|
659
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
660
|
+
}
|
|
661
|
+
if (!messages) {
|
|
662
|
+
throw new HTTPException(400, { message: "Messages are required" });
|
|
663
|
+
}
|
|
664
|
+
if (!Array.isArray(messages)) {
|
|
665
|
+
throw new HTTPException(400, { message: "Messages should be an array" });
|
|
666
|
+
}
|
|
667
|
+
const invalidMessages = messages.filter((message) => !message.threadId || !message.resourceId);
|
|
668
|
+
if (invalidMessages.length > 0) {
|
|
669
|
+
throw new HTTPException(400, {
|
|
670
|
+
message: `All messages must have threadId and resourceId fields. Found ${invalidMessages.length} invalid message(s).`
|
|
671
|
+
});
|
|
672
|
+
}
|
|
673
|
+
if (effectiveResourceId) {
|
|
674
|
+
const unauthorizedMessages = messages.filter((message) => message.resourceId !== effectiveResourceId);
|
|
675
|
+
if (unauthorizedMessages.length > 0) {
|
|
676
|
+
throw new HTTPException(403, {
|
|
677
|
+
message: "Access denied: cannot save messages for a different resource"
|
|
678
|
+
});
|
|
679
|
+
}
|
|
680
|
+
const threadIds = [...new Set(messages.map((m) => m.threadId).filter(Boolean))];
|
|
681
|
+
for (const threadId of threadIds) {
|
|
682
|
+
const thread = await memory.getThreadById({ threadId });
|
|
683
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
684
|
+
}
|
|
685
|
+
}
|
|
686
|
+
const processedMessages = messages.map((message) => ({
|
|
687
|
+
...message,
|
|
688
|
+
id: message.id || memory.generateId(),
|
|
689
|
+
createdAt: message.createdAt ? new Date(message.createdAt) : /* @__PURE__ */ new Date()
|
|
690
|
+
}));
|
|
691
|
+
const result = await memory.saveMessages({ messages: processedMessages, memoryConfig: {} });
|
|
692
|
+
return result;
|
|
693
|
+
} catch (error) {
|
|
694
|
+
return handleError(error, "Error saving messages");
|
|
695
|
+
}
|
|
696
|
+
}
|
|
697
|
+
});
|
|
698
|
+
var CREATE_THREAD_ROUTE = createRoute({
|
|
699
|
+
method: "POST",
|
|
700
|
+
path: "/memory/threads",
|
|
701
|
+
responseType: "json",
|
|
702
|
+
queryParamSchema: agentIdQuerySchema,
|
|
703
|
+
bodySchema: createThreadBodySchema,
|
|
704
|
+
responseSchema: getThreadByIdResponseSchema,
|
|
705
|
+
summary: "Create thread",
|
|
706
|
+
description: "Creates a new conversation thread",
|
|
707
|
+
tags: ["Memory"],
|
|
708
|
+
requiresAuth: true,
|
|
709
|
+
handler: async ({ mastra, agentId, resourceId, title, metadata, threadId, requestContext }) => {
|
|
710
|
+
try {
|
|
711
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
712
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
713
|
+
if (!memory) {
|
|
714
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
715
|
+
}
|
|
716
|
+
validateBody({ resourceId: effectiveResourceId });
|
|
717
|
+
const result = await memory.createThread({
|
|
718
|
+
resourceId: effectiveResourceId,
|
|
719
|
+
title,
|
|
720
|
+
metadata,
|
|
721
|
+
threadId
|
|
722
|
+
});
|
|
723
|
+
return result;
|
|
724
|
+
} catch (error) {
|
|
725
|
+
return handleError(error, "Error saving thread to memory");
|
|
726
|
+
}
|
|
727
|
+
}
|
|
728
|
+
});
|
|
729
|
+
var UPDATE_THREAD_ROUTE = createRoute({
|
|
730
|
+
method: "PATCH",
|
|
731
|
+
path: "/memory/threads/:threadId",
|
|
732
|
+
responseType: "json",
|
|
733
|
+
pathParamSchema: threadIdPathParams,
|
|
734
|
+
queryParamSchema: agentIdQuerySchema,
|
|
735
|
+
bodySchema: updateThreadBodySchema,
|
|
736
|
+
responseSchema: getThreadByIdResponseSchema,
|
|
737
|
+
summary: "Update thread",
|
|
738
|
+
description: "Updates a conversation thread",
|
|
739
|
+
tags: ["Memory"],
|
|
740
|
+
requiresAuth: true,
|
|
741
|
+
handler: async ({ mastra, agentId, threadId, title, metadata, resourceId, requestContext }) => {
|
|
742
|
+
try {
|
|
743
|
+
const effectiveThreadId = getEffectiveThreadId(requestContext, threadId);
|
|
744
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
745
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
746
|
+
const updatedAt = /* @__PURE__ */ new Date();
|
|
747
|
+
validateBody({ threadId: effectiveThreadId });
|
|
748
|
+
if (!memory) {
|
|
749
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
750
|
+
}
|
|
751
|
+
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
752
|
+
if (!thread) {
|
|
753
|
+
throw new HTTPException(404, { message: "Thread not found" });
|
|
754
|
+
}
|
|
755
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
756
|
+
const updatedThread = {
|
|
757
|
+
...thread,
|
|
758
|
+
title: title || thread.title,
|
|
759
|
+
metadata: metadata || thread.metadata,
|
|
760
|
+
// Don't allow changing resourceId if effectiveResourceId is set (prevents reassigning threads)
|
|
761
|
+
resourceId: effectiveResourceId || resourceId || thread.resourceId,
|
|
762
|
+
createdAt: thread.createdAt,
|
|
763
|
+
updatedAt
|
|
764
|
+
};
|
|
765
|
+
const result = await memory.saveThread({ thread: updatedThread });
|
|
766
|
+
return {
|
|
767
|
+
...result,
|
|
768
|
+
resourceId: result.resourceId ?? null
|
|
769
|
+
};
|
|
770
|
+
} catch (error) {
|
|
771
|
+
return handleError(error, "Error updating thread");
|
|
772
|
+
}
|
|
773
|
+
}
|
|
774
|
+
});
|
|
775
|
+
var DELETE_THREAD_ROUTE = createRoute({
|
|
776
|
+
method: "DELETE",
|
|
777
|
+
path: "/memory/threads/:threadId",
|
|
778
|
+
responseType: "json",
|
|
779
|
+
pathParamSchema: threadIdPathParams,
|
|
780
|
+
queryParamSchema: deleteThreadQuerySchema,
|
|
781
|
+
responseSchema: deleteThreadResponseSchema,
|
|
782
|
+
summary: "Delete thread",
|
|
783
|
+
description: "Deletes a conversation thread",
|
|
784
|
+
tags: ["Memory"],
|
|
785
|
+
requiresAuth: true,
|
|
786
|
+
handler: async ({ mastra, agentId, threadId, resourceId, requestContext }) => {
|
|
787
|
+
try {
|
|
788
|
+
const effectiveThreadId = getEffectiveThreadId(requestContext, threadId);
|
|
789
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
790
|
+
validateBody({ threadId: effectiveThreadId });
|
|
791
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
792
|
+
if (!memory) {
|
|
793
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
794
|
+
}
|
|
795
|
+
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
796
|
+
if (!thread) {
|
|
797
|
+
throw new HTTPException(404, { message: "Thread not found" });
|
|
798
|
+
}
|
|
799
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
800
|
+
await memory.deleteThread(effectiveThreadId);
|
|
801
|
+
return { result: "Thread deleted" };
|
|
802
|
+
} catch (error) {
|
|
803
|
+
return handleError(error, "Error deleting thread");
|
|
804
|
+
}
|
|
805
|
+
}
|
|
806
|
+
});
|
|
807
|
+
var CLONE_THREAD_ROUTE = createRoute({
|
|
808
|
+
method: "POST",
|
|
809
|
+
path: "/memory/threads/:threadId/clone",
|
|
810
|
+
responseType: "json",
|
|
811
|
+
pathParamSchema: threadIdPathParams,
|
|
812
|
+
queryParamSchema: agentIdQuerySchema,
|
|
813
|
+
bodySchema: cloneThreadBodySchema,
|
|
814
|
+
responseSchema: cloneThreadResponseSchema,
|
|
815
|
+
summary: "Clone thread",
|
|
816
|
+
description: "Creates a copy of a conversation thread with all its messages",
|
|
817
|
+
tags: ["Memory"],
|
|
818
|
+
requiresAuth: true,
|
|
819
|
+
handler: async ({ mastra, agentId, threadId, newThreadId, resourceId, title, metadata, options, requestContext }) => {
|
|
820
|
+
try {
|
|
821
|
+
const effectiveThreadId = getEffectiveThreadId(requestContext, threadId);
|
|
822
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
823
|
+
validateBody({ threadId: effectiveThreadId });
|
|
824
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
825
|
+
if (!memory) {
|
|
826
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
827
|
+
}
|
|
828
|
+
const sourceThread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
829
|
+
if (!sourceThread) {
|
|
830
|
+
throw new HTTPException(404, { message: "Source thread not found" });
|
|
831
|
+
}
|
|
832
|
+
await validateThreadOwnership(sourceThread, effectiveResourceId);
|
|
833
|
+
const result = await memory.cloneThread({
|
|
834
|
+
sourceThreadId: effectiveThreadId,
|
|
835
|
+
newThreadId,
|
|
836
|
+
// Use effective resourceId for the cloned thread
|
|
837
|
+
resourceId: effectiveResourceId,
|
|
838
|
+
title,
|
|
839
|
+
metadata,
|
|
840
|
+
options
|
|
841
|
+
});
|
|
842
|
+
return result;
|
|
843
|
+
} catch (error) {
|
|
844
|
+
return handleError(error, "Error cloning thread");
|
|
845
|
+
}
|
|
846
|
+
}
|
|
847
|
+
});
|
|
848
|
+
var UPDATE_WORKING_MEMORY_ROUTE = createRoute({
|
|
849
|
+
method: "POST",
|
|
850
|
+
path: "/memory/threads/:threadId/working-memory",
|
|
851
|
+
responseType: "json",
|
|
852
|
+
pathParamSchema: threadIdPathParams,
|
|
853
|
+
queryParamSchema: agentIdQuerySchema,
|
|
854
|
+
bodySchema: updateWorkingMemoryBodySchema,
|
|
855
|
+
responseSchema: updateWorkingMemoryResponseSchema,
|
|
856
|
+
summary: "Update working memory",
|
|
857
|
+
description: "Updates the working memory state for a thread",
|
|
858
|
+
tags: ["Memory"],
|
|
859
|
+
requiresAuth: true,
|
|
860
|
+
handler: async ({ mastra, agentId, threadId, resourceId, memoryConfig, workingMemory, requestContext }) => {
|
|
861
|
+
try {
|
|
862
|
+
const effectiveThreadId = getEffectiveThreadId(requestContext, threadId);
|
|
863
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
864
|
+
validateBody({ threadId: effectiveThreadId, workingMemory });
|
|
865
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
866
|
+
if (!memory) {
|
|
867
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
868
|
+
}
|
|
869
|
+
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
870
|
+
if (!thread) {
|
|
871
|
+
throw new HTTPException(404, { message: "Thread not found" });
|
|
872
|
+
}
|
|
873
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
874
|
+
await memory.updateWorkingMemory({
|
|
875
|
+
threadId: effectiveThreadId,
|
|
876
|
+
resourceId: effectiveResourceId,
|
|
877
|
+
workingMemory,
|
|
878
|
+
memoryConfig
|
|
879
|
+
});
|
|
880
|
+
return { success: true };
|
|
881
|
+
} catch (error) {
|
|
882
|
+
return handleError(error, "Error updating working memory");
|
|
883
|
+
}
|
|
884
|
+
}
|
|
885
|
+
});
|
|
886
|
+
var DELETE_MESSAGES_ROUTE = createRoute({
|
|
887
|
+
method: "POST",
|
|
888
|
+
path: "/memory/messages/delete",
|
|
889
|
+
responseType: "json",
|
|
890
|
+
queryParamSchema: deleteMessagesQuerySchema,
|
|
891
|
+
bodySchema: deleteMessagesBodySchema,
|
|
892
|
+
responseSchema: deleteMessagesResponseSchema,
|
|
893
|
+
summary: "Delete messages",
|
|
894
|
+
description: "Deletes specific messages from memory",
|
|
895
|
+
tags: ["Memory"],
|
|
896
|
+
requiresAuth: true,
|
|
897
|
+
handler: async ({ mastra, agentId, resourceId, messageIds, requestContext }) => {
|
|
898
|
+
try {
|
|
899
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
900
|
+
if (messageIds === void 0 || messageIds === null) {
|
|
901
|
+
throw new HTTPException(400, { message: "messageIds is required" });
|
|
902
|
+
}
|
|
903
|
+
let normalizedIds;
|
|
904
|
+
if (Array.isArray(messageIds)) {
|
|
905
|
+
normalizedIds = messageIds;
|
|
906
|
+
} else if (typeof messageIds === "string") {
|
|
907
|
+
normalizedIds = [messageIds];
|
|
908
|
+
} else {
|
|
909
|
+
normalizedIds = [messageIds];
|
|
910
|
+
}
|
|
911
|
+
const stringIds = normalizedIds.map((id) => typeof id === "string" ? id : id.id);
|
|
912
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
913
|
+
if (effectiveResourceId && stringIds.length > 0) {
|
|
914
|
+
const storage = memory?.storage || getStorageFromContext({ mastra });
|
|
915
|
+
if (!storage) {
|
|
916
|
+
throw new HTTPException(403, { message: "Access denied: unable to verify message ownership" });
|
|
917
|
+
}
|
|
918
|
+
const memoryStore = await storage.getStore("memory");
|
|
919
|
+
if (!memoryStore) {
|
|
920
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
921
|
+
}
|
|
922
|
+
const { messages } = await memoryStore.listMessagesById({ messageIds: stringIds });
|
|
923
|
+
const threadIds = [...new Set(messages.map((m) => m.threadId).filter(Boolean))];
|
|
924
|
+
for (const threadId of threadIds) {
|
|
925
|
+
const thread = await memoryStore.getThreadById({ threadId });
|
|
926
|
+
if (thread && thread.resourceId && thread.resourceId !== effectiveResourceId) {
|
|
927
|
+
throw new HTTPException(403, {
|
|
928
|
+
message: "Access denied: message belongs to a thread owned by a different resource"
|
|
929
|
+
});
|
|
930
|
+
}
|
|
931
|
+
}
|
|
932
|
+
}
|
|
933
|
+
if (memory) {
|
|
934
|
+
await memory.deleteMessages(normalizedIds);
|
|
935
|
+
} else if (!agentId) {
|
|
936
|
+
const storage = getStorageFromContext({ mastra });
|
|
937
|
+
if (storage) {
|
|
938
|
+
const memoryStore = await storage.getStore("memory");
|
|
939
|
+
if (memoryStore) {
|
|
940
|
+
await memoryStore.deleteMessages(stringIds);
|
|
941
|
+
} else {
|
|
942
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
943
|
+
}
|
|
944
|
+
} else {
|
|
945
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
946
|
+
}
|
|
947
|
+
} else {
|
|
948
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
949
|
+
}
|
|
950
|
+
const count = Array.isArray(messageIds) ? messageIds.length : 1;
|
|
951
|
+
return { success: true, message: `${count} message${count === 1 ? "" : "s"} deleted successfully` };
|
|
952
|
+
} catch (error) {
|
|
953
|
+
return handleError(error, "Error deleting messages");
|
|
954
|
+
}
|
|
955
|
+
}
|
|
956
|
+
});
|
|
957
|
+
var SEARCH_MEMORY_ROUTE = createRoute({
|
|
958
|
+
method: "GET",
|
|
959
|
+
path: "/memory/search",
|
|
960
|
+
responseType: "json",
|
|
961
|
+
queryParamSchema: searchMemoryQuerySchema,
|
|
962
|
+
responseSchema: searchMemoryResponseSchema,
|
|
963
|
+
summary: "Search memory",
|
|
964
|
+
description: "Searches across memory using semantic or text search",
|
|
965
|
+
tags: ["Memory"],
|
|
966
|
+
requiresAuth: true,
|
|
967
|
+
handler: async ({ mastra, agentId, searchQuery, resourceId, threadId, limit = 20, requestContext, memoryConfig }) => {
|
|
968
|
+
try {
|
|
969
|
+
const effectiveResourceId = getEffectiveResourceId(requestContext, resourceId);
|
|
970
|
+
const effectiveThreadId = getEffectiveThreadId(requestContext, threadId);
|
|
971
|
+
validateBody({ searchQuery, resourceId: effectiveResourceId });
|
|
972
|
+
const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
|
|
973
|
+
if (!memory) {
|
|
974
|
+
throw new HTTPException(400, { message: "Memory is not initialized" });
|
|
975
|
+
}
|
|
976
|
+
const config = memory.getMergedThreadConfig(memoryConfig || {});
|
|
977
|
+
const hasSemanticRecall = !!config?.semanticRecall;
|
|
978
|
+
const resourceScope = typeof config?.semanticRecall === "object" ? config?.semanticRecall?.scope !== "thread" : true;
|
|
979
|
+
const searchResults = [];
|
|
980
|
+
if (effectiveThreadId && !resourceScope) {
|
|
981
|
+
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
982
|
+
if (!thread) {
|
|
983
|
+
return {
|
|
984
|
+
results: [],
|
|
985
|
+
count: 0,
|
|
986
|
+
query: searchQuery,
|
|
987
|
+
searchScope: resourceScope ? "resource" : "thread",
|
|
988
|
+
searchType: hasSemanticRecall ? "semantic" : "text"
|
|
989
|
+
};
|
|
990
|
+
}
|
|
991
|
+
await validateThreadOwnership(thread, effectiveResourceId);
|
|
992
|
+
}
|
|
993
|
+
let searchThreadId = effectiveThreadId;
|
|
994
|
+
if (!searchThreadId) {
|
|
995
|
+
const { threads } = await memory.listThreads({
|
|
996
|
+
filter: { resourceId: effectiveResourceId },
|
|
997
|
+
page: 0,
|
|
998
|
+
perPage: 1,
|
|
999
|
+
orderBy: { field: "updatedAt", direction: "DESC" }
|
|
1000
|
+
});
|
|
1001
|
+
if (threads.length === 0) {
|
|
1002
|
+
return {
|
|
1003
|
+
results: [],
|
|
1004
|
+
count: 0,
|
|
1005
|
+
query: searchQuery,
|
|
1006
|
+
searchScope: resourceScope ? "resource" : "thread",
|
|
1007
|
+
searchType: hasSemanticRecall ? "semantic" : "text"
|
|
1008
|
+
};
|
|
1009
|
+
}
|
|
1010
|
+
searchThreadId = threads[0].id;
|
|
1011
|
+
}
|
|
1012
|
+
const beforeRange = typeof config.semanticRecall === `boolean` ? 2 : typeof config.semanticRecall?.messageRange === `number` ? config.semanticRecall.messageRange : config.semanticRecall?.messageRange.before || 2;
|
|
1013
|
+
const afterRange = typeof config.semanticRecall === `boolean` ? 2 : typeof config.semanticRecall?.messageRange === `number` ? config.semanticRecall.messageRange : config.semanticRecall?.messageRange.after || 2;
|
|
1014
|
+
if (resourceScope && config.semanticRecall) {
|
|
1015
|
+
config.semanticRecall = typeof config.semanticRecall === `boolean` ? (
|
|
1016
|
+
// make message range 0 so we can highlight the matches in search, message range will include other messages, not the matching ones
|
|
1017
|
+
// and we add prev/next messages in a special section on each message anyway
|
|
1018
|
+
{ messageRange: 0, topK: 2, scope: "resource" }
|
|
1019
|
+
) : { ...config.semanticRecall, messageRange: 0 };
|
|
1020
|
+
}
|
|
1021
|
+
const threadConfig = memory.getMergedThreadConfig(config || {});
|
|
1022
|
+
if (!threadConfig.lastMessages && !threadConfig.semanticRecall) {
|
|
1023
|
+
return { results: [], count: 0, query: searchQuery };
|
|
1024
|
+
}
|
|
1025
|
+
const result = await memory.recall({
|
|
1026
|
+
threadId: searchThreadId,
|
|
1027
|
+
resourceId: effectiveResourceId,
|
|
1028
|
+
perPage: threadConfig.lastMessages,
|
|
1029
|
+
threadConfig: config,
|
|
1030
|
+
vectorSearchString: threadConfig.semanticRecall && searchQuery ? searchQuery : void 0
|
|
1031
|
+
});
|
|
1032
|
+
const threadIds = Array.from(
|
|
1033
|
+
new Set(result.messages.map((m) => m.threadId || searchThreadId).filter(Boolean))
|
|
1034
|
+
);
|
|
1035
|
+
const fetched = await Promise.all(threadIds.map((id) => memory.getThreadById({ threadId: id })));
|
|
1036
|
+
const threadMap = new Map(fetched.filter(Boolean).map((t) => [t.id, t]));
|
|
1037
|
+
for (const msg of result.messages) {
|
|
1038
|
+
const content = getTextContent(msg);
|
|
1039
|
+
const msgThreadId = msg.threadId || searchThreadId;
|
|
1040
|
+
const thread = threadMap.get(msgThreadId);
|
|
1041
|
+
const threadMessages = (await memory.recall({ threadId: msgThreadId })).messages;
|
|
1042
|
+
const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
|
|
1043
|
+
const searchResult = {
|
|
1044
|
+
id: msg.id,
|
|
1045
|
+
role: msg.role,
|
|
1046
|
+
content,
|
|
1047
|
+
createdAt: msg.createdAt,
|
|
1048
|
+
threadId: msgThreadId,
|
|
1049
|
+
threadTitle: thread?.title || msgThreadId
|
|
1050
|
+
};
|
|
1051
|
+
if (messageIndex !== -1) {
|
|
1052
|
+
searchResult.context = {
|
|
1053
|
+
before: threadMessages.slice(Math.max(0, messageIndex - beforeRange), messageIndex).map((m) => ({
|
|
1054
|
+
id: m.id,
|
|
1055
|
+
role: m.role,
|
|
1056
|
+
content: getTextContent(m),
|
|
1057
|
+
createdAt: m.createdAt || /* @__PURE__ */ new Date()
|
|
1058
|
+
})),
|
|
1059
|
+
after: threadMessages.slice(messageIndex + 1, messageIndex + afterRange + 1).map((m) => ({
|
|
1060
|
+
id: m.id,
|
|
1061
|
+
role: m.role,
|
|
1062
|
+
content: getTextContent(m),
|
|
1063
|
+
createdAt: m.createdAt || /* @__PURE__ */ new Date()
|
|
1064
|
+
}))
|
|
1065
|
+
};
|
|
1066
|
+
}
|
|
1067
|
+
searchResults.push(searchResult);
|
|
1068
|
+
}
|
|
1069
|
+
const sortedResults = searchResults.sort((a, b) => new Date(b.createdAt).getTime() - new Date(a.createdAt).getTime()).slice(0, limit);
|
|
1070
|
+
return {
|
|
1071
|
+
results: sortedResults,
|
|
1072
|
+
count: sortedResults.length,
|
|
1073
|
+
query: searchQuery,
|
|
1074
|
+
searchScope: resourceScope ? "resource" : "thread",
|
|
1075
|
+
searchType: hasSemanticRecall ? "semantic" : "text"
|
|
1076
|
+
};
|
|
1077
|
+
} catch (error) {
|
|
1078
|
+
return handleError(error, "Error searching memory");
|
|
1079
|
+
}
|
|
1080
|
+
}
|
|
1081
|
+
});
|
|
1082
|
+
var GET_MEMORY_STATUS_NETWORK_ROUTE = createRoute({
|
|
1083
|
+
method: "GET",
|
|
1084
|
+
path: "/memory/network/status",
|
|
1085
|
+
responseType: "json",
|
|
1086
|
+
queryParamSchema: getMemoryStatusNetworkQuerySchema,
|
|
1087
|
+
responseSchema: memoryStatusResponseSchema,
|
|
1088
|
+
summary: "Get memory status (network)",
|
|
1089
|
+
description: "Returns the current status of the memory system (network route)",
|
|
1090
|
+
tags: ["Memory - Network"],
|
|
1091
|
+
requiresAuth: true,
|
|
1092
|
+
handler: GET_MEMORY_STATUS_ROUTE.handler
|
|
1093
|
+
});
|
|
1094
|
+
var LIST_THREADS_NETWORK_ROUTE = createRoute({
|
|
1095
|
+
method: "GET",
|
|
1096
|
+
path: "/memory/network/threads",
|
|
1097
|
+
responseType: "json",
|
|
1098
|
+
queryParamSchema: listThreadsNetworkQuerySchema,
|
|
1099
|
+
responseSchema: listThreadsResponseSchema,
|
|
1100
|
+
summary: "List memory threads (network)",
|
|
1101
|
+
description: "Returns a paginated list of conversation threads (network route)",
|
|
1102
|
+
tags: ["Memory - Network"],
|
|
1103
|
+
requiresAuth: true,
|
|
1104
|
+
handler: LIST_THREADS_ROUTE.handler
|
|
1105
|
+
});
|
|
1106
|
+
var GET_THREAD_BY_ID_NETWORK_ROUTE = createRoute({
|
|
1107
|
+
method: "GET",
|
|
1108
|
+
path: "/memory/network/threads/:threadId",
|
|
1109
|
+
responseType: "json",
|
|
1110
|
+
pathParamSchema: threadIdPathParams,
|
|
1111
|
+
queryParamSchema: getThreadByIdNetworkQuerySchema,
|
|
1112
|
+
responseSchema: getThreadByIdResponseSchema,
|
|
1113
|
+
summary: "Get thread by ID (network)",
|
|
1114
|
+
description: "Returns details for a specific conversation thread (network route)",
|
|
1115
|
+
tags: ["Memory - Network"],
|
|
1116
|
+
requiresAuth: true,
|
|
1117
|
+
handler: GET_THREAD_BY_ID_ROUTE.handler
|
|
1118
|
+
});
|
|
1119
|
+
var LIST_MESSAGES_NETWORK_ROUTE = createRoute({
|
|
1120
|
+
method: "GET",
|
|
1121
|
+
path: "/memory/network/threads/:threadId/messages",
|
|
1122
|
+
responseType: "json",
|
|
1123
|
+
pathParamSchema: threadIdPathParams,
|
|
1124
|
+
queryParamSchema: listMessagesNetworkQuerySchema,
|
|
1125
|
+
responseSchema: listMessagesResponseSchema,
|
|
1126
|
+
summary: "List thread messages (network)",
|
|
1127
|
+
description: "Returns a paginated list of messages in a conversation thread (network route)",
|
|
1128
|
+
tags: ["Memory - Network"],
|
|
1129
|
+
requiresAuth: true,
|
|
1130
|
+
handler: LIST_MESSAGES_ROUTE.handler
|
|
1131
|
+
});
|
|
1132
|
+
var SAVE_MESSAGES_NETWORK_ROUTE = createRoute({
|
|
1133
|
+
method: "POST",
|
|
1134
|
+
path: "/memory/network/save-messages",
|
|
1135
|
+
responseType: "json",
|
|
1136
|
+
queryParamSchema: saveMessagesNetworkQuerySchema,
|
|
1137
|
+
bodySchema: saveMessagesBodySchema,
|
|
1138
|
+
responseSchema: saveMessagesResponseSchema,
|
|
1139
|
+
summary: "Save messages (network)",
|
|
1140
|
+
description: "Saves new messages to memory (network route)",
|
|
1141
|
+
tags: ["Memory - Network"],
|
|
1142
|
+
requiresAuth: true,
|
|
1143
|
+
handler: SAVE_MESSAGES_ROUTE.handler
|
|
1144
|
+
});
|
|
1145
|
+
var CREATE_THREAD_NETWORK_ROUTE = createRoute({
|
|
1146
|
+
method: "POST",
|
|
1147
|
+
path: "/memory/network/threads",
|
|
1148
|
+
responseType: "json",
|
|
1149
|
+
queryParamSchema: createThreadNetworkQuerySchema,
|
|
1150
|
+
bodySchema: createThreadBodySchema,
|
|
1151
|
+
responseSchema: getThreadByIdResponseSchema,
|
|
1152
|
+
summary: "Create thread (network)",
|
|
1153
|
+
description: "Creates a new conversation thread (network route)",
|
|
1154
|
+
tags: ["Memory - Network"],
|
|
1155
|
+
requiresAuth: true,
|
|
1156
|
+
handler: CREATE_THREAD_ROUTE.handler
|
|
1157
|
+
});
|
|
1158
|
+
var UPDATE_THREAD_NETWORK_ROUTE = createRoute({
|
|
1159
|
+
method: "PATCH",
|
|
1160
|
+
path: "/memory/network/threads/:threadId",
|
|
1161
|
+
responseType: "json",
|
|
1162
|
+
pathParamSchema: threadIdPathParams,
|
|
1163
|
+
queryParamSchema: updateThreadNetworkQuerySchema,
|
|
1164
|
+
bodySchema: updateThreadBodySchema,
|
|
1165
|
+
responseSchema: getThreadByIdResponseSchema,
|
|
1166
|
+
summary: "Update thread (network)",
|
|
1167
|
+
description: "Updates a conversation thread (network route)",
|
|
1168
|
+
tags: ["Memory - Network"],
|
|
1169
|
+
requiresAuth: true,
|
|
1170
|
+
handler: UPDATE_THREAD_ROUTE.handler
|
|
1171
|
+
});
|
|
1172
|
+
var DELETE_THREAD_NETWORK_ROUTE = createRoute({
|
|
1173
|
+
method: "DELETE",
|
|
1174
|
+
path: "/memory/network/threads/:threadId",
|
|
1175
|
+
responseType: "json",
|
|
1176
|
+
pathParamSchema: threadIdPathParams,
|
|
1177
|
+
queryParamSchema: deleteThreadNetworkQuerySchema,
|
|
1178
|
+
responseSchema: deleteThreadResponseSchema,
|
|
1179
|
+
summary: "Delete thread (network)",
|
|
1180
|
+
description: "Deletes a conversation thread (network route)",
|
|
1181
|
+
tags: ["Memory - Network"],
|
|
1182
|
+
requiresAuth: true,
|
|
1183
|
+
handler: DELETE_THREAD_ROUTE.handler
|
|
1184
|
+
});
|
|
1185
|
+
var DELETE_MESSAGES_NETWORK_ROUTE = createRoute({
|
|
1186
|
+
method: "POST",
|
|
1187
|
+
path: "/memory/network/messages/delete",
|
|
1188
|
+
responseType: "json",
|
|
1189
|
+
queryParamSchema: deleteMessagesNetworkQuerySchema,
|
|
1190
|
+
bodySchema: deleteMessagesBodySchema,
|
|
1191
|
+
responseSchema: deleteMessagesResponseSchema,
|
|
1192
|
+
summary: "Delete messages (network)",
|
|
1193
|
+
description: "Deletes specific messages from memory (network route)",
|
|
1194
|
+
tags: ["Memory - Network"],
|
|
1195
|
+
requiresAuth: true,
|
|
1196
|
+
handler: DELETE_MESSAGES_ROUTE.handler
|
|
1197
|
+
});
|
|
1198
|
+
|
|
1199
|
+
export { CLONE_THREAD_ROUTE, CREATE_THREAD_NETWORK_ROUTE, CREATE_THREAD_ROUTE, DELETE_MESSAGES_NETWORK_ROUTE, DELETE_MESSAGES_ROUTE, DELETE_THREAD_NETWORK_ROUTE, DELETE_THREAD_ROUTE, GET_MEMORY_CONFIG_ROUTE, GET_MEMORY_STATUS_NETWORK_ROUTE, GET_MEMORY_STATUS_ROUTE, GET_THREAD_BY_ID_NETWORK_ROUTE, GET_THREAD_BY_ID_ROUTE, GET_WORKING_MEMORY_ROUTE, LIST_MESSAGES_NETWORK_ROUTE, LIST_MESSAGES_ROUTE, LIST_THREADS_NETWORK_ROUTE, LIST_THREADS_ROUTE, SAVE_MESSAGES_NETWORK_ROUTE, SAVE_MESSAGES_ROUTE, SEARCH_MEMORY_ROUTE, UPDATE_THREAD_NETWORK_ROUTE, UPDATE_THREAD_ROUTE, UPDATE_WORKING_MEMORY_ROUTE, getTextContent, memory_exports };
|
|
1200
|
+
//# sourceMappingURL=chunk-4JAEBN6N.js.map
|
|
1201
|
+
//# sourceMappingURL=chunk-4JAEBN6N.js.map
|