Bỏ qua để đến nội dung

TypeScript Agent đến DynamoDB

Generator connection kết nối một TypeScript Agent với dự án TypeScript DynamoDB, cấu hình phát triển cục bộ để cả hai khởi động cùng nhau tự động.

Trước khi sử dụng generator này, hãy đảm bảo bạn có:

  1. Một dự án ts#agent
  2. Một dự án ts#dynamodb
  1. Cài đặt Nx Console VSCode Plugin nếu bạn chưa cài đặt
  2. Mở Nx Console trong VSCode
  3. Nhấp Generate (UI) trong phần "Common Nx Commands"
  4. Tìm kiếm @aws/nx-plugin - connection
  5. Điền các tham số bắt buộc
    • Nhấp Generate

    Chọn dự án Agent của bạn làm nguồn và dự án DynamoDB của bạn làm đích. Nếu dự án chứa nhiều thành phần agent, hãy chỉ định sourceComponent để phân biệt.

    Tham số Kiểu Mặc định Mô tả
    sourceProject Bắt buộc string - Dự án nguồn
    targetProject Bắt buộc string - Dự án đích để kết nối tới
    sourceComponent string - Component nguồn để kết nối từ đó (tên component, đường dẫn tương đối so với thư mục gốc của dự án nguồn, hoặc generator id). Sử dụng '.' để chọn rõ ràng dự án làm nguồn.
    targetComponent string - Component đích để kết nối tới (tên component, đường dẫn tương đối so với thư mục gốc của dự án đích, hoặc generator id). Sử dụng '.' để chọn rõ ràng dự án làm đích.
    preferInstallDependencies boolean true Có nên cài đặt các dependencies sau khi generator chạy hay không. Đặt thành false để trì hoãn việc cài đặt khi chạy nhiều generator liên tiếp (việc cài đặt vẫn sẽ chạy nếu cần thiết để các generator tiếp theo có thể tính toán Nx project graph); cài đặt một lần vào cuối.

    Generator cập nhật target <agent-name>-dev của agent trong project.json để phụ thuộc vào target dev của dự án DynamoDB. Không có tệp nguồn nào được sửa đổi.

    Import các entity factory từ package DynamoDB và sử dụng chúng bên trong định nghĩa agent của bạn:

    packages/my-service/src/my-agent/agent.ts
    import { createExampleEntity } from ':my-scope/my-table';
    export const getAgent = async () => {
    // ...
    return new Agent({
    tools: [
    tool({
    name: 'list_examples',
    description: 'List all example items',
    func: async () => {
    const entity = await createExampleEntity();
    const result = await entity.scan.go();
    return result.data;
    },
    }),
    ],
    });
    };

    Để cho phép hàm Lambda của agent truy cập bảng DynamoDB, hãy cấp các quyền cần thiết trong cơ sở hạ tầng của bạn.

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

    grantReadWriteData cấp cả quyền DynamoDB và KMS cho execution role của agent.

    Trình tạo connection cấu hình target dev của dự án để phụ thuộc vào target dev của dự án DynamoDB. DynamoDB Local sẽ tự động khởi động cùng với dự án của bạn khi chạy dev.

    Biến môi trường LOCAL_DEV=true được thiết lập tự động, do đó getDynamoDBClient()resolveTableName() kết nối đến instance DynamoDB Local cục bộ thay vì AWS.

    elopment” />