Pular para o conteúdo

MCP Server para DynamoDB

O gerador connection conecta um TypeScript MCP Server a um projeto TypeScript DynamoDB, configurando o desenvolvimento local para que ambos iniciem juntos automaticamente.

Antes de usar este gerador, certifique-se de ter:

  1. Um projeto ts#mcp-server
  2. Um projeto ts#dynamodb
  1. Instale o Nx Console VSCode Plugin se ainda não o fez
  2. Abra o console Nx no VSCode
  3. Clique em Generate (UI) na seção "Common Nx Commands"
  4. Procure por @aws/nx-plugin - connection
  5. Preencha os parâmetros obrigatórios
    • Clique em Generate

    Selecione seu projeto MCP server como origem e seu projeto DynamoDB como destino. Se o projeto contiver múltiplos componentes MCP server, especifique sourceComponent para desambiguar.

    Parâmetro Tipo Padrão Descrição
    sourceProject Obrigatório string - O projeto de origem
    targetProject Obrigatório string - O projeto de destino para conectar
    sourceComponent string - O componente de origem para conectar (nome do componente, caminho relativo à raiz do projeto de origem, ou id do gerador). Use '.' para selecionar explicitamente o projeto como origem.
    targetComponent string - O componente de destino para conectar (nome do componente, caminho relativo à raiz do projeto de destino, ou id do gerador). Use '.' para selecionar explicitamente o projeto como destino.
    preferInstallDependencies boolean true Se deve preferir instalar dependências após a execução do gerador. Defina como false para adiar a instalação ao executar múltiplos geradores em lote (uma instalação ainda é executada se necessário para que os geradores subsequentes possam calcular o grafo de projetos Nx); instale uma vez no final.

    O gerador atualiza o target <mcp-server-name>-dev do MCP server em project.json para depender do target dev do projeto DynamoDB. Nenhum arquivo de código-fonte é modificado.

    Importe as factories de entidade do pacote DynamoDB e use-as dentro de createServer:

    packages/my-service/src/my-mcp/server.ts
    import { createExampleEntity } from ':my-scope/my-table';
    export const createServer = async () => {
    const server = new McpServer({ name: 'my-service', version: '1.0.0' });
    server.tool('list_examples', 'List all example items', {}, async () => {
    const entity = await createExampleEntity();
    const result = await entity.scan.go();
    return {
    content: [{ type: 'text', text: JSON.stringify(result.data) }],
    };
    });
    return server;
    };

    Para permitir que o MCP server acesse a tabela DynamoDB, conceda as permissões necessárias em sua infraestrutura.

    packages/infra/src/stacks/application-stack.ts
    import { MyTable } from ':my-scope/common-constructs';
    const table = new MyTable(this, 'Table');
    const myMcpServer = new MyMcpServer(this, 'MyMcpServer');
    table.grantReadWriteData(myMcpServer);

    grantReadWriteData concede as permissões DynamoDB e KMS ao papel de execução do MCP server.

    O gerador connection configura o target dev do seu projeto para depender do target dev do projeto DynamoDB. O DynamoDB Local será iniciado automaticamente junto com o seu projeto ao executar dev.

    A variável de ambiente LOCAL_DEV=true é definida automaticamente, então getDynamoDBClient() e resolveTableName() conectam-se à instância local do DynamoDB Local em vez da AWS.