2818936739
- Fix query param mismatch: rename GenerationStatusQuery.file_path to
path so the client's app-resume buildQuery({ path: ... }) resolves
correctly instead of always getting 400
- Remove dead _lib_id bindings from both generate handlers
- Return 202 Accepted instead of 200 from generate endpoints
- Restore OpenTelemetry span instrumentation on generate handlers
- Remove stale UNIQUE constraint from initial migration (incompatible
with plain-INSERT DAO)
- Add tests for status guard: complete_job/fail_job are no-ops when
job is already cancelled, and cancel_job by id
- Persist generation params (num_ctx, temperature, top_p, top_k, min_p,
system_prompt, persona_id) on the photo_insights table for auditing
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
29 lines
941 B
SQL
29 lines
941 B
SQL
-- Restore UNIQUE constraint
|
|
|
|
CREATE TABLE insight_generation_jobs_new (
|
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
library_id INTEGER NOT NULL DEFAULT 1,
|
|
file_path TEXT NOT NULL,
|
|
generation_type TEXT NOT NULL,
|
|
status TEXT NOT NULL DEFAULT 'running',
|
|
started_at INTEGER NOT NULL,
|
|
completed_at INTEGER,
|
|
result_insight_id INTEGER,
|
|
error_message TEXT,
|
|
UNIQUE(library_id, file_path, generation_type)
|
|
);
|
|
|
|
INSERT INTO insight_generation_jobs_new
|
|
SELECT id, library_id, file_path, generation_type, status, started_at, completed_at, result_insight_id, error_message
|
|
FROM insight_generation_jobs;
|
|
|
|
DROP TABLE insight_generation_jobs;
|
|
|
|
ALTER TABLE insight_generation_jobs_new RENAME TO insight_generation_jobs;
|
|
|
|
CREATE INDEX idx_insight_gen_jobs_file
|
|
ON insight_generation_jobs(library_id, file_path);
|
|
|
|
CREATE INDEX idx_insight_gen_jobs_status_cleanup
|
|
ON insight_generation_jobs(status, started_at);
|