Skip to main content

Utility library for building validated and typed AWS Lambda functions

Project description

AIBS Informatics AWS Lambda

Build Status codecov


This is a base package that can be used standalone with some core lambda functionality or as a dependency.

Package Overview

The package contains several classes and functions that make it easy to create strongly typed lambda functions with many nice-to-have features (serialization/deserialization, easy to add metrics, utilities to create batch sqs and dynamo db event bridge processing ). In addition to these base classes, you can also use a collection of general purpose lambda handler classes.

Base Classes and Functions

LambdaHandler

The LambdaHandler class provides a base class for creating strongly typed lambda functions with features like serialization/deserialization, logging, and metrics.

ApiLambdaHandler and ApiResolverBuilder

These classes extend the LambdaHandler class and provide a way to create strongly typed lambda functions that can be used as API Gateway endpoints.

Standalone Lambda Classes in this Package

Most of these lambda functions are found under src/aibs_informatics_aws_lambda/handlers/

AWS Batch Functions

Data Sync Functions

Data Sync Operations (Writing, Reading and Syncing Data)

Data Sync File System Functions (Managing Data Paths)

Demand Functions

Notification Functions

ECR Image Replicator

CLI Invocation

With this package, you can also invoke lambda functions from the command line. The CLI executable is installed as handle-lambda-request and can be used to invoke lambda functions with payloads that can be specified as JSON, files, or S3 objects.

usage: handle-lambda-request [-h] [--handler-qualified-name HANDLER_QUALIFIED_NAME] [--payload PAYLOAD] [--response-location RESPONSE_LOCATION]

CLI AWS Lambda Handler

options:
  -h, --help            show this help message and exit
  --handler-qualified-name HANDLER_QUALIFIED_NAME, --handler-name HANDLER_QUALIFIED_NAME, --handler HANDLER_QUALIFIED_NAME
                        handler function qualified name. If not provided, will try to load from ('AWS_LAMBDA_FUNCTION_HANDLER', '_HANDLER') env variables
  --payload PAYLOAD, --event PAYLOAD, -e PAYLOAD
                        event payload of function. If not provided, will try to load from AWS_LAMBDA_EVENT_PAYLOAD env variable
  --response-location RESPONSE_LOCATION, -o RESPONSE_LOCATION
                        optional response location to store response at. can be S3 or local file. If not provided, will load from AWS_LAMBDA_EVENT_RESPONSE_LOCATION env variable.

Examples

Invoking a Lambda Function with a JSON Payload
handle-lambda-request --handler-qualified-name aibs_informatics_aws_lambda.handlers.data_sync.operations.GetJSONFromFileHandler --payload '{"path": "/path/to/file.json"}' --response-location /tmp/response.json
Invoking a Lambda Function with a JSON Payload from a File
handle-lambda-request --handler-qualified-name aibs_informatics_aws_lambda.handlers.data_sync.operations.GetJSONFromFileHandler --payload-file /path/to/payload.json --response-location /tmp/response.json
Invoking a Lambda Function with a JSON Payload from S3 and Saving the Response to S3
handle-lambda-request --handler-qualified-name aibs_informatics_aws_lambda.handlers.data_sync.operations.GetJSONFromFileHandler --payload-file s3://bucket/key/payload.json --response-location s3://bucket/key/response.json
Invoking a Lambda Function with environment variables
AWS_LAMBDA_EVENT_PAYLOAD='{"path": "/path/to/file.json"}'
AWS_LAMBDA_EVENT_RESPONSE_LOCATION='/tmp/response.json'
handle-lambda-request --handler-qualified-name aibs_informatics_aws_lambda.handlers.data_sync.operations.GetJSONFromFileHandler

Testing

The package includes comprehensive tests for all handlers, which can be found under the test directory.

Contributing

Any and all PRs are welcome. Please see CONTRIBUTING.md for more information.

Licensing

This software is licensed under the Allen Institute Software License, which is the 2-clause BSD license plus a third clause that prohibits redistribution and use for commercial purposes without further permission. For more information, please visit Allen Institute Terms of Use.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aibs_informatics_aws_lambda-0.0.13.tar.gz (37.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aibs_informatics_aws_lambda-0.0.13-py3-none-any.whl (46.9 kB view details)

Uploaded Python 3

File details

Details for the file aibs_informatics_aws_lambda-0.0.13.tar.gz.

File metadata

File hashes

Hashes for aibs_informatics_aws_lambda-0.0.13.tar.gz
Algorithm Hash digest
SHA256 970e6580bd50d801a80c7b447cf6e6bd4099bfecb429f80ef79d93572640ba3d
MD5 f9257bf4ecabbf2ddcc19b1385b87e8a
BLAKE2b-256 05991be37e630e09014329c350367eab078405de9d093a5f354329a546b1d587

See more details on using hashes here.

Provenance

The following attestation bundles were made for aibs_informatics_aws_lambda-0.0.13.tar.gz:

Publisher: release.yml on AllenInstitute/aibs-informatics-aws-lambda

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file aibs_informatics_aws_lambda-0.0.13-py3-none-any.whl.

File metadata

File hashes

Hashes for aibs_informatics_aws_lambda-0.0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 cceb9e0590693ac218b534959b095a802ca233890b888a5d9a61637098cb2014
MD5 a795a7d107f8feef2e2e3fb7c4cc09fd
BLAKE2b-256 b89531f921efbb569ff9ddfea0b291df79ea361146ba87b33819d6525ff017e1

See more details on using hashes here.

Provenance

The following attestation bundles were made for aibs_informatics_aws_lambda-0.0.13-py3-none-any.whl:

Publisher: release.yml on AllenInstitute/aibs-informatics-aws-lambda

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page