Module aws_lambda_powertools.event_handler
Event handler decorators for common Lambda events
Expand source code
"""
Event handler decorators for common Lambda events
"""
from .appsync import AppSyncResolver
__all__ = ["AppSyncResolver"]
Sub-modules
aws_lambda_powertools.event_handler.appsync
Classes
class AppSyncResolver
-
AppSync resolver decorator
Example
Sample usage
from aws_lambda_powertools.event_handler import AppSyncResolver app = AppSyncResolver() @app.resolver(type_name="Query", field_name="listLocations") def list_locations(page: int = 0, size: int = 10) -> list: # Your logic to fetch locations with arguments passed in return [{"id": 100, "name": "Smooth Grooves"}] @app.resolver(type_name="Merchant", field_name="extraInfo") def get_extra_info() -> dict: # Can use "app.current_event.source" to filter within the parent context account_type = app.current_event.source["accountType"] method = "BTC" if account_type == "NEW" else "USD" return {"preferredPaymentMethod": method} @app.resolver(field_name="commonField") def common_field() -> str: # Would match all fieldNames matching 'commonField' return str(uuid.uuid4())
Expand source code
class AppSyncResolver: """ AppSync resolver decorator Example ------- **Sample usage** from aws_lambda_powertools.event_handler import AppSyncResolver app = AppSyncResolver() @app.resolver(type_name="Query", field_name="listLocations") def list_locations(page: int = 0, size: int = 10) -> list: # Your logic to fetch locations with arguments passed in return [{"id": 100, "name": "Smooth Grooves"}] @app.resolver(type_name="Merchant", field_name="extraInfo") def get_extra_info() -> dict: # Can use "app.current_event.source" to filter within the parent context account_type = app.current_event.source["accountType"] method = "BTC" if account_type == "NEW" else "USD" return {"preferredPaymentMethod": method} @app.resolver(field_name="commonField") def common_field() -> str: # Would match all fieldNames matching 'commonField' return str(uuid.uuid4()) """ current_event: AppSyncResolverEvent lambda_context: LambdaContext def __init__(self): self._resolvers: dict = {} def resolver(self, type_name: str = "*", field_name: str = None): """Registers the resolver for field_name Parameters ---------- type_name : str Type name field_name : str Field name """ def register_resolver(func): logger.debug(f"Adding resolver `{func.__name__}` for field `{type_name}.{field_name}`") self._resolvers[f"{type_name}.{field_name}"] = {"func": func} return func return register_resolver def resolve(self, event: dict, context: LambdaContext) -> Any: """Resolve field_name Parameters ---------- event : dict Lambda event context : LambdaContext Lambda context Returns ------- Any Returns the result of the resolver Raises ------- ValueError If we could not find a field resolver """ self.current_event = AppSyncResolverEvent(event) self.lambda_context = context resolver = self._get_resolver(self.current_event.type_name, self.current_event.field_name) return resolver(**self.current_event.arguments) def _get_resolver(self, type_name: str, field_name: str) -> Callable: """Get resolver for field_name Parameters ---------- type_name : str Type name field_name : str Field name Returns ------- Callable callable function and configuration """ full_name = f"{type_name}.{field_name}" resolver = self._resolvers.get(full_name, self._resolvers.get(f"*.{field_name}")) if not resolver: raise ValueError(f"No resolver found for '{full_name}'") return resolver["func"] def __call__(self, event, context) -> Any: """Implicit lambda handler which internally calls `resolve`""" return self.resolve(event, context)
Class variables
var current_event : AppSyncResolverEvent
var lambda_context : LambdaContext
Methods
def resolve(self, event: dict, context: LambdaContext) ‑> Any
-
Resolve field_name
Parameters
event
:dict
- Lambda event
context
:LambdaContext
- Lambda context
Returns
Any
- Returns the result of the resolver
Raises
ValueError
- If we could not find a field resolver
Expand source code
def resolve(self, event: dict, context: LambdaContext) -> Any: """Resolve field_name Parameters ---------- event : dict Lambda event context : LambdaContext Lambda context Returns ------- Any Returns the result of the resolver Raises ------- ValueError If we could not find a field resolver """ self.current_event = AppSyncResolverEvent(event) self.lambda_context = context resolver = self._get_resolver(self.current_event.type_name, self.current_event.field_name) return resolver(**self.current_event.arguments)
def resolver(self, type_name: str = '*', field_name: str = None)
-
Registers the resolver for field_name
Parameters
type_name
:str
- Type name
field_name
:str
- Field name
Expand source code
def resolver(self, type_name: str = "*", field_name: str = None): """Registers the resolver for field_name Parameters ---------- type_name : str Type name field_name : str Field name """ def register_resolver(func): logger.debug(f"Adding resolver `{func.__name__}` for field `{type_name}.{field_name}`") self._resolvers[f"{type_name}.{field_name}"] = {"func": func} return func return register_resolver