Zum Hauptinhalt springen

So funktioniert es

Jobs are registered in a central registry and executed via three triggers:

Cron (HTTP) Vercel cron hits /api/cron/[job]
Scheduler setInterval in persistent containers
Manual Admin dashboard at /admin/jobs

Every execution is logged to PostgreSQL with status, duration, trigger type, and result count. The runJob() wrapper handles timing and fire-and-forget logging — if the DB insert fails, the job result is still returned.

Registrierte Jobs

session-cleanup registered
log-cleanup registered
notification-cleanup registered
telegram-token-cleanup registered
discord-token-refresh registered
analytics-cleanup registered
analytics-rollup registered

Letzte Ausführungen

JobStatusAuslöserDauerErgebnisZeit
analytics-cleanupsuccessscheduler286ms04d ago
analytics-rollupsuccessscheduler184ms44d ago
grant-request-expirysuccessscheduler100ms04d ago
notification-cleanupsuccessscheduler103ms04d ago
discord-token-refreshsuccessscheduler100ms04d ago
log-cleanupsuccessscheduler106ms284d ago
telegram-token-cleanupsuccessscheduler84ms04d ago
session-cleanupsuccessscheduler72ms04d ago
analytics-rollupsuccessscheduler252ms1764d ago
grant-request-expirysuccessscheduler118ms04d ago

Wichtige Dateien

Registry src/lib/server/jobs/index.ts
Runner src/lib/server/jobs/runner.ts
Scheduler src/lib/server/jobs/scheduler.ts
Cron route src/routes/api/cron/[job]/+server.ts
Schema src/lib/server/db/schema/jobs/job-execution.ts
Admin src/routes/admin/jobs/+page.svelte