@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,135 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.clear = exports.store = exports.lookup = void 0;
|
|
37
|
+
/**
|
|
38
|
+
* Prompt-level response cache. Keyed by the deterministic prompt hash from
|
|
39
|
+
* the assembler plus call options. Only caches when temperature=0 (or
|
|
40
|
+
* deterministic=true). Keeps a small LRU in-process + an optional SQLite
|
|
41
|
+
* mirror so repeated runs benefit from prior output without hitting the
|
|
42
|
+
* model again.
|
|
43
|
+
*/
|
|
44
|
+
const crypto = __importStar(require("crypto"));
|
|
45
|
+
const index_db_1 = require("../persistence/index-db");
|
|
46
|
+
const logger_1 = require("../logging/logger");
|
|
47
|
+
const migrate = () => {
|
|
48
|
+
(0, index_db_1.getDb)().exec(`
|
|
49
|
+
CREATE TABLE IF NOT EXISTS prompt_cache (
|
|
50
|
+
key TEXT PRIMARY KEY,
|
|
51
|
+
provider TEXT NOT NULL,
|
|
52
|
+
model TEXT NOT NULL,
|
|
53
|
+
content TEXT NOT NULL,
|
|
54
|
+
input_tokens INTEGER,
|
|
55
|
+
output_tokens INTEGER,
|
|
56
|
+
finish_reason TEXT,
|
|
57
|
+
created_at TEXT NOT NULL
|
|
58
|
+
);
|
|
59
|
+
CREATE INDEX IF NOT EXISTS idx_prompt_cache_created ON prompt_cache(created_at);
|
|
60
|
+
`);
|
|
61
|
+
};
|
|
62
|
+
const MAX_LIVE = 128;
|
|
63
|
+
const live = [];
|
|
64
|
+
const makeKey = (provider, model, messages, options) => {
|
|
65
|
+
const hasher = crypto.createHash('sha256');
|
|
66
|
+
hasher.update(`${provider}::${model}::`);
|
|
67
|
+
for (const m of messages)
|
|
68
|
+
hasher.update(`${m.role}::${m.content}\n`);
|
|
69
|
+
hasher.update(JSON.stringify({ ...options, timeoutMs: undefined }));
|
|
70
|
+
return hasher.digest('hex');
|
|
71
|
+
};
|
|
72
|
+
const isCacheable = (options) => options.deterministic === true || (options.temperature ?? 0.3) === 0;
|
|
73
|
+
const lookup = (provider, model, messages, options) => {
|
|
74
|
+
if (!isCacheable(options))
|
|
75
|
+
return null;
|
|
76
|
+
const key = makeKey(provider, model, messages, options);
|
|
77
|
+
const fromLive = live.find((e) => e.key === key);
|
|
78
|
+
if (fromLive)
|
|
79
|
+
return fromLive.value;
|
|
80
|
+
try {
|
|
81
|
+
migrate();
|
|
82
|
+
const row = (0, index_db_1.getDb)()
|
|
83
|
+
.prepare('SELECT content, provider, model, input_tokens, output_tokens, finish_reason FROM prompt_cache WHERE key = ?')
|
|
84
|
+
.get(key);
|
|
85
|
+
if (!row)
|
|
86
|
+
return null;
|
|
87
|
+
return {
|
|
88
|
+
content: row.content,
|
|
89
|
+
provider: row.provider,
|
|
90
|
+
model: row.model,
|
|
91
|
+
inputTokens: row.input_tokens ?? undefined,
|
|
92
|
+
outputTokens: row.output_tokens ?? undefined,
|
|
93
|
+
finishReason: row.finish_reason ?? 'stop',
|
|
94
|
+
durationMs: 0,
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
catch (err) {
|
|
98
|
+
logger_1.log.debug('prompt cache lookup failed', { err: String(err) });
|
|
99
|
+
return null;
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
exports.lookup = lookup;
|
|
103
|
+
const store = (provider, model, messages, options, response) => {
|
|
104
|
+
if (!isCacheable(options))
|
|
105
|
+
return;
|
|
106
|
+
const key = makeKey(provider, model, messages, options);
|
|
107
|
+
live.push({ key, value: response, addedAt: Date.now() });
|
|
108
|
+
if (live.length > MAX_LIVE)
|
|
109
|
+
live.shift();
|
|
110
|
+
try {
|
|
111
|
+
migrate();
|
|
112
|
+
(0, index_db_1.getDb)()
|
|
113
|
+
.prepare(`INSERT INTO prompt_cache (key, provider, model, content, input_tokens, output_tokens, finish_reason, created_at)
|
|
114
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
|
|
115
|
+
ON CONFLICT(key) DO UPDATE SET content = excluded.content, created_at = excluded.created_at`)
|
|
116
|
+
.run(key, provider, model, response.content, response.inputTokens ?? null, response.outputTokens ?? null, response.finishReason ?? null, new Date().toISOString());
|
|
117
|
+
}
|
|
118
|
+
catch (err) {
|
|
119
|
+
logger_1.log.debug('prompt cache store failed', { err: String(err) });
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
exports.store = store;
|
|
123
|
+
const clear = () => {
|
|
124
|
+
live.length = 0;
|
|
125
|
+
try {
|
|
126
|
+
migrate();
|
|
127
|
+
const r = (0, index_db_1.getDb)().prepare('DELETE FROM prompt_cache').run();
|
|
128
|
+
return r.changes;
|
|
129
|
+
}
|
|
130
|
+
catch {
|
|
131
|
+
return 0;
|
|
132
|
+
}
|
|
133
|
+
};
|
|
134
|
+
exports.clear = clear;
|
|
135
|
+
//# sourceMappingURL=cache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../src/models/cache.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Minimal circuit breaker per provider. Opens after `failureThreshold`
|
|
3
|
+
* consecutive failures, waits `resetMs` before allowing a single probe, and
|
|
4
|
+
* closes on a successful probe. Half-open state is tracked but the public
|
|
5
|
+
* surface only distinguishes "can try" from "blocked".
|
|
6
|
+
*/
|
|
7
|
+
export type BreakerState = 'closed' | 'open' | 'half_open';
|
|
8
|
+
export interface BreakerConfig {
|
|
9
|
+
failureThreshold: number;
|
|
10
|
+
resetMs: number;
|
|
11
|
+
}
|
|
12
|
+
export declare const configure: (provider: string, cfg: Partial<BreakerConfig>) => void;
|
|
13
|
+
export declare const canTry: (provider: string) => boolean;
|
|
14
|
+
export declare const reportSuccess: (provider: string) => void;
|
|
15
|
+
export declare const reportFailure: (provider: string) => void;
|
|
16
|
+
export declare const status: () => Record<string, BreakerState>;
|
|
17
|
+
export declare const reset: (provider?: string) => void;
|
|
18
|
+
//# sourceMappingURL=circuit-breaker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"circuit-breaker.d.ts","sourceRoot":"","sources":["../../src/models/circuit-breaker.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,MAAM,GAAG,WAAW,CAAC;AAU3D,MAAM,WAAW,aAAa;IAC5B,gBAAgB,EAAE,MAAM,CAAC;IACzB,OAAO,EAAE,MAAM,CAAC;CACjB;AAeD,eAAO,MAAM,SAAS,GAAI,UAAU,MAAM,EAAE,KAAK,OAAO,CAAC,aAAa,CAAC,KAAG,IAGzE,CAAC;AAEF,eAAO,MAAM,MAAM,GAAI,UAAU,MAAM,KAAG,OAWzC,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,UAAU,MAAM,KAAG,IAIhD,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,UAAU,MAAM,KAAG,IAQhD,CAAC;AAEF,eAAO,MAAM,MAAM,QAAO,MAAM,CAAC,MAAM,EAAE,YAAY,CAIpD,CAAC;AAEF,eAAO,MAAM,KAAK,GAAI,WAAW,MAAM,KAAG,IAGzC,CAAC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.reset = exports.status = exports.reportFailure = exports.reportSuccess = exports.canTry = exports.configure = void 0;
|
|
4
|
+
const DEFAULTS = { failureThreshold: 5, resetMs: 60_000 };
|
|
5
|
+
const state = new Map();
|
|
6
|
+
const get = (provider) => {
|
|
7
|
+
let s = state.get(provider);
|
|
8
|
+
if (!s) {
|
|
9
|
+
s = { state: 'closed', failures: 0, opened: 0, lastFailure: 0, cfg: DEFAULTS };
|
|
10
|
+
state.set(provider, s);
|
|
11
|
+
}
|
|
12
|
+
return s;
|
|
13
|
+
};
|
|
14
|
+
const configure = (provider, cfg) => {
|
|
15
|
+
const s = get(provider);
|
|
16
|
+
s.cfg = { ...s.cfg, ...cfg };
|
|
17
|
+
};
|
|
18
|
+
exports.configure = configure;
|
|
19
|
+
const canTry = (provider) => {
|
|
20
|
+
const s = get(provider);
|
|
21
|
+
if (s.state === 'closed')
|
|
22
|
+
return true;
|
|
23
|
+
if (s.state === 'open') {
|
|
24
|
+
if (Date.now() - s.opened >= s.cfg.resetMs) {
|
|
25
|
+
s.state = 'half_open';
|
|
26
|
+
return true;
|
|
27
|
+
}
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
return true; // half_open: allow the probe
|
|
31
|
+
};
|
|
32
|
+
exports.canTry = canTry;
|
|
33
|
+
const reportSuccess = (provider) => {
|
|
34
|
+
const s = get(provider);
|
|
35
|
+
s.failures = 0;
|
|
36
|
+
s.state = 'closed';
|
|
37
|
+
};
|
|
38
|
+
exports.reportSuccess = reportSuccess;
|
|
39
|
+
const reportFailure = (provider) => {
|
|
40
|
+
const s = get(provider);
|
|
41
|
+
s.failures++;
|
|
42
|
+
s.lastFailure = Date.now();
|
|
43
|
+
if (s.failures >= s.cfg.failureThreshold) {
|
|
44
|
+
s.state = 'open';
|
|
45
|
+
s.opened = Date.now();
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
exports.reportFailure = reportFailure;
|
|
49
|
+
const status = () => {
|
|
50
|
+
const out = {};
|
|
51
|
+
for (const [k, v] of state)
|
|
52
|
+
out[k] = v.state;
|
|
53
|
+
return out;
|
|
54
|
+
};
|
|
55
|
+
exports.status = status;
|
|
56
|
+
const reset = (provider) => {
|
|
57
|
+
if (provider)
|
|
58
|
+
state.delete(provider);
|
|
59
|
+
else
|
|
60
|
+
state.clear();
|
|
61
|
+
};
|
|
62
|
+
exports.reset = reset;
|
|
63
|
+
//# sourceMappingURL=circuit-breaker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"circuit-breaker.js","sourceRoot":"","sources":["../../src/models/circuit-breaker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ModelResponse } from '../types';
|
|
2
|
+
export declare const estimateCostUsd: (provider: string, model: string, input: number, output: number) => number;
|
|
3
|
+
export declare const record: (ctx: {
|
|
4
|
+
projectId?: string;
|
|
5
|
+
taskId?: string;
|
|
6
|
+
}, response: ModelResponse) => number;
|
|
7
|
+
export declare const totals: (projectId?: string) => {
|
|
8
|
+
calls: number;
|
|
9
|
+
tokens: number;
|
|
10
|
+
usd: number;
|
|
11
|
+
};
|
|
12
|
+
export declare const recent: (limit?: number) => unknown[];
|
|
13
|
+
//# sourceMappingURL=cost.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cost.d.ts","sourceRoot":"","sources":["../../src/models/cost.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAyCzC,eAAO,MAAM,eAAe,GAC1B,UAAU,MAAM,EAChB,OAAO,MAAM,EACb,OAAO,MAAM,EACb,QAAQ,MAAM,KACb,MAKF,CAAC;AAEF,eAAO,MAAM,MAAM,GACjB,KAAK;IAAE,SAAS,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,EAC5C,UAAU,aAAa,KACtB,MA4BF,CAAC;AAEF,eAAO,MAAM,MAAM,GAAI,YAAY,MAAM,KAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,MAAM,CAAA;CAevF,CAAC;AAEF,eAAO,MAAM,MAAM,GAAI,cAAU,cAQhC,CAAC"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.recent = exports.totals = exports.record = exports.estimateCostUsd = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Cost ledger. Every model response is recorded with an estimated USD cost
|
|
6
|
+
* based on static per-model rates. Costs are a rough indicator — the
|
|
7
|
+
* provider's invoice is the source of truth. Rates live in one table so
|
|
8
|
+
* corrections are cheap.
|
|
9
|
+
*/
|
|
10
|
+
const index_db_1 = require("../persistence/index-db");
|
|
11
|
+
const logger_1 = require("../logging/logger");
|
|
12
|
+
const migrate = () => {
|
|
13
|
+
(0, index_db_1.getDb)().exec(`
|
|
14
|
+
CREATE TABLE IF NOT EXISTS model_cost_ledger (
|
|
15
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
16
|
+
project_id TEXT,
|
|
17
|
+
task_id TEXT,
|
|
18
|
+
provider TEXT NOT NULL,
|
|
19
|
+
model TEXT NOT NULL,
|
|
20
|
+
input_tokens INTEGER NOT NULL,
|
|
21
|
+
output_tokens INTEGER NOT NULL,
|
|
22
|
+
duration_ms INTEGER NOT NULL,
|
|
23
|
+
cost_usd REAL NOT NULL,
|
|
24
|
+
created_at TEXT NOT NULL
|
|
25
|
+
);
|
|
26
|
+
CREATE INDEX IF NOT EXISTS idx_cost_project ON model_cost_ledger(project_id);
|
|
27
|
+
CREATE INDEX IF NOT EXISTS idx_cost_created ON model_cost_ledger(created_at);
|
|
28
|
+
`);
|
|
29
|
+
};
|
|
30
|
+
// Approximate public rates. Local models (ollama/llamacpp) are free.
|
|
31
|
+
const RATE_TABLE = [
|
|
32
|
+
{ match: /^claude-opus/, rate: { inputUsdPerMTok: 15, outputUsdPerMTok: 75 } },
|
|
33
|
+
{ match: /^claude-sonnet/, rate: { inputUsdPerMTok: 3, outputUsdPerMTok: 15 } },
|
|
34
|
+
{ match: /^claude-haiku/, rate: { inputUsdPerMTok: 0.8, outputUsdPerMTok: 4 } },
|
|
35
|
+
{ match: /^gpt-4o-mini/, rate: { inputUsdPerMTok: 0.15, outputUsdPerMTok: 0.6 } },
|
|
36
|
+
{ match: /^gpt-4o/, rate: { inputUsdPerMTok: 2.5, outputUsdPerMTok: 10 } },
|
|
37
|
+
{ match: /^gpt-4-turbo/, rate: { inputUsdPerMTok: 10, outputUsdPerMTok: 30 } },
|
|
38
|
+
{ match: /^gpt-4/, rate: { inputUsdPerMTok: 30, outputUsdPerMTok: 60 } },
|
|
39
|
+
{ match: /^gpt-3\.5/, rate: { inputUsdPerMTok: 0.5, outputUsdPerMTok: 1.5 } },
|
|
40
|
+
{ match: /^o1-mini/, rate: { inputUsdPerMTok: 3, outputUsdPerMTok: 12 } },
|
|
41
|
+
{ match: /^o1/, rate: { inputUsdPerMTok: 15, outputUsdPerMTok: 60 } },
|
|
42
|
+
];
|
|
43
|
+
const estimateCostUsd = (provider, model, input, output) => {
|
|
44
|
+
if (provider === 'ollama' || provider === 'llamacpp')
|
|
45
|
+
return 0;
|
|
46
|
+
const rate = RATE_TABLE.find((r) => r.match.test(model));
|
|
47
|
+
if (!rate)
|
|
48
|
+
return 0;
|
|
49
|
+
return (input * rate.rate.inputUsdPerMTok + output * rate.rate.outputUsdPerMTok) / 1_000_000;
|
|
50
|
+
};
|
|
51
|
+
exports.estimateCostUsd = estimateCostUsd;
|
|
52
|
+
const record = (ctx, response) => {
|
|
53
|
+
try {
|
|
54
|
+
migrate();
|
|
55
|
+
const input = response.inputTokens ?? 0;
|
|
56
|
+
const output = response.outputTokens ?? 0;
|
|
57
|
+
const cost = (0, exports.estimateCostUsd)(response.provider, response.model, input, output);
|
|
58
|
+
(0, index_db_1.getDb)()
|
|
59
|
+
.prepare(`INSERT INTO model_cost_ledger
|
|
60
|
+
(project_id, task_id, provider, model, input_tokens, output_tokens, duration_ms, cost_usd, created_at)
|
|
61
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
62
|
+
.run(ctx.projectId ?? null, ctx.taskId ?? null, response.provider, response.model, input, output, response.durationMs, cost, new Date().toISOString());
|
|
63
|
+
return cost;
|
|
64
|
+
}
|
|
65
|
+
catch (err) {
|
|
66
|
+
logger_1.log.debug('cost ledger write failed', { err: String(err) });
|
|
67
|
+
return 0;
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
exports.record = record;
|
|
71
|
+
const totals = (projectId) => {
|
|
72
|
+
migrate();
|
|
73
|
+
const db = (0, index_db_1.getDb)();
|
|
74
|
+
const row = projectId
|
|
75
|
+
? db
|
|
76
|
+
.prepare('SELECT COUNT(*) as calls, COALESCE(SUM(input_tokens + output_tokens), 0) as tokens, COALESCE(SUM(cost_usd), 0) as usd FROM model_cost_ledger WHERE project_id = ?')
|
|
77
|
+
.get(projectId)
|
|
78
|
+
: db
|
|
79
|
+
.prepare('SELECT COUNT(*) as calls, COALESCE(SUM(input_tokens + output_tokens), 0) as tokens, COALESCE(SUM(cost_usd), 0) as usd FROM model_cost_ledger')
|
|
80
|
+
.get();
|
|
81
|
+
return row;
|
|
82
|
+
};
|
|
83
|
+
exports.totals = totals;
|
|
84
|
+
const recent = (limit = 25) => {
|
|
85
|
+
migrate();
|
|
86
|
+
return (0, index_db_1.getDb)()
|
|
87
|
+
.prepare(`SELECT provider, model, input_tokens, output_tokens, duration_ms, cost_usd, created_at
|
|
88
|
+
FROM model_cost_ledger ORDER BY id DESC LIMIT ?`)
|
|
89
|
+
.all(limit);
|
|
90
|
+
};
|
|
91
|
+
exports.recent = recent;
|
|
92
|
+
//# sourceMappingURL=cost.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cost.js","sourceRoot":"","sources":["../../src/models/cost.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { OpenAIProvider } from './openai';
|
|
2
|
+
/**
|
|
3
|
+
* llama.cpp via its OpenAI-compatible `server` endpoint. Same wire protocol,
|
|
4
|
+
* just a different default base URL and no API key required.
|
|
5
|
+
*/
|
|
6
|
+
export declare class LlamaCppProvider extends OpenAIProvider {
|
|
7
|
+
constructor(endpoint?: string);
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=llamacpp.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llamacpp.d.ts","sourceRoot":"","sources":["../../src/models/llamacpp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE1C;;;GAGG;AACH,qBAAa,gBAAiB,SAAQ,cAAc;gBACtC,QAAQ,GAAE,MAAoE;CAG3F"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LlamaCppProvider = void 0;
|
|
4
|
+
const openai_1 = require("./openai");
|
|
5
|
+
/**
|
|
6
|
+
* llama.cpp via its OpenAI-compatible `server` endpoint. Same wire protocol,
|
|
7
|
+
* just a different default base URL and no API key required.
|
|
8
|
+
*/
|
|
9
|
+
class LlamaCppProvider extends openai_1.OpenAIProvider {
|
|
10
|
+
constructor(endpoint = process.env.LLAMACPP_ENDPOINT ?? 'http://127.0.0.1:8080/v1') {
|
|
11
|
+
super(process.env.LLAMACPP_API_KEY, endpoint, 'llamacpp');
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
exports.LlamaCppProvider = LlamaCppProvider;
|
|
15
|
+
//# sourceMappingURL=llamacpp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llamacpp.js","sourceRoot":"","sources":["../../src/models/llamacpp.ts"],"names":[],"mappings":";;;AAAA,qCAA0C;AAE1C;;;GAGG;AACH,MAAa,gBAAiB,SAAQ,uBAAc;IAClD,YAAY,WAAmB,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,0BAA0B;QACxF,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;IAC5D,CAAC;CACF;AAJD,4CAIC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { OpenAIProvider } from './openai';
|
|
2
|
+
/**
|
|
3
|
+
* LM Studio's built-in server (Local Server → "Start Server"). Defaults to
|
|
4
|
+
* http://127.0.0.1:1234/v1 and speaks the OpenAI chat-completions API.
|
|
5
|
+
*
|
|
6
|
+
* Override with `LMSTUDIO_ENDPOINT`.
|
|
7
|
+
*/
|
|
8
|
+
export declare class LmStudioProvider extends OpenAIProvider {
|
|
9
|
+
constructor(endpoint?: string);
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=lmstudio.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lmstudio.d.ts","sourceRoot":"","sources":["../../src/models/lmstudio.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE1C;;;;;GAKG;AACH,qBAAa,gBAAiB,SAAQ,cAAc;gBACtC,QAAQ,GAAE,MAAoE;CAI3F"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LmStudioProvider = void 0;
|
|
4
|
+
const openai_1 = require("./openai");
|
|
5
|
+
/**
|
|
6
|
+
* LM Studio's built-in server (Local Server → "Start Server"). Defaults to
|
|
7
|
+
* http://127.0.0.1:1234/v1 and speaks the OpenAI chat-completions API.
|
|
8
|
+
*
|
|
9
|
+
* Override with `LMSTUDIO_ENDPOINT`.
|
|
10
|
+
*/
|
|
11
|
+
class LmStudioProvider extends openai_1.OpenAIProvider {
|
|
12
|
+
constructor(endpoint = process.env.LMSTUDIO_ENDPOINT ?? 'http://127.0.0.1:1234/v1') {
|
|
13
|
+
// LM Studio does not require an API key but will ignore one if sent.
|
|
14
|
+
super(process.env.LMSTUDIO_API_KEY ?? 'lm-studio', endpoint, 'lmstudio');
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.LmStudioProvider = LmStudioProvider;
|
|
18
|
+
//# sourceMappingURL=lmstudio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lmstudio.js","sourceRoot":"","sources":["../../src/models/lmstudio.ts"],"names":[],"mappings":";;;AAAA,qCAA0C;AAE1C;;;;;GAKG;AACH,MAAa,gBAAiB,SAAQ,uBAAc;IAClD,YAAY,WAAmB,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,0BAA0B;QACxF,qEAAqE;QACrE,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,WAAW,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;IAC3E,CAAC;CACF;AALD,4CAKC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Local-model catalogue: one place to map a model id → Forge's routing
|
|
3
|
+
* metadata. Used by every local-runtime provider (Ollama, llama.cpp, vLLM,
|
|
4
|
+
* LM Studio, LocalAI, OpenAI-compatible generic) so they stay consistent.
|
|
5
|
+
*
|
|
6
|
+
* The matcher intentionally handles both Ollama-style ids (`llama3.1:8b`,
|
|
7
|
+
* `qwen2.5-coder:14b`) and HF-style ids (`meta-llama/Llama-3.1-8B-Instruct`)
|
|
8
|
+
* without a hard dependency on either.
|
|
9
|
+
*/
|
|
10
|
+
import { ModelDescriptor, ModelRole } from '../types';
|
|
11
|
+
export type ModelClass = ModelDescriptor['class'];
|
|
12
|
+
export interface LocalModelMeta {
|
|
13
|
+
class: ModelClass;
|
|
14
|
+
roles: ModelRole[];
|
|
15
|
+
contextTokens: number;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Family detection — ordered by specificity so the most accurate hit wins.
|
|
19
|
+
* Every entry returns the *canonical* family tag which the metadata table
|
|
20
|
+
* then resolves into class/roles/context.
|
|
21
|
+
*/
|
|
22
|
+
type Family = 'llama4' | 'llama3' | 'llama2' | 'codellama' | 'deepseek-r1' | 'deepseek-v3' | 'deepseek-coder' | 'deepseek' | 'qwen3' | 'qwen25-coder' | 'qwen25' | 'qwen2' | 'qwen' | 'gemma3' | 'gemma2' | 'gemma' | 'phi4' | 'phi3' | 'phi' | 'mixtral' | 'mistral-nemo' | 'mistral-small' | 'mistral-large' | 'mistral' | 'command-r-plus' | 'command-r' | 'starcoder' | 'codegemma' | 'codestral' | 'granite-code' | 'granite' | 'yi' | 'solar' | 'zephyr' | 'minicpm' | 'llava' | 'openchat' | 'wizardcoder' | 'aya' | 'nemotron' | 'smollm' | 'orca' | 'tinyllama' | 'gpt4' | 'gpt35' | 'o-series' | 'claude-opus' | 'claude-sonnet' | 'claude-haiku' | 'unknown';
|
|
23
|
+
/**
|
|
24
|
+
* Classify any local/hosted model id.
|
|
25
|
+
*
|
|
26
|
+
* The function is deterministic and side-effect free so it's safe to call
|
|
27
|
+
* from anywhere (registry, router, doctor, UI).
|
|
28
|
+
*/
|
|
29
|
+
export declare const classifyModel: (id: string) => LocalModelMeta;
|
|
30
|
+
/**
|
|
31
|
+
* Given a list of models available on a provider, pick the best match
|
|
32
|
+
* for a role. Preference order:
|
|
33
|
+
* 1. models whose classifier roles explicitly include the desired role
|
|
34
|
+
* 2. specialized (for 'executor') or heavy (for architect/reviewer)
|
|
35
|
+
* 3. largest parameter count as a tiebreaker
|
|
36
|
+
* 4. any model at all as a last resort
|
|
37
|
+
*/
|
|
38
|
+
export declare const pickModelForRole: (installed: Array<{
|
|
39
|
+
id: string;
|
|
40
|
+
meta?: LocalModelMeta;
|
|
41
|
+
}>, role: ModelRole) => string | null;
|
|
42
|
+
export declare const _sizeBForTest: (id: string) => number | null;
|
|
43
|
+
export declare const _detectFamilyForTest: (rawId: string) => Family;
|
|
44
|
+
export {};
|
|
45
|
+
//# sourceMappingURL=local-catalog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-catalog.d.ts","sourceRoot":"","sources":["../../src/models/local-catalog.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAEtD,MAAM,MAAM,UAAU,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;AAElD,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,UAAU,CAAC;IAClB,KAAK,EAAE,SAAS,EAAE,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;CACvB;AAoBD;;;;GAIG;AACH,KAAK,MAAM,GACP,QAAQ,GACR,QAAQ,GACR,QAAQ,GACR,WAAW,GACX,aAAa,GACb,aAAa,GACb,gBAAgB,GAChB,UAAU,GACV,OAAO,GACP,cAAc,GACd,QAAQ,GACR,OAAO,GACP,MAAM,GACN,QAAQ,GACR,QAAQ,GACR,OAAO,GACP,MAAM,GACN,MAAM,GACN,KAAK,GACL,SAAS,GACT,cAAc,GACd,eAAe,GACf,eAAe,GACf,SAAS,GACT,gBAAgB,GAChB,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,cAAc,GACd,SAAS,GACT,IAAI,GACJ,OAAO,GACP,QAAQ,GACR,SAAS,GACT,OAAO,GACP,UAAU,GACV,aAAa,GACb,KAAK,GACL,UAAU,GACV,QAAQ,GACR,MAAM,GACN,WAAW,GACX,MAAM,GACN,OAAO,GACP,UAAU,GACV,aAAa,GACb,eAAe,GACf,cAAc,GACd,SAAS,CAAC;AAiNd;;;;;GAKG;AACH,eAAO,MAAM,aAAa,GAAI,IAAI,MAAM,KAAG,cAQ1C,CAAC;AAEF;;;;;;;GAOG;AACH,eAAO,MAAM,gBAAgB,GAC3B,WAAW,KAAK,CAAC;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,cAAc,CAAA;CAAE,CAAC,EACvD,MAAM,SAAS,KACd,MAAM,GAAG,IA6BX,CAAC;AAEF,eAAO,MAAM,aAAa,OApUP,MAAM,KAAG,MAAM,GAAG,IAoUH,CAAC;AACnC,eAAO,MAAM,oBAAoB,UA1QV,MAAM,KAAG,MA0QU,CAAC"}
|