import json import redis from config import Config CALENDAR_SYNC_LOCK_KEY = 'calendar_sync_lock' config = { 'type': 'api', 'name': 'Calendar Sync API Trigger', 'description': 'API-Endpunkt zum manuellen Auslösen des Calendar Sync', 'path': '/advoware/calendar/sync', 'method': 'POST', 'emits': ['calendar.sync.triggered'] } async def handler(req, context): try: # Prüfe ob bereits ein Sync läuft redis_client = redis.Redis( host=Config.REDIS_HOST, port=int(Config.REDIS_PORT), db=int(Config.REDIS_DB_CALENDAR_SYNC), socket_timeout=Config.REDIS_TIMEOUT_SECONDS ) if redis_client.get(CALENDAR_SYNC_LOCK_KEY): context.logger.info("Calendar Sync API: Sync bereits aktiv, überspringe") return { 'status': 409, 'body': { 'status': 'conflict', 'message': 'Calendar sync bereits aktiv', 'triggered_by': 'api' } } # Konfiguration aus Request-Body body = req.get('body', {}) full_content = body.get('full_content', True) context.logger.info(f"Calendar Sync API aufgerufen, full_content: {full_content}") # Setze Lock für 30 Minuten (Sync sollte max 30 Minuten dauern) redis_client.set(CALENDAR_SYNC_LOCK_KEY, 'api', ex=1800) context.logger.info("Calendar Sync API: Lock gesetzt") # Emit Event für den Sync await context.emit({ "topic": "calendar.sync.triggered", "data": { "body": { "full_content": full_content, "triggered_by": "api" } } }) return { 'status': 200, 'body': { 'status': 'triggered', 'message': 'Calendar sync wurde ausgelöst', 'full_content': full_content, 'triggered_by': 'api' } } except Exception as e: context.logger.error(f"Fehler beim API-Trigger: {e}") return { 'status': 500, 'body': { 'error': 'Internal server error', 'details': str(e) } }