3.8 KiB
3.8 KiB
Tasks: Refactor CLI Scripts to Web Application
Feature: Refactor CLI Scripts to Web Application Status: Completed Spec: specs/010-refactor-cli-to-web/spec.md
Phase 1: Core & Infrastructure
Goal: Enhance TaskManager to support returning results and set up Connection management.
- T001 Create
backend/src/models/connection.pywithConnectionConfigmodel (ensure secure storage of credentials) - T002 Update
backend/src/core/task_manager/models.pyto addresult: Optional[Dict[str, Any]]field toTaskmodel - T003 Update
backend/src/core/task_manager/manager.pyto captureplugin.executereturn value and store it intask.result - T004 [P] Create
frontend/src/services/toolsService.jsfor generic Task API communication (run task, poll status, get result) - T005 [P] Create
frontend/src/services/connectionService.jsfor Connection API - T006 Create
frontend/src/components/tools/directory structure
Phase 2: User Story 1 - Search Datasets
Goal: Enable users to search datasets via the Web UI using a Plugin.
- T007 [US1] Implement
SearchPlugininbackend/src/plugins/search.py(port logic fromsearch_script.py, return results) - T008 [US1] Create
frontend/src/components/tools/SearchTool.sveltecomponent (triggers SearchPlugin, displays results) - T009 [US1] Create
frontend/src/routes/tools/search/+page.sveltepage
Phase 3: User Story 2 - Map Dataset Columns
Goal: Enable users to map columns using saved connections via a Plugin.
- T010 [US2] Create API endpoints for Connections (
GET,POST,DELETE) inbackend/src/api/routes/connections.py - T011 [US2] Register
connectionsrouter inbackend/src/api/routes/__init__.py - T012 [US2] Implement
MapperPlugininbackend/src/plugins/mapper.py(port logic fromrun_mapper.py, supportconnection_id) - T013 [US2] Create
frontend/src/components/tools/ConnectionForm.svelteandConnectionList.svelte - T014 [US2] Create
frontend/src/routes/settings/connections/+page.sveltefor managing connections - T015 [US2] Create
frontend/src/components/tools/MapperTool.sveltecomponent - T016 [US2] Create
frontend/src/routes/tools/mapper/+page.sveltepage
Phase 4: User Story 3 - System Debugging
Goal: Enable users to run system diagnostics via a Plugin.
- T017 [US3] Implement
DebugPlugininbackend/src/plugins/debug.py(port logic fromdebug_db_api.py,get_dataset_structure.py) - T018 [US3] Create
frontend/src/components/tools/DebugTool.sveltecomponent - T019 [US3] Create
frontend/src/routes/tools/debug/+page.sveltepage
Phase 5: Cleanup & Polish
Goal: Remove legacy scripts and ensure system stability.
- T020 Verify all new tools are functional (Manual Test)
- T021 Verify existing Backup functionality fully covers legacy
backup_script.pycapabilities - T022 Remove legacy script
search_script.py - T023 Remove legacy script
run_mapper.py - T024 Remove legacy script
debug_db_api.py - T025 Remove legacy script
get_dataset_structure.py - T026 Remove legacy script
backup_script.py - T027 Update main navigation in
frontend/src/components/Navbar.svelteto include "Tools" dropdown
Dependencies
- Phase 2 (Search) depends on Phase 1 (Task Result support)
- Phase 3 (Mapper) depends on Phase 1 (Connection Model)
- Phase 4 (Debug) depends on Phase 1 (Task Result support)
- Phase 5 (Cleanup) depends on Phase 2, 3, 4 completion
Implementation Strategy
- Core: Upgrade TaskManager first to support return values.
- Search: Implement SearchPlugin as the first "Result-returning" plugin.
- Connections: Build connection management.
- Mapper: Implement MapperPlugin using Connections.
- Debug: Implement DebugPlugin.
- Cleanup: Verify and delete.