@mastra/core 0.22.2 → 0.23.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.
Files changed (199) hide show
  1. package/CHANGELOG.md +60 -0
  2. package/dist/agent/agent.d.ts +5 -1
  3. package/dist/agent/agent.d.ts.map +1 -1
  4. package/dist/agent/agent.types.d.ts +5 -1
  5. package/dist/agent/agent.types.d.ts.map +1 -1
  6. package/dist/agent/index.cjs +13 -13
  7. package/dist/agent/index.js +2 -2
  8. package/dist/agent/input-processor/index.cjs +6 -6
  9. package/dist/agent/input-processor/index.js +1 -1
  10. package/dist/agent/message-list/index.d.ts +32 -0
  11. package/dist/agent/message-list/index.d.ts.map +1 -1
  12. package/dist/agent/utils.d.ts +2 -8
  13. package/dist/agent/utils.d.ts.map +1 -1
  14. package/dist/agent/workflows/prepare-stream/index.d.ts +6 -2
  15. package/dist/agent/workflows/prepare-stream/index.d.ts.map +1 -1
  16. package/dist/agent/workflows/prepare-stream/stream-step.d.ts +6 -2
  17. package/dist/agent/workflows/prepare-stream/stream-step.d.ts.map +1 -1
  18. package/dist/ai-tracing/chunk-tracing.d.ts +10 -10
  19. package/dist/ai-tracing/chunk-tracing.d.ts.map +1 -1
  20. package/dist/ai-tracing/index.cjs +36 -36
  21. package/dist/ai-tracing/index.js +1 -1
  22. package/dist/ai-tracing/types.d.ts +17 -17
  23. package/dist/ai-tracing/types.d.ts.map +1 -1
  24. package/dist/{chunk-5CHZUAZV.cjs → chunk-34WQUECJ.cjs} +98 -98
  25. package/dist/chunk-34WQUECJ.cjs.map +1 -0
  26. package/dist/{chunk-VQLW7LPO.js → chunk-34ZCWSUA.js} +3 -3
  27. package/dist/{chunk-VQLW7LPO.js.map → chunk-34ZCWSUA.js.map} +1 -1
  28. package/dist/{chunk-YGL6E6PD.cjs → chunk-3JX2Y3WH.cjs} +9 -9
  29. package/dist/{chunk-YGL6E6PD.cjs.map → chunk-3JX2Y3WH.cjs.map} +1 -1
  30. package/dist/{chunk-RWWOJXMF.cjs → chunk-4XE7GVZM.cjs} +23 -23
  31. package/dist/{chunk-RWWOJXMF.cjs.map → chunk-4XE7GVZM.cjs.map} +1 -1
  32. package/dist/{chunk-FMNZ3BPT.cjs → chunk-4YHU6R7W.cjs} +96 -12
  33. package/dist/chunk-4YHU6R7W.cjs.map +1 -0
  34. package/dist/{chunk-WM4VQWOZ.cjs → chunk-5NTO7S5I.cjs} +72 -2
  35. package/dist/chunk-5NTO7S5I.cjs.map +1 -0
  36. package/dist/{chunk-MQ67HP3O.cjs → chunk-5P4S4AVU.cjs} +4 -4
  37. package/dist/{chunk-MQ67HP3O.cjs.map → chunk-5P4S4AVU.cjs.map} +1 -1
  38. package/dist/{chunk-576KDLXN.cjs → chunk-6KOL2B3A.cjs} +5 -5
  39. package/dist/{chunk-576KDLXN.cjs.map → chunk-6KOL2B3A.cjs.map} +1 -1
  40. package/dist/{chunk-T2RDWNN6.js → chunk-7KYNQSR4.js} +38 -39
  41. package/dist/chunk-7KYNQSR4.js.map +1 -0
  42. package/dist/{chunk-AMHNTB4N.cjs → chunk-7XAVBWZI.cjs} +19 -19
  43. package/dist/{chunk-AMHNTB4N.cjs.map → chunk-7XAVBWZI.cjs.map} +1 -1
  44. package/dist/{chunk-HZIF7HQC.js → chunk-A55YFHFT.js} +8 -8
  45. package/dist/{chunk-HZIF7HQC.js.map → chunk-A55YFHFT.js.map} +1 -1
  46. package/dist/{chunk-2JUDZXVI.cjs → chunk-AQGLVU53.cjs} +6 -6
  47. package/dist/{chunk-2JUDZXVI.cjs.map → chunk-AQGLVU53.cjs.map} +1 -1
  48. package/dist/{chunk-2DVGQK2L.js → chunk-BLUDYAPI.js} +3 -3
  49. package/dist/{chunk-2DVGQK2L.js.map → chunk-BLUDYAPI.js.map} +1 -1
  50. package/dist/{chunk-ROBLMWF6.cjs → chunk-DMBN72QF.cjs} +4 -4
  51. package/dist/{chunk-ROBLMWF6.cjs.map → chunk-DMBN72QF.cjs.map} +1 -1
  52. package/dist/{chunk-HD455BM6.cjs → chunk-DPE27ECD.cjs} +23 -23
  53. package/dist/{chunk-HD455BM6.cjs.map → chunk-DPE27ECD.cjs.map} +1 -1
  54. package/dist/{chunk-CGT36GQE.cjs → chunk-HANVMC6C.cjs} +36 -36
  55. package/dist/{chunk-CGT36GQE.cjs.map → chunk-HANVMC6C.cjs.map} +1 -1
  56. package/dist/{chunk-5NYWRAJN.js → chunk-HFXV34OE.js} +3 -3
  57. package/dist/{chunk-5NYWRAJN.js.map → chunk-HFXV34OE.js.map} +1 -1
  58. package/dist/{chunk-KQBF5ZEN.js → chunk-ITCG6QJR.js} +5 -5
  59. package/dist/{chunk-KQBF5ZEN.js.map → chunk-ITCG6QJR.js.map} +1 -1
  60. package/dist/{chunk-634YFL42.cjs → chunk-JTI6TVDV.cjs} +63 -12
  61. package/dist/chunk-JTI6TVDV.cjs.map +1 -0
  62. package/dist/{chunk-RBO5BUGG.js → chunk-JVV5LREI.js} +3 -3
  63. package/dist/{chunk-RBO5BUGG.js.map → chunk-JVV5LREI.js.map} +1 -1
  64. package/dist/{chunk-A3TQYIIR.js → chunk-JZ7I64PK.js} +93 -9
  65. package/dist/chunk-JZ7I64PK.js.map +1 -0
  66. package/dist/{chunk-PJDIDFKV.js → chunk-MRJUTTCU.js} +3 -3
  67. package/dist/{chunk-PJDIDFKV.js.map → chunk-MRJUTTCU.js.map} +1 -1
  68. package/dist/{chunk-NFIADRH5.js → chunk-NPNGPMT2.js} +3 -3
  69. package/dist/{chunk-NFIADRH5.js.map → chunk-NPNGPMT2.js.map} +1 -1
  70. package/dist/{chunk-IQGDOBME.cjs → chunk-NUAURT4I.cjs} +6 -6
  71. package/dist/{chunk-IQGDOBME.cjs.map → chunk-NUAURT4I.cjs.map} +1 -1
  72. package/dist/{chunk-4PMF7QUH.js → chunk-NVDVFJWA.js} +4 -4
  73. package/dist/{chunk-4PMF7QUH.js.map → chunk-NVDVFJWA.js.map} +1 -1
  74. package/dist/{chunk-M4AX46DS.js → chunk-OIT3PCWA.js} +3 -3
  75. package/dist/{chunk-M4AX46DS.js.map → chunk-OIT3PCWA.js.map} +1 -1
  76. package/dist/{chunk-3CVE7NQC.js → chunk-ONKGWHY6.js} +17 -17
  77. package/dist/chunk-ONKGWHY6.js.map +1 -0
  78. package/dist/{chunk-5GIAZ3CH.cjs → chunk-PDST7KX7.cjs} +22 -22
  79. package/dist/chunk-PDST7KX7.cjs.map +1 -0
  80. package/dist/{chunk-VD27FF3L.js → chunk-PS4ABZY7.js} +7 -7
  81. package/dist/{chunk-VD27FF3L.js.map → chunk-PS4ABZY7.js.map} +1 -1
  82. package/dist/{chunk-T3JFFQH2.js → chunk-PZUZNPFM.js} +72 -3
  83. package/dist/chunk-PZUZNPFM.js.map +1 -0
  84. package/dist/{chunk-VX7NIAMW.js → chunk-QOTPNUIA.js} +5 -5
  85. package/dist/{chunk-VX7NIAMW.js.map → chunk-QOTPNUIA.js.map} +1 -1
  86. package/dist/{chunk-TKYKL7Y4.cjs → chunk-TX4TTPYJ.cjs} +16 -16
  87. package/dist/{chunk-TKYKL7Y4.cjs.map → chunk-TX4TTPYJ.cjs.map} +1 -1
  88. package/dist/{chunk-ZDW322JC.cjs → chunk-TYWQLUF6.cjs} +8 -8
  89. package/dist/{chunk-ZDW322JC.cjs.map → chunk-TYWQLUF6.cjs.map} +1 -1
  90. package/dist/{chunk-A4B6IAKN.cjs → chunk-VTNVK7HN.cjs} +4 -4
  91. package/dist/{chunk-A4B6IAKN.cjs.map → chunk-VTNVK7HN.cjs.map} +1 -1
  92. package/dist/{chunk-I7KJDXUK.cjs → chunk-WBAXXG34.cjs} +19 -19
  93. package/dist/{chunk-I7KJDXUK.cjs.map → chunk-WBAXXG34.cjs.map} +1 -1
  94. package/dist/{chunk-LBEV3YZ2.js → chunk-WCHE6FJ7.js} +4 -4
  95. package/dist/{chunk-LBEV3YZ2.js.map → chunk-WCHE6FJ7.js.map} +1 -1
  96. package/dist/{chunk-Z2OK2JM2.js → chunk-ZISECZZO.js} +3 -3
  97. package/dist/{chunk-Z2OK2JM2.js.map → chunk-ZISECZZO.js.map} +1 -1
  98. package/dist/{chunk-AGD5B3FB.js → chunk-ZWF7AVLU.js} +55 -4
  99. package/dist/chunk-ZWF7AVLU.js.map +1 -0
  100. package/dist/error/index.cjs +9 -5
  101. package/dist/error/index.d.ts +1 -1
  102. package/dist/error/index.d.ts.map +1 -1
  103. package/dist/error/index.js +1 -1
  104. package/dist/error/utils.d.ts +28 -0
  105. package/dist/error/utils.d.ts.map +1 -1
  106. package/dist/eval/index.cjs +3 -3
  107. package/dist/eval/index.js +1 -1
  108. package/dist/index.cjs +72 -68
  109. package/dist/index.js +15 -15
  110. package/dist/llm/index.cjs +7 -7
  111. package/dist/llm/index.js +1 -1
  112. package/dist/llm/model/model.loop.d.ts +1 -1
  113. package/dist/llm/model/model.loop.d.ts.map +1 -1
  114. package/dist/llm/model/provider-registry.d.ts.map +1 -1
  115. package/dist/llm/model/provider-types.generated.d.ts +14 -0
  116. package/dist/loop/index.cjs +2 -2
  117. package/dist/loop/index.js +1 -1
  118. package/dist/loop/loop.d.ts.map +1 -1
  119. package/dist/loop/types.d.ts +6 -3
  120. package/dist/loop/types.d.ts.map +1 -1
  121. package/dist/loop/workflows/agentic-execution/llm-execution-step.d.ts.map +1 -1
  122. package/dist/loop/workflows/agentic-execution/tool-call-step.d.ts +1 -1
  123. package/dist/loop/workflows/agentic-execution/tool-call-step.d.ts.map +1 -1
  124. package/dist/loop/workflows/stream.d.ts +1 -1
  125. package/dist/loop/workflows/stream.d.ts.map +1 -1
  126. package/dist/mastra/index.cjs +2 -2
  127. package/dist/mastra/index.js +1 -1
  128. package/dist/memory/index.cjs +4 -4
  129. package/dist/memory/index.js +1 -1
  130. package/dist/netlify-TX6V7SJJ.cjs +12 -0
  131. package/dist/{netlify-F3MVGV4Y.cjs.map → netlify-TX6V7SJJ.cjs.map} +1 -1
  132. package/dist/netlify-VJXBII33.js +3 -0
  133. package/dist/{netlify-26MMY5X4.js.map → netlify-VJXBII33.js.map} +1 -1
  134. package/dist/processors/index.cjs +11 -11
  135. package/dist/processors/index.js +1 -1
  136. package/dist/provider-registry.json +38 -2
  137. package/dist/relevance/index.cjs +4 -4
  138. package/dist/relevance/index.js +1 -1
  139. package/dist/scores/index.cjs +9 -9
  140. package/dist/scores/index.js +2 -2
  141. package/dist/scores/scoreTraces/index.cjs +15 -15
  142. package/dist/scores/scoreTraces/index.cjs.map +1 -1
  143. package/dist/scores/scoreTraces/index.js +6 -6
  144. package/dist/scores/scoreTraces/index.js.map +1 -1
  145. package/dist/server/index.cjs +7 -7
  146. package/dist/server/index.js +2 -2
  147. package/dist/storage/index.cjs +25 -25
  148. package/dist/storage/index.js +4 -4
  149. package/dist/stream/aisdk/v5/execute.d.ts.map +1 -1
  150. package/dist/stream/aisdk/v5/output.d.ts +2 -8
  151. package/dist/stream/aisdk/v5/output.d.ts.map +1 -1
  152. package/dist/stream/base/output.d.ts +31 -13
  153. package/dist/stream/base/output.d.ts.map +1 -1
  154. package/dist/stream/index.cjs +11 -11
  155. package/dist/stream/index.js +2 -2
  156. package/dist/telemetry/index.cjs +7 -7
  157. package/dist/telemetry/index.js +1 -1
  158. package/dist/test-utils/llm-mock.cjs +2 -2
  159. package/dist/test-utils/llm-mock.js +1 -1
  160. package/dist/tts/index.cjs +2 -2
  161. package/dist/tts/index.js +1 -1
  162. package/dist/utils.cjs +17 -17
  163. package/dist/utils.js +1 -1
  164. package/dist/vector/index.cjs +4 -4
  165. package/dist/vector/index.js +1 -1
  166. package/dist/voice/index.cjs +4 -4
  167. package/dist/voice/index.js +1 -1
  168. package/dist/workflows/default.d.ts +11 -1
  169. package/dist/workflows/default.d.ts.map +1 -1
  170. package/dist/workflows/evented/index.cjs +10 -10
  171. package/dist/workflows/evented/index.js +1 -1
  172. package/dist/workflows/execution-engine.d.ts +3 -0
  173. package/dist/workflows/execution-engine.d.ts.map +1 -1
  174. package/dist/workflows/index.cjs +16 -12
  175. package/dist/workflows/index.js +1 -1
  176. package/dist/workflows/legacy/index.cjs +22 -22
  177. package/dist/workflows/legacy/index.js +1 -1
  178. package/dist/workflows/step.d.ts +1 -1
  179. package/dist/workflows/step.d.ts.map +1 -1
  180. package/dist/workflows/types.d.ts +16 -1
  181. package/dist/workflows/types.d.ts.map +1 -1
  182. package/dist/workflows/utils.d.ts +7 -0
  183. package/dist/workflows/utils.d.ts.map +1 -1
  184. package/dist/workflows/workflow.d.ts +12 -3
  185. package/dist/workflows/workflow.d.ts.map +1 -1
  186. package/package.json +11 -4
  187. package/src/llm/model/provider-types.generated.d.ts +14 -0
  188. package/dist/chunk-3CVE7NQC.js.map +0 -1
  189. package/dist/chunk-5CHZUAZV.cjs.map +0 -1
  190. package/dist/chunk-5GIAZ3CH.cjs.map +0 -1
  191. package/dist/chunk-634YFL42.cjs.map +0 -1
  192. package/dist/chunk-A3TQYIIR.js.map +0 -1
  193. package/dist/chunk-AGD5B3FB.js.map +0 -1
  194. package/dist/chunk-FMNZ3BPT.cjs.map +0 -1
  195. package/dist/chunk-T2RDWNN6.js.map +0 -1
  196. package/dist/chunk-T3JFFQH2.js.map +0 -1
  197. package/dist/chunk-WM4VQWOZ.cjs.map +0 -1
  198. package/dist/netlify-26MMY5X4.js +0 -3
  199. package/dist/netlify-F3MVGV4Y.cjs +0 -12
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/relevance/cohere/index.ts","../src/relevance/relevance-score-provider.ts","../src/relevance/mastra-agent/index.ts"],"names":["Agent"],"mappings":";;;;;AAoBO,IAAM,wBAAN,MAA8D;AAAA,EAC3D,KAAA;AAAA,EACA,MAAA;AAAA,EACR,WAAA,CAAY,OAAe,MAAA,EAAiB;AAC1C,IAAA,OAAA,CAAQ,IAAA;AAAA,MACN;AAAA,KACF;AACA,IAAA,IAAA,CAAK,MAAA,GAAS,MAAA;AACd,IAAA,IAAA,CAAK,KAAA,GAAQ,KAAA;AAAA,EACf;AAAA,EACA,MAAM,iBAAA,CAAkB,KAAA,EAAe,IAAA,EAA+B;AACpE,IAAA,MAAM,QAAA,GAAW,MAAM,KAAA,CAAM,CAAA,gCAAA,CAAA,EAAoC;AAAA,MAC/D,MAAA,EAAQ,MAAA;AAAA,MACR,OAAA,EAAS;AAAA,QACP,cAAA,EAAgB,kBAAA;AAAA,QAChB,aAAA,EAAe,CAAA,OAAA,EAAU,IAAA,CAAK,MAAM,CAAA;AAAA,OACtC;AAAA,MACA,IAAA,EAAM,KAAK,SAAA,CAAU;AAAA,QACnB,KAAA;AAAA,QACA,SAAA,EAAW,CAAC,IAAI,CAAA;AAAA,QAChB,OAAO,IAAA,CAAK,KAAA;AAAA,QACZ,KAAA,EAAO;AAAA,OACR;AAAA,KACF,CAAA;AAED,IAAA,IAAI,CAAC,SAAS,EAAA,EAAI;AAChB,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,kBAAA,EAAqB,QAAA,CAAS,MAAM,IAAI,MAAM,QAAA,CAAS,IAAA,EAAM,CAAA,CAAE,CAAA;AAAA,IACjF;AAEA,IAAA,MAAM,IAAA,GAAQ,MAAM,QAAA,CAAS,IAAA,EAAK;AAClC,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,OAAA,CAAQ,CAAC,CAAA,EAAG,eAAA;AAExC,IAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,MAAA,MAAM,IAAI,MAAM,6CAA6C,CAAA;AAAA,IAC/D;AAEA,IAAA,OAAO,cAAA;AAAA,EACT;AACF;;;ACpDO,SAAS,sBAAA,CAAuB,OAAe,IAAA,EAAsB;AAC1E,EAAA,OAAO,CAAA;;AAAA,OAAA,EAEA,KAAK;;AAAA,MAAA,EAEN,IAAI;;AAAA,sBAAA,CAAA;AAGZ;;;ACRO,IAAM,6BAAN,MAAmE;AAAA,EAChE,KAAA;AAAA,EAER,WAAA,CAAY,MAAc,KAAA,EAA0B;AAClD,IAAA,IAAA,CAAK,KAAA,GAAQ,IAAIA,uBAAA,CAAM;AAAA,MACrB,IAAA,EAAM,oBAAoB,IAAI,CAAA,CAAA;AAAA,MAC9B,YAAA,EAAc,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,8CAAA,CAAA;AAAA,MAUd;AAAA,KACD,CAAA;AAAA,EACH;AAAA,EAEA,MAAM,iBAAA,CAAkB,KAAA,EAAe,IAAA,EAA+B;AACpE,IAAA,MAAM,MAAA,GAAS,sBAAA,CAAuB,KAAA,EAAO,IAAI,CAAA;AAEjD,IAAA,MAAM,KAAA,GAAQ,MAAM,IAAA,CAAK,KAAA,CAAM,QAAA,EAAS;AAExC,IAAA,IAAI,QAAA;AACJ,IAAA,IAAI,KAAA,CAAM,yBAAyB,IAAA,EAAM;AACvC,MAAA,MAAM,YAAA,GAAe,MAAM,IAAA,CAAK,KAAA,CAAM,SAAS,MAAM,CAAA;AACrD,MAAA,QAAA,GAAW,YAAA,CAAa,IAAA;AAAA,IAC1B,CAAA,MAAO;AACL,MAAA,MAAM,YAAA,GAAe,MAAM,IAAA,CAAK,KAAA,CAAM,eAAe,MAAM,CAAA;AAC3D,MAAA,QAAA,GAAW,YAAA,CAAa,IAAA;AAAA,IAC1B;AACA,IAAA,OAAO,WAAW,QAAQ,CAAA;AAAA,EAC5B;AACF","file":"chunk-MQ67HP3O.cjs","sourcesContent":["import type { RelevanceScoreProvider } from '../relevance-score-provider';\n\ninterface CohereRerankingResponse {\n results: Array<{\n index: number;\n relevance_score: number;\n }>;\n id: string;\n meta: {\n api_version: {\n version: string;\n is_experimental: boolean;\n };\n billed_units: {\n search_units: number;\n };\n };\n}\n\n/** @deprecated Import from `@mastra/rag` instead */\nexport class CohereRelevanceScorer implements RelevanceScoreProvider {\n private model: string;\n private apiKey?: string;\n constructor(model: string, apiKey?: string) {\n console.warn(\n 'CohereRelevanceScorer exported from @mastra/core is deprecated. Please import from \"@mastra/rag\" instead.',\n );\n this.apiKey = apiKey;\n this.model = model;\n }\n async getRelevanceScore(query: string, text: string): Promise<number> {\n const response = await fetch(`https://api.cohere.com/v2/rerank`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${this.apiKey}`,\n },\n body: JSON.stringify({\n query,\n documents: [text],\n model: this.model,\n top_n: 1,\n }),\n });\n\n if (!response.ok) {\n throw new Error(`Cohere API error: ${response.status} ${await response.text()}`);\n }\n\n const data = (await response.json()) as CohereRerankingResponse;\n const relevanceScore = data.results[0]?.relevance_score;\n\n if (!relevanceScore) {\n throw new Error('No relevance score found on Cohere response');\n }\n\n return relevanceScore;\n }\n}\n","// Provider interfaces\nexport interface RelevanceScoreProvider {\n getRelevanceScore(text1: string, text2: string): Promise<number>;\n}\n\n// Helper function used by providers\nexport function createSimilarityPrompt(query: string, text: string): string {\n return `Rate the semantic similarity between the following the query and the text on a scale from 0 to 1 (decimals allowed), where 1 means exactly the same meaning and 0 means completely different:\n\nQuery: ${query}\n\nText: ${text}\n\nRelevance score (0-1):`;\n}\n","import { Agent } from '../../agent';\nimport type { MastraModelConfig } from '../../llm/model/shared.types';\nimport { createSimilarityPrompt } from '../relevance-score-provider';\nimport type { RelevanceScoreProvider } from '../relevance-score-provider';\n\n// Mastra Agent implementation\nexport class MastraAgentRelevanceScorer implements RelevanceScoreProvider {\n private agent: Agent;\n\n constructor(name: string, model: MastraModelConfig) {\n this.agent = new Agent({\n name: `Relevance Scorer ${name}`,\n instructions: `You are a specialized agent for evaluating the relevance of text to queries.\nYour task is to rate how well a text passage answers a given query.\nOutput only a number between 0 and 1, where:\n1.0 = Perfectly relevant, directly answers the query\n0.0 = Completely irrelevant\nConsider:\n- Direct relevance to the question\n- Completeness of information\n- Quality and specificity\nAlways return just the number, no explanation.`,\n model,\n });\n }\n\n async getRelevanceScore(query: string, text: string): Promise<number> {\n const prompt = createSimilarityPrompt(query, text);\n\n const model = await this.agent.getModel();\n\n let response: string;\n if (model.specificationVersion === 'v2') {\n const responseText = await this.agent.generate(prompt);\n response = responseText.text;\n } else {\n const responseText = await this.agent.generateLegacy(prompt);\n response = responseText.text;\n }\n return parseFloat(response);\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/relevance/cohere/index.ts","../src/relevance/relevance-score-provider.ts","../src/relevance/mastra-agent/index.ts"],"names":["Agent"],"mappings":";;;;;AAoBO,IAAM,wBAAN,MAA8D;AAAA,EAC3D,KAAA;AAAA,EACA,MAAA;AAAA,EACR,WAAA,CAAY,OAAe,MAAA,EAAiB;AAC1C,IAAA,OAAA,CAAQ,IAAA;AAAA,MACN;AAAA,KACF;AACA,IAAA,IAAA,CAAK,MAAA,GAAS,MAAA;AACd,IAAA,IAAA,CAAK,KAAA,GAAQ,KAAA;AAAA,EACf;AAAA,EACA,MAAM,iBAAA,CAAkB,KAAA,EAAe,IAAA,EAA+B;AACpE,IAAA,MAAM,QAAA,GAAW,MAAM,KAAA,CAAM,CAAA,gCAAA,CAAA,EAAoC;AAAA,MAC/D,MAAA,EAAQ,MAAA;AAAA,MACR,OAAA,EAAS;AAAA,QACP,cAAA,EAAgB,kBAAA;AAAA,QAChB,aAAA,EAAe,CAAA,OAAA,EAAU,IAAA,CAAK,MAAM,CAAA;AAAA,OACtC;AAAA,MACA,IAAA,EAAM,KAAK,SAAA,CAAU;AAAA,QACnB,KAAA;AAAA,QACA,SAAA,EAAW,CAAC,IAAI,CAAA;AAAA,QAChB,OAAO,IAAA,CAAK,KAAA;AAAA,QACZ,KAAA,EAAO;AAAA,OACR;AAAA,KACF,CAAA;AAED,IAAA,IAAI,CAAC,SAAS,EAAA,EAAI;AAChB,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,kBAAA,EAAqB,QAAA,CAAS,MAAM,IAAI,MAAM,QAAA,CAAS,IAAA,EAAM,CAAA,CAAE,CAAA;AAAA,IACjF;AAEA,IAAA,MAAM,IAAA,GAAQ,MAAM,QAAA,CAAS,IAAA,EAAK;AAClC,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,OAAA,CAAQ,CAAC,CAAA,EAAG,eAAA;AAExC,IAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,MAAA,MAAM,IAAI,MAAM,6CAA6C,CAAA;AAAA,IAC/D;AAEA,IAAA,OAAO,cAAA;AAAA,EACT;AACF;;;ACpDO,SAAS,sBAAA,CAAuB,OAAe,IAAA,EAAsB;AAC1E,EAAA,OAAO,CAAA;;AAAA,OAAA,EAEA,KAAK;;AAAA,MAAA,EAEN,IAAI;;AAAA,sBAAA,CAAA;AAGZ;;;ACRO,IAAM,6BAAN,MAAmE;AAAA,EAChE,KAAA;AAAA,EAER,WAAA,CAAY,MAAc,KAAA,EAA0B;AAClD,IAAA,IAAA,CAAK,KAAA,GAAQ,IAAIA,uBAAA,CAAM;AAAA,MACrB,IAAA,EAAM,oBAAoB,IAAI,CAAA,CAAA;AAAA,MAC9B,YAAA,EAAc,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,8CAAA,CAAA;AAAA,MAUd;AAAA,KACD,CAAA;AAAA,EACH;AAAA,EAEA,MAAM,iBAAA,CAAkB,KAAA,EAAe,IAAA,EAA+B;AACpE,IAAA,MAAM,MAAA,GAAS,sBAAA,CAAuB,KAAA,EAAO,IAAI,CAAA;AAEjD,IAAA,MAAM,KAAA,GAAQ,MAAM,IAAA,CAAK,KAAA,CAAM,QAAA,EAAS;AAExC,IAAA,IAAI,QAAA;AACJ,IAAA,IAAI,KAAA,CAAM,yBAAyB,IAAA,EAAM;AACvC,MAAA,MAAM,YAAA,GAAe,MAAM,IAAA,CAAK,KAAA,CAAM,SAAS,MAAM,CAAA;AACrD,MAAA,QAAA,GAAW,YAAA,CAAa,IAAA;AAAA,IAC1B,CAAA,MAAO;AACL,MAAA,MAAM,YAAA,GAAe,MAAM,IAAA,CAAK,KAAA,CAAM,eAAe,MAAM,CAAA;AAC3D,MAAA,QAAA,GAAW,YAAA,CAAa,IAAA;AAAA,IAC1B;AACA,IAAA,OAAO,WAAW,QAAQ,CAAA;AAAA,EAC5B;AACF","file":"chunk-5P4S4AVU.cjs","sourcesContent":["import type { RelevanceScoreProvider } from '../relevance-score-provider';\n\ninterface CohereRerankingResponse {\n results: Array<{\n index: number;\n relevance_score: number;\n }>;\n id: string;\n meta: {\n api_version: {\n version: string;\n is_experimental: boolean;\n };\n billed_units: {\n search_units: number;\n };\n };\n}\n\n/** @deprecated Import from `@mastra/rag` instead */\nexport class CohereRelevanceScorer implements RelevanceScoreProvider {\n private model: string;\n private apiKey?: string;\n constructor(model: string, apiKey?: string) {\n console.warn(\n 'CohereRelevanceScorer exported from @mastra/core is deprecated. Please import from \"@mastra/rag\" instead.',\n );\n this.apiKey = apiKey;\n this.model = model;\n }\n async getRelevanceScore(query: string, text: string): Promise<number> {\n const response = await fetch(`https://api.cohere.com/v2/rerank`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${this.apiKey}`,\n },\n body: JSON.stringify({\n query,\n documents: [text],\n model: this.model,\n top_n: 1,\n }),\n });\n\n if (!response.ok) {\n throw new Error(`Cohere API error: ${response.status} ${await response.text()}`);\n }\n\n const data = (await response.json()) as CohereRerankingResponse;\n const relevanceScore = data.results[0]?.relevance_score;\n\n if (!relevanceScore) {\n throw new Error('No relevance score found on Cohere response');\n }\n\n return relevanceScore;\n }\n}\n","// Provider interfaces\nexport interface RelevanceScoreProvider {\n getRelevanceScore(text1: string, text2: string): Promise<number>;\n}\n\n// Helper function used by providers\nexport function createSimilarityPrompt(query: string, text: string): string {\n return `Rate the semantic similarity between the following the query and the text on a scale from 0 to 1 (decimals allowed), where 1 means exactly the same meaning and 0 means completely different:\n\nQuery: ${query}\n\nText: ${text}\n\nRelevance score (0-1):`;\n}\n","import { Agent } from '../../agent';\nimport type { MastraModelConfig } from '../../llm/model/shared.types';\nimport { createSimilarityPrompt } from '../relevance-score-provider';\nimport type { RelevanceScoreProvider } from '../relevance-score-provider';\n\n// Mastra Agent implementation\nexport class MastraAgentRelevanceScorer implements RelevanceScoreProvider {\n private agent: Agent;\n\n constructor(name: string, model: MastraModelConfig) {\n this.agent = new Agent({\n name: `Relevance Scorer ${name}`,\n instructions: `You are a specialized agent for evaluating the relevance of text to queries.\nYour task is to rate how well a text passage answers a given query.\nOutput only a number between 0 and 1, where:\n1.0 = Perfectly relevant, directly answers the query\n0.0 = Completely irrelevant\nConsider:\n- Direct relevance to the question\n- Completeness of information\n- Quality and specificity\nAlways return just the number, no explanation.`,\n model,\n });\n }\n\n async getRelevanceScore(query: string, text: string): Promise<number> {\n const prompt = createSimilarityPrompt(query, text);\n\n const model = await this.agent.getModel();\n\n let response: string;\n if (model.specificationVersion === 'v2') {\n const responseText = await this.agent.generate(prompt);\n response = responseText.text;\n } else {\n const responseText = await this.agent.generateLegacy(prompt);\n response = responseText.text;\n }\n return parseFloat(response);\n }\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkTSNDVBUU_cjs = require('./chunk-TSNDVBUU.cjs');
4
- var chunkWM4VQWOZ_cjs = require('./chunk-WM4VQWOZ.cjs');
4
+ var chunk5NTO7S5I_cjs = require('./chunk-5NTO7S5I.cjs');
5
5
 
6
6
  // src/eval/metric.ts
7
7
  var Metric = class {
@@ -24,7 +24,7 @@ async function evaluate({
24
24
  try {
25
25
  metricResult = await metric.measure(input.toString(), output);
26
26
  } catch (e) {
27
- throw new chunkWM4VQWOZ_cjs.MastraError(
27
+ throw new chunk5NTO7S5I_cjs.MastraError(
28
28
  {
29
29
  id: "EVAL_METRIC_MEASURE_EXECUTION_FAILED",
30
30
  domain: "EVAL" /* EVAL */,
@@ -52,7 +52,7 @@ async function evaluate({
52
52
  try {
53
53
  chunkTSNDVBUU_cjs.executeHook("onEvaluation" /* ON_EVALUATION */, traceObject);
54
54
  } catch (e) {
55
- throw new chunkWM4VQWOZ_cjs.MastraError(
55
+ throw new chunk5NTO7S5I_cjs.MastraError(
56
56
  {
57
57
  id: "EVAL_HOOK_EXECUTION_FAILED",
58
58
  domain: "EVAL" /* EVAL */,
@@ -71,5 +71,5 @@ async function evaluate({
71
71
 
72
72
  exports.Metric = Metric;
73
73
  exports.evaluate = evaluate;
74
- //# sourceMappingURL=chunk-576KDLXN.cjs.map
75
- //# sourceMappingURL=chunk-576KDLXN.cjs.map
74
+ //# sourceMappingURL=chunk-6KOL2B3A.cjs.map
75
+ //# sourceMappingURL=chunk-6KOL2B3A.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/eval/metric.ts","../src/eval/evaluation.ts"],"names":["MastraError","executeHook"],"mappings":";;;;;;AAKO,IAAe,SAAf,MAAsB;AAE7B;;;ACDA,eAAsB,QAAA,CAA0B;AAAA,EAC9C,SAAA;AAAA,EACA,KAAA;AAAA,EACA,MAAA;AAAA,EACA,MAAA;AAAA,EACA,KAAA;AAAA,EACA,WAAA;AAAA,EACA,QAAA;AAAA,EACA;AACF,CAAA,EAS8B;AAC5B,EAAA,MAAM,UAAA,GAAa,KAAA,IAAS,MAAA,CAAO,UAAA,EAAW;AAE9C,EAAA,IAAI,YAAA;AACJ,EAAA,IAAI,UAAA,GAAa,OAAO,WAAA,CAAY,IAAA;AACpC,EAAA,IAAI;AACF,IAAA,YAAA,GAAe,MAAM,MAAA,CAAO,OAAA,CAAQ,KAAA,CAAM,QAAA,IAAY,MAAM,CAAA;AAAA,EAC9D,SAAS,CAAA,EAAY;AACnB,IAAA,MAAM,IAAIA,6BAAA;AAAA,MACR;AAAA,QACE,EAAA,EAAI,sCAAA;AAAA,QACJ,MAAA,EAAA,MAAA;AAAA,QACA,QAAA,EAAA,MAAA;AAAA,QACA,OAAA,EAAS;AAAA,UACP,SAAA;AAAA,UACA,UAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACA,EAAA,MAAM,WAAA,GAAc;AAAA,IAClB,KAAA,EAAO,MAAM,QAAA,EAAS;AAAA,IACtB,MAAA;AAAA,IACA,MAAA,EAAQ,YAAA;AAAA,IACR,SAAA;AAAA,IACA,UAAA;AAAA,IACA,YAAA;AAAA,IACA,WAAA;AAAA,IACA,KAAA,EAAO,UAAA;AAAA,IACP;AAAA,GACF;AAEA,EAAA,IAAI;AACF,IAAAC,6BAAA,CAAA,cAAA,sBAA0C,WAAW,CAAA;AAAA,EACvD,SAAS,CAAA,EAAY;AACnB,IAAA,MAAM,IAAID,6BAAA;AAAA,MACR;AAAA,QACE,EAAA,EAAI,4BAAA;AAAA,QACJ,MAAA,EAAA,MAAA;AAAA,QACA,QAAA,EAAA,MAAA;AAAA,QACA,OAAA,EAAS;AAAA,UACP,SAAA;AAAA,UACA,UAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAEA,EAAA,OAAO,EAAE,GAAG,YAAA,EAAc,MAAA,EAAO;AACnC","file":"chunk-576KDLXN.cjs","sourcesContent":["export interface MetricResult {\n score: number;\n info?: Record<string, any>;\n}\n\nexport abstract class Metric {\n abstract measure(input: string, output: string): Promise<MetricResult>;\n}\n","import type { Agent } from '../agent';\nimport { MastraError, ErrorCategory, ErrorDomain } from '../error';\nimport { AvailableHooks, executeHook } from '../hooks';\nimport type { Metric } from './metric';\nimport type { TestInfo, EvaluationResult } from './types';\n\nexport async function evaluate<T extends Agent>({\n agentName,\n input,\n metric,\n output,\n runId,\n globalRunId,\n testInfo,\n instructions,\n}: {\n agentName: string;\n input: Parameters<T['generate']>[0];\n metric: Metric;\n output: string;\n globalRunId: string;\n runId?: string;\n testInfo?: TestInfo;\n instructions: string;\n}): Promise<EvaluationResult> {\n const runIdToUse = runId || crypto.randomUUID();\n\n let metricResult;\n let metricName = metric.constructor.name;\n try {\n metricResult = await metric.measure(input.toString(), output);\n } catch (e: unknown) {\n throw new MastraError(\n {\n id: 'EVAL_METRIC_MEASURE_EXECUTION_FAILED',\n domain: ErrorDomain.EVAL,\n category: ErrorCategory.USER,\n details: {\n agentName,\n metricName,\n globalRunId,\n },\n },\n e,\n );\n }\n const traceObject = {\n input: input.toString(),\n output: output,\n result: metricResult,\n agentName,\n metricName,\n instructions,\n globalRunId,\n runId: runIdToUse,\n testInfo,\n };\n\n try {\n executeHook(AvailableHooks.ON_EVALUATION, traceObject);\n } catch (e: unknown) {\n throw new MastraError(\n {\n id: 'EVAL_HOOK_EXECUTION_FAILED',\n domain: ErrorDomain.EVAL,\n category: ErrorCategory.USER,\n details: {\n agentName,\n metricName,\n globalRunId,\n },\n },\n e,\n );\n }\n\n return { ...metricResult, output };\n}\n"]}
1
+ {"version":3,"sources":["../src/eval/metric.ts","../src/eval/evaluation.ts"],"names":["MastraError","executeHook"],"mappings":";;;;;;AAKO,IAAe,SAAf,MAAsB;AAE7B;;;ACDA,eAAsB,QAAA,CAA0B;AAAA,EAC9C,SAAA;AAAA,EACA,KAAA;AAAA,EACA,MAAA;AAAA,EACA,MAAA;AAAA,EACA,KAAA;AAAA,EACA,WAAA;AAAA,EACA,QAAA;AAAA,EACA;AACF,CAAA,EAS8B;AAC5B,EAAA,MAAM,UAAA,GAAa,KAAA,IAAS,MAAA,CAAO,UAAA,EAAW;AAE9C,EAAA,IAAI,YAAA;AACJ,EAAA,IAAI,UAAA,GAAa,OAAO,WAAA,CAAY,IAAA;AACpC,EAAA,IAAI;AACF,IAAA,YAAA,GAAe,MAAM,MAAA,CAAO,OAAA,CAAQ,KAAA,CAAM,QAAA,IAAY,MAAM,CAAA;AAAA,EAC9D,SAAS,CAAA,EAAY;AACnB,IAAA,MAAM,IAAIA,6BAAA;AAAA,MACR;AAAA,QACE,EAAA,EAAI,sCAAA;AAAA,QACJ,MAAA,EAAA,MAAA;AAAA,QACA,QAAA,EAAA,MAAA;AAAA,QACA,OAAA,EAAS;AAAA,UACP,SAAA;AAAA,UACA,UAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACA,EAAA,MAAM,WAAA,GAAc;AAAA,IAClB,KAAA,EAAO,MAAM,QAAA,EAAS;AAAA,IACtB,MAAA;AAAA,IACA,MAAA,EAAQ,YAAA;AAAA,IACR,SAAA;AAAA,IACA,UAAA;AAAA,IACA,YAAA;AAAA,IACA,WAAA;AAAA,IACA,KAAA,EAAO,UAAA;AAAA,IACP;AAAA,GACF;AAEA,EAAA,IAAI;AACF,IAAAC,6BAAA,CAAA,cAAA,sBAA0C,WAAW,CAAA;AAAA,EACvD,SAAS,CAAA,EAAY;AACnB,IAAA,MAAM,IAAID,6BAAA;AAAA,MACR;AAAA,QACE,EAAA,EAAI,4BAAA;AAAA,QACJ,MAAA,EAAA,MAAA;AAAA,QACA,QAAA,EAAA,MAAA;AAAA,QACA,OAAA,EAAS;AAAA,UACP,SAAA;AAAA,UACA,UAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAEA,EAAA,OAAO,EAAE,GAAG,YAAA,EAAc,MAAA,EAAO;AACnC","file":"chunk-6KOL2B3A.cjs","sourcesContent":["export interface MetricResult {\n score: number;\n info?: Record<string, any>;\n}\n\nexport abstract class Metric {\n abstract measure(input: string, output: string): Promise<MetricResult>;\n}\n","import type { Agent } from '../agent';\nimport { MastraError, ErrorCategory, ErrorDomain } from '../error';\nimport { AvailableHooks, executeHook } from '../hooks';\nimport type { Metric } from './metric';\nimport type { TestInfo, EvaluationResult } from './types';\n\nexport async function evaluate<T extends Agent>({\n agentName,\n input,\n metric,\n output,\n runId,\n globalRunId,\n testInfo,\n instructions,\n}: {\n agentName: string;\n input: Parameters<T['generate']>[0];\n metric: Metric;\n output: string;\n globalRunId: string;\n runId?: string;\n testInfo?: TestInfo;\n instructions: string;\n}): Promise<EvaluationResult> {\n const runIdToUse = runId || crypto.randomUUID();\n\n let metricResult;\n let metricName = metric.constructor.name;\n try {\n metricResult = await metric.measure(input.toString(), output);\n } catch (e: unknown) {\n throw new MastraError(\n {\n id: 'EVAL_METRIC_MEASURE_EXECUTION_FAILED',\n domain: ErrorDomain.EVAL,\n category: ErrorCategory.USER,\n details: {\n agentName,\n metricName,\n globalRunId,\n },\n },\n e,\n );\n }\n const traceObject = {\n input: input.toString(),\n output: output,\n result: metricResult,\n agentName,\n metricName,\n instructions,\n globalRunId,\n runId: runIdToUse,\n testInfo,\n };\n\n try {\n executeHook(AvailableHooks.ON_EVALUATION, traceObject);\n } catch (e: unknown) {\n throw new MastraError(\n {\n id: 'EVAL_HOOK_EXECUTION_FAILED',\n domain: ErrorDomain.EVAL,\n category: ErrorCategory.USER,\n details: {\n agentName,\n metricName,\n globalRunId,\n },\n },\n e,\n );\n }\n\n return { ...metricResult, output };\n}\n"]}