40 lines
923 B
Python
40 lines
923 B
Python
import json
|
|
import logging
|
|
import os
|
|
|
|
import boto3
|
|
from aws_lambda_powertools import Tracer
|
|
|
|
from common.response import ok, not_found
|
|
from libs.utils import response_error, log_json
|
|
|
|
tracer = Tracer()
|
|
|
|
logger = logging.getLogger(__name__)
|
|
logger.setLevel(os.environ.get('LOG_LEVEL') or logging.ERROR)
|
|
|
|
dynamodb = boto3.resource('dynamodb')
|
|
workflows_table = dynamodb.Table(os.environ.get('WORKFLOWS_TABLE'))
|
|
|
|
|
|
@tracer.capture_lambda_handler
|
|
def handler(event, ctx):
|
|
try:
|
|
logger.info(json.dumps(event))
|
|
|
|
name = event['pathParameters']['name']
|
|
|
|
inference = workflows_table.get_item(Key={'name': name})
|
|
|
|
if 'Item' not in inference:
|
|
return not_found(message=f'workflow with name {name} not found')
|
|
|
|
item = inference['Item']
|
|
|
|
log_json("inference job", item)
|
|
|
|
return ok(data=item, decimal=True)
|
|
|
|
except Exception as e:
|
|
return response_error(e)
|