This commit is contained in:
2025-11-11 17:06:25 -03:00
parent c00a42ea39
commit 39aedac972
30 changed files with 802 additions and 220 deletions

View File

@@ -46,6 +46,11 @@ app.include_router(orders.router, prefix='/orders')
app.include_router(orgs.custom_pricing, prefix='/orgs')
@app.get('/health')
def health():
return {'status': 'available'}
@app.exception_handler(ServiceError)
def exc_error(exc: ServiceError):
return JSONResponse(

View File

@@ -0,0 +1,45 @@
from concurrent.futures import ThreadPoolExecutor, as_completed
import requests
from aws_lambda_powertools import Logger, Tracer
from aws_lambda_powertools.utilities.data_classes import (
EventBridgeEvent,
event_source,
)
from aws_lambda_powertools.utilities.typing import LambdaContext
logger = Logger(__name__)
tracer = Tracer()
urls = ['https://bcs7fgb9og.execute-api.sa-east-1.amazonaws.com/health']
@tracer.capture_lambda_handler
@event_source(data_class=EventBridgeEvent)
def lambda_handler(event: EventBridgeEvent, context: LambdaContext) -> bool:
results = []
with ThreadPoolExecutor(max_workers=5) as executor:
futures = [executor.submit(ping, url) for url in urls]
for future in as_completed(futures):
results.append(future.result())
logger.info(results)
return True
def ping(url: str):
try:
r = requests.get(url, timeout=4)
r.raise_for_status()
except requests.exceptions.RequestException as exc:
return {
'url': url,
'error': str(exc),
}
else:
return {
'url': url,
'status': r.status_code,
}