import json import redis from config import Config config = { 'type': 'api', 'name': 'Calendar Sync API Trigger', 'description': 'API-Endpunkt zum manuellen Auslösen des Calendar Sync für einen Mitarbeiter oder ALL', 'path': '/advoware/calendar/sync', 'method': 'POST', 'emits': ['calendar_sync_employee', 'calendar_sync_all'], 'flows': ['advoware'] } async def handler(req, context): try: # Konfiguration aus Request-Body body = req.get('body', {}) kuerzel = body.get('kuerzel') if not kuerzel: return { 'status': 400, 'body': { 'error': 'kuerzel required', 'message': 'Bitte kuerzel im Body angeben' } } kuerzel_upper = kuerzel.upper() if kuerzel_upper == 'ALL': # Emit sync-all event context.logger.info("Calendar Sync API: Emitting sync-all event") await context.emit({ "topic": "calendar_sync_all", "data": { "triggered_by": "api" } }) return { 'status': 200, 'body': { 'status': 'triggered', 'message': 'Calendar sync wurde für alle Mitarbeiter ausgelöst', 'triggered_by': 'api' } } else: # Einzelnes Kürzel employee_lock_key = f'calendar_sync_lock_{kuerzel_upper}' # Prüfe ob bereits ein Sync für diesen Mitarbeiter 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.set(employee_lock_key, 'api', ex=1800, nx=True) is None: context.logger.info(f"Calendar Sync API: Sync bereits aktiv für {kuerzel_upper}, überspringe") return { 'status': 409, 'body': { 'status': 'conflict', 'message': f'Calendar sync bereits aktiv für {kuerzel_upper}', 'kuerzel': kuerzel_upper, 'triggered_by': 'api' } } context.logger.info(f"Calendar Sync API aufgerufen für {kuerzel_upper}") # Lock erfolgreich gesetzt, jetzt emittieren # Emit Event für den Sync await context.emit({ "topic": "calendar_sync_employee", "data": { "kuerzel": kuerzel_upper, "triggered_by": "api" } }) return { 'status': 200, 'body': { 'status': 'triggered', 'message': f'Calendar sync wurde ausgelöst für {kuerzel_upper}', 'kuerzel': kuerzel_upper, '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) } }