@mastra/core 1.13.3-alpha.1 → 1.14.0-alpha.2
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 +10 -0
- package/dist/_types/@internal_core/dist/index.d.ts +1333 -0
- package/dist/agent/index.cjs +13 -13
- package/dist/agent/index.js +2 -2
- package/dist/agent/message-list/conversion/output-converter.d.ts.map +1 -1
- package/dist/agent/message-list/index.cjs +18 -18
- package/dist/agent/message-list/index.js +1 -1
- package/dist/agent/message-list/message-list.d.ts +12 -1
- package/dist/agent/message-list/message-list.d.ts.map +1 -1
- package/dist/agent/message-list/types.d.ts +3 -3
- package/dist/agent/types.d.ts +1 -1
- package/dist/{chunk-3B6BQEKK.cjs → chunk-2FDGDAJQ.cjs} +3 -3
- package/dist/{chunk-3B6BQEKK.cjs.map → chunk-2FDGDAJQ.cjs.map} +1 -1
- package/dist/{chunk-GYSKVDYD.js → chunk-3TECGW34.js} +5 -5
- package/dist/{chunk-GYSKVDYD.js.map → chunk-3TECGW34.js.map} +1 -1
- package/dist/{chunk-Q4W5XQK2.cjs → chunk-445B4SO3.cjs} +292 -403
- package/dist/chunk-445B4SO3.cjs.map +1 -0
- package/dist/{chunk-WO2CP4Z2.cjs → chunk-4X35LO4W.cjs} +32 -156
- package/dist/chunk-4X35LO4W.cjs.map +1 -0
- package/dist/{chunk-GC7AHOXK.js → chunk-5LHPEIQQ.js} +12 -12
- package/dist/chunk-5LHPEIQQ.js.map +1 -0
- package/dist/{chunk-CMTNYR6E.js → chunk-5UAF67E3.js} +9 -9
- package/dist/{chunk-CMTNYR6E.js.map → chunk-5UAF67E3.js.map} +1 -1
- package/dist/{chunk-SBHYPYXD.js → chunk-5WKCTOYN.js} +13 -13
- package/dist/chunk-5WKCTOYN.js.map +1 -0
- package/dist/{chunk-WKZEZJKQ.js → chunk-7V4HN5NK.js} +5 -5
- package/dist/{chunk-WKZEZJKQ.js.map → chunk-7V4HN5NK.js.map} +1 -1
- package/dist/{chunk-F3SHGIQA.cjs → chunk-B3KIJAOJ.cjs} +185 -185
- package/dist/{chunk-F3SHGIQA.cjs.map → chunk-B3KIJAOJ.cjs.map} +1 -1
- package/dist/{chunk-TAXQJ5ZP.js → chunk-BOUXMXZQ.js} +4 -94
- package/dist/chunk-BOUXMXZQ.js.map +1 -0
- package/dist/{chunk-MIILNUS4.cjs → chunk-DDIY3CRP.cjs} +10 -10
- package/dist/chunk-DDIY3CRP.cjs.map +1 -0
- package/dist/{chunk-4RWTWZET.cjs → chunk-EAKNCJKL.cjs} +31 -433
- package/dist/chunk-EAKNCJKL.cjs.map +1 -0
- package/dist/{chunk-RE3YFYVQ.cjs → chunk-EH5D56XV.cjs} +7 -7
- package/dist/{chunk-RE3YFYVQ.cjs.map → chunk-EH5D56XV.cjs.map} +1 -1
- package/dist/{chunk-A2B3L753.js → chunk-FZNKE4DK.js} +4 -4
- package/dist/{chunk-A2B3L753.js.map → chunk-FZNKE4DK.js.map} +1 -1
- package/dist/chunk-GVQJCS5O.js +812 -0
- package/dist/chunk-GVQJCS5O.js.map +1 -0
- package/dist/{chunk-NUZYNU4M.cjs → chunk-J7Q3CZI5.cjs} +14 -14
- package/dist/{chunk-NUZYNU4M.cjs.map → chunk-J7Q3CZI5.cjs.map} +1 -1
- package/dist/{chunk-CJYTDH5Q.js → chunk-KJUHI5QK.js} +5 -5
- package/dist/chunk-KJUHI5QK.js.map +1 -0
- package/dist/{chunk-B44JEQHW.js → chunk-KKNT7W4Q.js} +4 -4
- package/dist/{chunk-B44JEQHW.js.map → chunk-KKNT7W4Q.js.map} +1 -1
- package/dist/{chunk-FDC6E3MJ.cjs → chunk-LAFTYVLN.cjs} +72 -72
- package/dist/chunk-LAFTYVLN.cjs.map +1 -0
- package/dist/chunk-LIRWMGGI.cjs +931 -0
- package/dist/chunk-LIRWMGGI.cjs.map +1 -0
- package/dist/{chunk-6JM4RID6.js → chunk-MCAE3D3S.js} +41 -7
- package/dist/chunk-MCAE3D3S.js.map +1 -0
- package/dist/{chunk-T5M2TGCD.js → chunk-OGR427FH.js} +14 -350
- package/dist/chunk-OGR427FH.js.map +1 -0
- package/dist/{chunk-AZZGCVBY.js → chunk-PV2DBPYF.js} +3 -3
- package/dist/{chunk-AZZGCVBY.js.map → chunk-PV2DBPYF.js.map} +1 -1
- package/dist/{chunk-Z7JQTINS.js → chunk-QROAUTDP.js} +3 -3
- package/dist/{chunk-Z7JQTINS.js.map → chunk-QROAUTDP.js.map} +1 -1
- package/dist/{chunk-DRZWU4MQ.cjs → chunk-RQFAL5VW.cjs} +13 -13
- package/dist/chunk-RQFAL5VW.cjs.map +1 -0
- package/dist/{chunk-YTSTLTQ5.cjs → chunk-SRNRUDZ2.cjs} +21 -21
- package/dist/{chunk-YTSTLTQ5.cjs.map → chunk-SRNRUDZ2.cjs.map} +1 -1
- package/dist/{chunk-L2YA2HHZ.js → chunk-SRVR5Z2F.js} +5 -5
- package/dist/{chunk-L2YA2HHZ.js.map → chunk-SRVR5Z2F.js.map} +1 -1
- package/dist/{chunk-KMG525KB.js → chunk-TFV75T4H.js} +10 -10
- package/dist/{chunk-KMG525KB.js.map → chunk-TFV75T4H.js.map} +1 -1
- package/dist/{chunk-26JVEE76.cjs → chunk-UHO57W6H.cjs} +7 -7
- package/dist/{chunk-26JVEE76.cjs.map → chunk-UHO57W6H.cjs.map} +1 -1
- package/dist/{chunk-QXNHZJRV.js → chunk-UWTB4U2X.js} +127 -238
- package/dist/chunk-UWTB4U2X.js.map +1 -0
- package/dist/{chunk-E2Y2HLCU.cjs → chunk-W2LUCUUP.cjs} +41 -7
- package/dist/chunk-W2LUCUUP.cjs.map +1 -0
- package/dist/{chunk-X7IX2H7I.cjs → chunk-XVH7SCZN.cjs} +13 -13
- package/dist/{chunk-X7IX2H7I.cjs.map → chunk-XVH7SCZN.cjs.map} +1 -1
- package/dist/{chunk-CXYQJVHK.cjs → chunk-YSQC2LEG.cjs} +10 -10
- package/dist/{chunk-CXYQJVHK.cjs.map → chunk-YSQC2LEG.cjs.map} +1 -1
- package/dist/{chunk-XNHOUTCP.cjs → chunk-ZSFSSMFT.cjs} +84 -84
- package/dist/{chunk-XNHOUTCP.cjs.map → chunk-ZSFSSMFT.cjs.map} +1 -1
- package/dist/datasets/index.cjs +17 -17
- package/dist/datasets/index.js +2 -2
- package/dist/docs/SKILL.md +1 -1
- package/dist/docs/assets/SOURCE_MAP.json +721 -708
- package/dist/docs/references/docs-agents-adding-voice.md +6 -6
- package/dist/docs/references/docs-agents-agent-approval.md +4 -4
- package/dist/docs/references/docs-agents-guardrails.md +1 -1
- package/dist/docs/references/docs-agents-network-approval.md +1 -1
- package/dist/docs/references/docs-agents-networks.md +1 -1
- package/dist/docs/references/docs-agents-overview.md +2 -2
- package/dist/docs/references/docs-agents-processors.md +11 -11
- package/dist/docs/references/docs-agents-structured-output.md +4 -4
- package/dist/docs/references/docs-agents-supervisor-agents.md +3 -3
- package/dist/docs/references/docs-agents-using-tools.md +4 -4
- package/dist/docs/references/docs-evals-custom-scorers.md +4 -4
- package/dist/docs/references/docs-evals-overview.md +2 -2
- package/dist/docs/references/docs-memory-memory-processors.md +6 -6
- package/dist/docs/references/docs-memory-semantic-recall.md +1 -1
- package/dist/docs/references/docs-memory-storage.md +1 -1
- package/dist/docs/references/docs-memory-working-memory.md +1 -1
- package/dist/docs/references/docs-observability-datasets-running-experiments.md +1 -1
- package/dist/docs/references/docs-observability-tracing-exporters-langfuse.md +1 -1
- package/dist/docs/references/docs-observability-tracing-exporters-langsmith.md +2 -2
- package/dist/docs/references/docs-rag-graph-rag.md +2 -2
- package/dist/docs/references/docs-rag-retrieval.md +12 -12
- package/dist/docs/references/docs-server-mastra-client.md +1 -1
- package/dist/docs/references/docs-server-request-context.md +3 -3
- package/dist/docs/references/docs-streaming-tool-streaming.md +1 -1
- package/dist/docs/references/docs-voice-overview.md +21 -21
- package/dist/docs/references/docs-voice-speech-to-speech.md +2 -2
- package/dist/docs/references/docs-voice-speech-to-text.md +1 -1
- package/dist/docs/references/docs-voice-text-to-speech.md +1 -1
- package/dist/docs/references/docs-workspace-filesystem.md +1 -1
- package/dist/docs/references/docs-workspace-overview.md +1 -1
- package/dist/docs/references/docs-workspace-sandbox.md +1 -1
- package/dist/docs/references/reference-agents-agent.md +5 -5
- package/dist/docs/references/reference-agents-generateLegacy.md +2 -2
- package/dist/docs/references/reference-agents-getLLM.md +1 -1
- package/dist/docs/references/reference-agents-network.md +1 -1
- package/dist/docs/references/reference-configuration.md +3 -3
- package/dist/docs/references/reference-evals-answer-relevancy.md +1 -1
- package/dist/docs/references/reference-evals-answer-similarity.md +1 -1
- package/dist/docs/references/reference-evals-bias.md +1 -1
- package/dist/docs/references/reference-evals-context-precision.md +3 -3
- package/dist/docs/references/reference-evals-faithfulness.md +1 -1
- package/dist/docs/references/reference-evals-hallucination.md +5 -5
- package/dist/docs/references/reference-evals-toxicity.md +1 -1
- package/dist/docs/references/reference-harness-harness-class.md +4 -4
- package/dist/docs/references/reference-memory-memory-class.md +3 -3
- package/dist/docs/references/reference-memory-observational-memory.md +5 -5
- package/dist/docs/references/reference-processors-batch-parts-processor.md +1 -1
- package/dist/docs/references/reference-processors-language-detector.md +1 -1
- package/dist/docs/references/reference-processors-moderation-processor.md +2 -2
- package/dist/docs/references/reference-processors-pii-detector.md +2 -2
- package/dist/docs/references/reference-processors-processor-interface.md +3 -3
- package/dist/docs/references/reference-processors-prompt-injection-detector.md +1 -1
- package/dist/docs/references/reference-processors-system-prompt-scrubber.md +1 -1
- package/dist/docs/references/reference-processors-token-limiter-processor.md +3 -3
- package/dist/docs/references/reference-processors-tool-search-processor.md +2 -2
- package/dist/docs/references/reference-processors-unicode-normalizer.md +1 -1
- package/dist/docs/references/reference-storage-mongodb.md +1 -1
- package/dist/docs/references/reference-storage-postgresql.md +1 -1
- package/dist/docs/references/reference-storage-upstash.md +1 -1
- package/dist/docs/references/reference-templates-overview.md +1 -1
- package/dist/docs/references/reference-tools-mcp-client.md +2 -2
- package/dist/docs/references/reference-tools-mcp-server.md +1 -1
- package/dist/docs/references/reference-tools-vector-query-tool.md +1 -1
- package/dist/docs/references/reference-vectors-libsql.md +1 -1
- package/dist/docs/references/reference-vectors-mongodb.md +1 -1
- package/dist/docs/references/reference-vectors-pg.md +1 -1
- package/dist/docs/references/reference-vectors-upstash.md +1 -1
- package/dist/docs/references/reference-voice-voice.addInstructions.md +1 -1
- package/dist/docs/references/reference-workspace-local-filesystem.md +1 -1
- package/dist/docs/references/reference-workspace-local-sandbox.md +1 -1
- package/dist/evals/index.cjs +20 -20
- package/dist/evals/index.js +3 -3
- package/dist/evals/scoreTraces/index.cjs +7 -7
- package/dist/evals/scoreTraces/index.js +3 -3
- package/dist/features/index.cjs +2 -1
- package/dist/features/index.cjs.map +1 -1
- package/dist/features/index.d.ts.map +1 -1
- package/dist/features/index.js +2 -1
- package/dist/features/index.js.map +1 -1
- package/dist/harness/index.cjs +7 -7
- package/dist/harness/index.js +5 -5
- package/dist/index.cjs +2 -2
- package/dist/index.js +1 -1
- package/dist/llm/index.cjs +16 -16
- package/dist/llm/index.js +5 -5
- package/dist/llm/model/base.types.d.ts +1 -1
- package/dist/llm/model/provider-types.generated.d.ts +4 -4
- package/dist/loop/index.cjs +14 -14
- package/dist/loop/index.js +1 -1
- package/dist/loop/workflows/agentic-execution/llm-execution-step.d.ts.map +1 -1
- package/dist/loop/workflows/agentic-execution/llm-mapping-step.d.ts.map +1 -1
- package/dist/loop/workflows/agentic-execution/tool-call-step.d.ts.map +1 -1
- package/dist/mastra/index.cjs +2 -2
- package/dist/mastra/index.js +1 -1
- package/dist/memory/index.cjs +14 -14
- package/dist/memory/index.js +1 -1
- package/dist/memory/types.d.ts +1 -1
- package/dist/models-dev-E24MAXL2.cjs +12 -0
- package/dist/{models-dev-SOEEI4UR.cjs.map → models-dev-E24MAXL2.cjs.map} +1 -1
- package/dist/models-dev-F65PLXGJ.js +3 -0
- package/dist/{models-dev-EKZCLX7Y.js.map → models-dev-F65PLXGJ.js.map} +1 -1
- package/dist/netlify-FT3VYX27.cjs +12 -0
- package/dist/{netlify-SSPGBXOO.cjs.map → netlify-FT3VYX27.cjs.map} +1 -1
- package/dist/netlify-NYUZ5ZTO.js +3 -0
- package/dist/{netlify-ALYV7577.js.map → netlify-NYUZ5ZTO.js.map} +1 -1
- package/dist/observability/index.cjs +17 -17
- package/dist/observability/index.js +1 -1
- package/dist/observability/types/tracing.d.ts +2 -22
- package/dist/observability/types/tracing.d.ts.map +1 -1
- package/dist/processor-provider/index.cjs +10 -10
- package/dist/processor-provider/index.js +1 -1
- package/dist/processors/index.cjs +42 -42
- package/dist/processors/index.js +1 -1
- package/dist/provider-registry-5R2TUINW.js +3 -0
- package/dist/{provider-registry-AZ4SPASK.js.map → provider-registry-5R2TUINW.js.map} +1 -1
- package/dist/provider-registry-TVYED7F2.cjs +40 -0
- package/dist/{provider-registry-35V252GM.cjs.map → provider-registry-TVYED7F2.cjs.map} +1 -1
- package/dist/provider-registry.json +8 -8
- package/dist/relevance/index.cjs +3 -3
- package/dist/relevance/index.js +1 -1
- package/dist/storage/constants.cjs +56 -56
- package/dist/storage/constants.d.ts +1 -1
- package/dist/storage/constants.js +1 -1
- package/dist/storage/domains/memory/inmemory.d.ts.map +1 -1
- package/dist/storage/domains/observability/discovery.d.ts +1 -63
- package/dist/storage/domains/observability/discovery.d.ts.map +1 -1
- package/dist/storage/domains/observability/feedback.d.ts +1 -185
- package/dist/storage/domains/observability/feedback.d.ts.map +1 -1
- package/dist/storage/domains/observability/logs.d.ts +1 -321
- package/dist/storage/domains/observability/logs.d.ts.map +1 -1
- package/dist/storage/domains/observability/metrics.d.ts +1 -394
- package/dist/storage/domains/observability/metrics.d.ts.map +1 -1
- package/dist/storage/domains/observability/scores.d.ts +1 -192
- package/dist/storage/domains/observability/scores.d.ts.map +1 -1
- package/dist/storage/domains/observability/tracing.d.ts +50 -52
- package/dist/storage/domains/observability/tracing.d.ts.map +1 -1
- package/dist/storage/domains/shared.d.ts +1 -118
- package/dist/storage/domains/shared.d.ts.map +1 -1
- package/dist/storage/index.cjs +479 -466
- package/dist/storage/index.js +3 -2
- package/dist/stream/index.cjs +11 -11
- package/dist/stream/index.js +2 -2
- package/dist/test-utils/llm-mock.cjs +4 -4
- package/dist/test-utils/llm-mock.js +1 -1
- package/dist/tool-loop-agent/index.cjs +4 -4
- package/dist/tool-loop-agent/index.js +1 -1
- package/dist/utils.cjs +23 -23
- package/dist/utils.js +1 -1
- package/dist/vector/embed.d.ts +2 -2
- package/dist/vector/index.cjs +7 -7
- package/dist/vector/index.js +1 -1
- package/dist/workflows/evented/index.cjs +10 -10
- package/dist/workflows/evented/index.js +1 -1
- package/dist/workflows/index.cjs +24 -24
- package/dist/workflows/index.js +1 -1
- package/package.json +6 -5
- package/src/llm/model/provider-types.generated.d.ts +4 -4
- package/dist/chunk-4RWTWZET.cjs.map +0 -1
- package/dist/chunk-6JM4RID6.js.map +0 -1
- package/dist/chunk-CJYTDH5Q.js.map +0 -1
- package/dist/chunk-DJCCDPZQ.js +0 -376
- package/dist/chunk-DJCCDPZQ.js.map +0 -1
- package/dist/chunk-DRZWU4MQ.cjs.map +0 -1
- package/dist/chunk-E2Y2HLCU.cjs.map +0 -1
- package/dist/chunk-FDC6E3MJ.cjs.map +0 -1
- package/dist/chunk-GC7AHOXK.js.map +0 -1
- package/dist/chunk-MIILNUS4.cjs.map +0 -1
- package/dist/chunk-PBDJR7QN.cjs +0 -393
- package/dist/chunk-PBDJR7QN.cjs.map +0 -1
- package/dist/chunk-Q4W5XQK2.cjs.map +0 -1
- package/dist/chunk-QXNHZJRV.js.map +0 -1
- package/dist/chunk-SBHYPYXD.js.map +0 -1
- package/dist/chunk-T5M2TGCD.js.map +0 -1
- package/dist/chunk-TAXQJ5ZP.js.map +0 -1
- package/dist/chunk-WO2CP4Z2.cjs.map +0 -1
- package/dist/models-dev-EKZCLX7Y.js +0 -3
- package/dist/models-dev-SOEEI4UR.cjs +0 -12
- package/dist/netlify-ALYV7577.js +0 -3
- package/dist/netlify-SSPGBXOO.cjs +0 -12
- package/dist/provider-registry-35V252GM.cjs +0 -40
- package/dist/provider-registry-AZ4SPASK.js +0 -3
|
@@ -1578,7 +1578,7 @@ function aiV5ModelMessageToV2PromptMessage(modelMessage) {
|
|
|
1578
1578
|
break;
|
|
1579
1579
|
}
|
|
1580
1580
|
case "tool-result": {
|
|
1581
|
-
if (role === `
|
|
1581
|
+
if (role === `user`) {
|
|
1582
1582
|
throw new Error(incompatibleMessage);
|
|
1583
1583
|
}
|
|
1584
1584
|
roleContent[role].push({
|
|
@@ -1823,10 +1823,7 @@ function sanitizeV5UIMessages(messages, filterIncompleteToolCalls = false) {
|
|
|
1823
1823
|
}
|
|
1824
1824
|
if (!chunkVBVOKSJK_cjs.isToolUIPart(p)) return true;
|
|
1825
1825
|
if (filterIncompleteToolCalls) {
|
|
1826
|
-
if (p.state === "output-available" || p.state === "output-error")
|
|
1827
|
-
if (p.providerExecuted) return false;
|
|
1828
|
-
return true;
|
|
1829
|
-
}
|
|
1826
|
+
if (p.state === "output-available" || p.state === "output-error") return true;
|
|
1830
1827
|
if (p.state === "input-available" && p.providerExecuted) return true;
|
|
1831
1828
|
return false;
|
|
1832
1829
|
}
|
|
@@ -3709,6 +3706,43 @@ var MessageList = class {
|
|
|
3709
3706
|
isNewMessage(messageOrId) {
|
|
3710
3707
|
return this.stateManager.isNewMessage(messageOrId);
|
|
3711
3708
|
}
|
|
3709
|
+
/**
|
|
3710
|
+
* Replace a tool-invocation part matching the given toolCallId with the
|
|
3711
|
+
* provided result part. Walks backwards through messages to find the match.
|
|
3712
|
+
* If the message was already persisted (e.g. as a memory message), it is
|
|
3713
|
+
* moved to the response source so it will be re-saved.
|
|
3714
|
+
*
|
|
3715
|
+
* @returns true if the tool call was found and updated, false otherwise.
|
|
3716
|
+
*/
|
|
3717
|
+
updateToolInvocation(inputPart) {
|
|
3718
|
+
if (!inputPart.toolInvocation?.toolCallId) {
|
|
3719
|
+
return false;
|
|
3720
|
+
}
|
|
3721
|
+
const toolCallId = inputPart.toolInvocation.toolCallId;
|
|
3722
|
+
for (let m = this.messages.length - 1; m >= 0; m--) {
|
|
3723
|
+
const msg = this.messages[m];
|
|
3724
|
+
if (msg.role !== "assistant" || !msg.content?.parts) continue;
|
|
3725
|
+
for (let i = 0; i < msg.content.parts.length; i++) {
|
|
3726
|
+
const part = msg.content.parts[i];
|
|
3727
|
+
if (part?.type === "tool-invocation" && part.toolInvocation?.toolCallId === toolCallId) {
|
|
3728
|
+
msg.content.parts[i] = {
|
|
3729
|
+
...inputPart,
|
|
3730
|
+
toolInvocation: {
|
|
3731
|
+
...inputPart.toolInvocation,
|
|
3732
|
+
args: part.toolInvocation.args
|
|
3733
|
+
}
|
|
3734
|
+
};
|
|
3735
|
+
if (!this.stateManager.isResponseMessage(msg)) {
|
|
3736
|
+
this.stateManager.removeMessage(msg);
|
|
3737
|
+
this.stateManager.addToSource(msg, "response");
|
|
3738
|
+
}
|
|
3739
|
+
return true;
|
|
3740
|
+
}
|
|
3741
|
+
}
|
|
3742
|
+
}
|
|
3743
|
+
this.logger?.warn(`updateToolInvocation: no matching tool call found for toolCallId=${toolCallId}`);
|
|
3744
|
+
return false;
|
|
3745
|
+
}
|
|
3712
3746
|
getSystemMessages(tag) {
|
|
3713
3747
|
if (tag) {
|
|
3714
3748
|
return this.taggedSystemMessages[tag] || [];
|
|
@@ -4022,5 +4056,5 @@ exports.getOpenAIReasoningItemId = getOpenAIReasoningItemId;
|
|
|
4022
4056
|
exports.hasOpenAIReasoningItemId = hasOpenAIReasoningItemId;
|
|
4023
4057
|
exports.messagesAreEqual = messagesAreEqual;
|
|
4024
4058
|
exports.sanitizeToolName = sanitizeToolName;
|
|
4025
|
-
//# sourceMappingURL=chunk-
|
|
4026
|
-
//# sourceMappingURL=chunk-
|
|
4059
|
+
//# sourceMappingURL=chunk-W2LUCUUP.cjs.map
|
|
4060
|
+
//# sourceMappingURL=chunk-W2LUCUUP.cjs.map
|