@mastra/server 1.31.1-alpha.0 → 1.32.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +15 -0
- package/dist/{chunk-Q2N5GR7X.cjs → chunk-2TRRXAQK.cjs} +3 -3
- package/dist/{chunk-Q2N5GR7X.cjs.map → chunk-2TRRXAQK.cjs.map} +1 -1
- package/dist/{chunk-2CFH32YO.cjs → chunk-3S5WOAYR.cjs} +3 -3
- package/dist/{chunk-2CFH32YO.cjs.map → chunk-3S5WOAYR.cjs.map} +1 -1
- package/dist/{chunk-7VXUWPHS.cjs → chunk-44JNOREB.cjs} +3 -3
- package/dist/{chunk-7VXUWPHS.cjs.map → chunk-44JNOREB.cjs.map} +1 -1
- package/dist/{chunk-TKHLXCSZ.cjs → chunk-6QL3PDQ7.cjs} +7 -7
- package/dist/{chunk-TKHLXCSZ.cjs.map → chunk-6QL3PDQ7.cjs.map} +1 -1
- package/dist/{chunk-NGYGE7QW.cjs → chunk-7QAQXIA4.cjs} +8 -8
- package/dist/{chunk-NGYGE7QW.cjs.map → chunk-7QAQXIA4.cjs.map} +1 -1
- package/dist/{chunk-OV64VJ5L.js → chunk-7RAGUCER.js} +3 -3
- package/dist/{chunk-OV64VJ5L.js.map → chunk-7RAGUCER.js.map} +1 -1
- package/dist/{chunk-FIP7YYSO.js → chunk-BCBNR2J2.js} +3 -3
- package/dist/{chunk-FIP7YYSO.js.map → chunk-BCBNR2J2.js.map} +1 -1
- package/dist/{chunk-2HIGXJMR.cjs → chunk-CC6HRROH.cjs} +37 -37
- package/dist/{chunk-2HIGXJMR.cjs.map → chunk-CC6HRROH.cjs.map} +1 -1
- package/dist/{chunk-RPMBPQNO.cjs → chunk-CPZEA2XG.cjs} +10 -3
- package/dist/chunk-CPZEA2XG.cjs.map +1 -0
- package/dist/{chunk-4GOK3PCO.js → chunk-DFEFYM5I.js} +4 -4
- package/dist/{chunk-4GOK3PCO.js.map → chunk-DFEFYM5I.js.map} +1 -1
- package/dist/{chunk-K6VEDPBD.js → chunk-DITB4LGJ.js} +5 -5
- package/dist/{chunk-K6VEDPBD.js.map → chunk-DITB4LGJ.js.map} +1 -1
- package/dist/{chunk-7GNVIWZY.js → chunk-DTB2PQPA.js} +3 -3
- package/dist/{chunk-7GNVIWZY.js.map → chunk-DTB2PQPA.js.map} +1 -1
- package/dist/{chunk-65MQD7JR.js → chunk-EAOBAXC7.js} +3 -3
- package/dist/{chunk-65MQD7JR.js.map → chunk-EAOBAXC7.js.map} +1 -1
- package/dist/{chunk-DG5RFCGJ.cjs → chunk-FRKJAWEK.cjs} +49 -49
- package/dist/{chunk-DG5RFCGJ.cjs.map → chunk-FRKJAWEK.cjs.map} +1 -1
- package/dist/{chunk-MROI3O6S.cjs → chunk-GITUJAKR.cjs} +3 -3
- package/dist/{chunk-MROI3O6S.cjs.map → chunk-GITUJAKR.cjs.map} +1 -1
- package/dist/{chunk-VZNOKYP5.js → chunk-HAOI6QSD.js} +3 -3
- package/dist/{chunk-VZNOKYP5.js.map → chunk-HAOI6QSD.js.map} +1 -1
- package/dist/{chunk-DZZBC6UV.cjs → chunk-I2IUAPQE.cjs} +5 -5
- package/dist/{chunk-DZZBC6UV.cjs.map → chunk-I2IUAPQE.cjs.map} +1 -1
- package/dist/chunk-JCWPQ5DD.cjs +256 -0
- package/dist/chunk-JCWPQ5DD.cjs.map +1 -0
- package/dist/{chunk-RTD3NZ4G.js → chunk-KG2CULOS.js} +3 -3
- package/dist/{chunk-RTD3NZ4G.js.map → chunk-KG2CULOS.js.map} +1 -1
- package/dist/{chunk-4J4K36CU.js → chunk-LHY3IIL2.js} +3 -3
- package/dist/{chunk-4J4K36CU.js.map → chunk-LHY3IIL2.js.map} +1 -1
- package/dist/{chunk-EQR4MMSL.cjs → chunk-ME255ZWD.cjs} +7 -7
- package/dist/{chunk-EQR4MMSL.cjs.map → chunk-ME255ZWD.cjs.map} +1 -1
- package/dist/{chunk-7E2JRYIE.js → chunk-N6EQZJFN.js} +3 -3
- package/dist/{chunk-7E2JRYIE.js.map → chunk-N6EQZJFN.js.map} +1 -1
- package/dist/{chunk-Y2SA2JZT.cjs → chunk-NB2NE7QS.cjs} +36 -36
- package/dist/{chunk-Y2SA2JZT.cjs.map → chunk-NB2NE7QS.cjs.map} +1 -1
- package/dist/{chunk-S4EHZQFI.js → chunk-NBEKX4M5.js} +7 -7
- package/dist/{chunk-S4EHZQFI.js.map → chunk-NBEKX4M5.js.map} +1 -1
- package/dist/{chunk-EETF75CE.cjs → chunk-NHJFLZZN.cjs} +3 -3
- package/dist/{chunk-EETF75CE.cjs.map → chunk-NHJFLZZN.cjs.map} +1 -1
- package/dist/{chunk-KI7TGMMV.cjs → chunk-O6YA7VM3.cjs} +43 -43
- package/dist/{chunk-KI7TGMMV.cjs.map → chunk-O6YA7VM3.cjs.map} +1 -1
- package/dist/{chunk-ARZ6W3O3.cjs → chunk-OBYYH7DX.cjs} +7 -7
- package/dist/{chunk-ARZ6W3O3.cjs.map → chunk-OBYYH7DX.cjs.map} +1 -1
- package/dist/{chunk-JQUNK754.js → chunk-PQDR7XQP.js} +4 -4
- package/dist/{chunk-JQUNK754.js.map → chunk-PQDR7XQP.js.map} +1 -1
- package/dist/{chunk-UZRD3SEA.js → chunk-QGNNJRKA.js} +5 -5
- package/dist/{chunk-UZRD3SEA.js.map → chunk-QGNNJRKA.js.map} +1 -1
- package/dist/{chunk-DBPJYWAH.js → chunk-R76F63OE.js} +3 -3
- package/dist/{chunk-DBPJYWAH.js.map → chunk-R76F63OE.js.map} +1 -1
- package/dist/{chunk-2HVAN7FF.js → chunk-RP7OLAVZ.js} +10 -3
- package/dist/chunk-RP7OLAVZ.js.map +1 -0
- package/dist/{chunk-245BXYGJ.cjs → chunk-RTYIV265.cjs} +3 -3
- package/dist/{chunk-245BXYGJ.cjs.map → chunk-RTYIV265.cjs.map} +1 -1
- package/dist/{chunk-UQLJDNXU.cjs → chunk-TGZNNEAI.cjs} +4 -4
- package/dist/{chunk-UQLJDNXU.cjs.map → chunk-TGZNNEAI.cjs.map} +1 -1
- package/dist/{chunk-JZNOIGOQ.js → chunk-TJAYLVG5.js} +3 -3
- package/dist/{chunk-JZNOIGOQ.js.map → chunk-TJAYLVG5.js.map} +1 -1
- package/dist/{chunk-5XQIAEWJ.cjs → chunk-U4ZN4PDI.cjs} +11 -11
- package/dist/{chunk-5XQIAEWJ.cjs.map → chunk-U4ZN4PDI.cjs.map} +1 -1
- package/dist/{chunk-QL62CV5V.js → chunk-UMVQATCY.js} +5 -5
- package/dist/{chunk-QL62CV5V.js.map → chunk-UMVQATCY.js.map} +1 -1
- package/dist/chunk-W53ZIS6J.js +250 -0
- package/dist/chunk-W53ZIS6J.js.map +1 -0
- package/dist/{chunk-LY6Q36YN.cjs → chunk-YP2KYGCY.cjs} +17 -17
- package/dist/{chunk-LY6Q36YN.cjs.map → chunk-YP2KYGCY.cjs.map} +1 -1
- package/dist/{chunk-AMC32S2M.js → chunk-ZEESV2HZ.js} +4 -4
- package/dist/{chunk-AMC32S2M.js.map → chunk-ZEESV2HZ.js.map} +1 -1
- package/dist/{chunk-KW2MZGRE.js → chunk-ZQVMWCVT.js} +3 -3
- package/dist/{chunk-KW2MZGRE.js.map → chunk-ZQVMWCVT.js.map} +1 -1
- package/dist/docs/SKILL.md +1 -1
- package/dist/docs/assets/SOURCE_MAP.json +1 -1
- package/dist/{observational-memory-ZS2HJPUO-472SI4TK.cjs → observational-memory-UMDC4VC2-3I52URYY.cjs} +26 -26
- package/dist/{observational-memory-ZS2HJPUO-472SI4TK.cjs.map → observational-memory-UMDC4VC2-3I52URYY.cjs.map} +1 -1
- package/dist/{observational-memory-ZS2HJPUO-2ZBP2HCP.js → observational-memory-UMDC4VC2-X5QMTUND.js} +3 -3
- package/dist/{observational-memory-ZS2HJPUO-2ZBP2HCP.js.map → observational-memory-UMDC4VC2-X5QMTUND.js.map} +1 -1
- package/dist/server/handlers/a2a.cjs +10 -10
- package/dist/server/handlers/a2a.js +1 -1
- package/dist/server/handlers/agent-builder.cjs +16 -16
- package/dist/server/handlers/agent-builder.js +1 -1
- package/dist/server/handlers/agents.cjs +38 -38
- package/dist/server/handlers/agents.js +1 -1
- package/dist/server/handlers/conversations.cjs +5 -5
- package/dist/server/handlers/conversations.js +1 -1
- package/dist/server/handlers/logs.cjs +4 -4
- package/dist/server/handlers/logs.js +1 -1
- package/dist/server/handlers/memory.cjs +27 -27
- package/dist/server/handlers/memory.js +1 -1
- package/dist/server/handlers/responses.cjs +4 -4
- package/dist/server/handlers/responses.js +1 -1
- package/dist/server/handlers/responses.storage.cjs +8 -8
- package/dist/server/handlers/responses.storage.js +1 -1
- package/dist/server/handlers/schedules.cjs +28 -0
- package/dist/server/handlers/schedules.cjs.map +1 -0
- package/dist/server/handlers/schedules.d.ts +345 -0
- package/dist/server/handlers/schedules.d.ts.map +1 -0
- package/dist/server/handlers/schedules.js +3 -0
- package/dist/server/handlers/schedules.js.map +1 -0
- package/dist/server/handlers/scores.cjs +7 -7
- package/dist/server/handlers/scores.js +1 -1
- package/dist/server/handlers/stored-agents.cjs +7 -7
- package/dist/server/handlers/stored-agents.js +1 -1
- package/dist/server/handlers/stored-mcp-clients.cjs +6 -6
- package/dist/server/handlers/stored-mcp-clients.js +1 -1
- package/dist/server/handlers/stored-prompt-blocks.cjs +6 -6
- package/dist/server/handlers/stored-prompt-blocks.js +1 -1
- package/dist/server/handlers/stored-scorers.cjs +6 -6
- package/dist/server/handlers/stored-scorers.js +1 -1
- package/dist/server/handlers/stored-workspaces.cjs +6 -6
- package/dist/server/handlers/stored-workspaces.js +1 -1
- package/dist/server/handlers/tools.cjs +6 -6
- package/dist/server/handlers/tools.js +1 -1
- package/dist/server/handlers/utils.cjs +9 -9
- package/dist/server/handlers/utils.js +1 -1
- package/dist/server/handlers/voice.cjs +8 -8
- package/dist/server/handlers/voice.js +1 -1
- package/dist/server/handlers/workflows.cjs +24 -24
- package/dist/server/handlers/workflows.js +1 -1
- package/dist/server/handlers.cjs +28 -28
- package/dist/server/handlers.js +12 -12
- package/dist/server/schemas/index.cjs +309 -309
- package/dist/server/schemas/index.js +7 -7
- package/dist/server/schemas/schedules.d.ts +204 -0
- package/dist/server/schemas/schedules.d.ts.map +1 -0
- package/dist/server/server-adapter/index.cjs +173 -162
- package/dist/server/server-adapter/index.cjs.map +1 -1
- package/dist/server/server-adapter/index.js +32 -21
- package/dist/server/server-adapter/index.js.map +1 -1
- package/dist/server/server-adapter/routes/index.d.ts.map +1 -1
- package/dist/server/server-adapter/routes/schedules.d.ts +3 -0
- package/dist/server/server-adapter/routes/schedules.d.ts.map +1 -0
- package/package.json +5 -5
- package/dist/chunk-2HVAN7FF.js.map +0 -1
- package/dist/chunk-RPMBPQNO.cjs.map +0 -1
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var chunkWIOYCLJC_cjs = require('./chunk-WIOYCLJC.cjs');
|
|
4
|
-
var chunkYJQYJ5WD_cjs = require('./chunk-YJQYJ5WD.cjs');
|
|
5
4
|
var chunk2XZ2466F_cjs = require('./chunk-2XZ2466F.cjs');
|
|
5
|
+
var chunkYJQYJ5WD_cjs = require('./chunk-YJQYJ5WD.cjs');
|
|
6
6
|
var chunkDIG2K5CV_cjs = require('./chunk-DIG2K5CV.cjs');
|
|
7
7
|
var chunk5UKYK7YK_cjs = require('./chunk-5UKYK7YK.cjs');
|
|
8
8
|
var chunkB34S64RC_cjs = require('./chunk-B34S64RC.cjs');
|
|
@@ -228,5 +228,5 @@ exports.DELETE_STORED_MCP_CLIENT_ROUTE = DELETE_STORED_MCP_CLIENT_ROUTE;
|
|
|
228
228
|
exports.GET_STORED_MCP_CLIENT_ROUTE = GET_STORED_MCP_CLIENT_ROUTE;
|
|
229
229
|
exports.LIST_STORED_MCP_CLIENTS_ROUTE = LIST_STORED_MCP_CLIENTS_ROUTE;
|
|
230
230
|
exports.UPDATE_STORED_MCP_CLIENT_ROUTE = UPDATE_STORED_MCP_CLIENT_ROUTE;
|
|
231
|
-
//# sourceMappingURL=chunk-
|
|
232
|
-
//# sourceMappingURL=chunk-
|
|
231
|
+
//# sourceMappingURL=chunk-NHJFLZZN.cjs.map
|
|
232
|
+
//# sourceMappingURL=chunk-NHJFLZZN.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/server/handlers/stored-mcp-clients.ts"],"names":["createRoute","listStoredMCPClientsQuerySchema","listStoredMCPClientsResponseSchema","HTTPException","handleError","storedMCPClientIdPathParams","statusQuerySchema","getStoredMCPClientResponseSchema","createStoredMCPClientBodySchema","createStoredMCPClientResponseSchema","toSlug","updateStoredMCPClientBodySchema","updateStoredMCPClientResponseSchema","handleAutoVersioning","MCP_CLIENT_SNAPSHOT_CONFIG_FIELDS","deleteStoredMCPClientResponseSchema"],"mappings":";;;;;;;;;;;AA2BO,IAAM,gCAAgCA,6BAAA,CAAY;AAAA,EACvD,MAAA,EAAQ,KAAA;AAAA,EACR,IAAA,EAAM,qBAAA;AAAA,EACN,YAAA,EAAc,MAAA;AAAA,EACd,gBAAA,EAAkBC,iDAAA;AAAA,EAClB,cAAA,EAAgBC,oDAAA;AAAA,EAChB,OAAA,EAAS,yBAAA;AAAA,EACT,WAAA,EAAa,kFAAA;AAAA,EACb,IAAA,EAAM,CAAC,oBAAoB,CAAA;AAAA,EAC3B,YAAA,EAAc,IAAA;AAAA,EACd,OAAA,EAAS,OAAO,EAAE,MAAA,EAAQ,IAAA,EAAM,SAAS,OAAA,EAAS,MAAA,EAAQ,QAAA,EAAU,QAAA,EAAS,KAAM;AACjF,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,GAAU,OAAO,UAAA,EAAW;AAElC,MAAA,IAAI,CAAC,OAAA,EAAS;AACZ,QAAA,MAAM,IAAIC,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,6BAA6B,CAAA;AAAA,MACvE;AAEA,MAAA,MAAM,cAAA,GAAiB,MAAM,OAAA,CAAQ,QAAA,CAAS,YAAY,CAAA;AAC1D,MAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,QAAA,MAAM,IAAIA,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,+CAA+C,CAAA;AAAA,MACzF;AAEA,MAAA,MAAM,MAAA,GAAS,MAAM,cAAA,CAAe,YAAA,CAAa;AAAA,QAC/C,IAAA;AAAA,QACA,OAAA;AAAA,QACA,OAAA;AAAA,QACA,MAAA;AAAA,QACA,QAAA;AAAA,QACA;AAAA,OACD,CAAA;AAED,MAAA,OAAO,MAAA;AAAA,IACT,SAAS,KAAA,EAAO;AACd,MAAA,OAAOC,6BAAA,CAAY,OAAO,kCAAkC,CAAA;AAAA,IAC9D;AAAA,EACF;AACF,CAAC;AAKM,IAAM,8BAA8BJ,6BAAA,CAAY;AAAA,EACrD,MAAA,EAAQ,KAAA;AAAA,EACR,IAAA,EAAM,wCAAA;AAAA,EACN,YAAA,EAAc,MAAA;AAAA,EACd,eAAA,EAAiBK,6CAAA;AAAA,EACjB,gBAAA,EAAkBC,mCAAA;AAAA,EAClB,cAAA,EAAgBC,kDAAA;AAAA,EAChB,OAAA,EAAS,6BAAA;AAAA,EACT,WAAA,EACE,qMAAA;AAAA,EACF,IAAA,EAAM,CAAC,oBAAoB,CAAA;AAAA,EAC3B,YAAA,EAAc,IAAA;AAAA,EACd,SAAS,OAAO,EAAE,MAAA,EAAQ,iBAAA,EAAmB,QAAO,KAAM;AACxD,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,GAAU,OAAO,UAAA,EAAW;AAElC,MAAA,IAAI,CAAC,OAAA,EAAS;AACZ,QAAA,MAAM,IAAIJ,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,6BAA6B,CAAA;AAAA,MACvE;AAEA,MAAA,MAAM,cAAA,GAAiB,MAAM,OAAA,CAAQ,QAAA,CAAS,YAAY,CAAA;AAC1D,MAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,QAAA,MAAM,IAAIA,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,+CAA+C,CAAA;AAAA,MACzF;AAEA,MAAA,MAAM,YAAY,MAAM,cAAA,CAAe,gBAAgB,iBAAA,EAAmB,EAAE,QAAQ,CAAA;AAEpF,MAAA,IAAI,CAAC,SAAA,EAAW;AACd,QAAA,MAAM,IAAIA,gCAAc,GAAA,EAAK,EAAE,SAAS,CAAA,0BAAA,EAA6B,iBAAiB,cAAc,CAAA;AAAA,MACtG;AAEA,MAAA,OAAO,SAAA;AAAA,IACT,SAAS,KAAA,EAAO;AACd,MAAA,OAAOC,6BAAA,CAAY,OAAO,iCAAiC,CAAA;AAAA,IAC7D;AAAA,EACF;AACF,CAAC;AAKM,IAAM,iCAAiCJ,6BAAA,CAAY;AAAA,EACxD,MAAA,EAAQ,MAAA;AAAA,EACR,IAAA,EAAM,qBAAA;AAAA,EACN,YAAA,EAAc,MAAA;AAAA,EACd,UAAA,EAAYQ,iDAAA;AAAA,EACZ,cAAA,EAAgBC,qDAAA;AAAA,EAChB,OAAA,EAAS,0BAAA;AAAA,EACT,WAAA,EAAa,6EAAA;AAAA,EACb,IAAA,EAAM,CAAC,oBAAoB,CAAA;AAAA,EAC3B,YAAA,EAAc,IAAA;AAAA,EACd,OAAA,EAAS,OAAO,EAAE,MAAA,EAAQ,EAAA,EAAI,UAAA,EAAY,QAAA,EAAU,QAAA,EAAU,IAAA,EAAM,WAAA,EAAa,OAAA,EAAQ,KAAM;AAC7F,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,GAAU,OAAO,UAAA,EAAW;AAElC,MAAA,IAAI,CAAC,OAAA,EAAS;AACZ,QAAA,MAAM,IAAIN,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,6BAA6B,CAAA;AAAA,MACvE;AAEA,MAAA,MAAM,cAAA,GAAiB,MAAM,OAAA,CAAQ,QAAA,CAAS,YAAY,CAAA;AAC1D,MAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,QAAA,MAAM,IAAIA,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,+CAA+C,CAAA;AAAA,MACzF;AAGA,MAAA,MAAM,EAAA,GAAK,UAAA,IAAcO,wBAAA,CAAO,IAAI,CAAA;AAEpC,MAAA,IAAI,CAAC,EAAA,EAAI;AACP,QAAA,MAAM,IAAIP,gCAAc,GAAA,EAAK;AAAA,UAC3B,OAAA,EAAS;AAAA,SACV,CAAA;AAAA,MACH;AAGA,MAAA,MAAM,QAAA,GAAW,MAAM,cAAA,CAAe,OAAA,CAAQ,EAAE,CAAA;AAChD,MAAA,IAAI,QAAA,EAAU;AACZ,QAAA,MAAM,IAAIA,gCAAc,GAAA,EAAK,EAAE,SAAS,CAAA,mBAAA,EAAsB,EAAE,mBAAmB,CAAA;AAAA,MACrF;AAEA,MAAA,MAAM,eAAe,MAAA,CAAO;AAAA,QAC1B,SAAA,EAAW;AAAA,UACT,EAAA;AAAA,UACA,QAAA;AAAA,UACA,QAAA;AAAA,UACA,IAAA;AAAA,UACA,WAAA;AAAA,UACA;AAAA;AACF,OACD,CAAA;AAID,MAAA,MAAM,QAAA,GAAW,MAAM,cAAA,CAAe,eAAA,CAAgB,IAAI,EAAE,MAAA,EAAQ,SAAS,CAAA;AAC7E,MAAA,IAAI,CAAC,QAAA,EAAU;AACb,QAAA,MAAM,IAAIA,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,wCAAwC,CAAA;AAAA,MAClF;AAEA,MAAA,OAAO,QAAA;AAAA,IACT,SAAS,KAAA,EAAO;AACd,MAAA,OAAOC,6BAAA,CAAY,OAAO,kCAAkC,CAAA;AAAA,IAC9D;AAAA,EACF;AACF,CAAC;AAKM,IAAM,iCAAiCJ,6BAAA,CAAY;AAAA,EACxD,MAAA,EAAQ,OAAA;AAAA,EACR,IAAA,EAAM,wCAAA;AAAA,EACN,YAAA,EAAc,MAAA;AAAA,EACd,eAAA,EAAiBK,6CAAA;AAAA,EACjB,UAAA,EAAYM,iDAAA;AAAA,EACZ,cAAA,EAAgBC,qDAAA;AAAA,EAChB,OAAA,EAAS,0BAAA;AAAA,EACT,WAAA,EAAa,oEAAA;AAAA,EACb,IAAA,EAAM,CAAC,oBAAoB,CAAA;AAAA,EAC3B,YAAA,EAAc,IAAA;AAAA,EACd,SAAS,OAAO;AAAA,IACd,MAAA;AAAA,IACA,iBAAA;AAAA;AAAA,IAEA,QAAA;AAAA,IACA,QAAA;AAAA;AAAA,IAEA,IAAA;AAAA,IACA,WAAA;AAAA,IACA;AAAA,GACF,KAAM;AACJ,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,GAAU,OAAO,UAAA,EAAW;AAElC,MAAA,IAAI,CAAC,OAAA,EAAS;AACZ,QAAA,MAAM,IAAIT,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,6BAA6B,CAAA;AAAA,MACvE;AAEA,MAAA,MAAM,cAAA,GAAiB,MAAM,OAAA,CAAQ,QAAA,CAAS,YAAY,CAAA;AAC1D,MAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,QAAA,MAAM,IAAIA,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,+CAA+C,CAAA;AAAA,MACzF;AAGA,MAAA,MAAM,QAAA,GAAW,MAAM,cAAA,CAAe,OAAA,CAAQ,iBAAiB,CAAA;AAC/D,MAAA,IAAI,CAAC,QAAA,EAAU;AACb,QAAA,MAAM,IAAIA,gCAAc,GAAA,EAAK,EAAE,SAAS,CAAA,0BAAA,EAA6B,iBAAiB,cAAc,CAAA;AAAA,MACtG;AAGA,MAAA,MAAM,gBAAA,GAAmB,MAAM,cAAA,CAAe,MAAA,CAAO;AAAA,QACnD,EAAA,EAAI,iBAAA;AAAA,QACJ,QAAA;AAAA,QACA,QAAA;AAAA,QACA,IAAA;AAAA,QACA,WAAA;AAAA,QACA;AAAA,OACD,CAAA;AAGD,MAAA,MAAM,YAAA,GAAe,EAAE,IAAA,EAAM,WAAA,EAAa,OAAA,EAAQ;AAGlD,MAAA,MAAM,oBAAA,GAAuB,MAAA,CAAO,WAAA,CAAY,MAAA,CAAO,QAAQ,YAAY,CAAA,CAAE,MAAA,CAAO,CAAC,CAAC,CAAA,EAAG,CAAC,CAAA,KAAM,CAAA,KAAM,MAAS,CAAC,CAAA;AAKhH,MAAA,MAAMU,sCAAA;AAAA,QACJ,cAAA;AAAA,QACA,iBAAA;AAAA,QACA,aAAA;AAAA,QACAC,mDAAA;AAAA,QACA,QAAA;AAAA,QACA,gBAAA;AAAA,QACA;AAAA,OACF;AAGA,MAAA,MAAM,QAAA,GAAW,MAAM,cAAA,CAAe,eAAA,CAAgB,mBAAmB,EAAE,MAAA,EAAQ,SAAS,CAAA;AAC5F,MAAA,IAAI,CAAC,QAAA,EAAU;AACb,QAAA,MAAM,IAAIX,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,wCAAwC,CAAA;AAAA,MAClF;AAEA,MAAA,OAAO,QAAA;AAAA,IACT,SAAS,KAAA,EAAO;AACd,MAAA,OAAOC,6BAAA,CAAY,OAAO,kCAAkC,CAAA;AAAA,IAC9D;AAAA,EACF;AACF,CAAC;AAKM,IAAM,iCAAiCJ,6BAAA,CAAY;AAAA,EACxD,MAAA,EAAQ,QAAA;AAAA,EACR,IAAA,EAAM,wCAAA;AAAA,EACN,YAAA,EAAc,MAAA;AAAA,EACd,eAAA,EAAiBK,6CAAA;AAAA,EACjB,cAAA,EAAgBU,qDAAA;AAAA,EAChB,OAAA,EAAS,0BAAA;AAAA,EACT,WAAA,EAAa,6DAAA;AAAA,EACb,IAAA,EAAM,CAAC,oBAAoB,CAAA;AAAA,EAC3B,YAAA,EAAc,IAAA;AAAA,EACd,OAAA,EAAS,OAAO,EAAE,MAAA,EAAQ,mBAAkB,KAAM;AAChD,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,GAAU,OAAO,UAAA,EAAW;AAElC,MAAA,IAAI,CAAC,OAAA,EAAS;AACZ,QAAA,MAAM,IAAIZ,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,6BAA6B,CAAA;AAAA,MACvE;AAEA,MAAA,MAAM,cAAA,GAAiB,MAAM,OAAA,CAAQ,QAAA,CAAS,YAAY,CAAA;AAC1D,MAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,QAAA,MAAM,IAAIA,+BAAA,CAAc,GAAA,EAAK,EAAE,OAAA,EAAS,+CAA+C,CAAA;AAAA,MACzF;AAGA,MAAA,MAAM,QAAA,GAAW,MAAM,cAAA,CAAe,OAAA,CAAQ,iBAAiB,CAAA;AAC/D,MAAA,IAAI,CAAC,QAAA,EAAU;AACb,QAAA,MAAM,IAAIA,gCAAc,GAAA,EAAK,EAAE,SAAS,CAAA,0BAAA,EAA6B,iBAAiB,cAAc,CAAA;AAAA,MACtG;AAEA,MAAA,MAAM,cAAA,CAAe,OAAO,iBAAiB,CAAA;AAE7C,MAAA,OAAO;AAAA,QACL,OAAA,EAAS,IAAA;AAAA,QACT,OAAA,EAAS,cAAc,iBAAiB,CAAA,qBAAA;AAAA,OAC1C;AAAA,IACF,SAAS,KAAA,EAAO;AACd,MAAA,OAAOC,6BAAA,CAAY,OAAO,kCAAkC,CAAA;AAAA,IAC9D;AAAA,EACF;AACF,CAAC","file":"chunk-EETF75CE.cjs","sourcesContent":["import { HTTPException } from '../http-exception';\nimport {\n storedMCPClientIdPathParams,\n statusQuerySchema,\n listStoredMCPClientsQuerySchema,\n createStoredMCPClientBodySchema,\n updateStoredMCPClientBodySchema,\n listStoredMCPClientsResponseSchema,\n getStoredMCPClientResponseSchema,\n createStoredMCPClientResponseSchema,\n updateStoredMCPClientResponseSchema,\n deleteStoredMCPClientResponseSchema,\n} from '../schemas/stored-mcp-clients';\nimport { createRoute } from '../server-adapter/routes/route-builder';\nimport { toSlug } from '../utils';\n\nimport { handleError } from './error';\nimport { handleAutoVersioning, MCP_CLIENT_SNAPSHOT_CONFIG_FIELDS } from './version-helpers';\nimport type { VersionedStoreInterface } from './version-helpers';\n\n// ============================================================================\n// Route Definitions\n// ============================================================================\n\n/**\n * GET /stored/mcp-clients - List all stored MCP clients\n */\nexport const LIST_STORED_MCP_CLIENTS_ROUTE = createRoute({\n method: 'GET',\n path: '/stored/mcp-clients',\n responseType: 'json',\n queryParamSchema: listStoredMCPClientsQuerySchema,\n responseSchema: listStoredMCPClientsResponseSchema,\n summary: 'List stored MCP clients',\n description: 'Returns a paginated list of all MCP client configurations stored in the database',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({ mastra, page, perPage, orderBy, status, authorId, metadata }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n const result = await mcpClientStore.listResolved({\n page,\n perPage,\n orderBy,\n status,\n authorId,\n metadata,\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error listing stored MCP clients');\n }\n },\n});\n\n/**\n * GET /stored/mcp-clients/:storedMCPClientId - Get a stored MCP client by ID\n */\nexport const GET_STORED_MCP_CLIENT_ROUTE = createRoute({\n method: 'GET',\n path: '/stored/mcp-clients/:storedMCPClientId',\n responseType: 'json',\n pathParamSchema: storedMCPClientIdPathParams,\n queryParamSchema: statusQuerySchema,\n responseSchema: getStoredMCPClientResponseSchema,\n summary: 'Get stored MCP client by ID',\n description:\n 'Returns a specific MCP client from storage by its unique identifier. Use ?status=draft to resolve with the latest (draft) version, or ?status=published (default) for the active published version.',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({ mastra, storedMCPClientId, status }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n const mcpClient = await mcpClientStore.getByIdResolved(storedMCPClientId, { status });\n\n if (!mcpClient) {\n throw new HTTPException(404, { message: `Stored MCP client with id ${storedMCPClientId} not found` });\n }\n\n return mcpClient;\n } catch (error) {\n return handleError(error, 'Error getting stored MCP client');\n }\n },\n});\n\n/**\n * POST /stored/mcp-clients - Create a new stored MCP client\n */\nexport const CREATE_STORED_MCP_CLIENT_ROUTE = createRoute({\n method: 'POST',\n path: '/stored/mcp-clients',\n responseType: 'json',\n bodySchema: createStoredMCPClientBodySchema,\n responseSchema: createStoredMCPClientResponseSchema,\n summary: 'Create stored MCP client',\n description: 'Creates a new MCP client configuration in storage with the provided servers',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({ mastra, id: providedId, authorId, metadata, name, description, servers }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n // Derive ID from name if not explicitly provided\n const id = providedId || toSlug(name);\n\n if (!id) {\n throw new HTTPException(400, {\n message: 'Could not derive MCP client ID from name. Please provide an explicit id.',\n });\n }\n\n // Check if MCP client with this ID already exists\n const existing = await mcpClientStore.getById(id);\n if (existing) {\n throw new HTTPException(409, { message: `MCP client with id ${id} already exists` });\n }\n\n await mcpClientStore.create({\n mcpClient: {\n id,\n authorId,\n metadata,\n name,\n description,\n servers,\n },\n });\n\n // Return the resolved MCP client (thin record + version config)\n // Use draft status since newly created entities start as drafts\n const resolved = await mcpClientStore.getByIdResolved(id, { status: 'draft' });\n if (!resolved) {\n throw new HTTPException(500, { message: 'Failed to resolve created MCP client' });\n }\n\n return resolved;\n } catch (error) {\n return handleError(error, 'Error creating stored MCP client');\n }\n },\n});\n\n/**\n * PATCH /stored/mcp-clients/:storedMCPClientId - Update a stored MCP client\n */\nexport const UPDATE_STORED_MCP_CLIENT_ROUTE = createRoute({\n method: 'PATCH',\n path: '/stored/mcp-clients/:storedMCPClientId',\n responseType: 'json',\n pathParamSchema: storedMCPClientIdPathParams,\n bodySchema: updateStoredMCPClientBodySchema,\n responseSchema: updateStoredMCPClientResponseSchema,\n summary: 'Update stored MCP client',\n description: 'Updates an existing MCP client in storage with the provided fields',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({\n mastra,\n storedMCPClientId,\n // Metadata-level fields\n authorId,\n metadata,\n // Config fields (snapshot-level)\n name,\n description,\n servers,\n }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n // Check if MCP client exists\n const existing = await mcpClientStore.getById(storedMCPClientId);\n if (!existing) {\n throw new HTTPException(404, { message: `Stored MCP client with id ${storedMCPClientId} not found` });\n }\n\n // Update the MCP client with both metadata-level and config-level fields\n const updatedMCPClient = await mcpClientStore.update({\n id: storedMCPClientId,\n authorId,\n metadata,\n name,\n description,\n servers,\n });\n\n // Build the snapshot config for auto-versioning comparison\n const configFields = { name, description, servers };\n\n // Filter out undefined values to get only the config fields that were provided\n const providedConfigFields = Object.fromEntries(Object.entries(configFields).filter(([_, v]) => v !== undefined));\n\n // Handle auto-versioning with retry logic for race conditions\n // This creates a new version if there are meaningful config changes.\n // It does NOT update activeVersionId — the version stays as a draft until explicitly published.\n await handleAutoVersioning(\n mcpClientStore as unknown as VersionedStoreInterface,\n storedMCPClientId,\n 'mcpClientId',\n MCP_CLIENT_SNAPSHOT_CONFIG_FIELDS,\n existing,\n updatedMCPClient,\n providedConfigFields,\n );\n\n // Return the resolved MCP client with the latest (draft) version so the UI sees its edits\n const resolved = await mcpClientStore.getByIdResolved(storedMCPClientId, { status: 'draft' });\n if (!resolved) {\n throw new HTTPException(500, { message: 'Failed to resolve updated MCP client' });\n }\n\n return resolved;\n } catch (error) {\n return handleError(error, 'Error updating stored MCP client');\n }\n },\n});\n\n/**\n * DELETE /stored/mcp-clients/:storedMCPClientId - Delete a stored MCP client\n */\nexport const DELETE_STORED_MCP_CLIENT_ROUTE = createRoute({\n method: 'DELETE',\n path: '/stored/mcp-clients/:storedMCPClientId',\n responseType: 'json',\n pathParamSchema: storedMCPClientIdPathParams,\n responseSchema: deleteStoredMCPClientResponseSchema,\n summary: 'Delete stored MCP client',\n description: 'Deletes an MCP client from storage by its unique identifier',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({ mastra, storedMCPClientId }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n // Check if MCP client exists\n const existing = await mcpClientStore.getById(storedMCPClientId);\n if (!existing) {\n throw new HTTPException(404, { message: `Stored MCP client with id ${storedMCPClientId} not found` });\n }\n\n await mcpClientStore.delete(storedMCPClientId);\n\n return {\n success: true,\n message: `MCP client ${storedMCPClientId} deleted successfully`,\n };\n } catch (error) {\n return handleError(error, 'Error deleting stored MCP client');\n }\n },\n});\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/server/handlers/stored-mcp-clients.ts"],"names":["createRoute","listStoredMCPClientsQuerySchema","listStoredMCPClientsResponseSchema","HTTPException","handleError","storedMCPClientIdPathParams","statusQuerySchema","getStoredMCPClientResponseSchema","createStoredMCPClientBodySchema","createStoredMCPClientResponseSchema","toSlug","updateStoredMCPClientBodySchema","updateStoredMCPClientResponseSchema","handleAutoVersioning","MCP_CLIENT_SNAPSHOT_CONFIG_FIELDS","deleteStoredMCPClientResponseSchema"],"mappings":"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","file":"chunk-NHJFLZZN.cjs","sourcesContent":["import { HTTPException } from '../http-exception';\nimport {\n storedMCPClientIdPathParams,\n statusQuerySchema,\n listStoredMCPClientsQuerySchema,\n createStoredMCPClientBodySchema,\n updateStoredMCPClientBodySchema,\n listStoredMCPClientsResponseSchema,\n getStoredMCPClientResponseSchema,\n createStoredMCPClientResponseSchema,\n updateStoredMCPClientResponseSchema,\n deleteStoredMCPClientResponseSchema,\n} from '../schemas/stored-mcp-clients';\nimport { createRoute } from '../server-adapter/routes/route-builder';\nimport { toSlug } from '../utils';\n\nimport { handleError } from './error';\nimport { handleAutoVersioning, MCP_CLIENT_SNAPSHOT_CONFIG_FIELDS } from './version-helpers';\nimport type { VersionedStoreInterface } from './version-helpers';\n\n// ============================================================================\n// Route Definitions\n// ============================================================================\n\n/**\n * GET /stored/mcp-clients - List all stored MCP clients\n */\nexport const LIST_STORED_MCP_CLIENTS_ROUTE = createRoute({\n method: 'GET',\n path: '/stored/mcp-clients',\n responseType: 'json',\n queryParamSchema: listStoredMCPClientsQuerySchema,\n responseSchema: listStoredMCPClientsResponseSchema,\n summary: 'List stored MCP clients',\n description: 'Returns a paginated list of all MCP client configurations stored in the database',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({ mastra, page, perPage, orderBy, status, authorId, metadata }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n const result = await mcpClientStore.listResolved({\n page,\n perPage,\n orderBy,\n status,\n authorId,\n metadata,\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error listing stored MCP clients');\n }\n },\n});\n\n/**\n * GET /stored/mcp-clients/:storedMCPClientId - Get a stored MCP client by ID\n */\nexport const GET_STORED_MCP_CLIENT_ROUTE = createRoute({\n method: 'GET',\n path: '/stored/mcp-clients/:storedMCPClientId',\n responseType: 'json',\n pathParamSchema: storedMCPClientIdPathParams,\n queryParamSchema: statusQuerySchema,\n responseSchema: getStoredMCPClientResponseSchema,\n summary: 'Get stored MCP client by ID',\n description:\n 'Returns a specific MCP client from storage by its unique identifier. Use ?status=draft to resolve with the latest (draft) version, or ?status=published (default) for the active published version.',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({ mastra, storedMCPClientId, status }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n const mcpClient = await mcpClientStore.getByIdResolved(storedMCPClientId, { status });\n\n if (!mcpClient) {\n throw new HTTPException(404, { message: `Stored MCP client with id ${storedMCPClientId} not found` });\n }\n\n return mcpClient;\n } catch (error) {\n return handleError(error, 'Error getting stored MCP client');\n }\n },\n});\n\n/**\n * POST /stored/mcp-clients - Create a new stored MCP client\n */\nexport const CREATE_STORED_MCP_CLIENT_ROUTE = createRoute({\n method: 'POST',\n path: '/stored/mcp-clients',\n responseType: 'json',\n bodySchema: createStoredMCPClientBodySchema,\n responseSchema: createStoredMCPClientResponseSchema,\n summary: 'Create stored MCP client',\n description: 'Creates a new MCP client configuration in storage with the provided servers',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({ mastra, id: providedId, authorId, metadata, name, description, servers }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n // Derive ID from name if not explicitly provided\n const id = providedId || toSlug(name);\n\n if (!id) {\n throw new HTTPException(400, {\n message: 'Could not derive MCP client ID from name. Please provide an explicit id.',\n });\n }\n\n // Check if MCP client with this ID already exists\n const existing = await mcpClientStore.getById(id);\n if (existing) {\n throw new HTTPException(409, { message: `MCP client with id ${id} already exists` });\n }\n\n await mcpClientStore.create({\n mcpClient: {\n id,\n authorId,\n metadata,\n name,\n description,\n servers,\n },\n });\n\n // Return the resolved MCP client (thin record + version config)\n // Use draft status since newly created entities start as drafts\n const resolved = await mcpClientStore.getByIdResolved(id, { status: 'draft' });\n if (!resolved) {\n throw new HTTPException(500, { message: 'Failed to resolve created MCP client' });\n }\n\n return resolved;\n } catch (error) {\n return handleError(error, 'Error creating stored MCP client');\n }\n },\n});\n\n/**\n * PATCH /stored/mcp-clients/:storedMCPClientId - Update a stored MCP client\n */\nexport const UPDATE_STORED_MCP_CLIENT_ROUTE = createRoute({\n method: 'PATCH',\n path: '/stored/mcp-clients/:storedMCPClientId',\n responseType: 'json',\n pathParamSchema: storedMCPClientIdPathParams,\n bodySchema: updateStoredMCPClientBodySchema,\n responseSchema: updateStoredMCPClientResponseSchema,\n summary: 'Update stored MCP client',\n description: 'Updates an existing MCP client in storage with the provided fields',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({\n mastra,\n storedMCPClientId,\n // Metadata-level fields\n authorId,\n metadata,\n // Config fields (snapshot-level)\n name,\n description,\n servers,\n }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n // Check if MCP client exists\n const existing = await mcpClientStore.getById(storedMCPClientId);\n if (!existing) {\n throw new HTTPException(404, { message: `Stored MCP client with id ${storedMCPClientId} not found` });\n }\n\n // Update the MCP client with both metadata-level and config-level fields\n const updatedMCPClient = await mcpClientStore.update({\n id: storedMCPClientId,\n authorId,\n metadata,\n name,\n description,\n servers,\n });\n\n // Build the snapshot config for auto-versioning comparison\n const configFields = { name, description, servers };\n\n // Filter out undefined values to get only the config fields that were provided\n const providedConfigFields = Object.fromEntries(Object.entries(configFields).filter(([_, v]) => v !== undefined));\n\n // Handle auto-versioning with retry logic for race conditions\n // This creates a new version if there are meaningful config changes.\n // It does NOT update activeVersionId — the version stays as a draft until explicitly published.\n await handleAutoVersioning(\n mcpClientStore as unknown as VersionedStoreInterface,\n storedMCPClientId,\n 'mcpClientId',\n MCP_CLIENT_SNAPSHOT_CONFIG_FIELDS,\n existing,\n updatedMCPClient,\n providedConfigFields,\n );\n\n // Return the resolved MCP client with the latest (draft) version so the UI sees its edits\n const resolved = await mcpClientStore.getByIdResolved(storedMCPClientId, { status: 'draft' });\n if (!resolved) {\n throw new HTTPException(500, { message: 'Failed to resolve updated MCP client' });\n }\n\n return resolved;\n } catch (error) {\n return handleError(error, 'Error updating stored MCP client');\n }\n },\n});\n\n/**\n * DELETE /stored/mcp-clients/:storedMCPClientId - Delete a stored MCP client\n */\nexport const DELETE_STORED_MCP_CLIENT_ROUTE = createRoute({\n method: 'DELETE',\n path: '/stored/mcp-clients/:storedMCPClientId',\n responseType: 'json',\n pathParamSchema: storedMCPClientIdPathParams,\n responseSchema: deleteStoredMCPClientResponseSchema,\n summary: 'Delete stored MCP client',\n description: 'Deletes an MCP client from storage by its unique identifier',\n tags: ['Stored MCP Clients'],\n requiresAuth: true,\n handler: async ({ mastra, storedMCPClientId }) => {\n try {\n const storage = mastra.getStorage();\n\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not configured' });\n }\n\n const mcpClientStore = await storage.getStore('mcpClients');\n if (!mcpClientStore) {\n throw new HTTPException(500, { message: 'MCP clients storage domain is not available' });\n }\n\n // Check if MCP client exists\n const existing = await mcpClientStore.getById(storedMCPClientId);\n if (!existing) {\n throw new HTTPException(404, { message: `Stored MCP client with id ${storedMCPClientId} not found` });\n }\n\n await mcpClientStore.delete(storedMCPClientId);\n\n return {\n success: true,\n message: `MCP client ${storedMCPClientId} deleted successfully`,\n };\n } catch (error) {\n return handleError(error, 'Error deleting stored MCP client');\n }\n },\n});\n"]}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var chunkHXICAUTW_cjs = require('./chunk-HXICAUTW.cjs');
|
|
4
|
+
var chunkWYLVJSGR_cjs = require('./chunk-WYLVJSGR.cjs');
|
|
4
5
|
var chunkGUWIV3ZN_cjs = require('./chunk-GUWIV3ZN.cjs');
|
|
5
6
|
var chunkYJQYJ5WD_cjs = require('./chunk-YJQYJ5WD.cjs');
|
|
6
|
-
var
|
|
7
|
-
var chunkEFW6MWXU_cjs = require('./chunk-EFW6MWXU.cjs');
|
|
8
|
-
var chunkWYLVJSGR_cjs = require('./chunk-WYLVJSGR.cjs');
|
|
7
|
+
var chunk3S5WOAYR_cjs = require('./chunk-3S5WOAYR.cjs');
|
|
9
8
|
var chunk5UKYK7YK_cjs = require('./chunk-5UKYK7YK.cjs');
|
|
10
9
|
var chunkB34S64RC_cjs = require('./chunk-B34S64RC.cjs');
|
|
11
10
|
var chunk64ITUOXI_cjs = require('./chunk-64ITUOXI.cjs');
|
|
11
|
+
var chunkEFW6MWXU_cjs = require('./chunk-EFW6MWXU.cjs');
|
|
12
12
|
var chunkO7I5CWRX_cjs = require('./chunk-O7I5CWRX.cjs');
|
|
13
13
|
var agent = require('@mastra/core/agent');
|
|
14
14
|
var durable = require('@mastra/core/agent/durable');
|
|
@@ -767,9 +767,9 @@ var GENERATE_AGENT_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
767
767
|
requiresPermission: "agents:execute",
|
|
768
768
|
handler: async ({ agentId, mastra, abortSignal, requestContext: serverRequestContext, ...params }) => {
|
|
769
769
|
try {
|
|
770
|
-
|
|
770
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
771
771
|
const { messages, memory: memoryOption, requestContext: bodyRequestContext, versions, ...rest } = params;
|
|
772
|
-
|
|
772
|
+
chunk3S5WOAYR_cjs.validateBody({ messages });
|
|
773
773
|
const agent = await getAgentFromSystem({
|
|
774
774
|
mastra,
|
|
775
775
|
agentId,
|
|
@@ -790,13 +790,13 @@ var GENERATE_AGENT_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
790
790
|
let authorizedMemoryOption = memoryOption;
|
|
791
791
|
if (memoryOption) {
|
|
792
792
|
const clientThreadId = typeof memoryOption.thread === "string" ? memoryOption.thread : memoryOption.thread?.id;
|
|
793
|
-
const effectiveResourceId =
|
|
794
|
-
const effectiveThreadId =
|
|
793
|
+
const effectiveResourceId = chunk3S5WOAYR_cjs.getEffectiveResourceId(serverRequestContext, memoryOption.resource);
|
|
794
|
+
const effectiveThreadId = chunk3S5WOAYR_cjs.getEffectiveThreadId(serverRequestContext, clientThreadId);
|
|
795
795
|
if (effectiveThreadId && effectiveResourceId) {
|
|
796
796
|
const memoryInstance = await agent.getMemory({ requestContext: serverRequestContext });
|
|
797
797
|
if (memoryInstance) {
|
|
798
798
|
const thread = await memoryInstance.getThreadById({ threadId: effectiveThreadId });
|
|
799
|
-
await
|
|
799
|
+
await chunk3S5WOAYR_cjs.validateThreadOwnership(thread, effectiveResourceId);
|
|
800
800
|
}
|
|
801
801
|
}
|
|
802
802
|
authorizedMemoryOption = {
|
|
@@ -838,12 +838,12 @@ var GENERATE_LEGACY_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
838
838
|
versionOptions: extractVersionOptions(requestContext),
|
|
839
839
|
requestContext
|
|
840
840
|
});
|
|
841
|
-
|
|
841
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
842
842
|
const { messages, resourceId, resourceid, threadId, ...rest } = params;
|
|
843
843
|
const clientResourceId = resourceId ?? resourceid;
|
|
844
|
-
const effectiveResourceId =
|
|
845
|
-
const effectiveThreadId =
|
|
846
|
-
|
|
844
|
+
const effectiveResourceId = chunk3S5WOAYR_cjs.getEffectiveResourceId(requestContext, clientResourceId);
|
|
845
|
+
const effectiveThreadId = chunk3S5WOAYR_cjs.getEffectiveThreadId(requestContext, threadId);
|
|
846
|
+
chunk3S5WOAYR_cjs.validateBody({ messages });
|
|
847
847
|
if (effectiveThreadId && !effectiveResourceId || !effectiveThreadId && effectiveResourceId) {
|
|
848
848
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Both threadId or resourceId must be provided" });
|
|
849
849
|
}
|
|
@@ -851,7 +851,7 @@ var GENERATE_LEGACY_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
851
851
|
const memory = await agent.getMemory({ requestContext });
|
|
852
852
|
if (memory) {
|
|
853
853
|
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
854
|
-
await
|
|
854
|
+
await chunk3S5WOAYR_cjs.validateThreadOwnership(thread, effectiveResourceId);
|
|
855
855
|
}
|
|
856
856
|
}
|
|
857
857
|
const result = await agent.generateLegacy(messages, {
|
|
@@ -885,12 +885,12 @@ var STREAM_GENERATE_LEGACY_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
885
885
|
versionOptions: extractVersionOptions(requestContext),
|
|
886
886
|
requestContext
|
|
887
887
|
});
|
|
888
|
-
|
|
888
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
889
889
|
const { messages, resourceId, resourceid, threadId, ...rest } = params;
|
|
890
890
|
const clientResourceId = resourceId ?? resourceid;
|
|
891
|
-
const effectiveResourceId =
|
|
892
|
-
const effectiveThreadId =
|
|
893
|
-
|
|
891
|
+
const effectiveResourceId = chunk3S5WOAYR_cjs.getEffectiveResourceId(requestContext, clientResourceId);
|
|
892
|
+
const effectiveThreadId = chunk3S5WOAYR_cjs.getEffectiveThreadId(requestContext, threadId);
|
|
893
|
+
chunk3S5WOAYR_cjs.validateBody({ messages });
|
|
894
894
|
if (effectiveThreadId && !effectiveResourceId || !effectiveThreadId && effectiveResourceId) {
|
|
895
895
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Both threadId or resourceId must be provided" });
|
|
896
896
|
}
|
|
@@ -898,7 +898,7 @@ var STREAM_GENERATE_LEGACY_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
898
898
|
const memory = await agent.getMemory({ requestContext });
|
|
899
899
|
if (memory) {
|
|
900
900
|
const thread = await memory.getThreadById({ threadId: effectiveThreadId });
|
|
901
|
-
await
|
|
901
|
+
await chunk3S5WOAYR_cjs.validateThreadOwnership(thread, effectiveResourceId);
|
|
902
902
|
}
|
|
903
903
|
}
|
|
904
904
|
const streamResult = await agent.streamLegacy(messages, {
|
|
@@ -998,9 +998,9 @@ var STREAM_GENERATE_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
998
998
|
requiresPermission: "agents:execute",
|
|
999
999
|
handler: async ({ mastra, agentId, abortSignal, requestContext: serverRequestContext, ...params }) => {
|
|
1000
1000
|
try {
|
|
1001
|
-
|
|
1001
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1002
1002
|
const { messages, memory: memoryOption, requestContext: bodyRequestContext, versions, ...rest } = params;
|
|
1003
|
-
|
|
1003
|
+
chunk3S5WOAYR_cjs.validateBody({ messages });
|
|
1004
1004
|
const agent = await getAgentFromSystem({
|
|
1005
1005
|
mastra,
|
|
1006
1006
|
agentId,
|
|
@@ -1021,13 +1021,13 @@ var STREAM_GENERATE_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1021
1021
|
let authorizedMemoryOption = memoryOption;
|
|
1022
1022
|
if (memoryOption) {
|
|
1023
1023
|
const clientThreadId = typeof memoryOption.thread === "string" ? memoryOption.thread : memoryOption.thread?.id;
|
|
1024
|
-
const effectiveResourceId =
|
|
1025
|
-
const effectiveThreadId =
|
|
1024
|
+
const effectiveResourceId = chunk3S5WOAYR_cjs.getEffectiveResourceId(serverRequestContext, memoryOption.resource);
|
|
1025
|
+
const effectiveThreadId = chunk3S5WOAYR_cjs.getEffectiveThreadId(serverRequestContext, clientThreadId);
|
|
1026
1026
|
if (effectiveThreadId && effectiveResourceId) {
|
|
1027
1027
|
const memoryInstance = await agent.getMemory({ requestContext: serverRequestContext });
|
|
1028
1028
|
if (memoryInstance) {
|
|
1029
1029
|
const thread = await memoryInstance.getThreadById({ threadId: effectiveThreadId });
|
|
1030
|
-
await
|
|
1030
|
+
await chunk3S5WOAYR_cjs.validateThreadOwnership(thread, effectiveResourceId);
|
|
1031
1031
|
}
|
|
1032
1032
|
}
|
|
1033
1033
|
authorizedMemoryOption = {
|
|
@@ -1065,9 +1065,9 @@ var STREAM_UNTIL_IDLE_GENERATE_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1065
1065
|
requiresPermission: "agents:execute",
|
|
1066
1066
|
handler: async ({ mastra, agentId, abortSignal, requestContext: serverRequestContext, ...params }) => {
|
|
1067
1067
|
try {
|
|
1068
|
-
|
|
1068
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1069
1069
|
const { messages, memory: memoryOption, requestContext: bodyRequestContext, ...rest } = params;
|
|
1070
|
-
|
|
1070
|
+
chunk3S5WOAYR_cjs.validateBody({ messages });
|
|
1071
1071
|
const agent = await getAgentFromSystem({
|
|
1072
1072
|
mastra,
|
|
1073
1073
|
agentId,
|
|
@@ -1087,13 +1087,13 @@ var STREAM_UNTIL_IDLE_GENERATE_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1087
1087
|
let authorizedMemoryOption = memoryOption;
|
|
1088
1088
|
if (memoryOption) {
|
|
1089
1089
|
const clientThreadId = typeof memoryOption.thread === "string" ? memoryOption.thread : memoryOption.thread?.id;
|
|
1090
|
-
const effectiveResourceId =
|
|
1091
|
-
const effectiveThreadId =
|
|
1090
|
+
const effectiveResourceId = chunk3S5WOAYR_cjs.getEffectiveResourceId(serverRequestContext, memoryOption.resource);
|
|
1091
|
+
const effectiveThreadId = chunk3S5WOAYR_cjs.getEffectiveThreadId(serverRequestContext, clientThreadId);
|
|
1092
1092
|
if (effectiveThreadId && effectiveResourceId) {
|
|
1093
1093
|
const memoryInstance = await agent.getMemory({ requestContext: serverRequestContext });
|
|
1094
1094
|
if (memoryInstance) {
|
|
1095
1095
|
const thread = await memoryInstance.getThreadById({ threadId: effectiveThreadId });
|
|
1096
|
-
await
|
|
1096
|
+
await chunk3S5WOAYR_cjs.validateThreadOwnership(thread, effectiveResourceId);
|
|
1097
1097
|
}
|
|
1098
1098
|
}
|
|
1099
1099
|
authorizedMemoryOption = {
|
|
@@ -1242,7 +1242,7 @@ var APPROVE_TOOL_CALL_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1242
1242
|
if (!params.toolCallId) {
|
|
1243
1243
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Tool call id is required" });
|
|
1244
1244
|
}
|
|
1245
|
-
|
|
1245
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1246
1246
|
const streamResult = await agent.approveToolCall({
|
|
1247
1247
|
...params,
|
|
1248
1248
|
requestContext,
|
|
@@ -1279,7 +1279,7 @@ var DECLINE_TOOL_CALL_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1279
1279
|
if (!params.toolCallId) {
|
|
1280
1280
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Tool call id is required" });
|
|
1281
1281
|
}
|
|
1282
|
-
|
|
1282
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1283
1283
|
const streamResult = await agent.declineToolCall({
|
|
1284
1284
|
...params,
|
|
1285
1285
|
requestContext,
|
|
@@ -1309,7 +1309,7 @@ var RESUME_STREAM_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1309
1309
|
if (!params.runId) {
|
|
1310
1310
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Run id is required" });
|
|
1311
1311
|
}
|
|
1312
|
-
|
|
1312
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1313
1313
|
const {
|
|
1314
1314
|
resumeData,
|
|
1315
1315
|
runId,
|
|
@@ -1337,13 +1337,13 @@ var RESUME_STREAM_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1337
1337
|
stashVersionOverrides(serverRequestContext, versions);
|
|
1338
1338
|
let authorizedMemoryOption = memoryOption;
|
|
1339
1339
|
const clientThreadId = typeof memoryOption?.thread === "string" ? memoryOption.thread : memoryOption?.thread?.id;
|
|
1340
|
-
const effectiveResourceId =
|
|
1341
|
-
const effectiveThreadId =
|
|
1340
|
+
const effectiveResourceId = chunk3S5WOAYR_cjs.getEffectiveResourceId(serverRequestContext, memoryOption?.resource);
|
|
1341
|
+
const effectiveThreadId = chunk3S5WOAYR_cjs.getEffectiveThreadId(serverRequestContext, clientThreadId);
|
|
1342
1342
|
if (effectiveThreadId && effectiveResourceId) {
|
|
1343
1343
|
const memoryInstance = await agent.getMemory({ requestContext: serverRequestContext });
|
|
1344
1344
|
if (memoryInstance) {
|
|
1345
1345
|
const thread = await memoryInstance.getThreadById({ threadId: effectiveThreadId });
|
|
1346
|
-
await
|
|
1346
|
+
await chunk3S5WOAYR_cjs.validateThreadOwnership(thread, effectiveResourceId);
|
|
1347
1347
|
}
|
|
1348
1348
|
}
|
|
1349
1349
|
if (memoryOption || effectiveResourceId || effectiveThreadId) {
|
|
@@ -1355,7 +1355,7 @@ var RESUME_STREAM_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1355
1355
|
}
|
|
1356
1356
|
const workflowsStore = await mastra.getStorage()?.getStore("workflows");
|
|
1357
1357
|
const workflowRun = await workflowsStore?.getWorkflowRunById({ workflowName: "agentic-loop", runId });
|
|
1358
|
-
await
|
|
1358
|
+
await chunk3S5WOAYR_cjs.validateRunOwnership(workflowRun, chunk3S5WOAYR_cjs.getEffectiveResourceId(serverRequestContext, void 0));
|
|
1359
1359
|
const { structuredOutput, ...restOptions } = rest;
|
|
1360
1360
|
const options = {
|
|
1361
1361
|
runId,
|
|
@@ -1396,7 +1396,7 @@ var APPROVE_TOOL_CALL_GENERATE_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1396
1396
|
if (!params.toolCallId) {
|
|
1397
1397
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Tool call id is required" });
|
|
1398
1398
|
}
|
|
1399
|
-
|
|
1399
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1400
1400
|
const result = await agent.approveToolCallGenerate({
|
|
1401
1401
|
...params,
|
|
1402
1402
|
requestContext,
|
|
@@ -1432,7 +1432,7 @@ var DECLINE_TOOL_CALL_GENERATE_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1432
1432
|
if (!params.toolCallId) {
|
|
1433
1433
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Tool call id is required" });
|
|
1434
1434
|
}
|
|
1435
|
-
|
|
1435
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1436
1436
|
const result = await agent.declineToolCallGenerate({
|
|
1437
1437
|
...params,
|
|
1438
1438
|
requestContext,
|
|
@@ -1463,8 +1463,8 @@ var STREAM_NETWORK_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1463
1463
|
agentId,
|
|
1464
1464
|
versionOptions: extractVersionOptions(requestContext)
|
|
1465
1465
|
});
|
|
1466
|
-
|
|
1467
|
-
|
|
1466
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1467
|
+
chunk3S5WOAYR_cjs.validateBody({ messages });
|
|
1468
1468
|
const streamResult = await agent.network(messages, {
|
|
1469
1469
|
...params
|
|
1470
1470
|
});
|
|
@@ -1496,7 +1496,7 @@ var APPROVE_NETWORK_TOOL_CALL_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1496
1496
|
if (!params.runId) {
|
|
1497
1497
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Run id is required" });
|
|
1498
1498
|
}
|
|
1499
|
-
|
|
1499
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1500
1500
|
const streamResult = await agent.approveNetworkToolCall({
|
|
1501
1501
|
...params
|
|
1502
1502
|
});
|
|
@@ -1528,7 +1528,7 @@ var DECLINE_NETWORK_TOOL_CALL_ROUTE = chunk5UKYK7YK_cjs.createRoute({
|
|
|
1528
1528
|
if (!params.runId) {
|
|
1529
1529
|
throw new chunk64ITUOXI_cjs.HTTPException(400, { message: "Run id is required" });
|
|
1530
1530
|
}
|
|
1531
|
-
|
|
1531
|
+
chunk3S5WOAYR_cjs.sanitizeBody(params, ["tools"]);
|
|
1532
1532
|
const streamResult = await agent.declineNetworkToolCall({
|
|
1533
1533
|
...params
|
|
1534
1534
|
});
|
|
@@ -1887,5 +1887,5 @@ exports.getSerializedProcessors = getSerializedProcessors;
|
|
|
1887
1887
|
exports.getSerializedSkillsFromAgent = getSerializedSkillsFromAgent;
|
|
1888
1888
|
exports.getWorkspaceToolsFromAgent = getWorkspaceToolsFromAgent;
|
|
1889
1889
|
exports.isProviderConnected = isProviderConnected;
|
|
1890
|
-
//# sourceMappingURL=chunk-
|
|
1891
|
-
//# sourceMappingURL=chunk-
|
|
1890
|
+
//# sourceMappingURL=chunk-O6YA7VM3.cjs.map
|
|
1891
|
+
//# sourceMappingURL=chunk-O6YA7VM3.cjs.map
|