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.11.tar.gz (37.6 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.11-py3-none-any.whl (46.9 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for aibs_informatics_aws_lambda-0.0.11.tar.gz
Algorithm Hash digest
SHA256 ae880a8aa70cd3a589aea1a50edeadbdada08d5ca1f3a4e6cc51322017a1b435
MD5 6d27cd2ed3dea049ebbabf47a39f021b
BLAKE2b-256 f8f0bcdcfc3f07da12ef60609dbda2e6c2473c3f304265022b4b9a5950af5de6

See more details on using hashes here.

Provenance

The following attestation bundles were made for aibs_informatics_aws_lambda-0.0.11.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.11-py3-none-any.whl.

File metadata

File hashes

Hashes for aibs_informatics_aws_lambda-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 806255aa2d1a7c77bc040013acab08d82e961b6cafdb528eba8881fbb74609fd
MD5 fe7847aa09df8e864b4d2be6acb21c10
BLAKE2b-256 cdaa36519c7ba8e70bf636fc45a5b022d11077bfad40844062ffecd9b0a3ad2b

See more details on using hashes here.

Provenance

The following attestation bundles were made for aibs_informatics_aws_lambda-0.0.11-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