Refactor calendar sync: move employee loop to cron step, parallel sync per employee
This commit is contained in:
@@ -15,40 +15,30 @@ config = {
|
||||
|
||||
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")
|
||||
# Konfiguration aus Request-Body
|
||||
body = req.get('body', {})
|
||||
kuerzel = body.get('kuerzel')
|
||||
full_content = body.get('full_content', True)
|
||||
|
||||
if not kuerzel:
|
||||
context.logger.error("Calendar Sync API: kuerzel is required")
|
||||
return {
|
||||
'status': 409,
|
||||
'status': 400,
|
||||
'body': {
|
||||
'status': 'conflict',
|
||||
'message': 'Calendar sync bereits aktiv',
|
||||
'status': 'error',
|
||||
'message': 'kuerzel is required',
|
||||
'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")
|
||||
context.logger.info(f"Calendar Sync API called for {kuerzel}, full_content: {full_content}")
|
||||
|
||||
# Emit Event für den Sync
|
||||
# Emit Event für den Sync mit kuerzel
|
||||
await context.emit({
|
||||
"topic": "calendar.sync.triggered",
|
||||
"data": {
|
||||
"body": {
|
||||
"kuerzel": kuerzel,
|
||||
"full_content": full_content,
|
||||
"triggered_by": "api"
|
||||
}
|
||||
@@ -60,6 +50,7 @@ async def handler(req, context):
|
||||
'body': {
|
||||
'status': 'triggered',
|
||||
'message': 'Calendar sync wurde ausgelöst',
|
||||
'kuerzel': kuerzel,
|
||||
'full_content': full_content,
|
||||
'triggered_by': 'api'
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user