Skip to main content

How It Works

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.

Registered Jobs

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

Recent Executions

JobStatusTriggerDurationResultTime
analytics-cleanupsuccessscheduler286ms03d ago
analytics-rollupsuccessscheduler184ms43d ago
grant-request-expirysuccessscheduler100ms03d ago
notification-cleanupsuccessscheduler103ms03d ago
discord-token-refreshsuccessscheduler100ms03d ago
log-cleanupsuccessscheduler106ms283d ago
telegram-token-cleanupsuccessscheduler84ms03d ago
session-cleanupsuccessscheduler72ms03d ago
analytics-rollupsuccessscheduler252ms1764d ago
grant-request-expirysuccessscheduler118ms04d ago

Key Files

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