Fix auto-refresh and queue claiming

This commit is contained in:
gpt-engineer-app[bot]
2025-10-06 18:58:21 +00:00
parent 2f71312f7c
commit e1e8fa2ddc
2 changed files with 93 additions and 15 deletions

View File

@@ -0,0 +1,47 @@
-- Fix ambiguous column reference in claim_next_submission
CREATE OR REPLACE FUNCTION public.claim_next_submission(
moderator_id UUID,
lock_duration INTERVAL DEFAULT '15 minutes'
)
RETURNS TABLE (
submission_id UUID,
submission_type TEXT,
priority INTEGER,
waiting_time INTERVAL
)
LANGUAGE plpgsql
SECURITY DEFINER
SET search_path = public
AS $$
BEGIN
-- Update priority for all pending submissions first
UPDATE content_submissions
SET priority = calculate_submission_priority(id)
WHERE status IN ('pending', 'partially_approved')
AND (assigned_to IS NULL OR locked_until < NOW());
-- Claim next item with row-level lock
RETURN QUERY
UPDATE content_submissions
SET
assigned_to = moderator_id,
assigned_at = NOW(),
locked_until = NOW() + lock_duration,
first_reviewed_at = COALESCE(first_reviewed_at, NOW())
WHERE id = (
SELECT cs.id FROM content_submissions cs
WHERE cs.status IN ('pending', 'partially_approved')
AND (cs.assigned_to IS NULL OR cs.locked_until < NOW())
ORDER BY
cs.priority DESC,
cs.submitted_at ASC
LIMIT 1
FOR UPDATE SKIP LOCKED
)
RETURNING
content_submissions.id,
content_submissions.submission_type,
content_submissions.priority,
NOW() - content_submissions.submitted_at;
END;
$$;