claude-code-workflow 6.3.18 → 6.3.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/CLAUDE.md +8 -5
- package/.claude/agents/action-planning-agent.md +26 -2
- package/.claude/agents/code-developer.md +132 -43
- package/.claude/agents/debug-explore-agent.md +434 -0
- package/.claude/agents/test-fix-agent.md +14 -0
- package/.claude/commands/issue/discover.md +41 -0
- package/.claude/commands/issue/execute.md +200 -19
- package/.claude/commands/issue/new.md +1 -1
- package/.claude/commands/issue/plan.md +6 -1
- package/.claude/commands/issue/queue.md +94 -39
- package/.claude/commands/memory/swagger-docs.md +773 -0
- package/.claude/commands/workflow/brainstorm/auto-parallel.md +21 -21
- package/.claude/commands/workflow/execute.md +54 -34
- package/.claude/commands/workflow/lite-execute.md +48 -164
- package/.claude/commands/workflow/lite-fix.md +4 -4
- package/.claude/commands/workflow/lite-plan.md +5 -5
- package/.claude/commands/workflow/plan.md +27 -27
- package/.claude/commands/workflow/review.md +42 -17
- package/.claude/commands/workflow/tdd-plan.md +25 -25
- package/.claude/commands/workflow/test-fix-gen.md +10 -10
- package/.claude/commands/workflow/test-gen.md +14 -14
- package/.claude/commands/workflow/ui-design/explore-auto.md +21 -21
- package/.claude/commands/workflow/ui-design/imitate-auto.md +24 -24
- package/.claude/skills/_shared/SKILL-DESIGN-SPEC.md +693 -0
- package/.claude/skills/ccw/SKILL.md +462 -0
- package/.claude/skills/ccw/index/command-capabilities.json +127 -0
- package/.claude/skills/ccw/index/intent-rules.json +136 -0
- package/.claude/skills/ccw/index/workflow-chains.json +451 -0
- package/.claude/skills/ccw/phases/actions/bugfix.md +218 -0
- package/.claude/skills/ccw/phases/actions/coupled.md +194 -0
- package/.claude/skills/ccw/phases/actions/docs.md +93 -0
- package/.claude/skills/ccw/phases/actions/full.md +154 -0
- package/.claude/skills/ccw/phases/actions/issue.md +201 -0
- package/.claude/skills/ccw/phases/actions/rapid.md +104 -0
- package/.claude/skills/ccw/phases/actions/review-fix.md +84 -0
- package/.claude/skills/ccw/phases/actions/tdd.md +66 -0
- package/.claude/skills/ccw/phases/actions/ui.md +79 -0
- package/.claude/skills/ccw/phases/orchestrator.md +435 -0
- package/.claude/skills/ccw/specs/intent-classification.md +336 -0
- package/.claude/skills/ccw-help/SKILL.md +177 -0
- package/.claude/skills/ccw-help/index/all-agents.json +82 -0
- package/.claude/skills/{command-guide → ccw-help}/index/all-commands.json +183 -73
- package/.claude/skills/{command-guide → ccw-help}/index/by-category.json +187 -73
- package/.claude/skills/{command-guide → ccw-help}/index/by-use-case.json +295 -185
- package/.claude/skills/{command-guide → ccw-help}/index/command-relationships.json +19 -166
- package/.claude/skills/{command-guide → ccw-help}/index/essential-commands.json +10 -10
- package/.claude/skills/ccw-help/scripts/analyze_commands.py +337 -0
- package/.claude/skills/code-reviewer/README.md +340 -0
- package/.claude/skills/code-reviewer/SKILL.md +308 -0
- package/.claude/skills/code-reviewer/phases/01-code-discovery.md +246 -0
- package/.claude/skills/code-reviewer/phases/02-security-analysis.md +442 -0
- package/.claude/skills/code-reviewer/phases/03-best-practices-review.md +36 -0
- package/.claude/skills/code-reviewer/phases/04-report-generation.md +278 -0
- package/.claude/skills/code-reviewer/specs/best-practices-requirements.md +346 -0
- package/.claude/skills/code-reviewer/specs/quality-standards.md +252 -0
- package/.claude/skills/code-reviewer/specs/security-requirements.md +243 -0
- package/.claude/skills/code-reviewer/templates/best-practice-finding.md +234 -0
- package/.claude/skills/code-reviewer/templates/report-template.md +316 -0
- package/.claude/skills/code-reviewer/templates/security-finding.md +161 -0
- package/.claude/skills/skill-generator/SKILL.md +187 -0
- package/.claude/skills/skill-generator/phases/01-requirements-discovery.md +239 -0
- package/.claude/skills/skill-generator/phases/02-structure-generation.md +207 -0
- package/.claude/skills/skill-generator/phases/03-phase-generation.md +802 -0
- package/.claude/skills/skill-generator/phases/04-specs-templates.md +328 -0
- package/.claude/skills/skill-generator/phases/05-validation.md +334 -0
- package/.claude/skills/skill-generator/specs/cli-integration.md +448 -0
- package/.claude/skills/skill-generator/specs/execution-modes.md +396 -0
- package/.claude/skills/skill-generator/specs/scripting-integration.md +265 -0
- package/.claude/skills/skill-generator/specs/skill-requirements.md +466 -0
- package/.claude/skills/skill-generator/templates/autonomous-action.md +517 -0
- package/.claude/skills/skill-generator/templates/autonomous-orchestrator.md +276 -0
- package/.claude/skills/skill-generator/templates/code-analysis-action.md +503 -0
- package/.claude/skills/skill-generator/templates/llm-action.md +355 -0
- package/.claude/skills/skill-generator/templates/script-bash.md +277 -0
- package/.claude/skills/skill-generator/templates/script-python.md +198 -0
- package/.claude/skills/skill-generator/templates/sequential-phase.md +441 -0
- package/.claude/skills/skill-generator/templates/skill-md.md +156 -0
- package/.claude/workflows/chinese-response.md +15 -28
- package/.claude/workflows/cli-templates/prompts/documentation/swagger-api.txt +266 -0
- package/.claude/workflows/cli-tools-usage.md +221 -177
- package/.claude/workflows/windows-platform.md +13 -10
- package/.codex/prompts/issue-execute.md +305 -82
- package/.codex/prompts/issue-queue.md +22 -0
- package/.codex/prompts/lite-execute.md +36 -11
- package/README.md +309 -305
- package/ccw/README.md +10 -4
- package/ccw/dist/cli.d.ts.map +1 -1
- package/ccw/dist/cli.js +4 -1
- package/ccw/dist/cli.js.map +1 -1
- package/ccw/dist/commands/cli.d.ts.map +1 -1
- package/ccw/dist/commands/cli.js +131 -34
- package/ccw/dist/commands/cli.js.map +1 -1
- package/ccw/dist/commands/issue.d.ts +152 -0
- package/ccw/dist/commands/issue.d.ts.map +1 -1
- package/ccw/dist/commands/issue.js +550 -85
- package/ccw/dist/commands/issue.js.map +1 -1
- package/ccw/dist/commands/serve.d.ts +1 -0
- package/ccw/dist/commands/serve.d.ts.map +1 -1
- package/ccw/dist/commands/serve.js +12 -5
- package/ccw/dist/commands/serve.js.map +1 -1
- package/ccw/dist/commands/stop.d.ts.map +1 -1
- package/ccw/dist/commands/stop.js +29 -5
- package/ccw/dist/commands/stop.js.map +1 -1
- package/ccw/dist/commands/tool.d.ts.map +1 -1
- package/ccw/dist/commands/tool.js +19 -2
- package/ccw/dist/commands/tool.js.map +1 -1
- package/ccw/dist/commands/view.d.ts +1 -0
- package/ccw/dist/commands/view.d.ts.map +1 -1
- package/ccw/dist/commands/view.js +10 -3
- package/ccw/dist/commands/view.js.map +1 -1
- package/ccw/dist/config/cli-settings-manager.d.ts +86 -0
- package/ccw/dist/config/cli-settings-manager.d.ts.map +1 -0
- package/ccw/dist/config/cli-settings-manager.js +392 -0
- package/ccw/dist/config/cli-settings-manager.js.map +1 -0
- package/ccw/dist/config/litellm-api-config-manager.d.ts +71 -5
- package/ccw/dist/config/litellm-api-config-manager.d.ts.map +1 -1
- package/ccw/dist/config/litellm-api-config-manager.js +290 -20
- package/ccw/dist/config/litellm-api-config-manager.js.map +1 -1
- package/ccw/dist/core/auth/csrf-manager.d.ts +18 -0
- package/ccw/dist/core/auth/csrf-manager.d.ts.map +1 -0
- package/ccw/dist/core/auth/csrf-manager.js +80 -0
- package/ccw/dist/core/auth/csrf-manager.js.map +1 -0
- package/ccw/dist/core/auth/csrf-middleware.d.ts +8 -0
- package/ccw/dist/core/auth/csrf-middleware.d.ts.map +1 -0
- package/ccw/dist/core/auth/csrf-middleware.js +141 -0
- package/ccw/dist/core/auth/csrf-middleware.js.map +1 -0
- package/ccw/dist/core/auth/middleware.d.ts +15 -0
- package/ccw/dist/core/auth/middleware.d.ts.map +1 -0
- package/ccw/dist/core/auth/middleware.js +76 -0
- package/ccw/dist/core/auth/middleware.js.map +1 -0
- package/ccw/dist/core/auth/token-manager.d.ts +41 -0
- package/ccw/dist/core/auth/token-manager.d.ts.map +1 -0
- package/ccw/dist/core/auth/token-manager.js +171 -0
- package/ccw/dist/core/auth/token-manager.js.map +1 -0
- package/ccw/dist/core/cache-manager.d.ts +6 -6
- package/ccw/dist/core/cache-manager.d.ts.map +1 -1
- package/ccw/dist/core/cache-manager.js +70 -48
- package/ccw/dist/core/cache-manager.js.map +1 -1
- package/ccw/dist/core/claude-freshness.d.ts.map +1 -1
- package/ccw/dist/core/claude-freshness.js +23 -3
- package/ccw/dist/core/claude-freshness.js.map +1 -1
- package/ccw/dist/core/core-memory-store.d.ts.map +1 -1
- package/ccw/dist/core/core-memory-store.js +2 -1
- package/ccw/dist/core/core-memory-store.js.map +1 -1
- package/ccw/dist/core/cors.d.ts +3 -0
- package/ccw/dist/core/cors.d.ts.map +1 -0
- package/ccw/dist/core/cors.js +10 -0
- package/ccw/dist/core/cors.js.map +1 -0
- package/ccw/dist/core/dashboard-generator-patch.js +0 -1
- package/ccw/dist/core/dashboard-generator-patch.js.map +1 -1
- package/ccw/dist/core/dashboard-generator.d.ts.map +1 -1
- package/ccw/dist/core/dashboard-generator.js +417 -416
- package/ccw/dist/core/dashboard-generator.js.map +1 -1
- package/ccw/dist/core/data-aggregator.js +2 -2
- package/ccw/dist/core/data-aggregator.js.map +1 -1
- package/ccw/dist/core/lite-scanner.d.ts +1 -1
- package/ccw/dist/core/lite-scanner.d.ts.map +1 -1
- package/ccw/dist/core/lite-scanner.js +130 -127
- package/ccw/dist/core/lite-scanner.js.map +1 -1
- package/ccw/dist/core/routes/auth-routes.d.ts +12 -0
- package/ccw/dist/core/routes/auth-routes.d.ts.map +1 -0
- package/ccw/dist/core/routes/auth-routes.js +80 -0
- package/ccw/dist/core/routes/auth-routes.js.map +1 -0
- package/ccw/dist/core/routes/ccw-routes.d.ts +1 -14
- package/ccw/dist/core/routes/ccw-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/ccw-routes.js +9 -4
- package/ccw/dist/core/routes/ccw-routes.js.map +1 -1
- package/ccw/dist/core/routes/claude-routes.d.ts +1 -14
- package/ccw/dist/core/routes/claude-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/claude-routes.js +98 -39
- package/ccw/dist/core/routes/claude-routes.js.map +1 -1
- package/ccw/dist/core/routes/cli-routes.d.ts +14 -12
- package/ccw/dist/core/routes/cli-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/cli-routes.js +122 -43
- package/ccw/dist/core/routes/cli-routes.js.map +1 -1
- package/ccw/dist/core/routes/cli-settings-routes.d.ts +11 -0
- package/ccw/dist/core/routes/cli-settings-routes.d.ts.map +1 -0
- package/ccw/dist/core/routes/cli-settings-routes.js +204 -0
- package/ccw/dist/core/routes/cli-settings-routes.js.map +1 -0
- package/ccw/dist/core/routes/codexlens/config-handlers.d.ts +6 -0
- package/ccw/dist/core/routes/codexlens/config-handlers.d.ts.map +1 -0
- package/ccw/dist/core/routes/codexlens/config-handlers.js +1195 -0
- package/ccw/dist/core/routes/codexlens/config-handlers.js.map +1 -0
- package/ccw/dist/core/routes/codexlens/index-handlers.d.ts +10 -0
- package/ccw/dist/core/routes/codexlens/index-handlers.d.ts.map +1 -0
- package/ccw/dist/core/routes/codexlens/index-handlers.js +322 -0
- package/ccw/dist/core/routes/codexlens/index-handlers.js.map +1 -0
- package/ccw/dist/core/routes/codexlens/semantic-handlers.d.ts +6 -0
- package/ccw/dist/core/routes/codexlens/semantic-handlers.d.ts.map +1 -0
- package/ccw/dist/core/routes/codexlens/semantic-handlers.js +865 -0
- package/ccw/dist/core/routes/codexlens/semantic-handlers.js.map +1 -0
- package/ccw/dist/core/routes/codexlens/utils.d.ts +23 -0
- package/ccw/dist/core/routes/codexlens/utils.d.ts.map +1 -0
- package/ccw/dist/core/routes/codexlens/utils.js +85 -0
- package/ccw/dist/core/routes/codexlens/utils.js.map +1 -0
- package/ccw/dist/core/routes/codexlens/watcher-handlers.d.ts +13 -0
- package/ccw/dist/core/routes/codexlens/watcher-handlers.d.ts.map +1 -0
- package/ccw/dist/core/routes/codexlens/watcher-handlers.js +235 -0
- package/ccw/dist/core/routes/codexlens/watcher-handlers.js.map +1 -0
- package/ccw/dist/core/routes/codexlens-routes.d.ts +2 -11
- package/ccw/dist/core/routes/codexlens-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/codexlens-routes.js +10 -981
- package/ccw/dist/core/routes/codexlens-routes.js.map +1 -1
- package/ccw/dist/core/routes/discovery-routes.d.ts +1 -35
- package/ccw/dist/core/routes/discovery-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/discovery-routes.js +25 -0
- package/ccw/dist/core/routes/discovery-routes.js.map +1 -1
- package/ccw/dist/core/routes/files-routes.d.ts +1 -14
- package/ccw/dist/core/routes/files-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/files-routes.js +57 -14
- package/ccw/dist/core/routes/files-routes.js.map +1 -1
- package/ccw/dist/core/routes/graph-routes.d.ts +1 -14
- package/ccw/dist/core/routes/graph-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/graph-routes.js +36 -37
- package/ccw/dist/core/routes/graph-routes.js.map +1 -1
- package/ccw/dist/core/routes/help-routes.d.ts +1 -14
- package/ccw/dist/core/routes/help-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/help-routes.js +5 -0
- package/ccw/dist/core/routes/help-routes.js.map +1 -1
- package/ccw/dist/core/routes/hooks-routes.d.ts +4 -14
- package/ccw/dist/core/routes/hooks-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/hooks-routes.js +43 -21
- package/ccw/dist/core/routes/hooks-routes.js.map +1 -1
- package/ccw/dist/core/routes/issue-routes.d.ts +1 -34
- package/ccw/dist/core/routes/issue-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/issue-routes.js +24 -0
- package/ccw/dist/core/routes/issue-routes.js.map +1 -1
- package/ccw/dist/core/routes/litellm-api-routes.d.ts +1 -14
- package/ccw/dist/core/routes/litellm-api-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/litellm-api-routes.js +505 -48
- package/ccw/dist/core/routes/litellm-api-routes.js.map +1 -1
- package/ccw/dist/core/routes/litellm-routes.d.ts +1 -14
- package/ccw/dist/core/routes/litellm-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/litellm-routes.js +28 -11
- package/ccw/dist/core/routes/litellm-routes.js.map +1 -1
- package/ccw/dist/core/routes/mcp-routes.d.ts +1 -14
- package/ccw/dist/core/routes/mcp-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/mcp-routes.js +99 -30
- package/ccw/dist/core/routes/mcp-routes.js.map +1 -1
- package/ccw/dist/core/routes/mcp-templates-db.d.ts.map +1 -1
- package/ccw/dist/core/routes/mcp-templates-db.js +30 -31
- package/ccw/dist/core/routes/mcp-templates-db.js.map +1 -1
- package/ccw/dist/core/routes/memory-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/memory-routes.js +74 -24
- package/ccw/dist/core/routes/memory-routes.js.map +1 -1
- package/ccw/dist/core/routes/nav-status-routes.d.ts +3 -0
- package/ccw/dist/core/routes/nav-status-routes.d.ts.map +1 -0
- package/ccw/dist/core/routes/nav-status-routes.js +217 -0
- package/ccw/dist/core/routes/nav-status-routes.js.map +1 -0
- package/ccw/dist/core/routes/rules-routes.d.ts +1 -14
- package/ccw/dist/core/routes/rules-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/rules-routes.js +481 -58
- package/ccw/dist/core/routes/rules-routes.js.map +1 -1
- package/ccw/dist/core/routes/session-routes.d.ts +1 -14
- package/ccw/dist/core/routes/session-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/session-routes.js +15 -3
- package/ccw/dist/core/routes/session-routes.js.map +1 -1
- package/ccw/dist/core/routes/skills-routes.d.ts +1 -14
- package/ccw/dist/core/routes/skills-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/skills-routes.js +394 -112
- package/ccw/dist/core/routes/skills-routes.js.map +1 -1
- package/ccw/dist/core/routes/status-routes.d.ts +1 -14
- package/ccw/dist/core/routes/status-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/status-routes.js +4 -0
- package/ccw/dist/core/routes/status-routes.js.map +1 -1
- package/ccw/dist/core/routes/system-routes.d.ts +4 -10
- package/ccw/dist/core/routes/system-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/system-routes.js +6 -4
- package/ccw/dist/core/routes/system-routes.js.map +1 -1
- package/ccw/dist/core/routes/types.d.ts +19 -0
- package/ccw/dist/core/routes/types.d.ts.map +1 -0
- package/ccw/dist/core/routes/types.js +2 -0
- package/ccw/dist/core/routes/types.js.map +1 -0
- package/ccw/dist/core/server.d.ts.map +1 -1
- package/ccw/dist/core/server.js +201 -29
- package/ccw/dist/core/server.js.map +1 -1
- package/ccw/dist/core/services/api-key-tester.d.ts +31 -0
- package/ccw/dist/core/services/api-key-tester.d.ts.map +1 -0
- package/ccw/dist/core/services/api-key-tester.js +106 -0
- package/ccw/dist/core/services/api-key-tester.js.map +1 -0
- package/ccw/dist/core/services/health-check-service.d.ts +82 -0
- package/ccw/dist/core/services/health-check-service.d.ts.map +1 -0
- package/ccw/dist/core/services/health-check-service.js +271 -0
- package/ccw/dist/core/services/health-check-service.js.map +1 -0
- package/ccw/dist/core/websocket.d.ts +9 -7
- package/ccw/dist/core/websocket.d.ts.map +1 -1
- package/ccw/dist/core/websocket.js +9 -4
- package/ccw/dist/core/websocket.js.map +1 -1
- package/ccw/dist/tools/claude-cli-tools.d.ts +152 -28
- package/ccw/dist/tools/claude-cli-tools.d.ts.map +1 -1
- package/ccw/dist/tools/claude-cli-tools.js +490 -100
- package/ccw/dist/tools/claude-cli-tools.js.map +1 -1
- package/ccw/dist/tools/cli-config-manager.d.ts +24 -8
- package/ccw/dist/tools/cli-config-manager.d.ts.map +1 -1
- package/ccw/dist/tools/cli-config-manager.js +76 -156
- package/ccw/dist/tools/cli-config-manager.js.map +1 -1
- package/ccw/dist/tools/cli-executor-core.d.ts +85 -0
- package/ccw/dist/tools/cli-executor-core.d.ts.map +1 -0
- package/ccw/dist/tools/cli-executor-core.js +1310 -0
- package/ccw/dist/tools/cli-executor-core.js.map +1 -0
- package/ccw/dist/tools/cli-executor-state.d.ts +241 -0
- package/ccw/dist/tools/cli-executor-state.d.ts.map +1 -0
- package/ccw/dist/tools/cli-executor-state.js +392 -0
- package/ccw/dist/tools/cli-executor-state.js.map +1 -0
- package/ccw/dist/tools/cli-executor-utils.d.ts +36 -0
- package/ccw/dist/tools/cli-executor-utils.d.ts.map +1 -0
- package/ccw/dist/tools/cli-executor-utils.js +298 -0
- package/ccw/dist/tools/cli-executor-utils.js.map +1 -0
- package/ccw/dist/tools/cli-executor.d.ts +3 -377
- package/ccw/dist/tools/cli-executor.d.ts.map +1 -1
- package/ccw/dist/tools/cli-executor.js +3 -1884
- package/ccw/dist/tools/cli-executor.js.map +1 -1
- package/ccw/dist/tools/cli-history-store.d.ts +2 -0
- package/ccw/dist/tools/cli-history-store.d.ts.map +1 -1
- package/ccw/dist/tools/cli-history-store.js.map +1 -1
- package/ccw/dist/tools/cli-output-converter.d.ts +192 -0
- package/ccw/dist/tools/cli-output-converter.d.ts.map +1 -0
- package/ccw/dist/tools/cli-output-converter.js +1047 -0
- package/ccw/dist/tools/cli-output-converter.js.map +1 -0
- package/ccw/dist/tools/cli-prompt-builder.d.ts +113 -0
- package/ccw/dist/tools/cli-prompt-builder.d.ts.map +1 -0
- package/ccw/dist/tools/cli-prompt-builder.js +363 -0
- package/ccw/dist/tools/cli-prompt-builder.js.map +1 -0
- package/ccw/dist/tools/codex-lens.d.ts +15 -1
- package/ccw/dist/tools/codex-lens.d.ts.map +1 -1
- package/ccw/dist/tools/codex-lens.js +289 -55
- package/ccw/dist/tools/codex-lens.js.map +1 -1
- package/ccw/dist/tools/detect-changed-modules.d.ts.map +1 -1
- package/ccw/dist/tools/detect-changed-modules.js +22 -4
- package/ccw/dist/tools/detect-changed-modules.js.map +1 -1
- package/ccw/dist/tools/index.d.ts.map +1 -1
- package/ccw/dist/tools/index.js +2 -0
- package/ccw/dist/tools/index.js.map +1 -1
- package/ccw/dist/tools/litellm-client.d.ts.map +1 -1
- package/ccw/dist/tools/litellm-client.js +10 -4
- package/ccw/dist/tools/litellm-client.js.map +1 -1
- package/ccw/dist/tools/litellm-executor.d.ts +2 -4
- package/ccw/dist/tools/litellm-executor.d.ts.map +1 -1
- package/ccw/dist/tools/litellm-executor.js +39 -8
- package/ccw/dist/tools/litellm-executor.js.map +1 -1
- package/ccw/dist/tools/native-session-discovery.d.ts +2 -0
- package/ccw/dist/tools/native-session-discovery.d.ts.map +1 -1
- package/ccw/dist/tools/native-session-discovery.js +197 -1
- package/ccw/dist/tools/native-session-discovery.js.map +1 -1
- package/ccw/dist/tools/session-manager.d.ts.map +1 -1
- package/ccw/dist/tools/session-manager.js +79 -0
- package/ccw/dist/tools/session-manager.js.map +1 -1
- package/ccw/dist/tools/skill-context-loader.d.ts +15 -0
- package/ccw/dist/tools/skill-context-loader.d.ts.map +1 -0
- package/ccw/dist/tools/skill-context-loader.js +198 -0
- package/ccw/dist/tools/skill-context-loader.js.map +1 -0
- package/ccw/dist/tools/smart-search.d.ts +8 -3
- package/ccw/dist/tools/smart-search.d.ts.map +1 -1
- package/ccw/dist/tools/smart-search.js +378 -75
- package/ccw/dist/tools/smart-search.js.map +1 -1
- package/ccw/dist/types/cli-settings.d.ts +86 -0
- package/ccw/dist/types/cli-settings.d.ts.map +1 -0
- package/ccw/dist/types/cli-settings.js +54 -0
- package/ccw/dist/types/cli-settings.js.map +1 -0
- package/ccw/dist/types/litellm-api-config.d.ts +40 -1
- package/ccw/dist/types/litellm-api-config.d.ts.map +1 -1
- package/ccw/dist/utils/exec-constants.d.ts +25 -0
- package/ccw/dist/utils/exec-constants.d.ts.map +1 -0
- package/ccw/dist/utils/exec-constants.js +25 -0
- package/ccw/dist/utils/exec-constants.js.map +1 -0
- package/ccw/dist/utils/path-resolver.d.ts +1 -0
- package/ccw/dist/utils/path-resolver.d.ts.map +1 -1
- package/ccw/dist/utils/path-resolver.js +48 -3
- package/ccw/dist/utils/path-resolver.js.map +1 -1
- package/ccw/dist/utils/path-validator.d.ts.map +1 -1
- package/ccw/dist/utils/path-validator.js +25 -6
- package/ccw/dist/utils/path-validator.js.map +1 -1
- package/ccw/dist/utils/python-utils.d.ts.map +1 -1
- package/ccw/dist/utils/python-utils.js +27 -7
- package/ccw/dist/utils/python-utils.js.map +1 -1
- package/ccw/dist/utils/shell-escape.d.ts +8 -0
- package/ccw/dist/utils/shell-escape.d.ts.map +1 -0
- package/ccw/dist/utils/shell-escape.js +24 -0
- package/ccw/dist/utils/shell-escape.js.map +1 -0
- package/ccw/dist/utils/uv-manager.d.ts +167 -0
- package/ccw/dist/utils/uv-manager.d.ts.map +1 -0
- package/ccw/dist/utils/uv-manager.js +644 -0
- package/ccw/dist/utils/uv-manager.js.map +1 -0
- package/ccw/src/cli.ts +4 -1
- package/ccw/src/commands/cli.ts +132 -34
- package/ccw/src/commands/issue.ts +605 -91
- package/ccw/src/commands/serve.ts +15 -5
- package/ccw/src/commands/stop.ts +32 -5
- package/ccw/src/commands/tool.ts +17 -2
- package/ccw/src/commands/view.ts +13 -3
- package/ccw/src/config/cli-settings-manager.ts +460 -0
- package/ccw/src/config/litellm-api-config-manager.ts +392 -57
- package/ccw/src/core/auth/csrf-manager.ts +104 -0
- package/ccw/src/core/auth/csrf-middleware.ts +159 -0
- package/ccw/src/core/auth/middleware.ts +94 -0
- package/ccw/src/core/auth/token-manager.ts +219 -0
- package/ccw/src/core/cache-manager.ts +64 -52
- package/ccw/src/core/claude-freshness.ts +26 -6
- package/ccw/src/core/core-memory-store.ts +2 -1
- package/ccw/src/core/cors.ts +10 -0
- package/ccw/src/core/dashboard-generator-patch.ts +47 -48
- package/ccw/src/core/dashboard-generator.ts +797 -744
- package/ccw/src/core/data-aggregator.ts +667 -667
- package/ccw/src/core/lite-scanner.ts +156 -140
- package/ccw/src/core/routes/auth-routes.ts +98 -0
- package/ccw/src/core/routes/ccw-routes.ts +10 -20
- package/ccw/src/core/routes/claude-routes.ts +101 -51
- package/ccw/src/core/routes/cli-routes.ts +152 -55
- package/ccw/src/core/routes/cli-settings-routes.ts +232 -0
- package/ccw/src/core/routes/codexlens/README.md +37 -0
- package/ccw/src/core/routes/codexlens/config-handlers.ts +1269 -0
- package/ccw/src/core/routes/codexlens/index-handlers.ts +354 -0
- package/ccw/src/core/routes/codexlens/semantic-handlers.ts +931 -0
- package/ccw/src/core/routes/codexlens/utils.ts +96 -0
- package/ccw/src/core/routes/codexlens/watcher-handlers.ts +265 -0
- package/ccw/src/core/routes/codexlens-routes.ts +11 -1044
- package/ccw/src/core/routes/discovery-routes.ts +1 -12
- package/ccw/src/core/routes/files-routes.ts +112 -40
- package/ccw/src/core/routes/graph-routes.ts +39 -46
- package/ccw/src/core/routes/help-routes.ts +2 -12
- package/ccw/src/core/routes/hooks-routes.ts +83 -44
- package/ccw/src/core/routes/issue-routes.ts +1 -12
- package/ccw/src/core/routes/litellm-api-routes.ts +566 -60
- package/ccw/src/core/routes/litellm-routes.ts +35 -27
- package/ccw/src/core/routes/mcp-routes.ts +157 -60
- package/ccw/src/core/routes/mcp-routes.ts.backup +549 -550
- package/ccw/src/core/routes/mcp-templates-db.ts +267 -268
- package/ccw/src/core/routes/memory-routes.ts +76 -22
- package/ccw/src/core/routes/nav-status-routes.ts +231 -0
- package/ccw/src/core/routes/rules-routes.ts +600 -81
- package/ccw/src/core/routes/session-routes.ts +28 -22
- package/ccw/src/core/routes/skills-routes.ts +452 -132
- package/ccw/src/core/routes/status-routes.ts +1 -12
- package/ccw/src/core/routes/system-routes.ts +15 -22
- package/ccw/src/core/routes/types.ts +25 -0
- package/ccw/src/core/server.ts +651 -468
- package/ccw/src/core/services/api-key-tester.ts +137 -0
- package/ccw/src/core/services/health-check-service.ts +340 -0
- package/ccw/src/core/websocket.ts +20 -12
- package/ccw/src/templates/dashboard-css/01-base.css +109 -0
- package/ccw/src/templates/dashboard-css/10-cli-status.css +202 -0
- package/ccw/src/templates/dashboard-css/21-cli-toolmgmt.css +308 -0
- package/ccw/src/templates/dashboard-css/30-core-memory.css +20 -0
- package/ccw/src/templates/dashboard-css/31-api-settings.css +751 -14
- package/ccw/src/templates/dashboard-css/33-cli-stream-viewer.css +230 -2
- package/ccw/src/templates/dashboard-js/api.js +5 -0
- package/ccw/src/templates/dashboard-js/components/cli-status.js +279 -107
- package/ccw/src/templates/dashboard-js/components/cli-stream-viewer.js +262 -20
- package/ccw/src/templates/dashboard-js/components/hook-manager.js +105 -5
- package/ccw/src/templates/dashboard-js/components/mcp-manager.js +317 -0
- package/ccw/src/templates/dashboard-js/components/navigation.js +45 -0
- package/ccw/src/templates/dashboard-js/components/notifications.js +128 -0
- package/ccw/src/templates/dashboard-js/i18n.js +4438 -3983
- package/ccw/src/templates/dashboard-js/main.js +71 -0
- package/ccw/src/templates/dashboard-js/services.js +289 -0
- package/ccw/src/templates/dashboard-js/views/api-settings.js +5613 -3361
- package/ccw/src/templates/dashboard-js/views/claude-manager.js +1 -7
- package/ccw/src/templates/dashboard-js/views/cli-manager.js +581 -87
- package/ccw/src/templates/dashboard-js/views/codexlens-manager.js +6091 -1965
- package/ccw/src/templates/dashboard-js/views/core-memory.js +129 -20
- package/ccw/src/templates/dashboard-js/views/hook-manager.js +17 -3
- package/ccw/src/templates/dashboard-js/views/mcp-manager.js +63 -0
- package/ccw/src/templates/dashboard-js/views/project-overview.js +182 -37
- package/ccw/src/templates/dashboard-js/views/rules-manager.js +26 -3
- package/ccw/src/templates/dashboard-js/views/skills-manager.js +2 -42
- package/ccw/src/templates/dashboard.html +6 -0
- package/ccw/src/tools/README.md +29 -0
- package/ccw/src/tools/claude-cli-tools.ts +640 -125
- package/ccw/src/tools/cli-config-manager.ts +102 -172
- package/ccw/src/tools/cli-executor-core.ts +1533 -0
- package/ccw/src/tools/cli-executor-state.ts +560 -0
- package/ccw/src/tools/cli-executor-utils.ts +349 -0
- package/ccw/src/tools/cli-executor.ts +3 -2309
- package/ccw/src/tools/cli-history-store.ts +2 -0
- package/ccw/src/tools/cli-output-converter.ts +1237 -0
- package/ccw/src/tools/cli-prompt-builder.ts +487 -0
- package/ccw/src/tools/codex-lens.ts +324 -59
- package/ccw/src/tools/detect-changed-modules.ts +24 -6
- package/ccw/src/tools/index.ts +2 -0
- package/ccw/src/tools/litellm-client.ts +10 -4
- package/ccw/src/tools/litellm-executor.ts +146 -114
- package/ccw/src/tools/native-session-discovery.ts +209 -1
- package/ccw/src/tools/session-manager.ts +88 -0
- package/ccw/src/tools/skill-context-loader.ts +213 -0
- package/ccw/src/tools/smart-search.ts +427 -76
- package/ccw/src/types/cli-settings.ts +137 -0
- package/ccw/src/types/litellm-api-config.ts +55 -1
- package/ccw/src/utils/exec-constants.ts +24 -0
- package/ccw/src/utils/path-resolver.ts +49 -3
- package/ccw/src/utils/path-validator.ts +28 -6
- package/ccw/src/utils/python-utils.ts +140 -121
- package/ccw/src/utils/shell-escape.ts +30 -0
- package/ccw/src/utils/uv-manager.ts +796 -0
- package/ccw-litellm/src/ccw_litellm/__pycache__/__init__.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/__pycache__/__init__.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/__pycache__/__init__.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/__pycache__/__init__.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/__pycache__/litellm_embedder.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/__pycache__/litellm_embedder.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/__pycache__/litellm_embedder.cpython-313.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/__pycache__/litellm_llm.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/__pycache__/litellm_llm.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/__pycache__/litellm_llm.cpython-313.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/clients/litellm_embedder.py +270 -251
- package/ccw-litellm/src/ccw_litellm/clients/litellm_llm.py +33 -0
- package/ccw-litellm/src/ccw_litellm/config/__pycache__/__init__.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/config/__pycache__/__init__.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/config/__pycache__/loader.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/config/__pycache__/loader.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/config/__pycache__/loader.cpython-313.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/config/__pycache__/models.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/config/__pycache__/models.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/config/__pycache__/models.cpython-313.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/config/loader.py +343 -316
- package/ccw-litellm/src/ccw_litellm/config/models.py +162 -130
- package/ccw-litellm/src/ccw_litellm/interfaces/__pycache__/__init__.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/interfaces/__pycache__/__init__.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/interfaces/__pycache__/embedder.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/interfaces/__pycache__/embedder.cpython-312.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/interfaces/__pycache__/llm.cpython-310.pyc +0 -0
- package/ccw-litellm/src/ccw_litellm/interfaces/__pycache__/llm.cpython-312.pyc +0 -0
- package/codex-lens/pyproject.toml +43 -0
- package/codex-lens/src/codexlens/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/__init__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/__main__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/__main__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/config.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/config.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/config.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/entities.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/entities.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/entities.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/env_config.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/env_config.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/env_config.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/errors.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/errors.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/__init__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/output.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/output.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/cli/commands.py +4416 -2295
- package/codex-lens/src/codexlens/cli/embedding_manager.py +767 -14
- package/codex-lens/src/codexlens/cli/model_manager.py +676 -0
- package/codex-lens/src/codexlens/config.py +321 -12
- package/codex-lens/src/codexlens/entities.py +4 -1
- package/codex-lens/src/codexlens/env_config.py +298 -0
- package/codex-lens/src/codexlens/indexing/__init__.py +23 -1
- package/codex-lens/src/codexlens/indexing/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/indexing/__pycache__/embedding.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/indexing/__pycache__/symbol_extractor.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/indexing/embedding.py +582 -0
- package/codex-lens/src/codexlens/indexing/symbol_extractor.py +62 -28
- package/codex-lens/src/codexlens/parsers/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/__init__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/tokenizer.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/tokenizer.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/factory.py +139 -10
- package/codex-lens/src/codexlens/parsers/treesitter_parser.py +487 -13
- package/codex-lens/src/codexlens/search/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/__init__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/binary_searcher.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/enrichment.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/graph_expander.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/binary_searcher.py +277 -0
- package/codex-lens/src/codexlens/search/chain_search.py +1642 -8
- package/codex-lens/src/codexlens/search/enrichment.py +21 -0
- package/codex-lens/src/codexlens/search/graph_expander.py +264 -0
- package/codex-lens/src/codexlens/search/hybrid_search.py +772 -37
- package/codex-lens/src/codexlens/search/ranking.py +347 -8
- package/codex-lens/src/codexlens/semantic/SPLADE_IMPLEMENTATION.md +225 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/__init__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/base.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/base.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/chunker.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/chunker.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/embedder.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/embedder.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/factory.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/factory.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/factory.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/gpu_support.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/gpu_support.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/gpu_support.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/litellm_embedder.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/litellm_embedder.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/litellm_embedder.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/reranker.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/splade_encoder.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/splade_encoder.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/splade_encoder.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/ann_index.py +654 -0
- package/codex-lens/src/codexlens/semantic/factory.py +63 -3
- package/codex-lens/src/codexlens/semantic/gpu_support.py +19 -2
- package/codex-lens/src/codexlens/semantic/litellm_embedder.py +144 -144
- package/codex-lens/src/codexlens/semantic/reranker/__init__.py +25 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/api_reranker.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/api_reranker.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/base.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/base.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/factory.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/factory.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/fastembed_reranker.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/fastembed_reranker.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/legacy.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/legacy.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/litellm_reranker.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/onnx_reranker.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/__pycache__/onnx_reranker.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/reranker/api_reranker.py +403 -0
- package/codex-lens/src/codexlens/semantic/reranker/base.py +46 -0
- package/codex-lens/src/codexlens/semantic/reranker/factory.py +159 -0
- package/codex-lens/src/codexlens/semantic/reranker/fastembed_reranker.py +257 -0
- package/codex-lens/src/codexlens/semantic/reranker/legacy.py +91 -0
- package/codex-lens/src/codexlens/semantic/reranker/litellm_reranker.py +214 -0
- package/codex-lens/src/codexlens/semantic/reranker/onnx_reranker.py +268 -0
- package/codex-lens/src/codexlens/semantic/splade_encoder.py +567 -0
- package/codex-lens/src/codexlens/semantic/vector_store.py +472 -352
- package/codex-lens/src/codexlens/storage/__init__.py +3 -0
- package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/global_index.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/global_index.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/merkle_tree.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/path_mapper.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/path_mapper.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/registry.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/registry.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/splade_index.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/splade_index.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/splade_index.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/sqlite_utils.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/sqlite_utils.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/vector_meta_store.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/vector_meta_store.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/vector_meta_store.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/dir_index.py +310 -12
- package/codex-lens/src/codexlens/storage/index_tree.py +194 -23
- package/codex-lens/src/codexlens/storage/merkle_tree.py +136 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/__init__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_006_enhance_relationships.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_007_add_graph_neighbors.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_007_add_graph_neighbors.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_007_add_graph_neighbors.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_008_add_merkle_hashes.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_009_add_splade.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_010_add_multi_vector_chunks.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_006_enhance_relationships.py +37 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_007_add_graph_neighbors.py +47 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_008_add_merkle_hashes.py +81 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_009_add_splade.py +103 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_010_add_multi_vector_chunks.py +162 -0
- package/codex-lens/src/codexlens/storage/splade_index.py +578 -0
- package/codex-lens/src/codexlens/storage/sqlite_store.py +508 -184
- package/codex-lens/src/codexlens/storage/vector_meta_store.py +415 -0
- package/codex-lens/src/codexlens/watcher/__init__.py +17 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/__init__.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/__init__.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/events.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/events.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/events.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/file_watcher.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/file_watcher.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/file_watcher.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/incremental_indexer.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/incremental_indexer.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/incremental_indexer.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/manager.cpython-310.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/manager.cpython-312.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/__pycache__/manager.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/watcher/events.py +82 -0
- package/codex-lens/src/codexlens/watcher/file_watcher.py +347 -0
- package/codex-lens/src/codexlens/watcher/incremental_indexer.py +369 -0
- package/codex-lens/src/codexlens/watcher/manager.py +255 -0
- package/package.json +4 -1
- package/.claude/commands/workflow/docs/analyze.md +0 -1467
- package/.claude/commands/workflow/docs/copyright.md +0 -1265
- package/.claude/skills/command-guide/SKILL.md +0 -388
- package/.claude/skills/command-guide/UPDATE-GUIDELINE.md +0 -592
- package/.claude/skills/command-guide/guides/cli-tools-guide.md +0 -410
- package/.claude/skills/command-guide/guides/examples.md +0 -537
- package/.claude/skills/command-guide/guides/getting-started.md +0 -242
- package/.claude/skills/command-guide/guides/implementation-details.md +0 -1010
- package/.claude/skills/command-guide/guides/index-structure.md +0 -326
- package/.claude/skills/command-guide/guides/troubleshooting.md +0 -92
- package/.claude/skills/command-guide/guides/ui-design-workflow-guide.md +0 -316
- package/.claude/skills/command-guide/guides/workflow-patterns.md +0 -662
- package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +0 -855
- package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +0 -267
- package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +0 -182
- package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +0 -446
- package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +0 -558
- package/.claude/skills/command-guide/reference/agents/code-developer.md +0 -311
- package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +0 -308
- package/.claude/skills/command-guide/reference/agents/context-search-agent.md +0 -581
- package/.claude/skills/command-guide/reference/agents/doc-generator.md +0 -330
- package/.claude/skills/command-guide/reference/agents/memory-bridge.md +0 -94
- package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +0 -400
- package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +0 -344
- package/.claude/skills/command-guide/reference/agents/ui-design-agent.md +0 -593
- package/.claude/skills/command-guide/reference/agents/universal-executor.md +0 -131
- package/.claude/skills/command-guide/reference/commands/cli/cli-init.md +0 -440
- package/.claude/skills/command-guide/reference/commands/enhance-prompt.md +0 -93
- package/.claude/skills/command-guide/reference/commands/memory/code-map-memory.md +0 -687
- package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +0 -471
- package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +0 -386
- package/.claude/skills/command-guide/reference/commands/memory/docs.md +0 -616
- package/.claude/skills/command-guide/reference/commands/memory/load-skill-memory.md +0 -182
- package/.claude/skills/command-guide/reference/commands/memory/load.md +0 -240
- package/.claude/skills/command-guide/reference/commands/memory/skill-memory.md +0 -525
- package/.claude/skills/command-guide/reference/commands/memory/style-skill-memory.md +0 -396
- package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +0 -314
- package/.claude/skills/command-guide/reference/commands/memory/update-full.md +0 -332
- package/.claude/skills/command-guide/reference/commands/memory/update-related.md +0 -332
- package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +0 -517
- package/.claude/skills/command-guide/reference/commands/task/breakdown.md +0 -204
- package/.claude/skills/command-guide/reference/commands/task/create.md +0 -152
- package/.claude/skills/command-guide/reference/commands/task/execute.md +0 -270
- package/.claude/skills/command-guide/reference/commands/task/replan.md +0 -437
- package/.claude/skills/command-guide/reference/commands/version.md +0 -254
- package/.claude/skills/command-guide/reference/commands/workflow/action-plan-verify.md +0 -447
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +0 -585
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/artifacts.md +0 -452
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +0 -443
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +0 -220
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/synthesis.md +0 -398
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +0 -387
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +0 -221
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +0 -221
- package/.claude/skills/command-guide/reference/commands/workflow/execute.md +0 -465
- package/.claude/skills/command-guide/reference/commands/workflow/init.md +0 -164
- package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +0 -748
- package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +0 -664
- package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +0 -645
- package/.claude/skills/command-guide/reference/commands/workflow/plan.md +0 -551
- package/.claude/skills/command-guide/reference/commands/workflow/replan.md +0 -515
- package/.claude/skills/command-guide/reference/commands/workflow/review-fix.md +0 -606
- package/.claude/skills/command-guide/reference/commands/workflow/review-module-cycle.md +0 -765
- package/.claude/skills/command-guide/reference/commands/workflow/review-session-cycle.md +0 -776
- package/.claude/skills/command-guide/reference/commands/workflow/review.md +0 -298
- package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +0 -547
- package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +0 -114
- package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +0 -77
- package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +0 -257
- package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +0 -460
- package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +0 -400
- package/.claude/skills/command-guide/reference/commands/workflow/test-cycle-execute.md +0 -498
- package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +0 -699
- package/.claude/skills/command-guide/reference/commands/workflow/test-gen.md +0 -529
- package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +0 -766
- package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +0 -433
- package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +0 -487
- package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +0 -518
- package/.claude/skills/command-guide/reference/commands/workflow/tools/tdd-coverage-analysis.md +0 -309
- package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +0 -163
- package/.claude/skills/command-guide/reference/commands/workflow/tools/test-context-gather.md +0 -232
- package/.claude/skills/command-guide/reference/commands/workflow/tools/test-task-generate.md +0 -254
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/animation-extract.md +0 -1150
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/codify-style.md +0 -652
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/design-sync.md +0 -454
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/explore-auto.md +0 -678
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/generate.md +0 -504
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/imitate-auto.md +0 -745
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +0 -537
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/layout-extract.md +0 -788
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/reference-page-generator.md +0 -356
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/style-extract.md +0 -773
- package/.claude/skills/command-guide/scripts/analyze_commands.py +0 -502
- package/.claude/skills/command-guide/scripts/update-index.sh +0 -130
- package/.claude/skills/command-guide/templates/issue-bug.md +0 -104
- package/.claude/skills/command-guide/templates/issue-diagnosis.md +0 -275
- package/.claude/skills/command-guide/templates/issue-feature.md +0 -97
- package/.claude/skills/command-guide/templates/issue-question.md +0 -141
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* Manages provider credentials, custom endpoints, and cache settings
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';
|
|
6
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync, chmodSync } from 'fs';
|
|
7
7
|
import { homedir } from 'os';
|
|
8
8
|
import { join } from 'path';
|
|
9
9
|
import { StoragePaths, GlobalPaths, ensureStorageDir } from './storage-paths.js';
|
|
@@ -18,6 +18,10 @@ import type {
|
|
|
18
18
|
CodexLensEmbeddingProvider,
|
|
19
19
|
EmbeddingPoolConfig,
|
|
20
20
|
} from '../types/litellm-api-config.js';
|
|
21
|
+
import {
|
|
22
|
+
addClaudeApiEndpoint,
|
|
23
|
+
removeClaudeApiEndpoint
|
|
24
|
+
} from '../tools/claude-cli-tools.js';
|
|
21
25
|
|
|
22
26
|
/**
|
|
23
27
|
* Default configuration
|
|
@@ -44,6 +48,14 @@ function getConfigPath(_baseDir?: string): string {
|
|
|
44
48
|
return join(configDir, 'litellm-api-config.json');
|
|
45
49
|
}
|
|
46
50
|
|
|
51
|
+
function bestEffortRestrictPermissions(filePath: string, mode: number): void {
|
|
52
|
+
try {
|
|
53
|
+
chmodSync(filePath, mode);
|
|
54
|
+
} catch {
|
|
55
|
+
// Ignore permission errors (e.g., Windows or restrictive environments)
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
47
59
|
/**
|
|
48
60
|
* Load configuration from file
|
|
49
61
|
*/
|
|
@@ -68,7 +80,8 @@ export function loadLiteLLMApiConfig(baseDir: string): LiteLLMApiConfig {
|
|
|
68
80
|
*/
|
|
69
81
|
function saveConfig(baseDir: string, config: LiteLLMApiConfig): void {
|
|
70
82
|
const configPath = getConfigPath(baseDir);
|
|
71
|
-
writeFileSync(configPath, JSON.stringify(config, null, 2), '
|
|
83
|
+
writeFileSync(configPath, JSON.stringify(config, null, 2), { encoding: 'utf8', mode: 0o600 });
|
|
84
|
+
bestEffortRestrictPermissions(configPath, 0o600);
|
|
72
85
|
}
|
|
73
86
|
|
|
74
87
|
/**
|
|
@@ -117,10 +130,26 @@ export function getProviderWithResolvedEnvVars(
|
|
|
117
130
|
const provider = getProvider(baseDir, providerId);
|
|
118
131
|
if (!provider) return null;
|
|
119
132
|
|
|
120
|
-
|
|
133
|
+
const resolvedApiKey = resolveEnvVar(provider.apiKey);
|
|
134
|
+
|
|
135
|
+
// Avoid leaking env-var syntax or secrets if this object is logged/serialized.
|
|
136
|
+
const sanitizedProvider: ProviderCredential = {
|
|
121
137
|
...provider,
|
|
122
|
-
|
|
138
|
+
apiKey: '***',
|
|
139
|
+
apiKeys: provider.apiKeys?.map(keyEntry => ({
|
|
140
|
+
...keyEntry,
|
|
141
|
+
key: '***',
|
|
142
|
+
})),
|
|
123
143
|
};
|
|
144
|
+
|
|
145
|
+
Object.defineProperty(sanitizedProvider, 'resolvedApiKey', {
|
|
146
|
+
value: resolvedApiKey,
|
|
147
|
+
enumerable: false,
|
|
148
|
+
writable: false,
|
|
149
|
+
configurable: false,
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
return sanitizedProvider as ProviderCredential & { resolvedApiKey: string };
|
|
124
153
|
}
|
|
125
154
|
|
|
126
155
|
/**
|
|
@@ -245,6 +274,20 @@ export function addEndpoint(
|
|
|
245
274
|
config.endpoints.push(endpoint);
|
|
246
275
|
saveConfig(baseDir, config);
|
|
247
276
|
|
|
277
|
+
// Sync to cli-tools.json as api-endpoint type
|
|
278
|
+
// Usage: ccw cli -p "..." --tool <endpoint-id>
|
|
279
|
+
try {
|
|
280
|
+
addClaudeApiEndpoint(homedir(), {
|
|
281
|
+
id: endpoint.id,
|
|
282
|
+
name: endpoint.id, // Use endpoint ID as tool name for CLI access
|
|
283
|
+
enabled: endpoint.enabled !== false
|
|
284
|
+
});
|
|
285
|
+
console.log(`[LiteLLM Config] Synced endpoint ${endpoint.id} to cli-tools.json (api-endpoint)`);
|
|
286
|
+
} catch (syncError) {
|
|
287
|
+
console.warn(`[LiteLLM Config] Failed to sync endpoint to cli-tools.json: ${syncError}`);
|
|
288
|
+
// Non-fatal: continue even if sync fails
|
|
289
|
+
}
|
|
290
|
+
|
|
248
291
|
return endpoint;
|
|
249
292
|
}
|
|
250
293
|
|
|
@@ -275,7 +318,21 @@ export function updateEndpoint(
|
|
|
275
318
|
};
|
|
276
319
|
|
|
277
320
|
saveConfig(baseDir, config);
|
|
278
|
-
|
|
321
|
+
|
|
322
|
+
// Sync enabled status to cli-tools.json
|
|
323
|
+
const updatedEndpoint = config.endpoints[endpointIndex];
|
|
324
|
+
try {
|
|
325
|
+
addClaudeApiEndpoint(homedir(), {
|
|
326
|
+
id: updatedEndpoint.id,
|
|
327
|
+
name: updatedEndpoint.id,
|
|
328
|
+
enabled: updatedEndpoint.enabled !== false
|
|
329
|
+
});
|
|
330
|
+
console.log(`[LiteLLM Config] Synced endpoint ${updatedEndpoint.id} update to cli-tools.json`);
|
|
331
|
+
} catch (syncError) {
|
|
332
|
+
console.warn(`[LiteLLM Config] Failed to sync endpoint update to cli-tools.json: ${syncError}`);
|
|
333
|
+
}
|
|
334
|
+
|
|
335
|
+
return updatedEndpoint;
|
|
279
336
|
}
|
|
280
337
|
|
|
281
338
|
/**
|
|
@@ -297,6 +354,15 @@ export function deleteEndpoint(baseDir: string, endpointId: string): boolean {
|
|
|
297
354
|
}
|
|
298
355
|
|
|
299
356
|
saveConfig(baseDir, config);
|
|
357
|
+
|
|
358
|
+
// Remove from cli-tools.json
|
|
359
|
+
try {
|
|
360
|
+
removeClaudeApiEndpoint(homedir(), endpointId);
|
|
361
|
+
console.log(`[LiteLLM Config] Removed endpoint ${endpointId} from cli-tools.json`);
|
|
362
|
+
} catch (syncError) {
|
|
363
|
+
console.warn(`[LiteLLM Config] Failed to remove endpoint from cli-tools.json: ${syncError}`);
|
|
364
|
+
}
|
|
365
|
+
|
|
300
366
|
return true;
|
|
301
367
|
}
|
|
302
368
|
|
|
@@ -479,18 +545,34 @@ export function getEmbeddingProvidersForRotation(baseDir: string): Array<{
|
|
|
479
545
|
}
|
|
480
546
|
|
|
481
547
|
/**
|
|
482
|
-
*
|
|
483
|
-
* Creates endpoint list from rotation config for parallel embedding
|
|
484
|
-
* Supports both legacy codexlensEmbeddingRotation and new embeddingPoolConfig
|
|
548
|
+
* Extended rotation endpoint with routing and health check info
|
|
485
549
|
*/
|
|
486
|
-
export
|
|
550
|
+
export interface RotationEndpointConfig {
|
|
487
551
|
name: string;
|
|
488
552
|
api_key: string;
|
|
489
553
|
api_base: string;
|
|
490
554
|
model: string;
|
|
491
555
|
weight: number;
|
|
492
556
|
max_concurrent: number;
|
|
493
|
-
|
|
557
|
+
/** Routing strategy for load balancing */
|
|
558
|
+
routing_strategy?: string;
|
|
559
|
+
/** Health check configuration */
|
|
560
|
+
health_check?: {
|
|
561
|
+
enabled: boolean;
|
|
562
|
+
interval_seconds: number;
|
|
563
|
+
cooldown_seconds: number;
|
|
564
|
+
failure_threshold: number;
|
|
565
|
+
};
|
|
566
|
+
/** Last recorded latency in milliseconds */
|
|
567
|
+
last_latency_ms?: number;
|
|
568
|
+
}
|
|
569
|
+
|
|
570
|
+
/**
|
|
571
|
+
* Generate rotation endpoints for ccw_litellm
|
|
572
|
+
* Creates endpoint list from rotation config for parallel embedding
|
|
573
|
+
* Supports both legacy codexlensEmbeddingRotation and new embeddingPoolConfig
|
|
574
|
+
*/
|
|
575
|
+
export function generateRotationEndpoints(baseDir: string): RotationEndpointConfig[] {
|
|
494
576
|
const config = loadLiteLLMApiConfig(baseDir);
|
|
495
577
|
|
|
496
578
|
// Prefer embeddingPoolConfig, fallback to codexlensEmbeddingRotation for backward compatibility
|
|
@@ -517,22 +599,8 @@ function generateEndpointsFromPool(
|
|
|
517
599
|
baseDir: string,
|
|
518
600
|
poolConfig: EmbeddingPoolConfig,
|
|
519
601
|
config: LiteLLMApiConfig
|
|
520
|
-
):
|
|
521
|
-
|
|
522
|
-
api_key: string;
|
|
523
|
-
api_base: string;
|
|
524
|
-
model: string;
|
|
525
|
-
weight: number;
|
|
526
|
-
max_concurrent: number;
|
|
527
|
-
}> {
|
|
528
|
-
const endpoints: Array<{
|
|
529
|
-
name: string;
|
|
530
|
-
api_key: string;
|
|
531
|
-
api_base: string;
|
|
532
|
-
model: string;
|
|
533
|
-
weight: number;
|
|
534
|
-
max_concurrent: number;
|
|
535
|
-
}> = [];
|
|
602
|
+
): RotationEndpointConfig[] {
|
|
603
|
+
const endpoints: RotationEndpointConfig[] = [];
|
|
536
604
|
|
|
537
605
|
if (poolConfig.autoDiscover) {
|
|
538
606
|
// Auto-discover all providers offering targetModel
|
|
@@ -560,10 +628,20 @@ function generateEndpointsFromPool(
|
|
|
560
628
|
let keysToUse: Array<{ id: string; key: string; label: string }> = [];
|
|
561
629
|
|
|
562
630
|
if (provider.apiKeys && provider.apiKeys.length > 0) {
|
|
563
|
-
// Use all enabled keys
|
|
564
|
-
|
|
565
|
-
.
|
|
566
|
-
|
|
631
|
+
// Use all enabled and healthy keys (filter out unhealthy)
|
|
632
|
+
const healthyKeys = provider.apiKeys.filter(k =>
|
|
633
|
+
k.enabled && k.healthStatus !== 'unhealthy'
|
|
634
|
+
);
|
|
635
|
+
|
|
636
|
+
// Log filtered keys for debugging
|
|
637
|
+
const unhealthyCount = provider.apiKeys.filter(k =>
|
|
638
|
+
k.enabled && k.healthStatus === 'unhealthy'
|
|
639
|
+
).length;
|
|
640
|
+
if (unhealthyCount > 0) {
|
|
641
|
+
console.log(`[RotationEndpoints] Filtered ${unhealthyCount} unhealthy key(s) from provider ${provider.name}`);
|
|
642
|
+
}
|
|
643
|
+
|
|
644
|
+
keysToUse = healthyKeys.map(k => ({ id: k.id, key: k.key, label: k.label || k.id }));
|
|
567
645
|
} else if (provider.apiKey) {
|
|
568
646
|
// Single key fallback
|
|
569
647
|
keysToUse = [{ id: 'default', key: provider.apiKey, label: 'Default' }];
|
|
@@ -571,14 +649,37 @@ function generateEndpointsFromPool(
|
|
|
571
649
|
|
|
572
650
|
// Create endpoint for each key
|
|
573
651
|
for (const keyInfo of keysToUse) {
|
|
574
|
-
|
|
652
|
+
const endpoint: RotationEndpointConfig = {
|
|
575
653
|
name: `${provider.name}-${keyInfo.label}`,
|
|
576
654
|
api_key: resolveEnvVar(keyInfo.key),
|
|
577
655
|
api_base: apiBase,
|
|
578
656
|
model: embeddingModel.name,
|
|
579
657
|
weight: 1.0, // Default weight for auto-discovered providers
|
|
580
658
|
max_concurrent: poolConfig.defaultMaxConcurrentPerKey,
|
|
581
|
-
}
|
|
659
|
+
};
|
|
660
|
+
|
|
661
|
+
// Add routing strategy from provider config
|
|
662
|
+
if (provider.routingStrategy) {
|
|
663
|
+
endpoint.routing_strategy = provider.routingStrategy;
|
|
664
|
+
}
|
|
665
|
+
|
|
666
|
+
// Add health check config from provider
|
|
667
|
+
if (provider.healthCheck) {
|
|
668
|
+
endpoint.health_check = {
|
|
669
|
+
enabled: provider.healthCheck.enabled,
|
|
670
|
+
interval_seconds: provider.healthCheck.intervalSeconds,
|
|
671
|
+
cooldown_seconds: provider.healthCheck.cooldownSeconds,
|
|
672
|
+
failure_threshold: provider.healthCheck.failureThreshold,
|
|
673
|
+
};
|
|
674
|
+
}
|
|
675
|
+
|
|
676
|
+
// Add last latency if available from key entry
|
|
677
|
+
const keyEntry = provider.apiKeys?.find(k => k.id === keyInfo.id);
|
|
678
|
+
if (keyEntry && keyEntry.lastLatencyMs !== undefined) {
|
|
679
|
+
endpoint.last_latency_ms = keyEntry.lastLatencyMs;
|
|
680
|
+
}
|
|
681
|
+
|
|
682
|
+
endpoints.push(endpoint);
|
|
582
683
|
}
|
|
583
684
|
}
|
|
584
685
|
}
|
|
@@ -593,22 +694,8 @@ function generateEndpointsFromLegacyRotation(
|
|
|
593
694
|
baseDir: string,
|
|
594
695
|
rotationConfig: CodexLensEmbeddingRotation,
|
|
595
696
|
config: LiteLLMApiConfig
|
|
596
|
-
):
|
|
597
|
-
|
|
598
|
-
api_key: string;
|
|
599
|
-
api_base: string;
|
|
600
|
-
model: string;
|
|
601
|
-
weight: number;
|
|
602
|
-
max_concurrent: number;
|
|
603
|
-
}> {
|
|
604
|
-
const endpoints: Array<{
|
|
605
|
-
name: string;
|
|
606
|
-
api_key: string;
|
|
607
|
-
api_base: string;
|
|
608
|
-
model: string;
|
|
609
|
-
weight: number;
|
|
610
|
-
max_concurrent: number;
|
|
611
|
-
}> = [];
|
|
697
|
+
): RotationEndpointConfig[] {
|
|
698
|
+
const endpoints: RotationEndpointConfig[] = [];
|
|
612
699
|
|
|
613
700
|
for (const rotationProvider of rotationConfig.providers) {
|
|
614
701
|
if (!rotationProvider.enabled) continue;
|
|
@@ -630,15 +717,26 @@ function generateEndpointsFromLegacyRotation(
|
|
|
630
717
|
let keysToUse: Array<{ id: string; key: string; label: string }> = [];
|
|
631
718
|
|
|
632
719
|
if (provider.apiKeys && provider.apiKeys.length > 0) {
|
|
720
|
+
// Filter out unhealthy keys first
|
|
721
|
+
const healthyKeys = provider.apiKeys.filter(k =>
|
|
722
|
+
k.enabled && k.healthStatus !== 'unhealthy'
|
|
723
|
+
);
|
|
724
|
+
|
|
725
|
+
// Log filtered keys for debugging
|
|
726
|
+
const unhealthyCount = provider.apiKeys.filter(k =>
|
|
727
|
+
k.enabled && k.healthStatus === 'unhealthy'
|
|
728
|
+
).length;
|
|
729
|
+
if (unhealthyCount > 0) {
|
|
730
|
+
console.log(`[RotationEndpoints] Filtered ${unhealthyCount} unhealthy key(s) from provider ${provider.name}`);
|
|
731
|
+
}
|
|
732
|
+
|
|
633
733
|
if (rotationProvider.useAllKeys) {
|
|
634
|
-
// Use all enabled keys
|
|
635
|
-
keysToUse =
|
|
636
|
-
.filter(k => k.enabled)
|
|
637
|
-
.map(k => ({ id: k.id, key: k.key, label: k.label || k.id }));
|
|
734
|
+
// Use all enabled and healthy keys
|
|
735
|
+
keysToUse = healthyKeys.map(k => ({ id: k.id, key: k.key, label: k.label || k.id }));
|
|
638
736
|
} else if (rotationProvider.selectedKeyIds && rotationProvider.selectedKeyIds.length > 0) {
|
|
639
|
-
// Use only selected keys
|
|
640
|
-
keysToUse =
|
|
641
|
-
.filter(k =>
|
|
737
|
+
// Use only selected healthy keys
|
|
738
|
+
keysToUse = healthyKeys
|
|
739
|
+
.filter(k => rotationProvider.selectedKeyIds!.includes(k.id))
|
|
642
740
|
.map(k => ({ id: k.id, key: k.key, label: k.label || k.id }));
|
|
643
741
|
}
|
|
644
742
|
} else if (provider.apiKey) {
|
|
@@ -648,14 +746,37 @@ function generateEndpointsFromLegacyRotation(
|
|
|
648
746
|
|
|
649
747
|
// Create endpoint for each key
|
|
650
748
|
for (const keyInfo of keysToUse) {
|
|
651
|
-
|
|
749
|
+
const endpoint: RotationEndpointConfig = {
|
|
652
750
|
name: `${provider.name}-${keyInfo.label}`,
|
|
653
751
|
api_key: resolveEnvVar(keyInfo.key),
|
|
654
752
|
api_base: apiBase,
|
|
655
753
|
model: embeddingModel.name,
|
|
656
754
|
weight: rotationProvider.weight,
|
|
657
755
|
max_concurrent: rotationProvider.maxConcurrentPerKey,
|
|
658
|
-
}
|
|
756
|
+
};
|
|
757
|
+
|
|
758
|
+
// Add routing strategy from provider config
|
|
759
|
+
if (provider.routingStrategy) {
|
|
760
|
+
endpoint.routing_strategy = provider.routingStrategy;
|
|
761
|
+
}
|
|
762
|
+
|
|
763
|
+
// Add health check config from provider
|
|
764
|
+
if (provider.healthCheck) {
|
|
765
|
+
endpoint.health_check = {
|
|
766
|
+
enabled: provider.healthCheck.enabled,
|
|
767
|
+
interval_seconds: provider.healthCheck.intervalSeconds,
|
|
768
|
+
cooldown_seconds: provider.healthCheck.cooldownSeconds,
|
|
769
|
+
failure_threshold: provider.healthCheck.failureThreshold,
|
|
770
|
+
};
|
|
771
|
+
}
|
|
772
|
+
|
|
773
|
+
// Add last latency if available from key entry
|
|
774
|
+
const keyEntry = provider.apiKeys?.find(k => k.id === keyInfo.id);
|
|
775
|
+
if (keyEntry && keyEntry.lastLatencyMs !== undefined) {
|
|
776
|
+
endpoint.last_latency_ms = keyEntry.lastLatencyMs;
|
|
777
|
+
}
|
|
778
|
+
|
|
779
|
+
endpoints.push(endpoint);
|
|
659
780
|
}
|
|
660
781
|
}
|
|
661
782
|
|
|
@@ -1008,5 +1129,219 @@ function objectToYaml(obj: unknown, indent: number = 0): string {
|
|
|
1008
1129
|
return String(obj);
|
|
1009
1130
|
}
|
|
1010
1131
|
|
|
1132
|
+
// ===========================
|
|
1133
|
+
// Multi-Model Pool Management
|
|
1134
|
+
// ===========================
|
|
1135
|
+
|
|
1136
|
+
/**
|
|
1137
|
+
* Migrate legacy embeddingPoolConfig to new modelPools array
|
|
1138
|
+
* This function ensures backward compatibility with existing configurations
|
|
1139
|
+
*/
|
|
1140
|
+
function migrateEmbeddingPoolToModelPools(config: LiteLLMApiConfig): void {
|
|
1141
|
+
// Skip if already has modelPools or no legacy config
|
|
1142
|
+
if (config.modelPools && config.modelPools.length > 0) return;
|
|
1143
|
+
if (!config.embeddingPoolConfig) return;
|
|
1144
|
+
|
|
1145
|
+
// Convert legacy embeddingPoolConfig to ModelPoolConfig
|
|
1146
|
+
const legacyPool = config.embeddingPoolConfig;
|
|
1147
|
+
const modelPool: import('../types/litellm-api-config.js').ModelPoolConfig = {
|
|
1148
|
+
id: `pool-embedding-${Date.now()}`,
|
|
1149
|
+
modelType: 'embedding',
|
|
1150
|
+
enabled: legacyPool.enabled,
|
|
1151
|
+
targetModel: legacyPool.targetModel,
|
|
1152
|
+
strategy: legacyPool.strategy,
|
|
1153
|
+
autoDiscover: legacyPool.autoDiscover,
|
|
1154
|
+
excludedProviderIds: legacyPool.excludedProviderIds || [],
|
|
1155
|
+
defaultCooldown: legacyPool.defaultCooldown,
|
|
1156
|
+
defaultMaxConcurrentPerKey: legacyPool.defaultMaxConcurrentPerKey,
|
|
1157
|
+
name: `Embedding Pool - ${legacyPool.targetModel}`,
|
|
1158
|
+
description: 'Migrated from legacy embeddingPoolConfig',
|
|
1159
|
+
};
|
|
1160
|
+
|
|
1161
|
+
config.modelPools = [modelPool];
|
|
1162
|
+
// Keep legacy config for backward compatibility with old CodexLens versions
|
|
1163
|
+
}
|
|
1164
|
+
|
|
1165
|
+
/**
|
|
1166
|
+
* Get all model pool configurations
|
|
1167
|
+
* Returns empty array if no pools configured
|
|
1168
|
+
*/
|
|
1169
|
+
export function getModelPools(baseDir: string): import('../types/litellm-api-config.js').ModelPoolConfig[] {
|
|
1170
|
+
const config = loadLiteLLMApiConfig(baseDir);
|
|
1171
|
+
|
|
1172
|
+
// Auto-migrate if needed
|
|
1173
|
+
migrateEmbeddingPoolToModelPools(config);
|
|
1174
|
+
|
|
1175
|
+
return config.modelPools || [];
|
|
1176
|
+
}
|
|
1177
|
+
|
|
1178
|
+
/**
|
|
1179
|
+
* Get a specific model pool by ID
|
|
1180
|
+
*/
|
|
1181
|
+
export function getModelPool(
|
|
1182
|
+
baseDir: string,
|
|
1183
|
+
poolId: string
|
|
1184
|
+
): import('../types/litellm-api-config.js').ModelPoolConfig | undefined {
|
|
1185
|
+
const pools = getModelPools(baseDir);
|
|
1186
|
+
return pools.find(p => p.id === poolId);
|
|
1187
|
+
}
|
|
1188
|
+
|
|
1189
|
+
/**
|
|
1190
|
+
* Add a new model pool configuration
|
|
1191
|
+
*/
|
|
1192
|
+
export function addModelPool(
|
|
1193
|
+
baseDir: string,
|
|
1194
|
+
poolConfig: Omit<import('../types/litellm-api-config.js').ModelPoolConfig, 'id'>
|
|
1195
|
+
): { poolId: string; syncResult?: { success: boolean; message: string; endpointCount?: number } } {
|
|
1196
|
+
const config = loadLiteLLMApiConfig(baseDir);
|
|
1197
|
+
|
|
1198
|
+
// Auto-migrate if needed
|
|
1199
|
+
migrateEmbeddingPoolToModelPools(config);
|
|
1200
|
+
|
|
1201
|
+
// Ensure modelPools array exists
|
|
1202
|
+
if (!config.modelPools) {
|
|
1203
|
+
config.modelPools = [];
|
|
1204
|
+
}
|
|
1205
|
+
|
|
1206
|
+
// Generate unique ID
|
|
1207
|
+
const poolId = `pool-${poolConfig.modelType}-${Date.now()}`;
|
|
1208
|
+
|
|
1209
|
+
const newPool: import('../types/litellm-api-config.js').ModelPoolConfig = {
|
|
1210
|
+
...poolConfig,
|
|
1211
|
+
id: poolId,
|
|
1212
|
+
};
|
|
1213
|
+
|
|
1214
|
+
config.modelPools.push(newPool);
|
|
1215
|
+
saveConfig(baseDir, config);
|
|
1216
|
+
|
|
1217
|
+
// Sync to CodexLens if this is an embedding pool
|
|
1218
|
+
const syncResult = poolConfig.modelType === 'embedding' && poolConfig.enabled
|
|
1219
|
+
? syncCodexLensConfig(baseDir)
|
|
1220
|
+
: undefined;
|
|
1221
|
+
|
|
1222
|
+
return { poolId, syncResult };
|
|
1223
|
+
}
|
|
1224
|
+
|
|
1225
|
+
/**
|
|
1226
|
+
* Update an existing model pool configuration
|
|
1227
|
+
*/
|
|
1228
|
+
export function updateModelPool(
|
|
1229
|
+
baseDir: string,
|
|
1230
|
+
poolId: string,
|
|
1231
|
+
updates: Partial<Omit<import('../types/litellm-api-config.js').ModelPoolConfig, 'id'>>
|
|
1232
|
+
): { success: boolean; syncResult?: { success: boolean; message: string; endpointCount?: number } } {
|
|
1233
|
+
const config = loadLiteLLMApiConfig(baseDir);
|
|
1234
|
+
|
|
1235
|
+
// Auto-migrate if needed
|
|
1236
|
+
migrateEmbeddingPoolToModelPools(config);
|
|
1237
|
+
|
|
1238
|
+
if (!config.modelPools) {
|
|
1239
|
+
return { success: false };
|
|
1240
|
+
}
|
|
1241
|
+
|
|
1242
|
+
const poolIndex = config.modelPools.findIndex(p => p.id === poolId);
|
|
1243
|
+
if (poolIndex === -1) {
|
|
1244
|
+
return { success: false };
|
|
1245
|
+
}
|
|
1246
|
+
|
|
1247
|
+
// Apply updates
|
|
1248
|
+
config.modelPools[poolIndex] = {
|
|
1249
|
+
...config.modelPools[poolIndex],
|
|
1250
|
+
...updates,
|
|
1251
|
+
};
|
|
1252
|
+
|
|
1253
|
+
saveConfig(baseDir, config);
|
|
1254
|
+
|
|
1255
|
+
// Sync to CodexLens if this is an enabled embedding pool
|
|
1256
|
+
const pool = config.modelPools[poolIndex];
|
|
1257
|
+
const syncResult = pool.modelType === 'embedding' && pool.enabled
|
|
1258
|
+
? syncCodexLensConfig(baseDir)
|
|
1259
|
+
: undefined;
|
|
1260
|
+
|
|
1261
|
+
return { success: true, syncResult };
|
|
1262
|
+
}
|
|
1263
|
+
|
|
1264
|
+
/**
|
|
1265
|
+
* Delete a model pool configuration
|
|
1266
|
+
*/
|
|
1267
|
+
export function deleteModelPool(
|
|
1268
|
+
baseDir: string,
|
|
1269
|
+
poolId: string
|
|
1270
|
+
): { success: boolean; syncResult?: { success: boolean; message: string; endpointCount?: number } } {
|
|
1271
|
+
const config = loadLiteLLMApiConfig(baseDir);
|
|
1272
|
+
|
|
1273
|
+
if (!config.modelPools) {
|
|
1274
|
+
return { success: false };
|
|
1275
|
+
}
|
|
1276
|
+
|
|
1277
|
+
const poolIndex = config.modelPools.findIndex(p => p.id === poolId);
|
|
1278
|
+
if (poolIndex === -1) {
|
|
1279
|
+
return { success: false };
|
|
1280
|
+
}
|
|
1281
|
+
|
|
1282
|
+
const deletedPool = config.modelPools[poolIndex];
|
|
1283
|
+
config.modelPools.splice(poolIndex, 1);
|
|
1284
|
+
|
|
1285
|
+
saveConfig(baseDir, config);
|
|
1286
|
+
|
|
1287
|
+
// Sync to CodexLens if we deleted an embedding pool
|
|
1288
|
+
const syncResult = deletedPool.modelType === 'embedding'
|
|
1289
|
+
? syncCodexLensConfig(baseDir)
|
|
1290
|
+
: undefined;
|
|
1291
|
+
|
|
1292
|
+
return { success: true, syncResult };
|
|
1293
|
+
}
|
|
1294
|
+
|
|
1295
|
+
/**
|
|
1296
|
+
* Get available models for a specific model type
|
|
1297
|
+
* Used for pool configuration UI
|
|
1298
|
+
*/
|
|
1299
|
+
export function getAvailableModelsForType(
|
|
1300
|
+
baseDir: string,
|
|
1301
|
+
modelType: import('../types/litellm-api-config.js').ModelPoolType
|
|
1302
|
+
): Array<{ modelId: string; modelName: string; providers: string[] }> {
|
|
1303
|
+
const config = loadLiteLLMApiConfig(baseDir);
|
|
1304
|
+
const availableModels: Array<{ modelId: string; modelName: string; providers: string[] }> = [];
|
|
1305
|
+
const modelMap = new Map<string, { modelId: string; modelName: string; providers: string[] }>();
|
|
1306
|
+
|
|
1307
|
+
for (const provider of config.providers) {
|
|
1308
|
+
if (!provider.enabled) continue;
|
|
1309
|
+
|
|
1310
|
+
let models: typeof provider.embeddingModels | undefined;
|
|
1311
|
+
|
|
1312
|
+
switch (modelType) {
|
|
1313
|
+
case 'embedding':
|
|
1314
|
+
models = provider.embeddingModels;
|
|
1315
|
+
break;
|
|
1316
|
+
case 'llm':
|
|
1317
|
+
models = provider.llmModels;
|
|
1318
|
+
break;
|
|
1319
|
+
case 'reranker':
|
|
1320
|
+
models = provider.rerankerModels;
|
|
1321
|
+
break;
|
|
1322
|
+
}
|
|
1323
|
+
|
|
1324
|
+
if (!models) continue;
|
|
1325
|
+
|
|
1326
|
+
for (const model of models) {
|
|
1327
|
+
if (!model.enabled) continue;
|
|
1328
|
+
|
|
1329
|
+
const key = model.id;
|
|
1330
|
+
if (modelMap.has(key)) {
|
|
1331
|
+
modelMap.get(key)!.providers.push(provider.name);
|
|
1332
|
+
} else {
|
|
1333
|
+
modelMap.set(key, {
|
|
1334
|
+
modelId: model.id,
|
|
1335
|
+
modelName: model.name,
|
|
1336
|
+
providers: [provider.name],
|
|
1337
|
+
});
|
|
1338
|
+
}
|
|
1339
|
+
}
|
|
1340
|
+
}
|
|
1341
|
+
|
|
1342
|
+
availableModels.push(...Array.from(modelMap.values()));
|
|
1343
|
+
return availableModels;
|
|
1344
|
+
}
|
|
1345
|
+
|
|
1011
1346
|
// Re-export types
|
|
1012
1347
|
export type { ProviderCredential, CustomEndpoint, ProviderType, CacheStrategy, CodexLensEmbeddingRotation, CodexLensEmbeddingProvider, EmbeddingPoolConfig };
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { randomBytes } from 'crypto';
|
|
2
|
+
|
|
3
|
+
export interface CsrfTokenManagerOptions {
|
|
4
|
+
tokenTtlMs?: number;
|
|
5
|
+
cleanupIntervalMs?: number;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
type CsrfTokenRecord = {
|
|
9
|
+
sessionId: string;
|
|
10
|
+
expiresAtMs: number;
|
|
11
|
+
used: boolean;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const DEFAULT_TOKEN_TTL_MS = 15 * 60 * 1000; // 15 minutes
|
|
15
|
+
const DEFAULT_CLEANUP_INTERVAL_MS = 5 * 60 * 1000; // 5 minutes
|
|
16
|
+
|
|
17
|
+
export class CsrfTokenManager {
|
|
18
|
+
private readonly tokenTtlMs: number;
|
|
19
|
+
private readonly records = new Map<string, CsrfTokenRecord>();
|
|
20
|
+
private readonly cleanupTimer: NodeJS.Timeout | null;
|
|
21
|
+
|
|
22
|
+
constructor(options: CsrfTokenManagerOptions = {}) {
|
|
23
|
+
this.tokenTtlMs = options.tokenTtlMs ?? DEFAULT_TOKEN_TTL_MS;
|
|
24
|
+
|
|
25
|
+
const cleanupIntervalMs = options.cleanupIntervalMs ?? DEFAULT_CLEANUP_INTERVAL_MS;
|
|
26
|
+
if (cleanupIntervalMs > 0) {
|
|
27
|
+
this.cleanupTimer = setInterval(() => {
|
|
28
|
+
this.cleanupExpiredTokens();
|
|
29
|
+
}, cleanupIntervalMs);
|
|
30
|
+
|
|
31
|
+
if (this.cleanupTimer.unref) {
|
|
32
|
+
this.cleanupTimer.unref();
|
|
33
|
+
}
|
|
34
|
+
} else {
|
|
35
|
+
this.cleanupTimer = null;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
dispose(): void {
|
|
40
|
+
if (this.cleanupTimer) {
|
|
41
|
+
clearInterval(this.cleanupTimer);
|
|
42
|
+
}
|
|
43
|
+
this.records.clear();
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
generateToken(sessionId: string): string {
|
|
47
|
+
const token = randomBytes(32).toString('hex');
|
|
48
|
+
this.records.set(token, {
|
|
49
|
+
sessionId,
|
|
50
|
+
expiresAtMs: Date.now() + this.tokenTtlMs,
|
|
51
|
+
used: false,
|
|
52
|
+
});
|
|
53
|
+
return token;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
validateToken(token: string, sessionId: string): boolean {
|
|
57
|
+
const record = this.records.get(token);
|
|
58
|
+
if (!record) return false;
|
|
59
|
+
if (record.used) return false;
|
|
60
|
+
if (record.sessionId !== sessionId) return false;
|
|
61
|
+
|
|
62
|
+
if (Date.now() > record.expiresAtMs) {
|
|
63
|
+
this.records.delete(token);
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
record.used = true;
|
|
68
|
+
return true;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
cleanupExpiredTokens(nowMs: number = Date.now()): number {
|
|
72
|
+
let removed = 0;
|
|
73
|
+
|
|
74
|
+
for (const [token, record] of this.records.entries()) {
|
|
75
|
+
if (record.used || nowMs > record.expiresAtMs) {
|
|
76
|
+
this.records.delete(token);
|
|
77
|
+
removed += 1;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
return removed;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
getActiveTokenCount(): number {
|
|
85
|
+
return this.records.size;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
let csrfManagerInstance: CsrfTokenManager | null = null;
|
|
90
|
+
|
|
91
|
+
export function getCsrfTokenManager(options?: CsrfTokenManagerOptions): CsrfTokenManager {
|
|
92
|
+
if (!csrfManagerInstance) {
|
|
93
|
+
csrfManagerInstance = new CsrfTokenManager(options);
|
|
94
|
+
}
|
|
95
|
+
return csrfManagerInstance;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
export function resetCsrfTokenManager(): void {
|
|
99
|
+
if (csrfManagerInstance) {
|
|
100
|
+
csrfManagerInstance.dispose();
|
|
101
|
+
}
|
|
102
|
+
csrfManagerInstance = null;
|
|
103
|
+
}
|
|
104
|
+
|