Ir al contenido

FastAPI a DynamoDB

El generador connection conecta una FastAPI a un proyecto Python DynamoDB, configurando el desarrollo local para que ambos se inicien juntos automáticamente.

Antes de usar este generador, asegúrate de tener:

  1. Un proyecto py#fast-api
  2. Un proyecto py#dynamodb
  1. Instale el Nx Console VSCode Plugin si aún no lo ha hecho
  2. Abra la consola Nx en VSCode
  3. Haga clic en Generate (UI) en la sección "Common Nx Commands"
  4. Busque @aws/nx-plugin - connection
  5. Complete los parámetros requeridos
    • Haga clic en Generate

    Selecciona tu proyecto FastAPI como origen y tu proyecto DynamoDB como destino.

    Parámetro Tipo Predeterminado Descripción
    sourceProject Requerido string - El proyecto de origen
    targetProject Requerido string - El proyecto de destino al que conectar
    sourceComponent string - El componente de origen desde el que conectar (nombre del componente, ruta relativa a la raíz del proyecto de origen, o id del generador). Use '.' para seleccionar explícitamente el proyecto como origen.
    targetComponent string - El componente de destino al que conectar (nombre del componente, ruta relativa a la raíz del proyecto de destino, o id del generador). Use '.' para seleccionar explícitamente el proyecto como destino.
    preferInstallDependencies boolean true Si se prefiere instalar las dependencias después de que se ejecute el generador. Establecer en false para diferir la instalación al ejecutar múltiples generadores en lote (la instalación aún se ejecuta si es necesario para que los generadores subsiguientes puedan calcular el grafo de proyectos de Nx); instalar una vez al final.

    El generador actualiza el project.json de FastAPI para agregar una dependencia desde su objetivo dev al objetivo dev del proyecto DynamoDB, y agrega el paquete DynamoDB como una dependencia del espacio de trabajo. No se modifican archivos de código fuente.

    Importa las clases de entidad del paquete DynamoDB y úsalas dentro de tus manejadores de rutas:

    packages/my_api/my_api/api.py
    from my_scope.my_table.entities.example import ExampleModel
    @app.get("/examples")
    def list_examples():
    return list(ExampleModel.scan())

    Para permitir que las funciones Lambda accedan a la tabla de DynamoDB, otorga los permisos necesarios en tu infraestructura.

    Llama a grantReadWriteData en el constructo de la tabla. Esto otorga tanto los permisos de DynamoDB como de KMS requeridos por el rol de ejecución de Lambda:

    packages/infra/src/stacks/application-stack.ts
    import { MyTable } from ':my-scope/common-constructs';
    const table = new MyTable(this, 'Table');
    const api = new Api(this, 'Api', {
    integrations: Api.defaultIntegrations(this).build(),
    });
    Object.entries(api.integrations).forEach(([, integration]) => {
    table.grantReadWriteData(integration.handler);
    });

    El generador connection configura el target dev de tu proyecto para que dependa del target dev del proyecto DynamoDB. DynamoDB Local se iniciará automáticamente junto con tu proyecto al ejecutar dev.

    La variable de entorno LOCAL_DEV=true se establece automáticamente, por lo que is_local() devuelve True y tus entidades PynamoDB se conectan a la instancia local de DynamoDB en lugar de AWS.