@hoangsonw/forge 0.1.0
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/LICENSE +21 -0
- package/README.md +919 -0
- package/bin/forge.js +30 -0
- package/dist/agents/architect.d.ts +20 -0
- package/dist/agents/architect.d.ts.map +1 -0
- package/dist/agents/architect.js +75 -0
- package/dist/agents/architect.js.map +1 -0
- package/dist/agents/base.d.ts +20 -0
- package/dist/agents/base.d.ts.map +1 -0
- package/dist/agents/base.js +3 -0
- package/dist/agents/base.js.map +1 -0
- package/dist/agents/debugger.d.ts +16 -0
- package/dist/agents/debugger.d.ts.map +1 -0
- package/dist/agents/debugger.js +93 -0
- package/dist/agents/debugger.js.map +1 -0
- package/dist/agents/executor.d.ts +48 -0
- package/dist/agents/executor.d.ts.map +1 -0
- package/dist/agents/executor.js +402 -0
- package/dist/agents/executor.js.map +1 -0
- package/dist/agents/memory.d.ts +8 -0
- package/dist/agents/memory.d.ts.map +1 -0
- package/dist/agents/memory.js +84 -0
- package/dist/agents/memory.js.map +1 -0
- package/dist/agents/planner.d.ts +5 -0
- package/dist/agents/planner.d.ts.map +1 -0
- package/dist/agents/planner.js +185 -0
- package/dist/agents/planner.js.map +1 -0
- package/dist/agents/registry.d.ts +6 -0
- package/dist/agents/registry.d.ts.map +1 -0
- package/dist/agents/registry.js +32 -0
- package/dist/agents/registry.js.map +1 -0
- package/dist/agents/reviewer.d.ts +18 -0
- package/dist/agents/reviewer.d.ts.map +1 -0
- package/dist/agents/reviewer.js +87 -0
- package/dist/agents/reviewer.js.map +1 -0
- package/dist/classifier/classifier.d.ts +9 -0
- package/dist/classifier/classifier.d.ts.map +1 -0
- package/dist/classifier/classifier.js +83 -0
- package/dist/classifier/classifier.js.map +1 -0
- package/dist/classifier/heuristics.d.ts +11 -0
- package/dist/classifier/heuristics.d.ts.map +1 -0
- package/dist/classifier/heuristics.js +112 -0
- package/dist/classifier/heuristics.js.map +1 -0
- package/dist/cli/animations.d.ts +27 -0
- package/dist/cli/animations.d.ts.map +1 -0
- package/dist/cli/animations.js +186 -0
- package/dist/cli/animations.js.map +1 -0
- package/dist/cli/banners.d.ts +47 -0
- package/dist/cli/banners.d.ts.map +1 -0
- package/dist/cli/banners.js +211 -0
- package/dist/cli/banners.js.map +1 -0
- package/dist/cli/bootstrap.d.ts +2 -0
- package/dist/cli/bootstrap.d.ts.map +1 -0
- package/dist/cli/bootstrap.js +21 -0
- package/dist/cli/bootstrap.js.map +1 -0
- package/dist/cli/commands/bundle.d.ts +3 -0
- package/dist/cli/commands/bundle.d.ts.map +1 -0
- package/dist/cli/commands/bundle.js +80 -0
- package/dist/cli/commands/bundle.js.map +1 -0
- package/dist/cli/commands/changelog.d.ts +3 -0
- package/dist/cli/commands/changelog.d.ts.map +1 -0
- package/dist/cli/commands/changelog.js +60 -0
- package/dist/cli/commands/changelog.js.map +1 -0
- package/dist/cli/commands/config.d.ts +3 -0
- package/dist/cli/commands/config.d.ts.map +1 -0
- package/dist/cli/commands/config.js +91 -0
- package/dist/cli/commands/config.js.map +1 -0
- package/dist/cli/commands/container.d.ts +3 -0
- package/dist/cli/commands/container.d.ts.map +1 -0
- package/dist/cli/commands/container.js +149 -0
- package/dist/cli/commands/container.js.map +1 -0
- package/dist/cli/commands/cost.d.ts +3 -0
- package/dist/cli/commands/cost.d.ts.map +1 -0
- package/dist/cli/commands/cost.js +38 -0
- package/dist/cli/commands/cost.js.map +1 -0
- package/dist/cli/commands/daemon.d.ts +3 -0
- package/dist/cli/commands/daemon.d.ts.map +1 -0
- package/dist/cli/commands/daemon.js +39 -0
- package/dist/cli/commands/daemon.js.map +1 -0
- package/dist/cli/commands/dev.d.ts +3 -0
- package/dist/cli/commands/dev.d.ts.map +1 -0
- package/dist/cli/commands/dev.js +73 -0
- package/dist/cli/commands/dev.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +3 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -0
- package/dist/cli/commands/doctor.js +214 -0
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/init.d.ts +3 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +148 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/mcp.d.ts +3 -0
- package/dist/cli/commands/mcp.d.ts.map +1 -0
- package/dist/cli/commands/mcp.js +227 -0
- package/dist/cli/commands/mcp.js.map +1 -0
- package/dist/cli/commands/memory.d.ts +3 -0
- package/dist/cli/commands/memory.d.ts.map +1 -0
- package/dist/cli/commands/memory.js +101 -0
- package/dist/cli/commands/memory.js.map +1 -0
- package/dist/cli/commands/migrate.d.ts +3 -0
- package/dist/cli/commands/migrate.d.ts.map +1 -0
- package/dist/cli/commands/migrate.js +18 -0
- package/dist/cli/commands/migrate.js.map +1 -0
- package/dist/cli/commands/model.d.ts +3 -0
- package/dist/cli/commands/model.d.ts.map +1 -0
- package/dist/cli/commands/model.js +37 -0
- package/dist/cli/commands/model.js.map +1 -0
- package/dist/cli/commands/permissions.d.ts +3 -0
- package/dist/cli/commands/permissions.d.ts.map +1 -0
- package/dist/cli/commands/permissions.js +32 -0
- package/dist/cli/commands/permissions.js.map +1 -0
- package/dist/cli/commands/resume.d.ts +3 -0
- package/dist/cli/commands/resume.d.ts.map +1 -0
- package/dist/cli/commands/resume.js +90 -0
- package/dist/cli/commands/resume.js.map +1 -0
- package/dist/cli/commands/run.d.ts +5 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/run.js +164 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/commands/session.d.ts +3 -0
- package/dist/cli/commands/session.d.ts.map +1 -0
- package/dist/cli/commands/session.js +94 -0
- package/dist/cli/commands/session.js.map +1 -0
- package/dist/cli/commands/skills.d.ts +4 -0
- package/dist/cli/commands/skills.d.ts.map +1 -0
- package/dist/cli/commands/skills.js +176 -0
- package/dist/cli/commands/skills.js.map +1 -0
- package/dist/cli/commands/spec.d.ts +3 -0
- package/dist/cli/commands/spec.d.ts.map +1 -0
- package/dist/cli/commands/spec.js +58 -0
- package/dist/cli/commands/spec.js.map +1 -0
- package/dist/cli/commands/status.d.ts +3 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +65 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/commands/task.d.ts +3 -0
- package/dist/cli/commands/task.d.ts.map +1 -0
- package/dist/cli/commands/task.js +42 -0
- package/dist/cli/commands/task.js.map +1 -0
- package/dist/cli/commands/ui.d.ts +3 -0
- package/dist/cli/commands/ui.d.ts.map +1 -0
- package/dist/cli/commands/ui.js +28 -0
- package/dist/cli/commands/ui.js.map +1 -0
- package/dist/cli/commands/update.d.ts +3 -0
- package/dist/cli/commands/update.d.ts.map +1 -0
- package/dist/cli/commands/update.js +53 -0
- package/dist/cli/commands/update.js.map +1 -0
- package/dist/cli/commands/web.d.ts +3 -0
- package/dist/cli/commands/web.d.ts.map +1 -0
- package/dist/cli/commands/web.js +42 -0
- package/dist/cli/commands/web.js.map +1 -0
- package/dist/cli/help.d.ts +21 -0
- package/dist/cli/help.d.ts.map +1 -0
- package/dist/cli/help.js +216 -0
- package/dist/cli/help.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +154 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/repl-commands.d.ts +47 -0
- package/dist/cli/repl-commands.d.ts.map +1 -0
- package/dist/cli/repl-commands.js +508 -0
- package/dist/cli/repl-commands.js.map +1 -0
- package/dist/cli/repl-input.d.ts +87 -0
- package/dist/cli/repl-input.d.ts.map +1 -0
- package/dist/cli/repl-input.js +764 -0
- package/dist/cli/repl-input.js.map +1 -0
- package/dist/cli/repl.d.ts +5 -0
- package/dist/cli/repl.d.ts.map +1 -0
- package/dist/cli/repl.js +1046 -0
- package/dist/cli/repl.js.map +1 -0
- package/dist/cli/ui.d.ts +19 -0
- package/dist/cli/ui.d.ts.map +1 -0
- package/dist/cli/ui.js +106 -0
- package/dist/cli/ui.js.map +1 -0
- package/dist/config/loader.d.ts +11 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +132 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/paths.d.ts +35 -0
- package/dist/config/paths.d.ts.map +1 -0
- package/dist/config/paths.js +114 -0
- package/dist/config/paths.js.map +1 -0
- package/dist/config/schema.d.ts +372 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +161 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/config/xdg.d.ts +2 -0
- package/dist/config/xdg.d.ts.map +1 -0
- package/dist/config/xdg.js +55 -0
- package/dist/config/xdg.js.map +1 -0
- package/dist/core/continuity.d.ts +8 -0
- package/dist/core/continuity.d.ts.map +1 -0
- package/dist/core/continuity.js +36 -0
- package/dist/core/continuity.js.map +1 -0
- package/dist/core/conversation.d.ts +152 -0
- package/dist/core/conversation.d.ts.map +1 -0
- package/dist/core/conversation.js +435 -0
- package/dist/core/conversation.js.map +1 -0
- package/dist/core/estimation.d.ts +19 -0
- package/dist/core/estimation.d.ts.map +1 -0
- package/dist/core/estimation.js +53 -0
- package/dist/core/estimation.js.map +1 -0
- package/dist/core/fork.d.ts +7 -0
- package/dist/core/fork.d.ts.map +1 -0
- package/dist/core/fork.js +93 -0
- package/dist/core/fork.js.map +1 -0
- package/dist/core/interactive-host.d.ts +28 -0
- package/dist/core/interactive-host.d.ts.map +1 -0
- package/dist/core/interactive-host.js +19 -0
- package/dist/core/interactive-host.js.map +1 -0
- package/dist/core/loop-detection.d.ts +25 -0
- package/dist/core/loop-detection.d.ts.map +1 -0
- package/dist/core/loop-detection.js +37 -0
- package/dist/core/loop-detection.js.map +1 -0
- package/dist/core/loop.d.ts +15 -0
- package/dist/core/loop.d.ts.map +1 -0
- package/dist/core/loop.js +417 -0
- package/dist/core/loop.js.map +1 -0
- package/dist/core/mode-policy.d.ts +33 -0
- package/dist/core/mode-policy.d.ts.map +1 -0
- package/dist/core/mode-policy.js +62 -0
- package/dist/core/mode-policy.js.map +1 -0
- package/dist/core/orchestrator.d.ts +14 -0
- package/dist/core/orchestrator.d.ts.map +1 -0
- package/dist/core/orchestrator.js +69 -0
- package/dist/core/orchestrator.js.map +1 -0
- package/dist/core/plan-fixer.d.ts +16 -0
- package/dist/core/plan-fixer.d.ts.map +1 -0
- package/dist/core/plan-fixer.js +55 -0
- package/dist/core/plan-fixer.js.map +1 -0
- package/dist/core/signals.d.ts +5 -0
- package/dist/core/signals.d.ts.map +1 -0
- package/dist/core/signals.js +44 -0
- package/dist/core/signals.js.map +1 -0
- package/dist/core/spec.d.ts +8 -0
- package/dist/core/spec.d.ts.map +1 -0
- package/dist/core/spec.js +75 -0
- package/dist/core/spec.js.map +1 -0
- package/dist/core/validation.d.ts +21 -0
- package/dist/core/validation.d.ts.map +1 -0
- package/dist/core/validation.js +126 -0
- package/dist/core/validation.js.map +1 -0
- package/dist/daemon/control.d.ts +9 -0
- package/dist/daemon/control.d.ts.map +1 -0
- package/dist/daemon/control.js +88 -0
- package/dist/daemon/control.js.map +1 -0
- package/dist/daemon/server.d.ts +8 -0
- package/dist/daemon/server.d.ts.map +1 -0
- package/dist/daemon/server.js +129 -0
- package/dist/daemon/server.js.map +1 -0
- package/dist/daemon/updater.d.ts +21 -0
- package/dist/daemon/updater.d.ts.map +1 -0
- package/dist/daemon/updater.js +159 -0
- package/dist/daemon/updater.js.map +1 -0
- package/dist/keychain/index.d.ts +8 -0
- package/dist/keychain/index.d.ts.map +1 -0
- package/dist/keychain/index.js +243 -0
- package/dist/keychain/index.js.map +1 -0
- package/dist/keychain/windows.d.ts +5 -0
- package/dist/keychain/windows.d.ts.map +1 -0
- package/dist/keychain/windows.js +65 -0
- package/dist/keychain/windows.js.map +1 -0
- package/dist/logging/logger.d.ts +12 -0
- package/dist/logging/logger.d.ts.map +1 -0
- package/dist/logging/logger.js +127 -0
- package/dist/logging/logger.js.map +1 -0
- package/dist/logging/rotation.d.ts +9 -0
- package/dist/logging/rotation.d.ts.map +1 -0
- package/dist/logging/rotation.js +85 -0
- package/dist/logging/rotation.js.map +1 -0
- package/dist/logging/trace.d.ts +7 -0
- package/dist/logging/trace.d.ts.map +1 -0
- package/dist/logging/trace.js +50 -0
- package/dist/logging/trace.js.map +1 -0
- package/dist/mcp/client.d.ts +37 -0
- package/dist/mcp/client.d.ts.map +1 -0
- package/dist/mcp/client.js +111 -0
- package/dist/mcp/client.js.map +1 -0
- package/dist/mcp/http-transport.d.ts +30 -0
- package/dist/mcp/http-transport.d.ts.map +1 -0
- package/dist/mcp/http-transport.js +109 -0
- package/dist/mcp/http-transport.js.map +1 -0
- package/dist/mcp/oauth.d.ts +23 -0
- package/dist/mcp/oauth.d.ts.map +1 -0
- package/dist/mcp/oauth.js +235 -0
- package/dist/mcp/oauth.js.map +1 -0
- package/dist/mcp/registry.d.ts +5 -0
- package/dist/mcp/registry.d.ts.map +1 -0
- package/dist/mcp/registry.js +35 -0
- package/dist/mcp/registry.js.map +1 -0
- package/dist/memory/cold.d.ts +16 -0
- package/dist/memory/cold.d.ts.map +1 -0
- package/dist/memory/cold.js +244 -0
- package/dist/memory/cold.js.map +1 -0
- package/dist/memory/graph.d.ts +19 -0
- package/dist/memory/graph.d.ts.map +1 -0
- package/dist/memory/graph.js +102 -0
- package/dist/memory/graph.js.map +1 -0
- package/dist/memory/hot.d.ts +26 -0
- package/dist/memory/hot.d.ts.map +1 -0
- package/dist/memory/hot.js +58 -0
- package/dist/memory/hot.js.map +1 -0
- package/dist/memory/index.d.ts +7 -0
- package/dist/memory/index.d.ts.map +1 -0
- package/dist/memory/index.js +26 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/memory/learning.d.ts +18 -0
- package/dist/memory/learning.d.ts.map +1 -0
- package/dist/memory/learning.js +83 -0
- package/dist/memory/learning.js.map +1 -0
- package/dist/memory/retrieval.d.ts +21 -0
- package/dist/memory/retrieval.d.ts.map +1 -0
- package/dist/memory/retrieval.js +114 -0
- package/dist/memory/retrieval.js.map +1 -0
- package/dist/memory/warm.d.ts +9 -0
- package/dist/memory/warm.d.ts.map +1 -0
- package/dist/memory/warm.js +150 -0
- package/dist/memory/warm.js.map +1 -0
- package/dist/migrations/runner.d.ts +18 -0
- package/dist/migrations/runner.d.ts.map +1 -0
- package/dist/migrations/runner.js +62 -0
- package/dist/migrations/runner.js.map +1 -0
- package/dist/models/adapter.d.ts +46 -0
- package/dist/models/adapter.d.ts.map +1 -0
- package/dist/models/adapter.js +85 -0
- package/dist/models/adapter.js.map +1 -0
- package/dist/models/anthropic.d.ts +17 -0
- package/dist/models/anthropic.d.ts.map +1 -0
- package/dist/models/anthropic.js +128 -0
- package/dist/models/anthropic.js.map +1 -0
- package/dist/models/cache.d.ts +5 -0
- package/dist/models/cache.d.ts.map +1 -0
- package/dist/models/cache.js +135 -0
- package/dist/models/cache.js.map +1 -0
- package/dist/models/circuit-breaker.d.ts +18 -0
- package/dist/models/circuit-breaker.d.ts.map +1 -0
- package/dist/models/circuit-breaker.js +63 -0
- package/dist/models/circuit-breaker.js.map +1 -0
- package/dist/models/cost.d.ts +13 -0
- package/dist/models/cost.d.ts.map +1 -0
- package/dist/models/cost.js +92 -0
- package/dist/models/cost.js.map +1 -0
- package/dist/models/llamacpp.d.ts +9 -0
- package/dist/models/llamacpp.d.ts.map +1 -0
- package/dist/models/llamacpp.js +15 -0
- package/dist/models/llamacpp.js.map +1 -0
- package/dist/models/lmstudio.d.ts +11 -0
- package/dist/models/lmstudio.d.ts.map +1 -0
- package/dist/models/lmstudio.js +18 -0
- package/dist/models/lmstudio.js.map +1 -0
- package/dist/models/local-catalog.d.ts +45 -0
- package/dist/models/local-catalog.d.ts.map +1 -0
- package/dist/models/local-catalog.js +314 -0
- package/dist/models/local-catalog.js.map +1 -0
- package/dist/models/ollama.d.ts +10 -0
- package/dist/models/ollama.d.ts.map +1 -0
- package/dist/models/ollama.js +98 -0
- package/dist/models/ollama.js.map +1 -0
- package/dist/models/openai.d.ts +16 -0
- package/dist/models/openai.d.ts.map +1 -0
- package/dist/models/openai.js +139 -0
- package/dist/models/openai.js.map +1 -0
- package/dist/models/provider.d.ts +7 -0
- package/dist/models/provider.d.ts.map +1 -0
- package/dist/models/provider.js +39 -0
- package/dist/models/provider.js.map +1 -0
- package/dist/models/rate-limit.d.ts +13 -0
- package/dist/models/rate-limit.d.ts.map +1 -0
- package/dist/models/rate-limit.js +37 -0
- package/dist/models/rate-limit.js.map +1 -0
- package/dist/models/registry.d.ts +2 -0
- package/dist/models/registry.d.ts.map +1 -0
- package/dist/models/registry.js +69 -0
- package/dist/models/registry.js.map +1 -0
- package/dist/models/router.d.ts +26 -0
- package/dist/models/router.d.ts.map +1 -0
- package/dist/models/router.js +185 -0
- package/dist/models/router.js.map +1 -0
- package/dist/models/vllm.d.ts +13 -0
- package/dist/models/vllm.d.ts.map +1 -0
- package/dist/models/vllm.js +19 -0
- package/dist/models/vllm.js.map +1 -0
- package/dist/notifications/manager.d.ts +5 -0
- package/dist/notifications/manager.d.ts.map +1 -0
- package/dist/notifications/manager.js +65 -0
- package/dist/notifications/manager.js.map +1 -0
- package/dist/permissions/manager.d.ts +15 -0
- package/dist/permissions/manager.d.ts.map +1 -0
- package/dist/permissions/manager.js +159 -0
- package/dist/permissions/manager.js.map +1 -0
- package/dist/permissions/risk.d.ts +13 -0
- package/dist/permissions/risk.d.ts.map +1 -0
- package/dist/permissions/risk.js +43 -0
- package/dist/permissions/risk.js.map +1 -0
- package/dist/persistence/compression.d.ts +9 -0
- package/dist/persistence/compression.d.ts.map +1 -0
- package/dist/persistence/compression.js +126 -0
- package/dist/persistence/compression.js.map +1 -0
- package/dist/persistence/conversation-store.d.ts +67 -0
- package/dist/persistence/conversation-store.d.ts.map +1 -0
- package/dist/persistence/conversation-store.js +370 -0
- package/dist/persistence/conversation-store.js.map +1 -0
- package/dist/persistence/events.d.ts +4 -0
- package/dist/persistence/events.d.ts.map +1 -0
- package/dist/persistence/events.js +50 -0
- package/dist/persistence/events.js.map +1 -0
- package/dist/persistence/index-db.d.ts +65 -0
- package/dist/persistence/index-db.d.ts.map +1 -0
- package/dist/persistence/index-db.js +280 -0
- package/dist/persistence/index-db.js.map +1 -0
- package/dist/persistence/jsonl.d.ts +8 -0
- package/dist/persistence/jsonl.d.ts.map +1 -0
- package/dist/persistence/jsonl.js +90 -0
- package/dist/persistence/jsonl.js.map +1 -0
- package/dist/persistence/sessions.d.ts +5 -0
- package/dist/persistence/sessions.d.ts.map +1 -0
- package/dist/persistence/sessions.js +54 -0
- package/dist/persistence/sessions.js.map +1 -0
- package/dist/persistence/tasks.d.ts +7 -0
- package/dist/persistence/tasks.d.ts.map +1 -0
- package/dist/persistence/tasks.js +162 -0
- package/dist/persistence/tasks.js.map +1 -0
- package/dist/prompts/assembler.d.ts +29 -0
- package/dist/prompts/assembler.d.ts.map +1 -0
- package/dist/prompts/assembler.js +136 -0
- package/dist/prompts/assembler.js.map +1 -0
- package/dist/prompts/layers.d.ts +6 -0
- package/dist/prompts/layers.d.ts.map +1 -0
- package/dist/prompts/layers.js +60 -0
- package/dist/prompts/layers.js.map +1 -0
- package/dist/release/download.d.ts +19 -0
- package/dist/release/download.d.ts.map +1 -0
- package/dist/release/download.js +187 -0
- package/dist/release/download.js.map +1 -0
- package/dist/release/verify.d.ts +34 -0
- package/dist/release/verify.d.ts.map +1 -0
- package/dist/release/verify.js +127 -0
- package/dist/release/verify.js.map +1 -0
- package/dist/sandbox/fs.d.ts +10 -0
- package/dist/sandbox/fs.d.ts.map +1 -0
- package/dist/sandbox/fs.js +114 -0
- package/dist/sandbox/fs.js.map +1 -0
- package/dist/sandbox/shell.d.ts +20 -0
- package/dist/sandbox/shell.d.ts.map +1 -0
- package/dist/sandbox/shell.js +131 -0
- package/dist/sandbox/shell.js.map +1 -0
- package/dist/scheduler/dag.d.ts +7 -0
- package/dist/scheduler/dag.d.ts.map +1 -0
- package/dist/scheduler/dag.js +72 -0
- package/dist/scheduler/dag.js.map +1 -0
- package/dist/scheduler/resource-manager.d.ts +25 -0
- package/dist/scheduler/resource-manager.d.ts.map +1 -0
- package/dist/scheduler/resource-manager.js +101 -0
- package/dist/scheduler/resource-manager.js.map +1 -0
- package/dist/security/injection.d.ts +14 -0
- package/dist/security/injection.d.ts.map +1 -0
- package/dist/security/injection.js +46 -0
- package/dist/security/injection.js.map +1 -0
- package/dist/security/redact.d.ts +10 -0
- package/dist/security/redact.d.ts.map +1 -0
- package/dist/security/redact.js +89 -0
- package/dist/security/redact.js.map +1 -0
- package/dist/skills/loader.d.ts +4 -0
- package/dist/skills/loader.d.ts.map +1 -0
- package/dist/skills/loader.js +142 -0
- package/dist/skills/loader.js.map +1 -0
- package/dist/skills/marketplace.d.ts +15 -0
- package/dist/skills/marketplace.d.ts.map +1 -0
- package/dist/skills/marketplace.js +132 -0
- package/dist/skills/marketplace.js.map +1 -0
- package/dist/tools/apply-patch.d.ts +20 -0
- package/dist/tools/apply-patch.d.ts.map +1 -0
- package/dist/tools/apply-patch.js +195 -0
- package/dist/tools/apply-patch.js.map +1 -0
- package/dist/tools/ask-user.d.ts +12 -0
- package/dist/tools/ask-user.d.ts.map +1 -0
- package/dist/tools/ask-user.js +86 -0
- package/dist/tools/ask-user.js.map +1 -0
- package/dist/tools/delete-file.d.ts +10 -0
- package/dist/tools/delete-file.d.ts.map +1 -0
- package/dist/tools/delete-file.js +94 -0
- package/dist/tools/delete-file.js.map +1 -0
- package/dist/tools/edit-file.d.ts +20 -0
- package/dist/tools/edit-file.d.ts.map +1 -0
- package/dist/tools/edit-file.js +128 -0
- package/dist/tools/edit-file.js.map +1 -0
- package/dist/tools/format.d.ts +5 -0
- package/dist/tools/format.d.ts.map +1 -0
- package/dist/tools/format.js +131 -0
- package/dist/tools/format.js.map +1 -0
- package/dist/tools/git.d.ts +24 -0
- package/dist/tools/git.d.ts.map +1 -0
- package/dist/tools/git.js +122 -0
- package/dist/tools/git.js.map +1 -0
- package/dist/tools/glob.d.ts +12 -0
- package/dist/tools/glob.d.ts.map +1 -0
- package/dist/tools/glob.js +55 -0
- package/dist/tools/glob.js.map +1 -0
- package/dist/tools/grep.d.ts +19 -0
- package/dist/tools/grep.d.ts.map +1 -0
- package/dist/tools/grep.js +97 -0
- package/dist/tools/grep.js.map +1 -0
- package/dist/tools/init.d.ts +3 -0
- package/dist/tools/init.d.ts.map +1 -0
- package/dist/tools/init.js +66 -0
- package/dist/tools/init.js.map +1 -0
- package/dist/tools/list-dir.d.ts +16 -0
- package/dist/tools/list-dir.d.ts.map +1 -0
- package/dist/tools/list-dir.js +107 -0
- package/dist/tools/list-dir.js.map +1 -0
- package/dist/tools/move-file.d.ts +13 -0
- package/dist/tools/move-file.d.ts.map +1 -0
- package/dist/tools/move-file.js +100 -0
- package/dist/tools/move-file.js.map +1 -0
- package/dist/tools/read-file.d.ts +14 -0
- package/dist/tools/read-file.d.ts.map +1 -0
- package/dist/tools/read-file.js +99 -0
- package/dist/tools/read-file.js.map +1 -0
- package/dist/tools/registry.d.ts +10 -0
- package/dist/tools/registry.d.ts.map +1 -0
- package/dist/tools/registry.js +30 -0
- package/dist/tools/registry.js.map +1 -0
- package/dist/tools/run-command.d.ts +17 -0
- package/dist/tools/run-command.d.ts.map +1 -0
- package/dist/tools/run-command.js +73 -0
- package/dist/tools/run-command.js.map +1 -0
- package/dist/tools/run-tests.d.ts +16 -0
- package/dist/tools/run-tests.d.ts.map +1 -0
- package/dist/tools/run-tests.js +140 -0
- package/dist/tools/run-tests.js.map +1 -0
- package/dist/tools/web-browse.d.ts +10 -0
- package/dist/tools/web-browse.d.ts.map +1 -0
- package/dist/tools/web-browse.js +45 -0
- package/dist/tools/web-browse.js.map +1 -0
- package/dist/tools/web-fetch.d.ts +11 -0
- package/dist/tools/web-fetch.d.ts.map +1 -0
- package/dist/tools/web-fetch.js +43 -0
- package/dist/tools/web-fetch.js.map +1 -0
- package/dist/tools/web-search.d.ts +12 -0
- package/dist/tools/web-search.d.ts.map +1 -0
- package/dist/tools/web-search.js +52 -0
- package/dist/tools/web-search.js.map +1 -0
- package/dist/tools/write-file.d.ts +13 -0
- package/dist/tools/write-file.d.ts.map +1 -0
- package/dist/tools/write-file.js +100 -0
- package/dist/tools/write-file.js.map +1 -0
- package/dist/types/errors.d.ts +14 -0
- package/dist/types/errors.d.ts.map +1 -0
- package/dist/types/errors.js +55 -0
- package/dist/types/errors.js.map +1 -0
- package/dist/types/index.d.ts +267 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +38 -0
- package/dist/types/index.js.map +1 -0
- package/dist/ui/chat.d.ts +89 -0
- package/dist/ui/chat.d.ts.map +1 -0
- package/dist/ui/chat.js +311 -0
- package/dist/ui/chat.js.map +1 -0
- package/dist/ui/public/app.js +2113 -0
- package/dist/ui/public/index.html +78 -0
- package/dist/ui/public/styles.css +1703 -0
- package/dist/ui/server-errors.d.ts +24 -0
- package/dist/ui/server-errors.d.ts.map +1 -0
- package/dist/ui/server-errors.js +31 -0
- package/dist/ui/server-errors.js.map +1 -0
- package/dist/ui/server.d.ts +10 -0
- package/dist/ui/server.d.ts.map +1 -0
- package/dist/ui/server.js +815 -0
- package/dist/ui/server.js.map +1 -0
- package/dist/ui/task-runner.d.ts +71 -0
- package/dist/ui/task-runner.d.ts.map +1 -0
- package/dist/ui/task-runner.js +334 -0
- package/dist/ui/task-runner.js.map +1 -0
- package/dist/web/browse.d.ts +35 -0
- package/dist/web/browse.d.ts.map +1 -0
- package/dist/web/browse.js +166 -0
- package/dist/web/browse.js.map +1 -0
- package/dist/web/fetch.d.ts +18 -0
- package/dist/web/fetch.d.ts.map +1 -0
- package/dist/web/fetch.js +107 -0
- package/dist/web/fetch.js.map +1 -0
- package/dist/web/sanitize.d.ts +8 -0
- package/dist/web/sanitize.d.ts.map +1 -0
- package/dist/web/sanitize.js +58 -0
- package/dist/web/sanitize.js.map +1 -0
- package/dist/web/search.d.ts +12 -0
- package/dist/web/search.d.ts.map +1 -0
- package/dist/web/search.js +124 -0
- package/dist/web/search.js.map +1 -0
- package/install/install.ps1 +46 -0
- package/install/install.sh +72 -0
- package/package.json +89 -0
- package/scripts/bundle.js +26 -0
- package/scripts/copy-assets.js +33 -0
- package/scripts/link.sh +79 -0
- package/scripts/metrics.sh +33 -0
- package/scripts/postinstall.js +36 -0
|
@@ -0,0 +1,314 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports._detectFamilyForTest = exports._sizeBForTest = exports.pickModelForRole = exports.classifyModel = void 0;
|
|
4
|
+
const norm = (id) => id.toLowerCase().replace(/[_/]/g, '-').replace(/\s+/g, '');
|
|
5
|
+
const extractParamsB = (id) => {
|
|
6
|
+
// "llama3.1:8b", "qwen2.5:14b", "mixtral-8x7b" etc.
|
|
7
|
+
const m = /[^0-9](\d{1,3})(?:\.\d+)?b\b/.exec(norm(id));
|
|
8
|
+
if (!m)
|
|
9
|
+
return null;
|
|
10
|
+
return Number(m[1]);
|
|
11
|
+
};
|
|
12
|
+
const extractMoeTotal = (id) => {
|
|
13
|
+
// "mixtral-8x7b" → 56, "8x22b" → 176
|
|
14
|
+
const m = /(\d+)x(\d+)b\b/.exec(norm(id));
|
|
15
|
+
if (!m)
|
|
16
|
+
return null;
|
|
17
|
+
return Number(m[1]) * Number(m[2]);
|
|
18
|
+
};
|
|
19
|
+
const sizeB = (id) => extractMoeTotal(id) ?? extractParamsB(id);
|
|
20
|
+
const detect = (rawId) => {
|
|
21
|
+
const id = norm(rawId);
|
|
22
|
+
// --- hosted (OpenAI, Anthropic) — still useful for openai-compat providers ---
|
|
23
|
+
if (/claude.*opus/.test(id))
|
|
24
|
+
return 'claude-opus';
|
|
25
|
+
if (/claude.*sonnet/.test(id))
|
|
26
|
+
return 'claude-sonnet';
|
|
27
|
+
if (/claude.*haiku/.test(id))
|
|
28
|
+
return 'claude-haiku';
|
|
29
|
+
if (/^o1\b|^o3\b|^o4\b/.test(id))
|
|
30
|
+
return 'o-series';
|
|
31
|
+
if (/^gpt-?4/.test(id))
|
|
32
|
+
return 'gpt4';
|
|
33
|
+
if (/^gpt-?3\.5/.test(id))
|
|
34
|
+
return 'gpt35';
|
|
35
|
+
// --- code-specialists (highest specificity) ---
|
|
36
|
+
if (/qwen-?2\.5-?coder|qwen2\.5-coder|qwen-coder/.test(id))
|
|
37
|
+
return 'qwen25-coder';
|
|
38
|
+
if (/deepseek-?coder|deepseek-?v2-?coder/.test(id))
|
|
39
|
+
return 'deepseek-coder';
|
|
40
|
+
if (/codellama/.test(id))
|
|
41
|
+
return 'codellama';
|
|
42
|
+
if (/codestral/.test(id))
|
|
43
|
+
return 'codestral';
|
|
44
|
+
if (/codegemma/.test(id))
|
|
45
|
+
return 'codegemma';
|
|
46
|
+
if (/starcoder/.test(id))
|
|
47
|
+
return 'starcoder';
|
|
48
|
+
if (/wizardcoder/.test(id))
|
|
49
|
+
return 'wizardcoder';
|
|
50
|
+
if (/granite.*code|granite-code/.test(id))
|
|
51
|
+
return 'granite-code';
|
|
52
|
+
// --- DeepSeek ---
|
|
53
|
+
if (/deepseek-?r1|deepseek.*r1/.test(id))
|
|
54
|
+
return 'deepseek-r1';
|
|
55
|
+
if (/deepseek-?v3/.test(id))
|
|
56
|
+
return 'deepseek-v3';
|
|
57
|
+
if (/deepseek/.test(id))
|
|
58
|
+
return 'deepseek';
|
|
59
|
+
// --- Qwen ---
|
|
60
|
+
if (/qwen-?3|qwen3/.test(id))
|
|
61
|
+
return 'qwen3';
|
|
62
|
+
if (/qwen-?2\.5|qwen2\.5/.test(id))
|
|
63
|
+
return 'qwen25';
|
|
64
|
+
if (/qwen-?2\b|qwen2/.test(id))
|
|
65
|
+
return 'qwen2';
|
|
66
|
+
if (/qwen/.test(id))
|
|
67
|
+
return 'qwen';
|
|
68
|
+
// --- Llama ---
|
|
69
|
+
if (/llama-?4|llama4/.test(id))
|
|
70
|
+
return 'llama4';
|
|
71
|
+
if (/llama-?3|llama3/.test(id))
|
|
72
|
+
return 'llama3';
|
|
73
|
+
if (/llama-?2|llama2/.test(id))
|
|
74
|
+
return 'llama2';
|
|
75
|
+
// --- Gemma ---
|
|
76
|
+
if (/gemma-?3|gemma3/.test(id))
|
|
77
|
+
return 'gemma3';
|
|
78
|
+
if (/gemma-?2|gemma2/.test(id))
|
|
79
|
+
return 'gemma2';
|
|
80
|
+
if (/gemma/.test(id))
|
|
81
|
+
return 'gemma';
|
|
82
|
+
// --- Phi ---
|
|
83
|
+
if (/phi-?4|phi4/.test(id))
|
|
84
|
+
return 'phi4';
|
|
85
|
+
if (/phi-?3|phi3/.test(id))
|
|
86
|
+
return 'phi3';
|
|
87
|
+
if (/phi/.test(id))
|
|
88
|
+
return 'phi';
|
|
89
|
+
// --- Mistral family ---
|
|
90
|
+
if (/mixtral/.test(id))
|
|
91
|
+
return 'mixtral';
|
|
92
|
+
if (/mistral.*nemo|nemotron/.test(id))
|
|
93
|
+
return 'mistral-nemo';
|
|
94
|
+
if (/mistral.*small/.test(id))
|
|
95
|
+
return 'mistral-small';
|
|
96
|
+
if (/mistral.*large/.test(id))
|
|
97
|
+
return 'mistral-large';
|
|
98
|
+
if (/mistral|mistal/.test(id))
|
|
99
|
+
return 'mistral';
|
|
100
|
+
if (/nemotron/.test(id))
|
|
101
|
+
return 'nemotron';
|
|
102
|
+
// --- Cohere ---
|
|
103
|
+
if (/command-?r-?plus|c4ai.*plus/.test(id))
|
|
104
|
+
return 'command-r-plus';
|
|
105
|
+
if (/command-?r|c4ai-command/.test(id))
|
|
106
|
+
return 'command-r';
|
|
107
|
+
if (/aya/.test(id))
|
|
108
|
+
return 'aya';
|
|
109
|
+
// --- IBM Granite ---
|
|
110
|
+
if (/granite/.test(id))
|
|
111
|
+
return 'granite';
|
|
112
|
+
// --- misc. common local models ---
|
|
113
|
+
if (/^yi[-:]|yi-\d/.test(id))
|
|
114
|
+
return 'yi';
|
|
115
|
+
if (/^solar/.test(id))
|
|
116
|
+
return 'solar';
|
|
117
|
+
if (/zephyr/.test(id))
|
|
118
|
+
return 'zephyr';
|
|
119
|
+
if (/minicpm/.test(id))
|
|
120
|
+
return 'minicpm';
|
|
121
|
+
if (/llava/.test(id))
|
|
122
|
+
return 'llava';
|
|
123
|
+
if (/openchat/.test(id))
|
|
124
|
+
return 'openchat';
|
|
125
|
+
if (/smollm/.test(id))
|
|
126
|
+
return 'smollm';
|
|
127
|
+
if (/orca/.test(id))
|
|
128
|
+
return 'orca';
|
|
129
|
+
if (/tinyllama/.test(id))
|
|
130
|
+
return 'tinyllama';
|
|
131
|
+
return 'unknown';
|
|
132
|
+
};
|
|
133
|
+
/**
|
|
134
|
+
* Per-family metadata. Context windows reflect the most common public
|
|
135
|
+
* release of each family; per-id overrides (below) handle exceptions.
|
|
136
|
+
*/
|
|
137
|
+
const FAMILY_META = {
|
|
138
|
+
// Hosted
|
|
139
|
+
'claude-opus': {
|
|
140
|
+
class: 'heavy',
|
|
141
|
+
roles: ['architect', 'planner', 'reviewer', 'debugger'],
|
|
142
|
+
contextTokens: 200_000,
|
|
143
|
+
},
|
|
144
|
+
'claude-sonnet': {
|
|
145
|
+
class: 'mid',
|
|
146
|
+
roles: ['planner', 'executor', 'reviewer'],
|
|
147
|
+
contextTokens: 200_000,
|
|
148
|
+
},
|
|
149
|
+
'claude-haiku': { class: 'mid', roles: ['fast', 'executor'], contextTokens: 200_000 },
|
|
150
|
+
'o-series': {
|
|
151
|
+
class: 'heavy',
|
|
152
|
+
roles: ['architect', 'planner', 'reviewer', 'debugger'],
|
|
153
|
+
contextTokens: 128_000,
|
|
154
|
+
},
|
|
155
|
+
gpt4: {
|
|
156
|
+
class: 'heavy',
|
|
157
|
+
roles: ['planner', 'architect', 'reviewer', 'executor'],
|
|
158
|
+
contextTokens: 128_000,
|
|
159
|
+
},
|
|
160
|
+
gpt35: { class: 'mid', roles: ['fast', 'executor'], contextTokens: 16_000 },
|
|
161
|
+
// Llama
|
|
162
|
+
llama4: {
|
|
163
|
+
class: 'heavy',
|
|
164
|
+
roles: ['architect', 'planner', 'reviewer', 'executor'],
|
|
165
|
+
contextTokens: 128_000,
|
|
166
|
+
},
|
|
167
|
+
llama3: { class: 'mid', roles: ['planner', 'executor', 'reviewer'], contextTokens: 128_000 },
|
|
168
|
+
llama2: { class: 'mid', roles: ['executor'], contextTokens: 4096 },
|
|
169
|
+
codellama: { class: 'specialized', roles: ['executor', 'fast'], contextTokens: 16_000 },
|
|
170
|
+
// DeepSeek
|
|
171
|
+
'deepseek-r1': {
|
|
172
|
+
class: 'heavy',
|
|
173
|
+
roles: ['architect', 'planner', 'reviewer', 'debugger'],
|
|
174
|
+
contextTokens: 128_000,
|
|
175
|
+
},
|
|
176
|
+
'deepseek-v3': {
|
|
177
|
+
class: 'heavy',
|
|
178
|
+
roles: ['architect', 'planner', 'reviewer'],
|
|
179
|
+
contextTokens: 128_000,
|
|
180
|
+
},
|
|
181
|
+
'deepseek-coder': { class: 'specialized', roles: ['executor', 'fast'], contextTokens: 16_000 },
|
|
182
|
+
deepseek: { class: 'mid', roles: ['planner', 'executor'], contextTokens: 32_000 },
|
|
183
|
+
// Qwen
|
|
184
|
+
qwen3: { class: 'mid', roles: ['planner', 'executor', 'reviewer'], contextTokens: 128_000 },
|
|
185
|
+
'qwen25-coder': { class: 'specialized', roles: ['executor', 'fast'], contextTokens: 128_000 },
|
|
186
|
+
qwen25: { class: 'mid', roles: ['planner', 'executor', 'reviewer'], contextTokens: 128_000 },
|
|
187
|
+
qwen2: { class: 'mid', roles: ['planner', 'executor'], contextTokens: 32_000 },
|
|
188
|
+
qwen: { class: 'mid', roles: ['planner', 'executor'], contextTokens: 32_000 },
|
|
189
|
+
// Gemma
|
|
190
|
+
gemma3: { class: 'mid', roles: ['planner', 'executor', 'fast'], contextTokens: 128_000 },
|
|
191
|
+
gemma2: { class: 'mid', roles: ['fast', 'executor'], contextTokens: 8192 },
|
|
192
|
+
gemma: { class: 'micro', roles: ['fast'], contextTokens: 8192 },
|
|
193
|
+
// Phi
|
|
194
|
+
phi4: { class: 'mid', roles: ['planner', 'executor'], contextTokens: 16_000 },
|
|
195
|
+
phi3: { class: 'micro', roles: ['fast', 'executor'], contextTokens: 128_000 },
|
|
196
|
+
phi: { class: 'micro', roles: ['fast'], contextTokens: 4096 },
|
|
197
|
+
// Mistral family
|
|
198
|
+
mixtral: {
|
|
199
|
+
class: 'heavy',
|
|
200
|
+
roles: ['architect', 'planner', 'reviewer', 'executor'],
|
|
201
|
+
contextTokens: 64_000,
|
|
202
|
+
},
|
|
203
|
+
'mistral-nemo': { class: 'mid', roles: ['planner', 'executor'], contextTokens: 128_000 },
|
|
204
|
+
'mistral-small': { class: 'mid', roles: ['planner', 'executor'], contextTokens: 32_000 },
|
|
205
|
+
'mistral-large': {
|
|
206
|
+
class: 'heavy',
|
|
207
|
+
roles: ['architect', 'planner', 'reviewer'],
|
|
208
|
+
contextTokens: 128_000,
|
|
209
|
+
},
|
|
210
|
+
mistral: { class: 'mid', roles: ['planner', 'executor'], contextTokens: 32_000 },
|
|
211
|
+
nemotron: { class: 'heavy', roles: ['planner', 'architect', 'reviewer'], contextTokens: 128_000 },
|
|
212
|
+
// Code specialists
|
|
213
|
+
codestral: { class: 'specialized', roles: ['executor', 'fast'], contextTokens: 32_000 },
|
|
214
|
+
codegemma: { class: 'specialized', roles: ['executor', 'fast'], contextTokens: 8192 },
|
|
215
|
+
starcoder: { class: 'specialized', roles: ['executor'], contextTokens: 16_000 },
|
|
216
|
+
wizardcoder: { class: 'specialized', roles: ['executor'], contextTokens: 16_000 },
|
|
217
|
+
'granite-code': { class: 'specialized', roles: ['executor', 'fast'], contextTokens: 128_000 },
|
|
218
|
+
// Cohere
|
|
219
|
+
'command-r-plus': {
|
|
220
|
+
class: 'heavy',
|
|
221
|
+
roles: ['planner', 'architect', 'reviewer'],
|
|
222
|
+
contextTokens: 128_000,
|
|
223
|
+
},
|
|
224
|
+
'command-r': { class: 'mid', roles: ['planner', 'executor'], contextTokens: 128_000 },
|
|
225
|
+
aya: { class: 'mid', roles: ['planner', 'executor'], contextTokens: 32_000 },
|
|
226
|
+
// Misc
|
|
227
|
+
granite: { class: 'mid', roles: ['planner', 'executor'], contextTokens: 8192 },
|
|
228
|
+
yi: { class: 'mid', roles: ['planner', 'executor'], contextTokens: 32_000 },
|
|
229
|
+
solar: { class: 'mid', roles: ['executor'], contextTokens: 4096 },
|
|
230
|
+
zephyr: { class: 'mid', roles: ['executor'], contextTokens: 32_000 },
|
|
231
|
+
minicpm: { class: 'micro', roles: ['fast'], contextTokens: 4096 },
|
|
232
|
+
llava: { class: 'mid', roles: ['executor'], contextTokens: 4096 },
|
|
233
|
+
openchat: { class: 'mid', roles: ['executor'], contextTokens: 8192 },
|
|
234
|
+
smollm: { class: 'micro', roles: ['fast'], contextTokens: 2048 },
|
|
235
|
+
orca: { class: 'mid', roles: ['executor'], contextTokens: 4096 },
|
|
236
|
+
tinyllama: { class: 'micro', roles: ['fast'], contextTokens: 2048 },
|
|
237
|
+
// Fallback: accept any unknown model as a mid-range executor so Forge
|
|
238
|
+
// still gives it a chance rather than refusing to route.
|
|
239
|
+
unknown: { class: 'mid', roles: ['executor', 'planner'], contextTokens: 8192 },
|
|
240
|
+
};
|
|
241
|
+
/**
|
|
242
|
+
* Parameter-count overrides. A 70B model is "heavy" even if its family
|
|
243
|
+
* baseline is "mid"; a 1B model is "micro" even if its family is "mid".
|
|
244
|
+
*/
|
|
245
|
+
const classForSize = (b) => {
|
|
246
|
+
if (b === null)
|
|
247
|
+
return null;
|
|
248
|
+
if (b <= 4)
|
|
249
|
+
return 'micro';
|
|
250
|
+
if (b <= 13)
|
|
251
|
+
return 'mid';
|
|
252
|
+
if (b >= 30)
|
|
253
|
+
return 'heavy';
|
|
254
|
+
return null;
|
|
255
|
+
};
|
|
256
|
+
/**
|
|
257
|
+
* Classify any local/hosted model id.
|
|
258
|
+
*
|
|
259
|
+
* The function is deterministic and side-effect free so it's safe to call
|
|
260
|
+
* from anywhere (registry, router, doctor, UI).
|
|
261
|
+
*/
|
|
262
|
+
const classifyModel = (id) => {
|
|
263
|
+
const family = detect(id);
|
|
264
|
+
const base = FAMILY_META[family];
|
|
265
|
+
const sized = classForSize(sizeB(id));
|
|
266
|
+
const cls = sized ?? base.class;
|
|
267
|
+
// For code-specialists, keep the specialist tag even at large sizes.
|
|
268
|
+
const klass = base.class === 'specialized' ? 'specialized' : cls;
|
|
269
|
+
return { class: klass, roles: base.roles, contextTokens: base.contextTokens };
|
|
270
|
+
};
|
|
271
|
+
exports.classifyModel = classifyModel;
|
|
272
|
+
/**
|
|
273
|
+
* Given a list of models available on a provider, pick the best match
|
|
274
|
+
* for a role. Preference order:
|
|
275
|
+
* 1. models whose classifier roles explicitly include the desired role
|
|
276
|
+
* 2. specialized (for 'executor') or heavy (for architect/reviewer)
|
|
277
|
+
* 3. largest parameter count as a tiebreaker
|
|
278
|
+
* 4. any model at all as a last resort
|
|
279
|
+
*/
|
|
280
|
+
const pickModelForRole = (installed, role) => {
|
|
281
|
+
if (!installed.length)
|
|
282
|
+
return null;
|
|
283
|
+
const enriched = installed.map((m) => ({
|
|
284
|
+
id: m.id,
|
|
285
|
+
meta: m.meta ?? (0, exports.classifyModel)(m.id),
|
|
286
|
+
size: sizeB(m.id) ?? 0,
|
|
287
|
+
}));
|
|
288
|
+
const score = (m) => {
|
|
289
|
+
let s = 0;
|
|
290
|
+
if (m.meta.roles.includes(role))
|
|
291
|
+
s += 100;
|
|
292
|
+
if (role === 'executor' && m.meta.class === 'specialized')
|
|
293
|
+
s += 30;
|
|
294
|
+
if ((role === 'architect' || role === 'reviewer' || role === 'debugger') &&
|
|
295
|
+
m.meta.class === 'heavy')
|
|
296
|
+
s += 25;
|
|
297
|
+
if ((role === 'fast' || role === 'executor') && m.meta.class === 'micro' && role === 'fast')
|
|
298
|
+
s += 15;
|
|
299
|
+
// Prefer newer families over older; cheap proxy via context window size.
|
|
300
|
+
s += Math.log2(Math.max(1, m.meta.contextTokens / 4096));
|
|
301
|
+
// Size: for heavy roles, bigger is better; for fast, smaller wins.
|
|
302
|
+
if (role === 'fast')
|
|
303
|
+
s -= m.size * 0.5;
|
|
304
|
+
else
|
|
305
|
+
s += m.size * 0.1;
|
|
306
|
+
return s;
|
|
307
|
+
};
|
|
308
|
+
const ranked = [...enriched].sort((a, b) => score(b) - score(a));
|
|
309
|
+
return ranked[0]?.id ?? null;
|
|
310
|
+
};
|
|
311
|
+
exports.pickModelForRole = pickModelForRole;
|
|
312
|
+
exports._sizeBForTest = sizeB;
|
|
313
|
+
exports._detectFamilyForTest = detect;
|
|
314
|
+
//# sourceMappingURL=local-catalog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-catalog.js","sourceRoot":"","sources":["../../src/models/local-catalog.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ModelProvider, ModelDescriptor, ModelMessage, ModelCallOptions, ModelResponse } from '../types';
|
|
2
|
+
export declare class OllamaProvider implements ModelProvider {
|
|
3
|
+
private endpoint;
|
|
4
|
+
readonly name = "ollama";
|
|
5
|
+
constructor(endpoint?: string);
|
|
6
|
+
isAvailable(): Promise<boolean>;
|
|
7
|
+
listModels(): Promise<ModelDescriptor[]>;
|
|
8
|
+
complete(model: string, messages: ModelMessage[], options?: ModelCallOptions): Promise<ModelResponse>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=ollama.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ollama.d.ts","sourceRoot":"","sources":["../../src/models/ollama.ts"],"names":[],"mappings":"AACA,OAAO,EACL,aAAa,EACb,eAAe,EACf,YAAY,EACZ,gBAAgB,EAChB,aAAa,EACd,MAAM,UAAU,CAAC;AAKlB,qBAAa,cAAe,YAAW,aAAa;IAGtC,OAAO,CAAC,QAAQ;IAF5B,QAAQ,CAAC,IAAI,YAAY;gBAEL,QAAQ,GAAE,MAA2C;IAEnE,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAS/B,UAAU,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;IAqBxC,QAAQ,CACZ,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,YAAY,EAAE,EACxB,OAAO,GAAE,gBAAqB,GAC7B,OAAO,CAAC,aAAa,CAAC;CAsD1B"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.OllamaProvider = void 0;
|
|
4
|
+
const undici_1 = require("undici");
|
|
5
|
+
const errors_1 = require("../types/errors");
|
|
6
|
+
const loader_1 = require("../config/loader");
|
|
7
|
+
const local_catalog_1 = require("./local-catalog");
|
|
8
|
+
class OllamaProvider {
|
|
9
|
+
endpoint;
|
|
10
|
+
name = 'ollama';
|
|
11
|
+
constructor(endpoint = (0, loader_1.loadGlobalConfig)().ollama.endpoint) {
|
|
12
|
+
this.endpoint = endpoint;
|
|
13
|
+
}
|
|
14
|
+
async isAvailable() {
|
|
15
|
+
try {
|
|
16
|
+
const res = await (0, undici_1.request)(`${this.endpoint}/api/tags`, { method: 'GET' });
|
|
17
|
+
return res.statusCode === 200;
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
async listModels() {
|
|
24
|
+
try {
|
|
25
|
+
const res = await (0, undici_1.request)(`${this.endpoint}/api/tags`, { method: 'GET' });
|
|
26
|
+
if (res.statusCode !== 200)
|
|
27
|
+
return [];
|
|
28
|
+
const body = (await res.body.json());
|
|
29
|
+
return (body.models ?? []).map((m) => {
|
|
30
|
+
const meta = (0, local_catalog_1.classifyModel)(m.name);
|
|
31
|
+
return {
|
|
32
|
+
provider: 'ollama',
|
|
33
|
+
id: m.name,
|
|
34
|
+
class: meta.class,
|
|
35
|
+
contextTokens: meta.contextTokens,
|
|
36
|
+
supportsStreaming: true,
|
|
37
|
+
roles: meta.roles,
|
|
38
|
+
};
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
catch {
|
|
42
|
+
return [];
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
async complete(model, messages, options = {}) {
|
|
46
|
+
const started = Date.now();
|
|
47
|
+
const body = {
|
|
48
|
+
model,
|
|
49
|
+
messages: messages.map((m) => ({ role: m.role, content: m.content })),
|
|
50
|
+
stream: false,
|
|
51
|
+
format: options.jsonMode ? 'json' : undefined,
|
|
52
|
+
options: {
|
|
53
|
+
temperature: options.deterministic ? 0 : (options.temperature ?? 0.2),
|
|
54
|
+
num_predict: options.maxTokens ?? 2048,
|
|
55
|
+
stop: options.stop,
|
|
56
|
+
},
|
|
57
|
+
};
|
|
58
|
+
try {
|
|
59
|
+
const res = await (0, undici_1.request)(`${this.endpoint}/api/chat`, {
|
|
60
|
+
method: 'POST',
|
|
61
|
+
headers: { 'content-type': 'application/json' },
|
|
62
|
+
body: JSON.stringify(body),
|
|
63
|
+
bodyTimeout: options.timeoutMs ?? 120_000,
|
|
64
|
+
headersTimeout: options.timeoutMs ?? 120_000,
|
|
65
|
+
});
|
|
66
|
+
if (res.statusCode !== 200) {
|
|
67
|
+
const text = await res.body.text();
|
|
68
|
+
throw new errors_1.ForgeRuntimeError({
|
|
69
|
+
class: 'model_error',
|
|
70
|
+
message: `Ollama ${res.statusCode}: ${text.slice(0, 500)}`,
|
|
71
|
+
retryable: res.statusCode >= 500,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
const payload = (await res.body.json());
|
|
75
|
+
return {
|
|
76
|
+
content: payload.message?.content ?? '',
|
|
77
|
+
model,
|
|
78
|
+
provider: 'ollama',
|
|
79
|
+
inputTokens: payload.prompt_eval_count,
|
|
80
|
+
outputTokens: payload.eval_count,
|
|
81
|
+
durationMs: Date.now() - started,
|
|
82
|
+
finishReason: payload.done_reason === 'length' ? 'length' : 'stop',
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
catch (err) {
|
|
86
|
+
if (err instanceof errors_1.ForgeRuntimeError)
|
|
87
|
+
throw err;
|
|
88
|
+
throw new errors_1.ForgeRuntimeError({
|
|
89
|
+
class: 'model_error',
|
|
90
|
+
message: `Ollama request failed: ${String(err)}`,
|
|
91
|
+
retryable: true,
|
|
92
|
+
cause: err,
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
exports.OllamaProvider = OllamaProvider;
|
|
98
|
+
//# sourceMappingURL=ollama.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ollama.js","sourceRoot":"","sources":["../../src/models/ollama.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ModelProvider, ModelDescriptor, ModelMessage, ModelCallOptions, ModelResponse } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* OpenAI-compatible provider. Works with api.openai.com out of the box and
|
|
4
|
+
* with any local OpenAI-compatible server (llama.cpp `server`, vLLM,
|
|
5
|
+
* LocalAI, Together, Azure OpenAI with a base-URL override).
|
|
6
|
+
*/
|
|
7
|
+
export declare class OpenAIProvider implements ModelProvider {
|
|
8
|
+
private apiKey;
|
|
9
|
+
private endpoint;
|
|
10
|
+
readonly name: string;
|
|
11
|
+
constructor(apiKey?: string | undefined, endpoint?: string, name?: string);
|
|
12
|
+
isAvailable(): Promise<boolean>;
|
|
13
|
+
listModels(): Promise<ModelDescriptor[]>;
|
|
14
|
+
complete(model: string, messages: ModelMessage[], options?: ModelCallOptions): Promise<ModelResponse>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=openai.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openai.d.ts","sourceRoot":"","sources":["../../src/models/openai.ts"],"names":[],"mappings":"AACA,OAAO,EACL,aAAa,EACb,eAAe,EACf,YAAY,EACZ,gBAAgB,EAChB,aAAa,EACd,MAAM,UAAU,CAAC;AAIlB;;;;GAIG;AACH,qBAAa,cAAe,YAAW,aAAa;IAIhD,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,QAAQ;IAJlB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;gBAGZ,MAAM,GAAE,MAAM,GAAG,SAAsC,EACvD,QAAQ,GAAE,MAAmE,EACrF,IAAI,SAAW;IAKX,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IA4B/B,UAAU,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;IA2BxC,QAAQ,CACZ,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,YAAY,EAAE,EACxB,OAAO,GAAE,gBAAqB,GAC7B,OAAO,CAAC,aAAa,CAAC;CA4D1B"}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.OpenAIProvider = void 0;
|
|
4
|
+
const undici_1 = require("undici");
|
|
5
|
+
const errors_1 = require("../types/errors");
|
|
6
|
+
const local_catalog_1 = require("./local-catalog");
|
|
7
|
+
/**
|
|
8
|
+
* OpenAI-compatible provider. Works with api.openai.com out of the box and
|
|
9
|
+
* with any local OpenAI-compatible server (llama.cpp `server`, vLLM,
|
|
10
|
+
* LocalAI, Together, Azure OpenAI with a base-URL override).
|
|
11
|
+
*/
|
|
12
|
+
class OpenAIProvider {
|
|
13
|
+
apiKey;
|
|
14
|
+
endpoint;
|
|
15
|
+
name;
|
|
16
|
+
constructor(apiKey = process.env.OPENAI_API_KEY, endpoint = process.env.OPENAI_BASE_URL ?? 'https://api.openai.com/v1', name = 'openai') {
|
|
17
|
+
this.apiKey = apiKey;
|
|
18
|
+
this.endpoint = endpoint;
|
|
19
|
+
this.name = name;
|
|
20
|
+
}
|
|
21
|
+
async isAvailable() {
|
|
22
|
+
// Hosted OpenAI: needs an API key; if we have one, trust it. Skipping
|
|
23
|
+
// a probe here avoids an unnecessary network call per `forge` invocation.
|
|
24
|
+
if (this.endpoint === 'https://api.openai.com/v1') {
|
|
25
|
+
return Boolean(this.apiKey);
|
|
26
|
+
}
|
|
27
|
+
// Any other endpoint (LM Studio, vLLM, llama.cpp, LocalAI, Together…).
|
|
28
|
+
// We need to actually reach the server or the router will happily send
|
|
29
|
+
// traffic to a dead port. Short timeout keeps the probe cheap.
|
|
30
|
+
try {
|
|
31
|
+
const res = await (0, undici_1.request)(`${this.endpoint}/models`, {
|
|
32
|
+
method: 'GET',
|
|
33
|
+
headers: this.apiKey ? { authorization: `Bearer ${this.apiKey}` } : {},
|
|
34
|
+
headersTimeout: 1_500,
|
|
35
|
+
bodyTimeout: 1_500,
|
|
36
|
+
});
|
|
37
|
+
// Drain the body so undici doesn't keep the socket pinned.
|
|
38
|
+
try {
|
|
39
|
+
await res.body.dump();
|
|
40
|
+
}
|
|
41
|
+
catch {
|
|
42
|
+
// ignore
|
|
43
|
+
}
|
|
44
|
+
return res.statusCode >= 200 && res.statusCode < 500;
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async listModels() {
|
|
51
|
+
if (!(await this.isAvailable()))
|
|
52
|
+
return [];
|
|
53
|
+
try {
|
|
54
|
+
const res = await (0, undici_1.request)(`${this.endpoint}/models`, {
|
|
55
|
+
method: 'GET',
|
|
56
|
+
headers: this.apiKey ? { authorization: `Bearer ${this.apiKey}` } : {},
|
|
57
|
+
headersTimeout: 5000,
|
|
58
|
+
bodyTimeout: 5000,
|
|
59
|
+
});
|
|
60
|
+
if (res.statusCode !== 200)
|
|
61
|
+
return [];
|
|
62
|
+
const body = (await res.body.json());
|
|
63
|
+
return (body.data ?? []).map((m) => {
|
|
64
|
+
const meta = (0, local_catalog_1.classifyModel)(m.id);
|
|
65
|
+
return {
|
|
66
|
+
provider: this.name,
|
|
67
|
+
id: m.id,
|
|
68
|
+
class: meta.class,
|
|
69
|
+
contextTokens: meta.contextTokens,
|
|
70
|
+
supportsStreaming: true,
|
|
71
|
+
roles: meta.roles,
|
|
72
|
+
};
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
catch {
|
|
76
|
+
return [];
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
async complete(model, messages, options = {}) {
|
|
80
|
+
const started = Date.now();
|
|
81
|
+
const body = {
|
|
82
|
+
model,
|
|
83
|
+
messages: messages.map((m) => ({ role: m.role, content: m.content })),
|
|
84
|
+
temperature: options.deterministic ? 0 : (options.temperature ?? 0.3),
|
|
85
|
+
max_tokens: options.maxTokens ?? 2048,
|
|
86
|
+
stop: options.stop,
|
|
87
|
+
stream: false,
|
|
88
|
+
response_format: options.jsonMode ? { type: 'json_object' } : undefined,
|
|
89
|
+
};
|
|
90
|
+
const headers = {
|
|
91
|
+
'content-type': 'application/json',
|
|
92
|
+
};
|
|
93
|
+
if (this.apiKey)
|
|
94
|
+
headers.authorization = `Bearer ${this.apiKey}`;
|
|
95
|
+
try {
|
|
96
|
+
const res = await (0, undici_1.request)(`${this.endpoint}/chat/completions`, {
|
|
97
|
+
method: 'POST',
|
|
98
|
+
headers,
|
|
99
|
+
body: JSON.stringify(body),
|
|
100
|
+
bodyTimeout: options.timeoutMs ?? 180_000,
|
|
101
|
+
headersTimeout: options.timeoutMs ?? 180_000,
|
|
102
|
+
});
|
|
103
|
+
if (res.statusCode !== 200) {
|
|
104
|
+
const text = await res.body.text();
|
|
105
|
+
throw new errors_1.ForgeRuntimeError({
|
|
106
|
+
class: 'model_error',
|
|
107
|
+
message: `${this.name} ${res.statusCode}: ${text.slice(0, 500)}`,
|
|
108
|
+
retryable: res.statusCode === 429 || res.statusCode >= 500,
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
const data = (await res.body.json());
|
|
112
|
+
const content = data.choices?.[0]?.message?.content ?? '';
|
|
113
|
+
const finish = data.choices?.[0]?.finish_reason;
|
|
114
|
+
return {
|
|
115
|
+
content,
|
|
116
|
+
model,
|
|
117
|
+
provider: this.name,
|
|
118
|
+
inputTokens: data.usage?.prompt_tokens,
|
|
119
|
+
outputTokens: data.usage?.completion_tokens,
|
|
120
|
+
durationMs: Date.now() - started,
|
|
121
|
+
finishReason: finish === 'length' ? 'length' : finish === 'tool_calls' ? 'tool_call' : 'stop',
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
catch (err) {
|
|
125
|
+
if (err instanceof errors_1.ForgeRuntimeError)
|
|
126
|
+
throw err;
|
|
127
|
+
throw new errors_1.ForgeRuntimeError({
|
|
128
|
+
class: 'model_error',
|
|
129
|
+
message: `${this.name} request failed: ${String(err)}`,
|
|
130
|
+
retryable: true,
|
|
131
|
+
cause: err,
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
exports.OpenAIProvider = OpenAIProvider;
|
|
137
|
+
// Model classification has moved to `./local-catalog.ts` so every provider
|
|
138
|
+
// stays consistent. See `classifyModel()`.
|
|
139
|
+
//# sourceMappingURL=openai.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openai.js","sourceRoot":"","sources":["../../src/models/openai.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ModelDescriptor, ModelMessage, ModelCallOptions, ModelResponse, ModelProvider } from '../types';
|
|
2
|
+
export declare const registerProvider: (p: ModelProvider) => void;
|
|
3
|
+
export declare const getProvider: (name: string) => ModelProvider;
|
|
4
|
+
export declare const listProviders: () => ModelProvider[];
|
|
5
|
+
export declare const firstAvailableProvider: () => Promise<ModelProvider | null>;
|
|
6
|
+
export type { ModelProvider, ModelDescriptor, ModelMessage, ModelCallOptions, ModelResponse };
|
|
7
|
+
//# sourceMappingURL=provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/models/provider.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,eAAe,EACf,YAAY,EACZ,gBAAgB,EAChB,aAAa,EACb,aAAa,EACd,MAAM,UAAU,CAAC;AAMlB,eAAO,MAAM,gBAAgB,GAAI,GAAG,aAAa,KAAG,IAEnD,CAAC;AAEF,eAAO,MAAM,WAAW,GAAI,MAAM,MAAM,KAAG,aAW1C,CAAC;AAEF,eAAO,MAAM,aAAa,QAAO,aAAa,EAA6B,CAAC;AAE5E,eAAO,MAAM,sBAAsB,QAAa,OAAO,CAAC,aAAa,GAAG,IAAI,CAS3E,CAAC;AAEF,YAAY,EAAE,aAAa,EAAE,eAAe,EAAE,YAAY,EAAE,gBAAgB,EAAE,aAAa,EAAE,CAAC"}
|