@mastra/server 0.0.0-playground-studio-cloud-20251031080052 → 0.0.0-playground-studio-again-20251114102707
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 +685 -3
- package/README.md +1 -1
- package/dist/{chunk-7HCPO76Z.js → chunk-2IS5WICF.js} +4505 -1017
- package/dist/chunk-2IS5WICF.js.map +1 -0
- package/dist/{chunk-SPRRK3P7.cjs → chunk-2YZH5PH6.cjs} +47 -47
- package/dist/chunk-2YZH5PH6.cjs.map +1 -0
- package/dist/{chunk-BATEJLED.js → chunk-3AMNUUZF.js} +20 -20
- package/dist/chunk-3AMNUUZF.js.map +1 -0
- package/dist/{chunk-AW5BU3RQ.js → chunk-3F52QCI4.js} +40 -40
- package/dist/chunk-3F52QCI4.js.map +1 -0
- package/dist/{chunk-7NADHFD2.cjs → chunk-64ITUOXI.cjs} +2 -2
- package/dist/chunk-64ITUOXI.cjs.map +1 -0
- package/dist/{chunk-MMROOK5J.js → chunk-6QWQZI4Q.js} +2 -2
- package/dist/{chunk-7NADHFD2.cjs.map → chunk-6QWQZI4Q.js.map} +1 -1
- package/dist/{chunk-ABRFV4XP.js → chunk-73PAWDM5.js} +13 -13
- package/dist/chunk-73PAWDM5.js.map +1 -0
- package/dist/{chunk-2S4IMB6E.cjs → chunk-A24TSVEZ.cjs} +39 -39
- package/dist/chunk-A24TSVEZ.cjs.map +1 -0
- package/dist/{chunk-QQXMIP6C.js → chunk-B3Z6J745.js} +17 -17
- package/dist/chunk-B3Z6J745.js.map +1 -0
- package/dist/{chunk-G4PUALCE.cjs → chunk-BTWIR2B7.cjs} +4 -4
- package/dist/{chunk-G4PUALCE.cjs.map → chunk-BTWIR2B7.cjs.map} +1 -1
- package/dist/{chunk-KSFLUEWV.js → chunk-D7T74TVR.js} +4 -5
- package/dist/chunk-D7T74TVR.js.map +1 -0
- package/dist/{chunk-YSHNCC6F.cjs → chunk-EHACNWDL.cjs} +169 -201
- package/dist/chunk-EHACNWDL.cjs.map +1 -0
- package/dist/{chunk-MN2TZQ7I.js → chunk-FPBYKMIS.js} +13 -13
- package/dist/chunk-FPBYKMIS.js.map +1 -0
- package/dist/{chunk-3SNGNFUJ.cjs → chunk-GLAZTMX3.cjs} +37 -37
- package/dist/chunk-GLAZTMX3.cjs.map +1 -0
- package/dist/{chunk-KDUHLUK4.cjs → chunk-ID6JYDNL.cjs} +4387 -896
- package/dist/chunk-ID6JYDNL.cjs.map +1 -0
- package/dist/{chunk-TRGAMKHX.cjs → chunk-KF3RI45U.cjs} +46 -41
- package/dist/chunk-KF3RI45U.cjs.map +1 -0
- package/dist/{chunk-K5T5A3AL.cjs → chunk-KJIDZQRA.cjs} +14 -14
- package/dist/chunk-KJIDZQRA.cjs.map +1 -0
- package/dist/{chunk-MYR4PVGN.js → chunk-KWH5QBXP.js} +4 -4
- package/dist/{chunk-MYR4PVGN.js.map → chunk-KWH5QBXP.js.map} +1 -1
- package/dist/{chunk-AHB4JCIQ.js → chunk-ND5OKOMT.js} +31 -26
- package/dist/chunk-ND5OKOMT.js.map +1 -0
- package/dist/{chunk-XN74I6VW.cjs → chunk-PPMIB3FQ.cjs} +20 -20
- package/dist/chunk-PPMIB3FQ.cjs.map +1 -0
- package/dist/{chunk-EP3JQDPD.cjs → chunk-S54HNARD.cjs} +18 -18
- package/dist/{chunk-EP3JQDPD.cjs.map → chunk-S54HNARD.cjs.map} +1 -1
- package/dist/{chunk-4QCXUEAT.js → chunk-SZIFSF4T.js} +3 -3
- package/dist/{chunk-4QCXUEAT.js.map → chunk-SZIFSF4T.js.map} +1 -1
- package/dist/{chunk-Y7SH5ZKM.cjs → chunk-U7GLIXYO.cjs} +157 -172
- package/dist/chunk-U7GLIXYO.cjs.map +1 -0
- package/dist/{chunk-CY4TP3FK.js → chunk-UXGQZUYZ.js} +3 -3
- package/dist/{chunk-CY4TP3FK.js.map → chunk-UXGQZUYZ.js.map} +1 -1
- package/dist/{chunk-RE4RPXT2.cjs → chunk-V5WWQN7P.cjs} +4 -4
- package/dist/{chunk-RE4RPXT2.cjs.map → chunk-V5WWQN7P.cjs.map} +1 -1
- package/dist/{chunk-OGK26QPW.js → chunk-V6JYJS7O.js} +109 -123
- package/dist/chunk-V6JYJS7O.js.map +1 -0
- package/dist/{chunk-CJFKRVED.cjs → chunk-W2KMU354.cjs} +4 -5
- package/dist/chunk-W2KMU354.cjs.map +1 -0
- package/dist/{chunk-B7QWVGQQ.cjs → chunk-X3MICMI2.cjs} +140 -249
- package/dist/chunk-X3MICMI2.cjs.map +1 -0
- package/dist/{chunk-6VPAV4ZV.js → chunk-Z2O5YVHY.js} +134 -165
- package/dist/chunk-Z2O5YVHY.js.map +1 -0
- package/dist/{chunk-ZLBL4NQC.js → chunk-ZJ6KEY6H.js} +67 -174
- package/dist/chunk-ZJ6KEY6H.js.map +1 -0
- package/dist/server/handlers/a2a.cjs +7 -7
- package/dist/server/handlers/a2a.d.ts +10 -10
- package/dist/server/handlers/a2a.d.ts.map +1 -1
- package/dist/server/handlers/a2a.js +1 -1
- package/dist/server/handlers/agent-builder.cjs +31 -19
- package/dist/server/handlers/agent-builder.d.ts +38 -47
- package/dist/server/handlers/agent-builder.d.ts.map +1 -1
- package/dist/server/handlers/agent-builder.js +1 -1
- package/dist/server/handlers/agents.cjs +25 -29
- package/dist/server/handlers/agents.d.ts +41 -55
- package/dist/server/handlers/agents.d.ts.map +1 -1
- package/dist/server/handlers/agents.js +1 -1
- package/dist/server/handlers/error.cjs +2 -2
- package/dist/server/handlers/error.js +1 -1
- package/dist/server/handlers/logs.cjs +7 -7
- package/dist/server/handlers/logs.d.ts +3 -3
- package/dist/server/handlers/logs.d.ts.map +1 -1
- package/dist/server/handlers/logs.js +1 -1
- package/dist/server/handlers/memory.cjs +19 -23
- package/dist/server/handlers/memory.d.ts +30 -35
- package/dist/server/handlers/memory.d.ts.map +1 -1
- package/dist/server/handlers/memory.js +1 -1
- package/dist/server/handlers/observability.cjs +8 -8
- package/dist/server/handlers/observability.d.ts +12 -12
- package/dist/server/handlers/observability.d.ts.map +1 -1
- package/dist/server/handlers/observability.js +1 -1
- package/dist/server/handlers/scores.cjs +11 -11
- package/dist/server/handlers/scores.d.ts +24 -24
- package/dist/server/handlers/scores.d.ts.map +1 -1
- package/dist/server/handlers/scores.js +1 -1
- package/dist/server/handlers/tools.cjs +7 -7
- package/dist/server/handlers/tools.d.ts +8 -8
- package/dist/server/handlers/tools.d.ts.map +1 -1
- package/dist/server/handlers/tools.js +1 -1
- package/dist/server/handlers/utils.cjs +3 -3
- package/dist/server/handlers/utils.js +1 -1
- package/dist/server/handlers/vector.cjs +7 -7
- package/dist/server/handlers/vector.js +1 -1
- package/dist/server/handlers/voice.cjs +5 -5
- package/dist/server/handlers/voice.d.ts +6 -6
- package/dist/server/handlers/voice.js +1 -1
- package/dist/server/handlers/workflows.cjs +21 -29
- package/dist/server/handlers/workflows.d.ts +27 -36
- package/dist/server/handlers/workflows.d.ts.map +1 -1
- package/dist/server/handlers/workflows.js +1 -1
- package/dist/server/handlers.cjs +23 -28
- package/dist/server/handlers.d.ts +0 -1
- package/dist/server/handlers.d.ts.map +1 -1
- package/dist/server/handlers.js +11 -12
- package/dist/server/http-exception.d.ts +0 -5
- package/dist/server/http-exception.d.ts.map +1 -1
- package/dist/server/utils.d.ts +3 -2
- package/dist/server/utils.d.ts.map +1 -1
- package/package.json +13 -8
- package/dist/chunk-2S4IMB6E.cjs.map +0 -1
- package/dist/chunk-3SNGNFUJ.cjs.map +0 -1
- package/dist/chunk-6VPAV4ZV.js.map +0 -1
- package/dist/chunk-7HCPO76Z.js.map +0 -1
- package/dist/chunk-ABRFV4XP.js.map +0 -1
- package/dist/chunk-AHB4JCIQ.js.map +0 -1
- package/dist/chunk-AW5BU3RQ.js.map +0 -1
- package/dist/chunk-B7QWVGQQ.cjs.map +0 -1
- package/dist/chunk-BATEJLED.js.map +0 -1
- package/dist/chunk-CJFKRVED.cjs.map +0 -1
- package/dist/chunk-I3C4ODGV.cjs +0 -335
- package/dist/chunk-I3C4ODGV.cjs.map +0 -1
- package/dist/chunk-K5T5A3AL.cjs.map +0 -1
- package/dist/chunk-KDUHLUK4.cjs.map +0 -1
- package/dist/chunk-KSFLUEWV.js.map +0 -1
- package/dist/chunk-LLUOPR3J.js +0 -323
- package/dist/chunk-LLUOPR3J.js.map +0 -1
- package/dist/chunk-MMROOK5J.js.map +0 -1
- package/dist/chunk-MN2TZQ7I.js.map +0 -1
- package/dist/chunk-OGK26QPW.js.map +0 -1
- package/dist/chunk-QQXMIP6C.js.map +0 -1
- package/dist/chunk-SPRRK3P7.cjs.map +0 -1
- package/dist/chunk-TRGAMKHX.cjs.map +0 -1
- package/dist/chunk-XN74I6VW.cjs.map +0 -1
- package/dist/chunk-Y7SH5ZKM.cjs.map +0 -1
- package/dist/chunk-YSHNCC6F.cjs.map +0 -1
- package/dist/chunk-ZLBL4NQC.js.map +0 -1
- package/dist/server/handlers/legacyWorkflows.cjs +0 -48
- package/dist/server/handlers/legacyWorkflows.cjs.map +0 -1
- package/dist/server/handlers/legacyWorkflows.d.ts +0 -59
- package/dist/server/handlers/legacyWorkflows.d.ts.map +0 -1
- package/dist/server/handlers/legacyWorkflows.js +0 -3
- package/dist/server/handlers/legacyWorkflows.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/server/handlers/agents.ts"],"names":["agent","acc","key"],"mappings":"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","file":"chunk-Z2O5YVHY.js","sourcesContent":["import type { Agent, AgentModelManagerConfig } from '@mastra/core/agent';\nimport { ErrorCategory, ErrorDomain, MastraError } from '@mastra/core/error';\nimport { PROVIDER_REGISTRY } from '@mastra/core/llm';\nimport type { SystemMessage } from '@mastra/core/llm';\nimport type { InputProcessor, OutputProcessor } from '@mastra/core/processors';\nimport { RequestContext } from '@mastra/core/request-context';\nimport { zodToJsonSchema } from '@mastra/core/utils/zod-to-json';\nimport { stringify } from 'superjson';\n\nimport type {\n StreamTextOnFinishCallback,\n StreamTextOnStepFinishCallback,\n} from '../../../../core/dist/llm/model/base.types';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\n\nimport { handleError } from './error';\nimport { sanitizeBody, validateBody } from './utils';\n\ntype GetBody<\n T extends keyof Agent & { [K in keyof Agent]: Agent[K] extends (...args: any) => any ? K : never }[keyof Agent],\n> = {\n messages: Parameters<Agent[T]>[0];\n} & Parameters<Agent[T]>[1];\n\ntype GetHITLBody<\n T extends keyof Agent & { [K in keyof Agent]: Agent[K] extends (...args: any) => any ? K : never }[keyof Agent],\n> = Parameters<Agent[T]>[0];\n\nexport interface SerializedProcessor {\n id: string;\n name?: string;\n}\n\nexport interface SerializedTool {\n id: string;\n description?: string;\n inputSchema?: string;\n outputSchema?: string;\n requireApproval?: boolean;\n}\n\nexport interface SerializedWorkflow {\n name: string;\n steps?: Record<string, { id: string; description?: string }>;\n}\n\nexport interface SerializedAgent {\n name: string;\n description?: string;\n instructions?: SystemMessage;\n tools: Record<string, SerializedTool>;\n agents: Record<string, SerializedAgentDefinition>;\n workflows: Record<string, SerializedWorkflow>;\n inputProcessors: SerializedProcessor[];\n outputProcessors: SerializedProcessor[];\n provider?: string;\n modelId?: string;\n modelVersion?: string;\n modelList?: Array<\n Omit<AgentModelManagerConfig, 'model'> & {\n model: {\n modelId: string;\n provider: string;\n modelVersion: string;\n };\n }\n >;\n // We can't use the true types here because they are not serializable\n defaultOptions?: Record<string, unknown>;\n defaultGenerateOptionsLegacy?: Record<string, unknown>;\n defaultStreamOptionsLegacy?: Record<string, unknown>;\n}\n\nexport interface SerializedAgentWithId extends SerializedAgent {\n id: string;\n}\n\nexport async function getSerializedAgentTools(tools: Record<string, unknown>): Promise<Record<string, SerializedTool>> {\n return Object.entries(tools || {}).reduce<Record<string, SerializedTool>>((acc, [key, tool]) => {\n const _tool = tool as {\n id?: string;\n description?: string;\n inputSchema?: { jsonSchema?: unknown } | unknown;\n outputSchema?: { jsonSchema?: unknown } | unknown;\n };\n\n const toolId = _tool.id ?? `tool-${key}`;\n\n let inputSchemaForReturn: string | undefined = undefined;\n let outputSchemaForReturn: string | undefined = undefined;\n\n try {\n if (_tool.inputSchema) {\n if (_tool.inputSchema && typeof _tool.inputSchema === 'object' && 'jsonSchema' in _tool.inputSchema) {\n inputSchemaForReturn = stringify(_tool.inputSchema.jsonSchema);\n } else if (typeof _tool.inputSchema === 'function') {\n const inputSchema = _tool.inputSchema();\n if (inputSchema && inputSchema.jsonSchema) {\n inputSchemaForReturn = stringify(inputSchema.jsonSchema);\n }\n } else if (_tool.inputSchema) {\n inputSchemaForReturn = stringify(zodToJsonSchema(_tool.inputSchema as Parameters<typeof zodToJsonSchema>[0]));\n }\n }\n\n if (_tool.outputSchema) {\n if (_tool.outputSchema && typeof _tool.outputSchema === 'object' && 'jsonSchema' in _tool.outputSchema) {\n outputSchemaForReturn = stringify(_tool.outputSchema.jsonSchema);\n } else if (typeof _tool.outputSchema === 'function') {\n const outputSchema = _tool.outputSchema();\n if (outputSchema && outputSchema.jsonSchema) {\n outputSchemaForReturn = stringify(outputSchema.jsonSchema);\n }\n } else if (_tool.outputSchema) {\n outputSchemaForReturn = stringify(\n zodToJsonSchema(_tool.outputSchema as Parameters<typeof zodToJsonSchema>[0]),\n );\n }\n }\n } catch (error) {\n console.error(`Error getting serialized tool`, {\n toolId: _tool.id,\n error,\n });\n }\n\n acc[key] = {\n ..._tool,\n id: toolId,\n inputSchema: inputSchemaForReturn,\n outputSchema: outputSchemaForReturn,\n };\n return acc;\n }, {});\n}\n\nexport function getSerializedProcessors(processors: (InputProcessor | OutputProcessor)[]): SerializedProcessor[] {\n return processors.map(processor => {\n // Processors are class instances or objects with a name property\n // Use the name property if available, otherwise fall back to constructor name\n return {\n id: processor.id,\n name: processor.name || processor.constructor.name,\n };\n });\n}\n\ninterface SerializedAgentDefinition {\n id: string;\n name: string;\n}\n\nasync function getSerializedAgentDefinition({\n agent,\n requestContext,\n}: {\n agent: Agent;\n requestContext: RequestContext;\n}): Promise<Record<string, SerializedAgentDefinition>> {\n let serializedAgentAgents: Record<string, SerializedAgentDefinition> = {};\n\n if ('listAgents' in agent) {\n const agents = await agent.listAgents({ requestContext });\n serializedAgentAgents = Object.entries(agents || {}).reduce<Record<string, SerializedAgentDefinition>>(\n (acc, [key, agent]) => {\n return {\n ...acc,\n [key]: { id: agent.id, name: agent.name },\n };\n },\n {},\n );\n }\n return serializedAgentAgents;\n}\n\nasync function formatAgentList({\n id,\n mastra,\n agent,\n requestContext,\n}: {\n id: string;\n mastra: Context['mastra'];\n agent: Agent;\n requestContext: RequestContext;\n}): Promise<SerializedAgentWithId> {\n const description = agent.getDescription();\n const instructions = await agent.getInstructions({ requestContext });\n const tools = await agent.listTools({ requestContext });\n const llm = await agent.getLLM({ requestContext });\n const defaultGenerateOptionsLegacy = await agent.getDefaultGenerateOptionsLegacy({ requestContext });\n const defaultStreamOptionsLegacy = await agent.getDefaultStreamOptionsLegacy({ requestContext });\n const defaultOptions = await agent.getDefaultOptions({ requestContext });\n const serializedAgentTools = await getSerializedAgentTools(tools);\n\n let serializedAgentWorkflows: Record<\n string,\n { name: string; steps?: Record<string, { id: string; description?: string }> }\n > = {};\n\n if ('listWorkflows' in agent) {\n const logger = mastra.getLogger();\n try {\n const workflows = await agent.listWorkflows({ requestContext });\n serializedAgentWorkflows = Object.entries(workflows || {}).reduce<\n Record<string, { name: string; steps?: Record<string, { id: string; description?: string }> }>\n >((acc, [key, workflow]) => {\n return {\n ...acc,\n [key]: {\n name: workflow.name || 'Unnamed workflow',\n },\n };\n }, {});\n } catch (error) {\n logger.error('Error getting workflows for agent', { agentName: agent.name, error });\n }\n }\n\n const serializedAgentAgents = await getSerializedAgentDefinition({ agent, requestContext });\n\n // Get and serialize processors\n const inputProcessors = await agent.listInputProcessors(requestContext);\n const outputProcessors = await agent.listOutputProcessors(requestContext);\n const serializedInputProcessors = getSerializedProcessors(inputProcessors);\n const serializedOutputProcessors = getSerializedProcessors(outputProcessors);\n\n const model = llm?.getModel();\n const models = await agent.getModelList(requestContext);\n const modelList = models?.map(md => ({\n ...md,\n model: {\n modelId: md.model.modelId,\n provider: md.model.provider,\n modelVersion: md.model.specificationVersion,\n },\n }));\n\n return {\n id: agent.id || id,\n name: agent.name,\n description,\n instructions,\n agents: serializedAgentAgents,\n tools: serializedAgentTools,\n workflows: serializedAgentWorkflows,\n inputProcessors: serializedInputProcessors,\n outputProcessors: serializedOutputProcessors,\n provider: llm?.getProvider(),\n modelId: llm?.getModelId(),\n modelVersion: model?.specificationVersion,\n defaultOptions,\n modelList,\n defaultGenerateOptionsLegacy,\n defaultStreamOptionsLegacy,\n };\n}\n\nexport async function getAgentFromSystem({ mastra, agentId }: { mastra: Context['mastra']; agentId: string }) {\n const logger = mastra.getLogger();\n\n if (!agentId) {\n throw new HTTPException(400, { message: 'Agent ID is required' });\n }\n\n let agent;\n\n try {\n agent = mastra.getAgentById(agentId);\n } catch (error) {\n logger.debug('Error getting agent from mastra, searching agents for agent', error);\n }\n\n if (!agent) {\n logger.debug(`Agent ${agentId} not found, looking through sub-agents`);\n const agents = mastra.listAgents();\n if (Object.keys(agents || {}).length) {\n for (const [_, ag] of Object.entries(agents)) {\n try {\n const subAgents = await ag.listAgents();\n\n if (subAgents[agentId]) {\n agent = subAgents[agentId];\n break;\n }\n } catch (error) {\n logger.debug('Error getting agent from agent', error);\n }\n }\n }\n }\n\n if (!agent) {\n throw new HTTPException(404, { message: `Agent with id ${agentId} not found` });\n }\n\n return agent;\n}\n\n// Agent handlers\nexport async function listAgentsHandler({\n mastra,\n requestContext,\n}: Context & { requestContext: RequestContext }): Promise<Record<string, SerializedAgent>> {\n try {\n const agents = mastra.listAgents();\n\n const serializedAgentsMap = await Promise.all(\n Object.entries(agents).map(async ([id, agent]) => {\n return formatAgentList({ id, mastra, agent, requestContext });\n }),\n );\n\n const serializedAgents = serializedAgentsMap.reduce<Record<string, (typeof serializedAgentsMap)[number]>>(\n (acc, { id, ...rest }) => {\n acc[id] = { id, ...rest };\n return acc;\n },\n {},\n );\n\n return serializedAgents;\n } catch (error) {\n return handleError(error, 'Error getting agents');\n }\n}\n\nasync function formatAgent({\n mastra,\n agent,\n requestContext,\n isPlayground,\n}: {\n mastra: Context['mastra'];\n agent: Agent;\n requestContext: RequestContext;\n isPlayground: boolean;\n}): Promise<SerializedAgent> {\n const description = agent.getDescription();\n const tools = await agent.listTools({ requestContext });\n\n const serializedAgentTools = await getSerializedAgentTools(tools);\n\n let serializedAgentWorkflows: Record<\n string,\n { name: string; steps: Record<string, { id: string; description?: string }> }\n > = {};\n\n if ('listWorkflows' in agent) {\n const logger = mastra.getLogger();\n try {\n const workflows = await agent.listWorkflows({ requestContext });\n\n serializedAgentWorkflows = Object.entries(workflows || {}).reduce<\n Record<string, { name: string; steps: Record<string, { id: string; description?: string }> }>\n >((acc, [key, workflow]) => {\n return {\n ...acc,\n [key]: {\n name: workflow.name || 'Unnamed workflow',\n steps: Object.entries(workflow.steps).reduce<Record<string, { id: string; description?: string }>>(\n (acc, [key, step]) => {\n return {\n ...acc,\n [key]: {\n id: step.id,\n description: step.description,\n },\n };\n },\n {},\n ),\n },\n };\n }, {});\n } catch (error) {\n logger.error('Error getting workflows for agent', { agentName: agent.name, error });\n }\n }\n\n let proxyRequestContext = requestContext;\n if (isPlayground) {\n proxyRequestContext = new Proxy(requestContext, {\n get(target, prop) {\n if (prop === 'get') {\n return function (key: string) {\n const value = target.get(key);\n return value ?? `<${key}>`;\n };\n }\n return Reflect.get(target, prop);\n },\n });\n }\n\n const instructions = await agent.getInstructions({ requestContext: proxyRequestContext });\n const llm = await agent.getLLM({ requestContext });\n const defaultGenerateOptionsLegacy = await agent.getDefaultGenerateOptionsLegacy({\n requestContext: proxyRequestContext,\n });\n const defaultStreamOptionsLegacy = await agent.getDefaultStreamOptionsLegacy({ requestContext: proxyRequestContext });\n const defaultOptions = await agent.getDefaultOptions({ requestContext: proxyRequestContext });\n\n const model = llm?.getModel();\n const models = await agent.getModelList(requestContext);\n const modelList = models?.map(md => ({\n ...md,\n model: {\n modelId: md.model.modelId,\n provider: md.model.provider,\n modelVersion: md.model.specificationVersion,\n },\n }));\n\n const serializedAgentAgents = await getSerializedAgentDefinition({ agent, requestContext: proxyRequestContext });\n\n // Get and serialize processors\n const inputProcessors = await agent.listInputProcessors(proxyRequestContext);\n const outputProcessors = await agent.listOutputProcessors(proxyRequestContext);\n const serializedInputProcessors = getSerializedProcessors(inputProcessors);\n const serializedOutputProcessors = getSerializedProcessors(outputProcessors);\n\n return {\n name: agent.name,\n description,\n instructions,\n tools: serializedAgentTools,\n agents: serializedAgentAgents,\n workflows: serializedAgentWorkflows,\n inputProcessors: serializedInputProcessors,\n outputProcessors: serializedOutputProcessors,\n provider: llm?.getProvider(),\n modelId: llm?.getModelId(),\n modelVersion: model?.specificationVersion,\n modelList,\n defaultOptions,\n defaultGenerateOptionsLegacy,\n defaultStreamOptionsLegacy,\n };\n}\n\nexport async function getAgentByIdHandler({\n mastra,\n requestContext,\n agentId,\n isPlayground = false,\n}: Context & { isPlayground?: boolean; requestContext: RequestContext; agentId: string }): Promise<\n SerializedAgent | ReturnType<typeof handleError>\n> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n return formatAgent({ mastra, agent, requestContext, isPlayground });\n } catch (error) {\n return handleError(error, 'Error getting agent');\n }\n}\n\nexport async function generateLegacyHandler({\n mastra,\n requestContext,\n agentId,\n body,\n abortSignal,\n}: Context & {\n requestContext: RequestContext;\n agentId: string;\n body: GetBody<'generateLegacy'> & {\n // @deprecated use resourceId\n resourceid?: string;\n requestContext?: Record<string, unknown>;\n };\n abortSignal?: AbortSignal;\n}) {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n // UI Frameworks may send \"client tools\" in the body,\n // but it interferes with llm providers tool handling, so we remove them\n sanitizeBody(body, ['tools']);\n\n const { messages, resourceId, resourceid, requestContext: agentRequestContext, ...rest } = body;\n // Use resourceId if provided, fall back to resourceid (deprecated)\n const finalResourceId = resourceId ?? resourceid;\n\n const finalRequestContext = new RequestContext<Record<string, unknown>>([\n ...Array.from(requestContext.entries()),\n ...Array.from(Object.entries(agentRequestContext ?? {})),\n ]);\n\n validateBody({ messages });\n\n const result = await agent.generateLegacy(messages, {\n ...rest,\n abortSignal,\n // @ts-expect-error TODO fix types\n resourceId: finalResourceId,\n requestContext: finalRequestContext,\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error generating from agent');\n }\n}\n\nexport async function generateHandler({\n mastra,\n requestContext,\n agentId,\n body,\n abortSignal,\n}: Context & {\n requestContext: RequestContext;\n agentId: string;\n body: GetBody<'generate'> & {\n requestContext?: Record<string, unknown>;\n };\n abortSignal?: AbortSignal;\n}): Promise<ReturnType<Agent['generate']>> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n // UI Frameworks may send \"client tools\" in the body,\n // but it interferes with llm providers tool handling, so we remove them\n sanitizeBody(body, ['tools']);\n\n const { messages, requestContext: agentRequestContext, ...rest } = body;\n\n const finalRequestContext = new RequestContext<Record<string, unknown>>([\n ...Array.from(requestContext.entries()),\n ...Array.from(Object.entries(agentRequestContext ?? {})),\n ]);\n\n validateBody({ messages });\n\n const result = await agent.generate(messages, {\n ...rest,\n requestContext: finalRequestContext,\n abortSignal,\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error generating from agent');\n }\n}\n\nexport async function streamGenerateLegacyHandler({\n mastra,\n requestContext,\n agentId,\n body,\n abortSignal,\n}: Context & {\n requestContext: RequestContext;\n agentId: string;\n body: GetBody<'streamLegacy'> & {\n // @deprecated use resourceId\n resourceid?: string;\n requestContext?: string;\n };\n abortSignal?: AbortSignal;\n}): Promise<Response | undefined> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n const { messages, resourceId, resourceid, requestContext: agentRequestContext, ...rest } = body;\n // Use resourceId if provided, fall back to resourceid (deprecated)\n const finalResourceId = resourceId ?? resourceid;\n\n const finalRequestContext = new RequestContext<Record<string, unknown>>([\n ...Array.from(requestContext.entries()),\n ...Array.from(Object.entries(agentRequestContext ?? {})),\n ]);\n\n validateBody({ messages });\n\n const streamResult = await agent.streamLegacy(messages, {\n ...rest,\n abortSignal,\n // @ts-expect-error TODO fix types\n resourceId: finalResourceId,\n requestContext: finalRequestContext,\n });\n\n const streamResponse = rest.output\n ? streamResult.toTextStreamResponse({\n headers: {\n 'Transfer-Encoding': 'chunked',\n },\n })\n : streamResult.toDataStreamResponse({\n sendUsage: true,\n sendReasoning: true,\n getErrorMessage: (error: any) => {\n return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;\n },\n headers: {\n 'Transfer-Encoding': 'chunked',\n },\n });\n\n return streamResponse;\n } catch (error) {\n return handleError(error, 'error streaming agent response');\n }\n}\n\nexport async function streamGenerateHandler({\n mastra,\n requestContext,\n agentId,\n body,\n abortSignal,\n}: Context & {\n requestContext: RequestContext;\n agentId: string;\n body: GetBody<'stream'> & {\n requestContext?: string;\n };\n abortSignal?: AbortSignal;\n}): ReturnType<Agent['stream']> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n // UI Frameworks may send \"client tools\" in the body,\n // but it interferes with llm providers tool handling, so we remove them\n sanitizeBody(body, ['tools']);\n\n const { messages, requestContext: agentRequestContext, ...rest } = body;\n const finalRequestContext = new RequestContext<Record<string, unknown>>([\n ...Array.from(requestContext.entries()),\n ...Array.from(Object.entries(agentRequestContext ?? {})),\n ]);\n\n validateBody({ messages });\n\n const streamResult = agent.stream(messages, {\n ...rest,\n requestContext: finalRequestContext,\n abortSignal,\n });\n\n return streamResult;\n } catch (error) {\n return handleError(error, 'error streaming agent response');\n }\n}\n\nexport async function approveToolCallHandler({\n mastra,\n requestContext,\n agentId,\n body,\n abortSignal,\n}: Context & {\n requestContext: RequestContext;\n agentId: string;\n body: GetHITLBody<'approveToolCall'> & {\n requestContext?: string;\n };\n abortSignal?: AbortSignal;\n}): ReturnType<Agent['approveToolCall']> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n if (!body.runId) {\n throw new HTTPException(400, { message: 'Run id is required' });\n }\n\n if (!body.toolCallId) {\n throw new HTTPException(400, { message: 'Tool call id is required' });\n }\n\n // UI Frameworks may send \"client tools\" in the body,\n // but it interferes with llm providers tool handling, so we remove them\n sanitizeBody(body, ['tools']);\n\n const { runId, requestContext: agentRequestContext, ...rest } = body;\n\n const finalRequestContext = new RequestContext<Record<string, unknown>>([\n ...Array.from(requestContext.entries()),\n ...Array.from(Object.entries(agentRequestContext ?? {})),\n ]);\n\n const streamResult = agent.approveToolCall({\n ...rest,\n runId,\n requestContext: finalRequestContext,\n abortSignal,\n });\n\n return streamResult;\n } catch (error) {\n return handleError(error, 'error streaming agent response');\n }\n}\n\nexport async function declineToolCallHandler({\n mastra,\n requestContext,\n agentId,\n body,\n abortSignal,\n}: Context & {\n requestContext: RequestContext;\n agentId: string;\n body: GetHITLBody<'declineToolCall'> & {\n requestContext?: string;\n };\n abortSignal?: AbortSignal;\n}): ReturnType<Agent['declineToolCall']> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n if (!body.runId) {\n throw new HTTPException(400, { message: 'Run id is required' });\n }\n\n if (!body.toolCallId) {\n throw new HTTPException(400, { message: 'Tool call id is required' });\n }\n\n // UI Frameworks may send \"client tools\" in the body,\n // but it interferes with llm providers tool handling, so we remove them\n sanitizeBody(body, ['tools']);\n\n const { runId, requestContext: agentRequestContext, ...rest } = body;\n\n const finalRequestContext = new RequestContext<Record<string, unknown>>([\n ...Array.from(requestContext.entries()),\n ...Array.from(Object.entries(agentRequestContext ?? {})),\n ]);\n\n const streamResult = agent.declineToolCall({\n ...rest,\n runId,\n requestContext: finalRequestContext,\n abortSignal,\n });\n\n return streamResult;\n } catch (error) {\n return handleError(error, 'error streaming agent response');\n }\n}\n\nexport async function streamNetworkHandler({\n mastra,\n requestContext,\n agentId,\n body,\n // abortSignal,\n}: Context & {\n requestContext: RequestContext;\n agentId: string;\n body: GetBody<'network'> & {\n thread?: string;\n resourceId?: string;\n };\n // abortSignal?: AbortSignal;\n}): ReturnType<Agent['network']> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n // UI Frameworks may send \"client tools\" in the body,\n // but it interferes with llm providers tool handling, so we remove them\n sanitizeBody(body, ['tools']);\n\n const { messages, requestContext: agentRequestContext, ...rest } = body;\n const finalRequestContext = new RequestContext<Record<string, unknown>>([\n ...Array.from(requestContext.entries()),\n ...Array.from(Object.entries(agentRequestContext ?? {})),\n ]);\n\n validateBody({ messages });\n\n const streamResult = agent.network(messages, {\n ...rest,\n memory: {\n thread: rest.thread ?? '',\n resource: rest.resourceId ?? '',\n options: rest.memory?.options ?? {},\n },\n requestContext: finalRequestContext,\n });\n\n return streamResult;\n } catch (error) {\n return handleError(error, 'error streaming agent loop response');\n }\n}\n\nexport async function streamUIMessageHandler(\n _params: Context & {\n requestContext: RequestContext;\n agentId: string;\n body: GetBody<'stream'> & {\n requestContext?: string;\n onStepFinish?: StreamTextOnStepFinishCallback<any>;\n onFinish?: StreamTextOnFinishCallback<any>;\n output?: undefined;\n };\n abortSignal?: AbortSignal;\n },\n): Promise<Response | undefined> {\n try {\n throw new MastraError({\n category: ErrorCategory.USER,\n domain: ErrorDomain.MASTRA_SERVER,\n id: 'DEPRECATED_ENDPOINT',\n text: 'This endpoint is deprecated. Please use the @mastra/ai-sdk package to for uiMessage transformations',\n });\n } catch (error) {\n return handleError(error, 'error streaming agent response');\n }\n}\n\nexport async function updateAgentModelHandler({\n mastra,\n agentId,\n body,\n}: Context & {\n agentId: string;\n body: {\n modelId: string;\n provider: string;\n };\n}): Promise<{ message: string }> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n const { modelId, provider } = body;\n\n // Use the universal Mastra router format: provider/model\n const newModel = `${provider}/${modelId}`;\n\n agent.__updateModel({ model: newModel });\n\n return { message: 'Agent model updated' };\n } catch (error) {\n return handleError(error, 'error updating agent model');\n }\n}\n\nexport async function resetAgentModelHandler({\n mastra,\n agentId,\n}: Context & {\n agentId: string;\n}): Promise<{ message: string }> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n agent.__resetToOriginalModel();\n\n return { message: 'Agent model reset to original' };\n } catch (error) {\n return handleError(error, 'error resetting agent model');\n }\n}\n\nexport async function reorderAgentModelListHandler({\n mastra,\n agentId,\n body,\n}: Context & {\n agentId: string;\n body: {\n reorderedModelIds: Array<string>;\n };\n}): Promise<{ message: string }> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n const modelList = await agent.getModelList();\n if (!modelList || modelList.length === 0) {\n throw new HTTPException(400, { message: 'Agent model list is not found or empty' });\n }\n\n agent.reorderModels(body.reorderedModelIds);\n\n return { message: 'Model list reordered' };\n } catch (error) {\n return handleError(error, 'error reordering model list');\n }\n}\n\nexport async function updateAgentModelInModelListHandler({\n mastra,\n agentId,\n modelConfigId,\n body,\n}: Context & {\n agentId: string;\n modelConfigId: string;\n body: {\n model?: {\n modelId: string;\n provider: string;\n };\n maxRetries?: number;\n enabled?: boolean;\n };\n}): Promise<{ message: string }> {\n try {\n const agent = await getAgentFromSystem({ mastra, agentId });\n\n const { model: bodyModel, maxRetries, enabled } = body;\n\n if (!modelConfigId) {\n throw new HTTPException(400, { message: 'Model id is required' });\n }\n\n const modelList = await agent.getModelList();\n if (!modelList || modelList.length === 0) {\n throw new HTTPException(400, { message: 'Agent model list is not found or empty' });\n }\n\n const modelToUpdate = modelList.find(m => m.id === modelConfigId);\n if (!modelToUpdate) {\n throw new HTTPException(400, { message: 'Model to update is not found in agent model list' });\n }\n\n let model: string | undefined;\n if (bodyModel) {\n const { modelId, provider } = bodyModel;\n // Use the universal Mastra router format: provider/model\n model = `${provider}/${modelId}`;\n }\n\n agent.updateModelInModelList({ id: modelConfigId, model, maxRetries, enabled });\n\n return { message: 'Model list updated' };\n } catch (error) {\n return handleError(error, 'error updating model list');\n }\n}\n\nexport async function getProvidersHandler() {\n try {\n const providers = Object.entries(PROVIDER_REGISTRY).map(([id, provider]) => {\n // Check if the provider is connected by checking for its API key env var(s)\n const envVars = Array.isArray(provider.apiKeyEnvVar) ? provider.apiKeyEnvVar : [provider.apiKeyEnvVar];\n const connected = envVars.every(envVar => !!process.env[envVar]);\n\n return {\n id,\n name: provider.name,\n envVar: provider.apiKeyEnvVar,\n connected,\n docUrl: provider.docUrl,\n models: [...provider.models], // Convert readonly array to regular array\n };\n });\n\n return { providers };\n } catch (error) {\n return handleError(error, 'error fetching providers');\n }\n}\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { getWorkflowInfo, WorkflowRegistry } from './chunk-
|
|
2
|
-
import { handleError } from './chunk-
|
|
3
|
-
import { HTTPException } from './chunk-
|
|
1
|
+
import { getWorkflowInfo, WorkflowRegistry } from './chunk-D7T74TVR.js';
|
|
2
|
+
import { handleError } from './chunk-UXGQZUYZ.js';
|
|
3
|
+
import { HTTPException } from './chunk-6QWQZI4Q.js';
|
|
4
4
|
import { __export } from './chunk-PR4QN5HX.js';
|
|
5
|
-
import {
|
|
5
|
+
import { TransformStream, ReadableStream } from 'stream/web';
|
|
6
6
|
|
|
7
7
|
// src/server/handlers/workflows.ts
|
|
8
8
|
var workflows_exports = {};
|
|
@@ -12,25 +12,23 @@ __export(workflows_exports, {
|
|
|
12
12
|
getWorkflowByIdHandler: () => getWorkflowByIdHandler,
|
|
13
13
|
getWorkflowRunByIdHandler: () => getWorkflowRunByIdHandler,
|
|
14
14
|
getWorkflowRunExecutionResultHandler: () => getWorkflowRunExecutionResultHandler,
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
listWorkflowRunsHandler: () => listWorkflowRunsHandler,
|
|
16
|
+
listWorkflowsHandler: () => listWorkflowsHandler,
|
|
17
17
|
observeStreamLegacyWorkflowHandler: () => observeStreamLegacyWorkflowHandler,
|
|
18
18
|
observeStreamVNextWorkflowHandler: () => observeStreamVNextWorkflowHandler,
|
|
19
19
|
observeStreamWorkflowHandler: () => observeStreamWorkflowHandler,
|
|
20
20
|
resumeAsyncWorkflowHandler: () => resumeAsyncWorkflowHandler,
|
|
21
21
|
resumeStreamWorkflowHandler: () => resumeStreamWorkflowHandler,
|
|
22
22
|
resumeWorkflowHandler: () => resumeWorkflowHandler,
|
|
23
|
-
sendWorkflowRunEventHandler: () => sendWorkflowRunEventHandler,
|
|
24
23
|
startAsyncWorkflowHandler: () => startAsyncWorkflowHandler,
|
|
25
24
|
startWorkflowRunHandler: () => startWorkflowRunHandler,
|
|
26
25
|
streamLegacyWorkflowHandler: () => streamLegacyWorkflowHandler,
|
|
27
26
|
streamVNextWorkflowHandler: () => streamVNextWorkflowHandler,
|
|
28
|
-
streamWorkflowHandler: () => streamWorkflowHandler
|
|
29
|
-
watchWorkflowHandler: () => watchWorkflowHandler
|
|
27
|
+
streamWorkflowHandler: () => streamWorkflowHandler
|
|
30
28
|
});
|
|
31
|
-
async function
|
|
29
|
+
async function listWorkflowsHandler({ mastra }) {
|
|
32
30
|
try {
|
|
33
|
-
const workflows = mastra.
|
|
31
|
+
const workflows = mastra.listWorkflows({ serialized: false });
|
|
34
32
|
const _workflows = Object.entries(workflows).reduce((acc, [key, workflow]) => {
|
|
35
33
|
acc[key] = getWorkflowInfo(workflow);
|
|
36
34
|
return acc;
|
|
@@ -40,7 +38,7 @@ async function getWorkflowsHandler({ mastra }) {
|
|
|
40
38
|
return handleError(error, "Error getting workflows");
|
|
41
39
|
}
|
|
42
40
|
}
|
|
43
|
-
async function
|
|
41
|
+
async function listWorkflowsFromSystem({ mastra, workflowId }) {
|
|
44
42
|
const logger = mastra.getLogger();
|
|
45
43
|
if (!workflowId) {
|
|
46
44
|
throw new HTTPException(400, { message: "Workflow ID is required" });
|
|
@@ -49,18 +47,18 @@ async function getWorkflowsFromSystem({ mastra, workflowId }) {
|
|
|
49
47
|
workflow = WorkflowRegistry.getWorkflow(workflowId);
|
|
50
48
|
if (!workflow) {
|
|
51
49
|
try {
|
|
52
|
-
workflow = mastra.
|
|
50
|
+
workflow = mastra.getWorkflowById(workflowId);
|
|
53
51
|
} catch (error) {
|
|
54
52
|
logger.debug("Error getting workflow, searching agents for workflow", error);
|
|
55
53
|
}
|
|
56
54
|
}
|
|
57
55
|
if (!workflow) {
|
|
58
56
|
logger.debug("Workflow not found, searching agents for workflow", { workflowId });
|
|
59
|
-
const agents = mastra.
|
|
57
|
+
const agents = mastra.listAgents();
|
|
60
58
|
if (Object.keys(agents || {}).length) {
|
|
61
59
|
for (const [_, agent] of Object.entries(agents)) {
|
|
62
60
|
try {
|
|
63
|
-
const workflows = await agent.
|
|
61
|
+
const workflows = await agent.listWorkflows();
|
|
64
62
|
if (workflows[workflowId]) {
|
|
65
63
|
workflow = workflows[workflowId];
|
|
66
64
|
break;
|
|
@@ -82,7 +80,7 @@ async function getWorkflowByIdHandler({ mastra, workflowId }) {
|
|
|
82
80
|
if (!workflowId) {
|
|
83
81
|
throw new HTTPException(400, { message: "Workflow ID is required" });
|
|
84
82
|
}
|
|
85
|
-
const { workflow } = await
|
|
83
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
86
84
|
if (!workflow) {
|
|
87
85
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
88
86
|
}
|
|
@@ -103,7 +101,7 @@ async function getWorkflowRunByIdHandler({
|
|
|
103
101
|
if (!runId) {
|
|
104
102
|
throw new HTTPException(400, { message: "Run ID is required" });
|
|
105
103
|
}
|
|
106
|
-
const { workflow } = await
|
|
104
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
107
105
|
if (!workflow) {
|
|
108
106
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
109
107
|
}
|
|
@@ -150,11 +148,11 @@ async function createWorkflowRunHandler({
|
|
|
150
148
|
if (!workflowId) {
|
|
151
149
|
throw new HTTPException(400, { message: "Workflow ID is required" });
|
|
152
150
|
}
|
|
153
|
-
const { workflow } = await
|
|
151
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
154
152
|
if (!workflow) {
|
|
155
153
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
156
154
|
}
|
|
157
|
-
const run = await workflow.
|
|
155
|
+
const run = await workflow.createRun({ runId: prevRunId });
|
|
158
156
|
return { runId: run.runId };
|
|
159
157
|
} catch (error) {
|
|
160
158
|
return handleError(error, "Error creating workflow run");
|
|
@@ -162,7 +160,7 @@ async function createWorkflowRunHandler({
|
|
|
162
160
|
}
|
|
163
161
|
async function startAsyncWorkflowHandler({
|
|
164
162
|
mastra,
|
|
165
|
-
|
|
163
|
+
requestContext,
|
|
166
164
|
workflowId,
|
|
167
165
|
runId,
|
|
168
166
|
inputData,
|
|
@@ -172,14 +170,14 @@ async function startAsyncWorkflowHandler({
|
|
|
172
170
|
if (!workflowId) {
|
|
173
171
|
throw new HTTPException(400, { message: "Workflow ID is required" });
|
|
174
172
|
}
|
|
175
|
-
const { workflow } = await
|
|
173
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
176
174
|
if (!workflow) {
|
|
177
175
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
178
176
|
}
|
|
179
|
-
const _run = await workflow.
|
|
177
|
+
const _run = await workflow.createRun({ runId });
|
|
180
178
|
const result = await _run.start({
|
|
181
179
|
inputData,
|
|
182
|
-
|
|
180
|
+
requestContext,
|
|
183
181
|
tracingOptions
|
|
184
182
|
});
|
|
185
183
|
return result;
|
|
@@ -189,7 +187,7 @@ async function startAsyncWorkflowHandler({
|
|
|
189
187
|
}
|
|
190
188
|
async function startWorkflowRunHandler({
|
|
191
189
|
mastra,
|
|
192
|
-
|
|
190
|
+
requestContext,
|
|
193
191
|
workflowId,
|
|
194
192
|
runId,
|
|
195
193
|
inputData,
|
|
@@ -202,7 +200,7 @@ async function startWorkflowRunHandler({
|
|
|
202
200
|
if (!runId) {
|
|
203
201
|
throw new HTTPException(400, { message: "runId required to start run" });
|
|
204
202
|
}
|
|
205
|
-
const { workflow } = await
|
|
203
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
206
204
|
if (!workflow) {
|
|
207
205
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
208
206
|
}
|
|
@@ -210,10 +208,10 @@ async function startWorkflowRunHandler({
|
|
|
210
208
|
if (!run) {
|
|
211
209
|
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
212
210
|
}
|
|
213
|
-
const _run = await workflow.
|
|
211
|
+
const _run = await workflow.createRun({ runId, resourceId: run.resourceId });
|
|
214
212
|
void _run.start({
|
|
215
213
|
inputData,
|
|
216
|
-
|
|
214
|
+
requestContext,
|
|
217
215
|
tracingOptions
|
|
218
216
|
});
|
|
219
217
|
return { message: "Workflow run started" };
|
|
@@ -221,92 +219,19 @@ async function startWorkflowRunHandler({
|
|
|
221
219
|
return handleError(e, "Error starting workflow run");
|
|
222
220
|
}
|
|
223
221
|
}
|
|
224
|
-
async function watchWorkflowHandler({
|
|
225
|
-
mastra,
|
|
226
|
-
workflowId,
|
|
227
|
-
runId,
|
|
228
|
-
eventType = "watch"
|
|
229
|
-
}) {
|
|
230
|
-
try {
|
|
231
|
-
if (!workflowId) {
|
|
232
|
-
throw new HTTPException(400, { message: "Workflow ID is required" });
|
|
233
|
-
}
|
|
234
|
-
if (!runId) {
|
|
235
|
-
throw new HTTPException(400, { message: "runId required to watch workflow" });
|
|
236
|
-
}
|
|
237
|
-
const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
|
|
238
|
-
if (!workflow) {
|
|
239
|
-
throw new HTTPException(404, { message: "Workflow not found" });
|
|
240
|
-
}
|
|
241
|
-
const run = await workflow.getWorkflowRunById(runId);
|
|
242
|
-
if (!run) {
|
|
243
|
-
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
244
|
-
}
|
|
245
|
-
const _run = await workflow.createRunAsync({ runId, resourceId: run.resourceId });
|
|
246
|
-
let unwatch;
|
|
247
|
-
let asyncRef = null;
|
|
248
|
-
const stream = new ReadableStream({
|
|
249
|
-
start(controller) {
|
|
250
|
-
if (eventType === "watch") {
|
|
251
|
-
unwatch = _run.watch((event) => {
|
|
252
|
-
const { type, payload, eventTimestamp } = event;
|
|
253
|
-
controller.enqueue(JSON.stringify({ type, payload, eventTimestamp, runId }));
|
|
254
|
-
if (asyncRef) {
|
|
255
|
-
clearImmediate(asyncRef);
|
|
256
|
-
asyncRef = null;
|
|
257
|
-
}
|
|
258
|
-
asyncRef = setImmediate(async () => {
|
|
259
|
-
const runDone = payload.workflowState?.status !== "running";
|
|
260
|
-
if (runDone) {
|
|
261
|
-
controller.close();
|
|
262
|
-
unwatch?.();
|
|
263
|
-
}
|
|
264
|
-
});
|
|
265
|
-
}, eventType);
|
|
266
|
-
} else {
|
|
267
|
-
unwatch = _run.watch((event) => {
|
|
268
|
-
const { type, payload } = event;
|
|
269
|
-
controller.enqueue(JSON.stringify({ type, payload, runId }));
|
|
270
|
-
if (asyncRef) {
|
|
271
|
-
clearImmediate(asyncRef);
|
|
272
|
-
asyncRef = null;
|
|
273
|
-
}
|
|
274
|
-
asyncRef = setImmediate(async () => {
|
|
275
|
-
const runDone = type === "workflow-finish";
|
|
276
|
-
if (runDone) {
|
|
277
|
-
controller.close();
|
|
278
|
-
unwatch?.();
|
|
279
|
-
}
|
|
280
|
-
});
|
|
281
|
-
}, eventType);
|
|
282
|
-
}
|
|
283
|
-
},
|
|
284
|
-
cancel() {
|
|
285
|
-
if (asyncRef) {
|
|
286
|
-
clearImmediate(asyncRef);
|
|
287
|
-
asyncRef = null;
|
|
288
|
-
}
|
|
289
|
-
unwatch?.();
|
|
290
|
-
}
|
|
291
|
-
});
|
|
292
|
-
return stream;
|
|
293
|
-
} catch (error) {
|
|
294
|
-
return handleError(error, "Error watching workflow");
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
222
|
async function streamWorkflowHandler({
|
|
298
223
|
mastra,
|
|
299
|
-
|
|
224
|
+
requestContext,
|
|
300
225
|
workflowId,
|
|
301
226
|
runId,
|
|
302
227
|
inputData,
|
|
303
228
|
tracingOptions
|
|
304
229
|
}) {
|
|
305
|
-
return streamVNextWorkflowHandler({ mastra, workflowId, runId, inputData,
|
|
230
|
+
return streamVNextWorkflowHandler({ mastra, workflowId, runId, inputData, requestContext, tracingOptions });
|
|
306
231
|
}
|
|
307
232
|
async function streamLegacyWorkflowHandler({
|
|
308
233
|
mastra,
|
|
309
|
-
|
|
234
|
+
requestContext,
|
|
310
235
|
workflowId,
|
|
311
236
|
runId,
|
|
312
237
|
inputData,
|
|
@@ -319,15 +244,15 @@ async function streamLegacyWorkflowHandler({
|
|
|
319
244
|
if (!runId) {
|
|
320
245
|
throw new HTTPException(400, { message: "runId required to resume workflow" });
|
|
321
246
|
}
|
|
322
|
-
const { workflow } = await
|
|
247
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
323
248
|
if (!workflow) {
|
|
324
249
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
325
250
|
}
|
|
326
251
|
const serverCache = mastra.getServerCache();
|
|
327
|
-
const run = await workflow.
|
|
252
|
+
const run = await workflow.createRun({ runId });
|
|
328
253
|
const result = run.streamLegacy({
|
|
329
254
|
inputData,
|
|
330
|
-
|
|
255
|
+
requestContext,
|
|
331
256
|
onChunk: async (chunk) => {
|
|
332
257
|
if (serverCache) {
|
|
333
258
|
const cacheKey = runId;
|
|
@@ -353,7 +278,7 @@ async function observeStreamLegacyWorkflowHandler({
|
|
|
353
278
|
if (!runId) {
|
|
354
279
|
throw new HTTPException(400, { message: "runId required to observe workflow stream" });
|
|
355
280
|
}
|
|
356
|
-
const { workflow } = await
|
|
281
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
357
282
|
if (!workflow) {
|
|
358
283
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
359
284
|
}
|
|
@@ -361,7 +286,7 @@ async function observeStreamLegacyWorkflowHandler({
|
|
|
361
286
|
if (!run) {
|
|
362
287
|
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
363
288
|
}
|
|
364
|
-
const _run = await workflow.
|
|
289
|
+
const _run = await workflow.createRun({ runId, resourceId: run.resourceId });
|
|
365
290
|
const serverCache = mastra.getServerCache();
|
|
366
291
|
if (!serverCache) {
|
|
367
292
|
throw new HTTPException(500, { message: "Server cache not found" });
|
|
@@ -388,7 +313,7 @@ async function observeStreamWorkflowHandler({
|
|
|
388
313
|
}
|
|
389
314
|
async function streamVNextWorkflowHandler({
|
|
390
315
|
mastra,
|
|
391
|
-
|
|
316
|
+
requestContext,
|
|
392
317
|
workflowId,
|
|
393
318
|
runId,
|
|
394
319
|
inputData,
|
|
@@ -402,15 +327,15 @@ async function streamVNextWorkflowHandler({
|
|
|
402
327
|
if (!runId) {
|
|
403
328
|
throw new HTTPException(400, { message: "runId required to stream workflow" });
|
|
404
329
|
}
|
|
405
|
-
const { workflow } = await
|
|
330
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
406
331
|
if (!workflow) {
|
|
407
332
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
408
333
|
}
|
|
409
334
|
const serverCache = mastra.getServerCache();
|
|
410
|
-
const run = await workflow.
|
|
335
|
+
const run = await workflow.createRun({ runId });
|
|
411
336
|
const result = run.stream({
|
|
412
337
|
inputData,
|
|
413
|
-
|
|
338
|
+
requestContext,
|
|
414
339
|
closeOnSuspend,
|
|
415
340
|
tracingOptions
|
|
416
341
|
});
|
|
@@ -442,7 +367,7 @@ async function observeStreamVNextWorkflowHandler({
|
|
|
442
367
|
if (!runId) {
|
|
443
368
|
throw new HTTPException(400, { message: "runId required to observe workflow stream" });
|
|
444
369
|
}
|
|
445
|
-
const { workflow } = await
|
|
370
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
446
371
|
if (!workflow) {
|
|
447
372
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
448
373
|
}
|
|
@@ -450,7 +375,7 @@ async function observeStreamVNextWorkflowHandler({
|
|
|
450
375
|
if (!run) {
|
|
451
376
|
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
452
377
|
}
|
|
453
|
-
const _run = await workflow.
|
|
378
|
+
const _run = await workflow.createRun({ runId, resourceId: run.resourceId });
|
|
454
379
|
const serverCache = mastra.getServerCache();
|
|
455
380
|
if (!serverCache) {
|
|
456
381
|
throw new HTTPException(500, { message: "Server cache not found" });
|
|
@@ -498,7 +423,7 @@ async function resumeAsyncWorkflowHandler({
|
|
|
498
423
|
workflowId,
|
|
499
424
|
runId,
|
|
500
425
|
body,
|
|
501
|
-
|
|
426
|
+
requestContext,
|
|
502
427
|
tracingOptions
|
|
503
428
|
}) {
|
|
504
429
|
try {
|
|
@@ -508,10 +433,7 @@ async function resumeAsyncWorkflowHandler({
|
|
|
508
433
|
if (!runId) {
|
|
509
434
|
throw new HTTPException(400, { message: "runId required to resume workflow" });
|
|
510
435
|
}
|
|
511
|
-
|
|
512
|
-
throw new HTTPException(400, { message: "step required to resume workflow" });
|
|
513
|
-
}
|
|
514
|
-
const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
|
|
436
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
515
437
|
if (!workflow) {
|
|
516
438
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
517
439
|
}
|
|
@@ -519,11 +441,11 @@ async function resumeAsyncWorkflowHandler({
|
|
|
519
441
|
if (!run) {
|
|
520
442
|
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
521
443
|
}
|
|
522
|
-
const _run = await workflow.
|
|
444
|
+
const _run = await workflow.createRun({ runId, resourceId: run.resourceId });
|
|
523
445
|
const result = await _run.resume({
|
|
524
446
|
step: body.step,
|
|
525
447
|
resumeData: body.resumeData,
|
|
526
|
-
|
|
448
|
+
requestContext,
|
|
527
449
|
tracingOptions
|
|
528
450
|
});
|
|
529
451
|
return result;
|
|
@@ -536,7 +458,7 @@ async function resumeWorkflowHandler({
|
|
|
536
458
|
workflowId,
|
|
537
459
|
runId,
|
|
538
460
|
body,
|
|
539
|
-
|
|
461
|
+
requestContext,
|
|
540
462
|
tracingOptions
|
|
541
463
|
}) {
|
|
542
464
|
try {
|
|
@@ -546,10 +468,7 @@ async function resumeWorkflowHandler({
|
|
|
546
468
|
if (!runId) {
|
|
547
469
|
throw new HTTPException(400, { message: "runId required to resume workflow" });
|
|
548
470
|
}
|
|
549
|
-
|
|
550
|
-
throw new HTTPException(400, { message: "step required to resume workflow" });
|
|
551
|
-
}
|
|
552
|
-
const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
|
|
471
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
553
472
|
if (!workflow) {
|
|
554
473
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
555
474
|
}
|
|
@@ -557,11 +476,11 @@ async function resumeWorkflowHandler({
|
|
|
557
476
|
if (!run) {
|
|
558
477
|
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
559
478
|
}
|
|
560
|
-
const _run = await workflow.
|
|
479
|
+
const _run = await workflow.createRun({ runId, resourceId: run.resourceId });
|
|
561
480
|
void _run.resume({
|
|
562
481
|
step: body.step,
|
|
563
482
|
resumeData: body.resumeData,
|
|
564
|
-
|
|
483
|
+
requestContext,
|
|
565
484
|
tracingOptions
|
|
566
485
|
});
|
|
567
486
|
return { message: "Workflow run resumed" };
|
|
@@ -574,7 +493,7 @@ async function resumeStreamWorkflowHandler({
|
|
|
574
493
|
workflowId,
|
|
575
494
|
runId,
|
|
576
495
|
body,
|
|
577
|
-
|
|
496
|
+
requestContext,
|
|
578
497
|
tracingOptions
|
|
579
498
|
}) {
|
|
580
499
|
try {
|
|
@@ -584,10 +503,7 @@ async function resumeStreamWorkflowHandler({
|
|
|
584
503
|
if (!runId) {
|
|
585
504
|
throw new HTTPException(400, { message: "runId required to resume workflow" });
|
|
586
505
|
}
|
|
587
|
-
|
|
588
|
-
throw new HTTPException(400, { message: "step required to resume workflow" });
|
|
589
|
-
}
|
|
590
|
-
const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
|
|
506
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
591
507
|
if (!workflow) {
|
|
592
508
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
593
509
|
}
|
|
@@ -595,12 +511,12 @@ async function resumeStreamWorkflowHandler({
|
|
|
595
511
|
if (!run) {
|
|
596
512
|
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
597
513
|
}
|
|
598
|
-
const _run = await workflow.
|
|
514
|
+
const _run = await workflow.createRun({ runId, resourceId: run.resourceId });
|
|
599
515
|
const serverCache = mastra.getServerCache();
|
|
600
516
|
const stream = _run.resumeStream({
|
|
601
517
|
step: body.step,
|
|
602
518
|
resumeData: body.resumeData,
|
|
603
|
-
|
|
519
|
+
requestContext,
|
|
604
520
|
tracingOptions
|
|
605
521
|
}).fullStream.pipeThrough(
|
|
606
522
|
new TransformStream({
|
|
@@ -619,24 +535,30 @@ async function resumeStreamWorkflowHandler({
|
|
|
619
535
|
return handleError(error, "Error resuming workflow");
|
|
620
536
|
}
|
|
621
537
|
}
|
|
622
|
-
async function
|
|
538
|
+
async function listWorkflowRunsHandler({
|
|
623
539
|
mastra,
|
|
624
540
|
workflowId,
|
|
625
541
|
fromDate,
|
|
626
542
|
toDate,
|
|
627
|
-
|
|
628
|
-
|
|
543
|
+
perPage,
|
|
544
|
+
page,
|
|
629
545
|
resourceId
|
|
630
546
|
}) {
|
|
631
547
|
try {
|
|
632
548
|
if (!workflowId) {
|
|
633
549
|
throw new HTTPException(400, { message: "Workflow ID is required" });
|
|
634
550
|
}
|
|
635
|
-
|
|
551
|
+
if (perPage !== void 0 && perPage !== false && (!Number.isInteger(perPage) || perPage <= 0)) {
|
|
552
|
+
throw new HTTPException(400, { message: "perPage must be a positive integer or false" });
|
|
553
|
+
}
|
|
554
|
+
if (page !== void 0 && (!Number.isInteger(page) || page < 0)) {
|
|
555
|
+
throw new HTTPException(400, { message: "page must be a non-negative integer" });
|
|
556
|
+
}
|
|
557
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
636
558
|
if (!workflow) {
|
|
637
559
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
638
560
|
}
|
|
639
|
-
const workflowRuns = await workflow.
|
|
561
|
+
const workflowRuns = await workflow.listWorkflowRuns({ fromDate, toDate, perPage, page, resourceId }) || {
|
|
640
562
|
runs: [],
|
|
641
563
|
total: 0
|
|
642
564
|
};
|
|
@@ -657,7 +579,7 @@ async function cancelWorkflowRunHandler({
|
|
|
657
579
|
if (!runId) {
|
|
658
580
|
throw new HTTPException(400, { message: "runId required to cancel workflow run" });
|
|
659
581
|
}
|
|
660
|
-
const { workflow } = await
|
|
582
|
+
const { workflow } = await listWorkflowsFromSystem({ mastra, workflowId });
|
|
661
583
|
if (!workflow) {
|
|
662
584
|
throw new HTTPException(404, { message: "Workflow not found" });
|
|
663
585
|
}
|
|
@@ -665,43 +587,14 @@ async function cancelWorkflowRunHandler({
|
|
|
665
587
|
if (!run) {
|
|
666
588
|
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
667
589
|
}
|
|
668
|
-
const _run = await workflow.
|
|
590
|
+
const _run = await workflow.createRun({ runId, resourceId: run.resourceId });
|
|
669
591
|
await _run.cancel();
|
|
670
592
|
return { message: "Workflow run cancelled" };
|
|
671
593
|
} catch (error) {
|
|
672
594
|
return handleError(error, "Error canceling workflow run");
|
|
673
595
|
}
|
|
674
596
|
}
|
|
675
|
-
async function sendWorkflowRunEventHandler({
|
|
676
|
-
mastra,
|
|
677
|
-
workflowId,
|
|
678
|
-
runId,
|
|
679
|
-
event,
|
|
680
|
-
data
|
|
681
|
-
}) {
|
|
682
|
-
try {
|
|
683
|
-
if (!workflowId) {
|
|
684
|
-
throw new HTTPException(400, { message: "Workflow ID is required" });
|
|
685
|
-
}
|
|
686
|
-
if (!runId) {
|
|
687
|
-
throw new HTTPException(400, { message: "runId required to send workflow run event" });
|
|
688
|
-
}
|
|
689
|
-
const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
|
|
690
|
-
if (!workflow) {
|
|
691
|
-
throw new HTTPException(404, { message: "Workflow not found" });
|
|
692
|
-
}
|
|
693
|
-
const run = await workflow.getWorkflowRunById(runId);
|
|
694
|
-
if (!run) {
|
|
695
|
-
throw new HTTPException(404, { message: "Workflow run not found" });
|
|
696
|
-
}
|
|
697
|
-
const _run = await workflow.createRunAsync({ runId, resourceId: run.resourceId });
|
|
698
|
-
await _run.sendEvent(event, data);
|
|
699
|
-
return { message: "Workflow run event sent" };
|
|
700
|
-
} catch (error) {
|
|
701
|
-
return handleError(error, "Error sending workflow run event");
|
|
702
|
-
}
|
|
703
|
-
}
|
|
704
597
|
|
|
705
|
-
export { cancelWorkflowRunHandler, createWorkflowRunHandler, getWorkflowByIdHandler, getWorkflowRunByIdHandler, getWorkflowRunExecutionResultHandler,
|
|
706
|
-
//# sourceMappingURL=chunk-
|
|
707
|
-
//# sourceMappingURL=chunk-
|
|
598
|
+
export { cancelWorkflowRunHandler, createWorkflowRunHandler, getWorkflowByIdHandler, getWorkflowRunByIdHandler, getWorkflowRunExecutionResultHandler, listWorkflowRunsHandler, listWorkflowsHandler, observeStreamLegacyWorkflowHandler, observeStreamVNextWorkflowHandler, observeStreamWorkflowHandler, resumeAsyncWorkflowHandler, resumeStreamWorkflowHandler, resumeWorkflowHandler, startAsyncWorkflowHandler, startWorkflowRunHandler, streamLegacyWorkflowHandler, streamVNextWorkflowHandler, streamWorkflowHandler, workflows_exports };
|
|
599
|
+
//# sourceMappingURL=chunk-ZJ6KEY6H.js.map
|
|
600
|
+
//# sourceMappingURL=chunk-ZJ6KEY6H.js.map
|