Helps you write Amazon Web Services Lambda functions called by Step Functions via SQS
Project description
LambdaQ
LambdaQ ("lambda queue") is a Python package that helps you to write Amazon Web Services Lambda functions that receive events from Step Functions state machines via SQS queues.
Why use it?
Frankly, I write a lot of Lambda functions that need to be invoked by Step Functions state machines via SQS queues, and my team is as bored reviewing the boilerplate as I am writing it.
I also find myself needing to upgrade Lambda functions from direct invocation to indirect via-SQS invocation for resilience, and I wanted a handler that supports both event styles during migrations.
So, LambdaQ helps you to write clean, testable Lambda functions without needing to care whether the event arrived directly or via a queue.
Example
Say you want to build a Lambda function that sums two numbers together then returns the result. You want this function to be invoked by a Step Functions state machine, and you want the function to be deployed behind an SQS queue for resilience.
With LambdaQ, your script looks like this:
from typing import Any, TypedDict
from lambdaq import Metadata, handle_event
class Inputs(TypedDict):
x: int
y: int
task_token: str
class Sum(TypedDict):
result: int
def main(event: Any, context: Any) -> Sum | None:
return handle_event(
event,
perform_sum,
task_token_key="task_token",
)
def perform_sum(inputs: Inputs, metadata: Metadata) -> Sum:
return Sum(result=inputs["x"] + inputs["y"])
The lambdaq.handle_event
function reads the invocation event, a reference to a message handler, and the key of the task token injected by the state machine.
If the task token key is omitted then the work will still be performed, but the state won't be reported back to Step Functions. This would be used, for example, for functions invoked by SQS queues that don't need to report back any status.
The message handler--perform_sum
in this example--reads a strongly-typed message and returns a strongly-typed response.
How does it work?
Behind the scenes, LambdaQ checks if the event describes a single direct invocation or a collection of (one or more) messages plucked from an SQS queue.
If the event describes a single direct invocation, LambdaQ calls the message handler then returns the response directly.
if the event describes a collection of messages from a queue then LambdaQ calls the message handler for each message, and includes calls to the Step Functions send_task_success
and send_task_failure
APIs as-and-when each message succeeds or fails.
Installation
LambdaQ requires Python 3.10 or later and can be installed from PyPI.
pip install lambdaq
Support
Please submit all your questions, feature requests and bug reports at github.com/cariad/lambdaq/issues. Thank you!
Licence
LambdaQ is open-source and released under the MIT License.
You don't have to give attribution in your project, but--as a freelance developer with rent to pay--I appreciate it!
Author
Hello! 👋 I'm Cariad Eccleston, and I'm a freelance Amazon Web Services architect, DevOps evangelist, CI/CD pipeline engineer and backend developer.
You can find me at cariad.earth, github.com/cariad, linkedin.com/in/cariad and on the Fediverse at @cariad@gamedev.lgbt.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file lambdaq-2.0.0-py3-none-any.whl
.
File metadata
- Download URL: lambdaq-2.0.0-py3-none-any.whl
- Upload date:
- Size: 7.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f8b0235eca004c13957b71fdbc7fb71994cb73ba620866552c5afb3e7e8a842f |
|
MD5 | 6e32ead8aa61e6b989829555897c83a9 |
|
BLAKE2b-256 | ebf020f64c8281d957da781a016b36d89b1f78df2849eaa25ec8339f98802d27 |