mirror of
https://github.com/catlog22/Claude-Code-Workflow.git
synced 2026-02-10 02:24:35 +08:00
- Improved the reading of the discovery index by adding a fallback mechanism to scan directories for discovery folders if the index.json is invalid or missing. - Added sorting of discoveries by creation time in descending order. - Enhanced the `appendToIssuesJsonl` function to include deduplication logic for issues based on ID and source finding ID. - Updated the discovery route handler to reflect the number of issues added and skipped during export. - Introduced UI elements for selecting and deselecting findings in the dashboard. - Added CSS styles for exported findings and action buttons. - Implemented search functionality for filtering findings based on title, file, and description. - Added internationalization support for new UI elements. - Created scripts for automated API extraction from various project types, including FastAPI and TypeScript. - Documented the API extraction process and library bundling instructions.
169 lines
4.8 KiB
JSON
169 lines
4.8 KiB
JSON
{
|
|
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
"title": "Issues JSONL Schema",
|
|
"description": "Schema for each line in issues.jsonl (flat storage)",
|
|
"type": "object",
|
|
"required": ["id", "title", "status", "created_at"],
|
|
"properties": {
|
|
"id": {
|
|
"type": "string",
|
|
"description": "Issue ID (GH-123, ISS-xxx, DSC-001)"
|
|
},
|
|
"title": {
|
|
"type": "string"
|
|
},
|
|
"status": {
|
|
"type": "string",
|
|
"enum": ["registered", "planning", "planned", "queued", "executing", "completed", "failed", "paused"],
|
|
"default": "registered"
|
|
},
|
|
"priority": {
|
|
"type": "integer",
|
|
"minimum": 1,
|
|
"maximum": 5,
|
|
"default": 3,
|
|
"description": "1=critical, 2=high, 3=medium, 4=low, 5=trivial"
|
|
},
|
|
"context": {
|
|
"type": "string",
|
|
"description": "Issue context/description (markdown)"
|
|
},
|
|
"source": {
|
|
"type": "string",
|
|
"enum": ["github", "text", "discovery"],
|
|
"description": "Source of the issue"
|
|
},
|
|
"source_url": {
|
|
"type": "string",
|
|
"description": "Original source URL (for GitHub issues)"
|
|
},
|
|
"labels": {
|
|
"type": "array",
|
|
"items": { "type": "string" },
|
|
"description": "Issue labels/tags"
|
|
},
|
|
"discovery_context": {
|
|
"type": "object",
|
|
"description": "Enriched context from issue:discover (only when source=discovery)",
|
|
"properties": {
|
|
"discovery_id": {
|
|
"type": "string",
|
|
"description": "Source discovery session ID"
|
|
},
|
|
"perspective": {
|
|
"type": "string",
|
|
"enum": ["bug", "ux", "test", "quality", "security", "performance", "maintainability", "best-practices"]
|
|
},
|
|
"category": {
|
|
"type": "string",
|
|
"description": "Finding category (e.g., edge-case, race-condition)"
|
|
},
|
|
"file": {
|
|
"type": "string",
|
|
"description": "Primary affected file"
|
|
},
|
|
"line": {
|
|
"type": "integer",
|
|
"description": "Line number in primary file"
|
|
},
|
|
"snippet": {
|
|
"type": "string",
|
|
"description": "Code snippet showing the issue"
|
|
},
|
|
"confidence": {
|
|
"type": "number",
|
|
"minimum": 0,
|
|
"maximum": 1,
|
|
"description": "Agent confidence score"
|
|
},
|
|
"suggested_fix": {
|
|
"type": "string",
|
|
"description": "Suggested remediation from discovery"
|
|
}
|
|
}
|
|
},
|
|
"affected_components": {
|
|
"type": "array",
|
|
"items": { "type": "string" },
|
|
"description": "Files/modules affected"
|
|
},
|
|
"lifecycle_requirements": {
|
|
"type": "object",
|
|
"properties": {
|
|
"test_strategy": {
|
|
"type": "string",
|
|
"enum": ["unit", "integration", "e2e", "manual", "auto"]
|
|
},
|
|
"regression_scope": {
|
|
"type": "string",
|
|
"enum": ["affected", "related", "full"]
|
|
},
|
|
"acceptance_type": {
|
|
"type": "string",
|
|
"enum": ["automated", "manual", "both"]
|
|
},
|
|
"commit_strategy": {
|
|
"type": "string",
|
|
"enum": ["per-task", "squash", "atomic"]
|
|
}
|
|
}
|
|
},
|
|
"bound_solution_id": {
|
|
"type": "string",
|
|
"description": "ID of the bound solution (null if none bound)"
|
|
},
|
|
"solution_count": {
|
|
"type": "integer",
|
|
"default": 0,
|
|
"description": "Number of candidate solutions"
|
|
},
|
|
"created_at": {
|
|
"type": "string",
|
|
"format": "date-time"
|
|
},
|
|
"updated_at": {
|
|
"type": "string",
|
|
"format": "date-time"
|
|
},
|
|
"planned_at": {
|
|
"type": "string",
|
|
"format": "date-time"
|
|
},
|
|
"completed_at": {
|
|
"type": "string",
|
|
"format": "date-time"
|
|
}
|
|
},
|
|
"examples": [
|
|
{
|
|
"id": "DSC-001",
|
|
"title": "Fix: SQLite connection pool memory leak",
|
|
"status": "registered",
|
|
"priority": 1,
|
|
"context": "Connection pool cleanup only happens when MAX_POOL_SIZE is reached...",
|
|
"source": "discovery",
|
|
"labels": ["bug", "resource-leak", "critical"],
|
|
"discovery_context": {
|
|
"discovery_id": "DSC-20251228-182237",
|
|
"perspective": "bug",
|
|
"category": "resource-leak",
|
|
"file": "storage/sqlite_store.py",
|
|
"line": 59,
|
|
"snippet": "if len(self._pool) >= self.MAX_POOL_SIZE:\n self._cleanup_stale_connections()",
|
|
"confidence": 0.85,
|
|
"suggested_fix": "Implement periodic cleanup or weak references"
|
|
},
|
|
"affected_components": ["storage/sqlite_store.py"],
|
|
"lifecycle_requirements": {
|
|
"test_strategy": "unit",
|
|
"regression_scope": "affected",
|
|
"acceptance_type": "automated",
|
|
"commit_strategy": "per-task"
|
|
},
|
|
"bound_solution_id": null,
|
|
"solution_count": 0,
|
|
"created_at": "2025-12-28T18:22:37Z"
|
|
}
|
|
]
|
|
}
|