All checks were successful
G12 Leak-Guard / leak-guard (pull_request) Successful in 13s
גל-1 מבקלוג #127 (docs/ia-audit-redesign.md §4) — תיקון מקומי, ללא הגירת-IA. מקיים G2 בשכבת-ה-UI דרך INV-IA1/IA2/IA5/IA6 (docs/spec/X17). א) פערי-סנכרון (INV-IA2 — mutation מבטל כל קורא): - CAS-1/2: העלאת-DOCX/export מבטלים ['decision-blocks'] (מחוון source_of_truth) - APR-1/4: פתרון/יצירת-הערה מבטלים ['chair','pending'] (תיבה+תג-סרגל) - APR-5/ADM-2: אישור/batch הלכות מבטלים ['chair','pending']+['operations'] - APR-6/ADM-3: create/update/delete/upload פסיקה-חסרה מבטלים שניהם - LRN-6: ComparePanel גוזר בחירה מהקורפוס המרוענן (אין POST ל-id מחוק → 404) - LRN-8: מחיקת-קורפוס מבטלת רשימת-צ'אטים (chat שהתייתם לא נשאר עם קישור-קורפוס תקוע) - LRN-10/MET-1/MET-8: promote מבטל גם lessons וגם methodology (LessonsTab+/methodology) ב) נתונים-שגויים (INV-IA5 — סטטוס מגובה-צרכן): - LRN-4: KPI "דפוסי סגנון" — הוסר היחס-השקרי "מתוך total_patterns" (שאילתות עצמאיות) - LRN-5: findings_applied (דגל אינפורמטיבי-בלבד) → findings_approved (שער INV-LRN1 האמיתי) - ADM-1: halacha_backlog שהוחזר ונזרק → מרונדר ב-/diagnostics, מצביע ל-/approvals (INV-IA1) - ADM-6: מוני-סוכנים מסמנים "חלקי+" כשחברת-Paperclip לא נטענה - APR-3: מכוסה ע"י APR-1 (count+sample מאותה שאילתה; הבעיה היתה staleness-cache) - MET-6: עורך-צ'קליסטים מציג איזה case בוחר כל צ'קליסט (explainer-תחולה) - ADM-5: ערך-Container מסומן "ממתין ל-redeploy" כש-Coolify≠Container ג) מתים/jargon: - PRE-2: הוסר GET /api/precedent-library/queue/pending (אפס צרכני-frontend) - PRE-3/5: AuthorityBadge (binding/persuasive) מרונדר גם בחיפוש, לא רק בתור-הביקורת - MET-5: הוסר ז'רגון T7/T15 מטקסט-העזר ב-/methodology (INV-IA6) Invariants: מקיים INV-IA1/IA2/IA5/IA6 (X17), G2 (מקור-אמת יחיד בשכבת-UI), G10 (לא הוסר שום שער-אנושי — רק סנכרון/נתון/קוד-מת). שומר INV-LRN1. בדיקות: py_compile web/app.py ✓ · tsc --noEmit ✓ · eslint ✓ (לבד מ-learning-panel:109 unescaped-quote — קיים-מראש ב-main, מחוץ לסט-הממצאים). next build נכשל רק בגלל symlink node_modules ב-worktree (Turbopack) — ה-build ב-Docker/CI תקין. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
62 lines
1.7 KiB
TypeScript
62 lines
1.7 KiB
TypeScript
/**
|
|
* System-level hooks: diagnostics + active task snapshot.
|
|
*
|
|
* The vanilla UI polled /api/system/diagnostics and /api/system/tasks on
|
|
* an interval. We replace the polling with TanStack Query's refetchInterval
|
|
* — same effect, but participates in the shared cache and survives route
|
|
* transitions without setting up its own setInterval bookkeeping.
|
|
*/
|
|
|
|
import { useQuery } from "@tanstack/react-query";
|
|
import { apiRequest } from "./client";
|
|
|
|
export type DiagDoc = {
|
|
id: string;
|
|
title: string;
|
|
status: string;
|
|
case_number: string;
|
|
created_at: string | null;
|
|
};
|
|
|
|
/** Halacha review backlog (GAP-14 / INV-QA1 / G10) — human-gate visibility. */
|
|
export type HalachaBacklog = {
|
|
pending_review: number;
|
|
pending_clean: number;
|
|
pending_flagged: number;
|
|
approved: number;
|
|
rejected: number;
|
|
deferred: number;
|
|
published: number;
|
|
total: number;
|
|
reviewed_total: number;
|
|
oldest_pending_at: string | null;
|
|
throughput_24h: number;
|
|
throughput_7d: number;
|
|
};
|
|
|
|
export type Diagnostics = {
|
|
db_ok: boolean;
|
|
tables: Record<string, number | null>;
|
|
// ADM-1 (INV-IA5): the backend returns this human-gate counter; render it
|
|
// rather than silently dropping it. /approvals owns the action (INV-IA1).
|
|
halacha_backlog: HalachaBacklog;
|
|
failed_documents: DiagDoc[];
|
|
stuck_documents: DiagDoc[];
|
|
active_tasks: Array<{
|
|
task_id: string;
|
|
filename: string;
|
|
status: string;
|
|
step: string;
|
|
}>;
|
|
};
|
|
|
|
export function useDiagnostics() {
|
|
return useQuery({
|
|
queryKey: ["system", "diagnostics"] as const,
|
|
queryFn: ({ signal }) =>
|
|
apiRequest<Diagnostics>("/api/system/diagnostics", { signal }),
|
|
refetchInterval: 10_000,
|
|
staleTime: 5_000,
|
|
});
|
|
}
|