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', 'path': '/advoware/calendar/sync', 'method': 'POST', 'emits': ['calendar.sync.employee'] } 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' } } employee_lock_key = f'calendar_sync_lock_{kuerzel}' # 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.get(employee_lock_key): context.logger.info(f"Calendar Sync API: Sync bereits aktiv für {kuerzel}, überspringe") return { 'status': 409, 'body': { 'status': 'conflict', 'message': f'Calendar sync bereits aktiv für {kuerzel}', 'kuerzel': kuerzel, 'triggered_by': 'api' } } context.logger.info(f"Calendar Sync API aufgerufen für {kuerzel}") # Setze Lock für 30 Minuten redis_client.set(employee_lock_key, 'api', ex=1800) context.logger.info(f"Calendar Sync API: Lock gesetzt für {kuerzel}") # Emit Event für den Sync await context.emit({ "topic": "calendar.sync.employee", "data": { "kuerzel": kuerzel, "triggered_by": "api" } }) return { 'status': 200, 'body': { 'status': 'triggered', 'message': f'Calendar sync wurde ausgelöst für {kuerzel}', 'kuerzel': kuerzel, '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) } }