in __app__/actions/osci-azure.py [0:0]
def main(req: func.HttpRequest) -> func.HttpResponse:
"""Handle http request and run azure function handlers"""
logging.basicConfig(format='[%(asctime)s] [%(levelname)s] %(message)s', level=logging.DEBUG)
handlers: Mapping[str, Action] = {class_var.name(): class_var for class_var in Action.__subclasses__()}
log.info(f"Find Actions subclasses: {handlers}")
success_message = {"output": "This HTTP triggered function executed."}
try:
action_name = req.route_params.get('action_name', 'list')
log.info(f"Action name: `{action_name}`")
action = handlers.get(action_name)
if not action:
raise KeyError(f"Can't find required Action for `{action_name}` azure function")
params: Dict = req.params or req.get_json()
message = action().execute(**params) or success_message
return func.HttpResponse(json.dumps(message), status_code=HTTPStatus.OK)
except Exception as ex:
ex_message = (f'Exception {ex} \n'
f'{"".join(tb.format_exception(etype=type(ex), value=ex, tb=ex.__traceback__))}')
log.error(ex_message)
return func.HttpResponse(ex_message, status_code=HTTPStatus.INTERNAL_SERVER_ERROR)