"""VMH Webhook - Beteiligte Create""" import json import datetime from typing import Any from motia import FlowContext, http, ApiRequest, ApiResponse config = { "name": "VMH Webhook Beteiligte Create", "description": "Receives create webhooks from EspoCRM for Beteiligte", "flows": ["vmh-beteiligte"], "triggers": [ http("POST", "/vmh/webhook/beteiligte/create") ], "enqueues": ["vmh.beteiligte.create"], } async def handler(request: ApiRequest, ctx: FlowContext[Any]) -> ApiResponse: """ Webhook handler for Beteiligte creation in EspoCRM. Receives batch or single entity notifications and emits queue events for each entity ID to be synced to Advoware. """ try: payload = request.body or [] ctx.logger.info("=" * 80) ctx.logger.info("📥 VMH WEBHOOK: BETEILIGTE CREATE") ctx.logger.info("=" * 80) ctx.logger.info(f"Payload: {json.dumps(payload, indent=2, ensure_ascii=False)}") ctx.logger.info("=" * 80) # Collect all IDs from batch entity_ids = set() if isinstance(payload, list): for entity in payload: if isinstance(entity, dict) and 'id' in entity: entity_ids.add(entity['id']) elif isinstance(payload, dict) and 'id' in payload: entity_ids.add(payload['id']) ctx.logger.info(f"{len(entity_ids)} IDs found for create sync") # Emit events for queue processing (deduplication via lock in event handler) for entity_id in entity_ids: await ctx.enqueue({ 'topic': 'vmh.beteiligte.create', 'data': { 'entity_id': entity_id, 'action': 'create', 'source': 'webhook', 'timestamp': datetime.datetime.now().isoformat() } }) ctx.logger.info("✅ VMH Create Webhook processed: " f"{len(entity_ids)} events emitted") return ApiResponse( status=200, body={ 'status': 'received', 'action': 'create', 'ids_count': len(entity_ids) } ) except Exception as e: ctx.logger.error("=" * 80) ctx.logger.error("❌ ERROR: VMH CREATE WEBHOOK") ctx.logger.error("=" * 80) ctx.logger.error(f"Error: {e}") ctx.logger.error(f"Entity IDs attempted: {list(entity_ids) if 'entity_ids' in locals() else 'N/A'}") ctx.logger.error(f"Full Payload: {json.dumps(request.body, indent=2, ensure_ascii=False)}") ctx.logger.error(f"Timestamp: {datetime.datetime.now().isoformat()}") ctx.logger.error("=" * 80) return ApiResponse( status=500, body={ 'error': 'Internal server error', 'details': str(e) } )