Skip to content

TypeScript Strands Agent to MCP

The connection generator can connect your TypeScript Strands Agent to an MCP server (either TypeScript or Python).

The generator sets up all the necessary wiring so your agent can discover and invoke the MCP server’s tools, both when deployed to AWS (via Bedrock AgentCore) and when running locally.

Before using this generator, ensure you have:

  1. A TypeScript project with a Strands Agent component
  2. A project with an MCP server component (either ts#mcp-server or py#mcp-server)
  3. Both components created with computeType: BedrockAgentCoreRuntime
  1. Install the Nx Console VSCode Plugin if you haven't already
  2. Open the Nx Console in VSCode
  3. Click Generate (UI) in the "Common Nx Commands" section
  4. Search for @aws/nx-plugin - connection
  5. Fill in the required parameters
    • Click Generate

    Select your agent project as the source and your MCP server project as the target. If your projects contain multiple components, specify the sourceComponent and targetComponent options to disambiguate.

    Parameter Type Default Description
    sourceProject Required string - The source project
    targetProject Required string - The target project to connect to
    sourceComponent string - The source component to connect from (component name, path relative to source project root, or generator id). Use '.' to explicitly select the project as the source.
    targetComponent string - The target component to connect to (component name, path relative to target project root, or generator id). Use '.' to explicitly select the project as the target.

    The generator creates a shared agent-connection package and modifies your agent code:

    • Directorypackages/common/agent-connection
      • Directorysrc
        • Directoryapp
          • <mcp-server-name>-client.ts High-level client for the connected MCP server
        • Directorycore
          • agentcore-mcp-client.ts Low-level AgentCore MCP client with SigV4/JWT authentication
        • index.ts Exports all clients
      • project.json
      • tsconfig.json

    Additionally, it:

    • Transforms your agent’s agent.ts to import and use the MCP server’s tools
    • Updates the agent’s serve-local target to depend on the MCP server’s serve target
    • Installs required dependencies

    The generator transforms your agent’s agent.ts to use the MCP server’s tools:

    packages/example/src/my-agent/agent.ts
    import { Agent, tool } from '@strands-agents/sdk';
    import { MyMcpServerClient } from ':my-scope/agent-connection';
    export const getAgent = async (sessionId: string) => {
    const myMcpServerClient = await MyMcpServerClient.create(sessionId);
    return new Agent({
    systemPrompt: '...',
    tools: [myMcpServerClient],
    });
    };

    The sessionId parameter is plumbed through from the caller, ensuring consistency for Bedrock AgentCore Observability.

    After running the connection generator, you need to grant the agent permission to invoke the MCP server:

    packages/infra/src/stacks/application-stack.ts
    const mcpServer = new MyMcpServer(this, 'MyMcpServer');
    const myAgent = new MyAgent(this, 'MyAgent');
    // Grant the agent access to bedrock models
    myAgent.agentCoreRuntime.addToRolePolicy(
    new PolicyStatement({
    actions: ['bedrock:InvokeModel', 'bedrock:InvokeModelWithResponseStream'],
    resources: ['arn:aws:bedrock:*:*:foundation-model/*', 'arn:aws:bedrock:*:*:inference-profile/*'],
    }),
    );
    // Grant the agent permissions to invoke the MCP server
    mcpServer.agentCoreRuntime.grantInvoke(myAgent.agentCoreRuntime);

    The MCP server’s AgentCore runtime ARN is automatically registered in the connection namespace of Runtime Configuration by the generated CDK construct, so the agent can discover it at runtime.

    The generator configures the agent’s serve-local target to:

    1. Start the connected MCP server(s) automatically
    2. Set SERVE_LOCAL=true so the generated client uses direct HTTP transport instead of AgentCore

    Run the agent locally with:

    Terminal window
    pnpm nx <agent-name>-serve-local <project-name>

    This will start both the agent and all connected MCP servers, with the agent connecting to the MCP servers directly via HTTP on their assigned local ports.