feat: Implement async import jobs with background worker#295
Merged
Conversation
This fixes fedify-dev#94 where importing follows would block the server. Changes: - Add database tables for import jobs and items with status tracking - Create background worker that polls for pending jobs every 5 seconds - Process imports in batches with concurrency control (batch 10, concurrent 5) - Add progress tracking UI with auto-refresh - Support job cancellation for in-progress imports - Graceful shutdown handling for the import worker 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <[email protected]>
Use FOR UPDATE SKIP LOCKED to ensure multiple worker instances don't process the same import job or items concurrently. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <[email protected]>
f69104f to
45db26c
Compare
Replace raw SQL `ANY(${itemIds})` with Drizzle's `inArray()` function.
The raw SQL was incorrectly generating `ANY(($3, $4, ...))` which
PostgreSQL rejects as invalid syntax (error 42809). The `inArray()`
function properly generates an `IN` clause.
Co-Authored-By: Claude <[email protected]>
Co-Authored-By: Claude <[email protected]>
dahlia
approved these changes
Nov 26, 2025
dahlia
left a comment
Member
There was a problem hiding this comment.
Thanks for your contribution! 👍 I fixed a small bug and added a changelog for this patch.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
This PR implements asynchronous import job processing with a background worker to improve the reliability and performance of account data imports (following accounts, lists, muted/blocked accounts, bookmarks). (#94)
Changes
import_jobsandimport_job_itemstables to track import job status and individual item processingsrc/import/worker.ts) that processes pending import jobs with database locking (FOR UPDATE SKIP LOCKED) to prevent duplicate processingsrc/import/processors.ts) for each import categoryBenefits
Test plan
Automated checks (passed):
pnpm check)Manual verification needed: