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.12.tar.gz (37.4 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.12-py3-none-any.whl (46.6 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for aibs_informatics_aws_lambda-0.0.12.tar.gz
Algorithm Hash digest
SHA256 6f62781351ff55452188bb3601b877e1edd86dc16101c491368cd9acc0a2219a
MD5 284cc7ae830cb0d19eaa23683ddd2a78
BLAKE2b-256 0fc20f2c05e34a4cefab0b9854f55fe24849e533804b962ba67b745f8edd9f2f

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for aibs_informatics_aws_lambda-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 1b64374e6765b9e4d2359a1a3039758e7e2996ec23f090d89a823e0fd0c9290d
MD5 0d22591e11a5585fdfc36b117d4932d1
BLAKE2b-256 daf9064d71f699c5a8cc4b0ae0b1164c209305c2422b42dd8f5a3b52b73b07dc

See more details on using hashes here.

Provenance

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