@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,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.firstAvailableProvider = exports.listProviders = exports.getProvider = exports.registerProvider = void 0;
|
|
4
|
+
const errors_1 = require("../types/errors");
|
|
5
|
+
const logger_1 = require("../logging/logger");
|
|
6
|
+
const providers = new Map();
|
|
7
|
+
const registerProvider = (p) => {
|
|
8
|
+
providers.set(p.name, p);
|
|
9
|
+
};
|
|
10
|
+
exports.registerProvider = registerProvider;
|
|
11
|
+
const getProvider = (name) => {
|
|
12
|
+
const p = providers.get(name);
|
|
13
|
+
if (!p) {
|
|
14
|
+
throw new errors_1.ForgeRuntimeError({
|
|
15
|
+
class: 'not_found',
|
|
16
|
+
message: `Model provider '${name}' is not registered.`,
|
|
17
|
+
retryable: false,
|
|
18
|
+
recoveryHint: `Available: ${[...providers.keys()].join(', ') || '(none)'}`,
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
return p;
|
|
22
|
+
};
|
|
23
|
+
exports.getProvider = getProvider;
|
|
24
|
+
const listProviders = () => [...providers.values()];
|
|
25
|
+
exports.listProviders = listProviders;
|
|
26
|
+
const firstAvailableProvider = async () => {
|
|
27
|
+
for (const p of providers.values()) {
|
|
28
|
+
try {
|
|
29
|
+
if (await p.isAvailable())
|
|
30
|
+
return p;
|
|
31
|
+
}
|
|
32
|
+
catch (err) {
|
|
33
|
+
logger_1.log.debug('provider availability probe failed', { provider: p.name, err: String(err) });
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return null;
|
|
37
|
+
};
|
|
38
|
+
exports.firstAvailableProvider = firstAvailableProvider;
|
|
39
|
+
//# sourceMappingURL=provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../src/models/provider.ts"],"names":[],"mappings":";;;AAOA,4CAAoD;AACpD,8CAAwC;AAExC,MAAM,SAAS,GAA+B,IAAI,GAAG,EAAE,CAAC;AAEjD,MAAM,gBAAgB,GAAG,CAAC,CAAgB,EAAQ,EAAE;IACzD,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;AAC3B,CAAC,CAAC;AAFW,QAAA,gBAAgB,oBAE3B;AAEK,MAAM,WAAW,GAAG,CAAC,IAAY,EAAiB,EAAE;IACzD,MAAM,CAAC,GAAG,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC9B,IAAI,CAAC,CAAC,EAAE,CAAC;QACP,MAAM,IAAI,0BAAiB,CAAC;YAC1B,KAAK,EAAE,WAAW;YAClB,OAAO,EAAE,mBAAmB,IAAI,sBAAsB;YACtD,SAAS,EAAE,KAAK;YAChB,YAAY,EAAE,cAAc,CAAC,GAAG,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,QAAQ,EAAE;SAC3E,CAAC,CAAC;IACL,CAAC;IACD,OAAO,CAAC,CAAC;AACX,CAAC,CAAC;AAXW,QAAA,WAAW,eAWtB;AAEK,MAAM,aAAa,GAAG,GAAoB,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;AAA/D,QAAA,aAAa,iBAAkD;AAErE,MAAM,sBAAsB,GAAG,KAAK,IAAmC,EAAE;IAC9E,KAAK,MAAM,CAAC,IAAI,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC;QACnC,IAAI,CAAC;YACH,IAAI,MAAM,CAAC,CAAC,WAAW,EAAE;gBAAE,OAAO,CAAC,CAAC;QACtC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,YAAG,CAAC,KAAK,CAAC,oCAAoC,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC1F,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AATW,QAAA,sBAAsB,0BASjC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Per-provider token-bucket rate limiter. Keeps the model router from
|
|
3
|
+
* hammering a provider past its documented rate limit, especially in the
|
|
4
|
+
* retry loop where backoff + retry can pile up fast.
|
|
5
|
+
*/
|
|
6
|
+
export interface BucketConfig {
|
|
7
|
+
capacity: number;
|
|
8
|
+
refillPerSec: number;
|
|
9
|
+
}
|
|
10
|
+
export declare const configure: (provider: string, cfg: BucketConfig) => void;
|
|
11
|
+
export declare const acquire: (provider: string) => Promise<void>;
|
|
12
|
+
export declare const reset: (provider?: string) => void;
|
|
13
|
+
//# sourceMappingURL=rate-limit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limit.d.ts","sourceRoot":"","sources":["../../src/models/rate-limit.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,WAAW,YAAY;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;CACtB;AAUD,eAAO,MAAM,SAAS,GAAI,UAAU,MAAM,EAAE,KAAK,YAAY,KAAG,IAE/D,CAAC;AASF,eAAO,MAAM,OAAO,GAAU,UAAU,MAAM,KAAG,OAAO,CAAC,IAAI,CAY5D,CAAC;AAEF,eAAO,MAAM,KAAK,GAAI,WAAW,MAAM,KAAG,IAGzC,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.reset = exports.acquire = exports.configure = void 0;
|
|
4
|
+
const buckets = new Map();
|
|
5
|
+
const configure = (provider, cfg) => {
|
|
6
|
+
buckets.set(provider, { tokens: cfg.capacity, lastRefill: Date.now(), cfg });
|
|
7
|
+
};
|
|
8
|
+
exports.configure = configure;
|
|
9
|
+
const refill = (state) => {
|
|
10
|
+
const now = Date.now();
|
|
11
|
+
const elapsed = (now - state.lastRefill) / 1000;
|
|
12
|
+
state.tokens = Math.min(state.cfg.capacity, state.tokens + elapsed * state.cfg.refillPerSec);
|
|
13
|
+
state.lastRefill = now;
|
|
14
|
+
};
|
|
15
|
+
const acquire = async (provider) => {
|
|
16
|
+
const state = buckets.get(provider);
|
|
17
|
+
if (!state)
|
|
18
|
+
return; // no limit configured
|
|
19
|
+
refill(state);
|
|
20
|
+
if (state.tokens >= 1) {
|
|
21
|
+
state.tokens -= 1;
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
const waitMs = Math.ceil(((1 - state.tokens) / state.cfg.refillPerSec) * 1000);
|
|
25
|
+
await new Promise((resolve) => setTimeout(resolve, Math.min(waitMs, 30_000)));
|
|
26
|
+
refill(state);
|
|
27
|
+
state.tokens = Math.max(0, state.tokens - 1);
|
|
28
|
+
};
|
|
29
|
+
exports.acquire = acquire;
|
|
30
|
+
const reset = (provider) => {
|
|
31
|
+
if (provider)
|
|
32
|
+
buckets.delete(provider);
|
|
33
|
+
else
|
|
34
|
+
buckets.clear();
|
|
35
|
+
};
|
|
36
|
+
exports.reset = reset;
|
|
37
|
+
//# sourceMappingURL=rate-limit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limit.js","sourceRoot":"","sources":["../../src/models/rate-limit.ts"],"names":[],"mappings":";;;AAgBA,MAAM,OAAO,GAAG,IAAI,GAAG,EAAuB,CAAC;AAExC,MAAM,SAAS,GAAG,CAAC,QAAgB,EAAE,GAAiB,EAAQ,EAAE;IACrE,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,QAAQ,EAAE,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;AAC/E,CAAC,CAAC;AAFW,QAAA,SAAS,aAEpB;AAEF,MAAM,MAAM,GAAG,CAAC,KAAkB,EAAQ,EAAE;IAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACvB,MAAM,OAAO,GAAG,CAAC,GAAG,GAAG,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC;IAChD,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,GAAG,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAC7F,KAAK,CAAC,UAAU,GAAG,GAAG,CAAC;AACzB,CAAC,CAAC;AAEK,MAAM,OAAO,GAAG,KAAK,EAAE,QAAgB,EAAiB,EAAE;IAC/D,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACpC,IAAI,CAAC,KAAK;QAAE,OAAO,CAAC,sBAAsB;IAC1C,MAAM,CAAC,KAAK,CAAC,CAAC;IACd,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;QACtB,KAAK,CAAC,MAAM,IAAI,CAAC,CAAC;QAClB,OAAO;IACT,CAAC;IACD,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,CAAC;IAC/E,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;IAC9E,MAAM,CAAC,KAAK,CAAC,CAAC;IACd,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAC/C,CAAC,CAAC;AAZW,QAAA,OAAO,WAYlB;AAEK,MAAM,KAAK,GAAG,CAAC,QAAiB,EAAQ,EAAE;IAC/C,IAAI,QAAQ;QAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;;QAClC,OAAO,CAAC,KAAK,EAAE,CAAC;AACvB,CAAC,CAAC;AAHW,QAAA,KAAK,SAGhB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/models/registry.ts"],"names":[],"mappings":"AAYA,eAAO,MAAM,aAAa,QAAO,IAqBhC,CAAC"}
|
|
@@ -0,0 +1,69 @@
|
|
|
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.initProviders = void 0;
|
|
37
|
+
const provider_1 = require("./provider");
|
|
38
|
+
const ollama_1 = require("./ollama");
|
|
39
|
+
const anthropic_1 = require("./anthropic");
|
|
40
|
+
const openai_1 = require("./openai");
|
|
41
|
+
const llamacpp_1 = require("./llamacpp");
|
|
42
|
+
const vllm_1 = require("./vllm");
|
|
43
|
+
const lmstudio_1 = require("./lmstudio");
|
|
44
|
+
const rateLimit = __importStar(require("./rate-limit"));
|
|
45
|
+
const breaker = __importStar(require("./circuit-breaker"));
|
|
46
|
+
let initialized = false;
|
|
47
|
+
const initProviders = () => {
|
|
48
|
+
if (initialized)
|
|
49
|
+
return;
|
|
50
|
+
(0, provider_1.registerProvider)(new ollama_1.OllamaProvider());
|
|
51
|
+
(0, provider_1.registerProvider)(new anthropic_1.AnthropicProvider());
|
|
52
|
+
(0, provider_1.registerProvider)(new openai_1.OpenAIProvider());
|
|
53
|
+
(0, provider_1.registerProvider)(new llamacpp_1.LlamaCppProvider());
|
|
54
|
+
(0, provider_1.registerProvider)(new vllm_1.VllmProvider());
|
|
55
|
+
(0, provider_1.registerProvider)(new lmstudio_1.LmStudioProvider());
|
|
56
|
+
// Sensible default limits. Local runtimes aren't rate-limited; remote
|
|
57
|
+
// providers get conservative caps so bursts don't trip 429s.
|
|
58
|
+
rateLimit.configure('anthropic', { capacity: 30, refillPerSec: 2 });
|
|
59
|
+
rateLimit.configure('openai', { capacity: 60, refillPerSec: 3 });
|
|
60
|
+
breaker.configure('anthropic', { failureThreshold: 4, resetMs: 30_000 });
|
|
61
|
+
breaker.configure('openai', { failureThreshold: 4, resetMs: 30_000 });
|
|
62
|
+
breaker.configure('ollama', { failureThreshold: 6, resetMs: 10_000 });
|
|
63
|
+
breaker.configure('llamacpp', { failureThreshold: 6, resetMs: 10_000 });
|
|
64
|
+
breaker.configure('vllm', { failureThreshold: 6, resetMs: 10_000 });
|
|
65
|
+
breaker.configure('lmstudio', { failureThreshold: 6, resetMs: 10_000 });
|
|
66
|
+
initialized = true;
|
|
67
|
+
};
|
|
68
|
+
exports.initProviders = initProviders;
|
|
69
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/models/registry.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,yCAA8C;AAC9C,qCAA0C;AAC1C,2CAAgD;AAChD,qCAA0C;AAC1C,yCAA8C;AAC9C,iCAAsC;AACtC,yCAA8C;AAC9C,wDAA0C;AAC1C,2DAA6C;AAE7C,IAAI,WAAW,GAAG,KAAK,CAAC;AAEjB,MAAM,aAAa,GAAG,GAAS,EAAE;IACtC,IAAI,WAAW;QAAE,OAAO;IACxB,IAAA,2BAAgB,EAAC,IAAI,uBAAc,EAAE,CAAC,CAAC;IACvC,IAAA,2BAAgB,EAAC,IAAI,6BAAiB,EAAE,CAAC,CAAC;IAC1C,IAAA,2BAAgB,EAAC,IAAI,uBAAc,EAAE,CAAC,CAAC;IACvC,IAAA,2BAAgB,EAAC,IAAI,2BAAgB,EAAE,CAAC,CAAC;IACzC,IAAA,2BAAgB,EAAC,IAAI,mBAAY,EAAE,CAAC,CAAC;IACrC,IAAA,2BAAgB,EAAC,IAAI,2BAAgB,EAAE,CAAC,CAAC;IAEzC,sEAAsE;IACtE,6DAA6D;IAC7D,SAAS,CAAC,SAAS,CAAC,WAAW,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC;IACpE,SAAS,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC;IACjE,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IACzE,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IACtE,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IACtE,OAAO,CAAC,SAAS,CAAC,UAAU,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IACxE,OAAO,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IACpE,OAAO,CAAC,SAAS,CAAC,UAAU,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IAExE,WAAW,GAAG,IAAI,CAAC;AACrB,CAAC,CAAC;AArBW,QAAA,aAAa,iBAqBxB"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Mode, ModelMessage, ModelCallOptions, ModelResponse, ModelRole } from '../types';
|
|
2
|
+
export interface RoutingDecision {
|
|
3
|
+
provider: string;
|
|
4
|
+
model: string;
|
|
5
|
+
reason: string;
|
|
6
|
+
fallback?: {
|
|
7
|
+
provider: string;
|
|
8
|
+
model: string;
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
export declare const resolveModel: (params: {
|
|
12
|
+
role: ModelRole;
|
|
13
|
+
mode: Mode;
|
|
14
|
+
preferredProvider?: string;
|
|
15
|
+
}) => Promise<RoutingDecision>;
|
|
16
|
+
export interface CallContext {
|
|
17
|
+
projectId?: string;
|
|
18
|
+
taskId?: string;
|
|
19
|
+
}
|
|
20
|
+
export declare const callModel: (role: ModelRole, mode: Mode, messages: ModelMessage[], options?: ModelCallOptions, ctx?: CallContext) => Promise<{
|
|
21
|
+
response: ModelResponse;
|
|
22
|
+
decision: RoutingDecision;
|
|
23
|
+
cached: boolean;
|
|
24
|
+
costUsd: number;
|
|
25
|
+
}>;
|
|
26
|
+
//# sourceMappingURL=router.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"router.d.ts","sourceRoot":"","sources":["../../src/models/router.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,gBAAgB,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAW1F,MAAM,WAAW,eAAe;IAC9B,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;CAChD;AAgBD,eAAO,MAAM,YAAY,GAAU,QAAQ;IACzC,IAAI,EAAE,SAAS,CAAC;IAChB,IAAI,EAAE,IAAI,CAAC;IACX,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B,KAAG,OAAO,CAAC,eAAe,CA8D1B,CAAC;AAEF,MAAM,WAAW,WAAW;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,eAAO,MAAM,SAAS,GACpB,MAAM,SAAS,EACf,MAAM,IAAI,EACV,UAAU,YAAY,EAAE,EACxB,UAAS,gBAAqB,EAC9B,MAAK,WAAgB,KACpB,OAAO,CAAC;IACT,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,EAAE,eAAe,CAAC;IAC1B,MAAM,EAAE,OAAO,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;CACjB,CAmEA,CAAC"}
|
|
@@ -0,0 +1,185 @@
|
|
|
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.callModel = exports.resolveModel = void 0;
|
|
37
|
+
const loader_1 = require("../config/loader");
|
|
38
|
+
const errors_1 = require("../types/errors");
|
|
39
|
+
const provider_1 = require("./provider");
|
|
40
|
+
const logger_1 = require("../logging/logger");
|
|
41
|
+
const cache = __importStar(require("./cache"));
|
|
42
|
+
const rateLimit = __importStar(require("./rate-limit"));
|
|
43
|
+
const breaker = __importStar(require("./circuit-breaker"));
|
|
44
|
+
const cost = __importStar(require("./cost"));
|
|
45
|
+
const adapter_1 = require("./adapter");
|
|
46
|
+
const pickAnthropicForRole = (role) => {
|
|
47
|
+
if (role === 'architect' || role === 'reviewer' || role === 'debugger')
|
|
48
|
+
return 'claude-opus-4-7';
|
|
49
|
+
if (role === 'planner')
|
|
50
|
+
return 'claude-sonnet-4-6';
|
|
51
|
+
if (role === 'fast')
|
|
52
|
+
return 'claude-haiku-4-5-20251001';
|
|
53
|
+
return 'claude-sonnet-4-6';
|
|
54
|
+
};
|
|
55
|
+
const pickOllamaForRole = (role, cfg = (0, loader_1.loadGlobalConfig)()) => {
|
|
56
|
+
if (role === 'fast')
|
|
57
|
+
return cfg.models.fast;
|
|
58
|
+
if (role === 'executor')
|
|
59
|
+
return cfg.models.code;
|
|
60
|
+
if (role === 'planner' || role === 'architect')
|
|
61
|
+
return cfg.models.planner;
|
|
62
|
+
return cfg.models.balanced;
|
|
63
|
+
};
|
|
64
|
+
const resolveModel = async (params) => {
|
|
65
|
+
const cfg = (0, loader_1.loadGlobalConfig)();
|
|
66
|
+
const preferred = params.preferredProvider ?? cfg.provider;
|
|
67
|
+
// Offline-safe never uses anthropic.
|
|
68
|
+
if (params.mode === 'offline-safe' && preferred === 'anthropic') {
|
|
69
|
+
logger_1.log.info('routing: forcing ollama due to offline-safe mode');
|
|
70
|
+
}
|
|
71
|
+
const desired = params.mode === 'offline-safe' ? 'ollama' : preferred;
|
|
72
|
+
const pickFor = async (providerName) => {
|
|
73
|
+
if (providerName === 'anthropic') {
|
|
74
|
+
return cfg.anthropic.model || pickAnthropicForRole(params.role);
|
|
75
|
+
}
|
|
76
|
+
const configured = pickOllamaForRole(params.role, cfg);
|
|
77
|
+
if ((0, adapter_1.isLocalProvider)(providerName)) {
|
|
78
|
+
try {
|
|
79
|
+
return await (0, adapter_1.resolveLocalModel)((0, provider_1.getProvider)(providerName), params.role, configured);
|
|
80
|
+
}
|
|
81
|
+
catch (err) {
|
|
82
|
+
logger_1.log.debug('adapter failed; falling back to configured model', {
|
|
83
|
+
provider: providerName,
|
|
84
|
+
err: String(err),
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return configured;
|
|
89
|
+
};
|
|
90
|
+
try {
|
|
91
|
+
const provider = (0, provider_1.getProvider)(desired);
|
|
92
|
+
if (await provider.isAvailable()) {
|
|
93
|
+
const model = await pickFor(desired);
|
|
94
|
+
const fb = (0, provider_1.listProviders)().find((p) => p.name !== desired);
|
|
95
|
+
const fbModel = fb ? await pickFor(fb.name) : undefined;
|
|
96
|
+
return {
|
|
97
|
+
provider: desired,
|
|
98
|
+
model,
|
|
99
|
+
reason: `routed to ${desired} for role=${params.role} mode=${params.mode}`,
|
|
100
|
+
fallback: fb && fbModel ? { provider: fb.name, model: fbModel } : undefined,
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
catch {
|
|
105
|
+
// fall through
|
|
106
|
+
}
|
|
107
|
+
const fallback = await (0, provider_1.firstAvailableProvider)();
|
|
108
|
+
if (!fallback) {
|
|
109
|
+
const tried = (0, provider_1.listProviders)().map((p) => p.name);
|
|
110
|
+
throw new errors_1.ForgeRuntimeError({
|
|
111
|
+
class: 'model_error',
|
|
112
|
+
message: `No model provider is available (tried: ${tried.join(', ') || 'none'}).`,
|
|
113
|
+
retryable: false,
|
|
114
|
+
recoveryHint: 'Start a local runtime — `ollama serve`, `vllm serve <model>`, or LM Studio → ' +
|
|
115
|
+
'Start Server — or set ANTHROPIC_API_KEY / OPENAI_API_KEY. `forge doctor` shows details.',
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
return {
|
|
119
|
+
provider: fallback.name,
|
|
120
|
+
model: await pickFor(fallback.name),
|
|
121
|
+
reason: `fallback: ${desired} unavailable, using ${fallback.name}`,
|
|
122
|
+
};
|
|
123
|
+
};
|
|
124
|
+
exports.resolveModel = resolveModel;
|
|
125
|
+
const callModel = async (role, mode, messages, options = {}, ctx = {}) => {
|
|
126
|
+
const decision = await (0, exports.resolveModel)({ role, mode });
|
|
127
|
+
// Prompt cache lookup (deterministic / temperature=0 only).
|
|
128
|
+
const cached = cache.lookup(decision.provider, decision.model, messages, options);
|
|
129
|
+
if (cached) {
|
|
130
|
+
logger_1.log.debug('prompt cache hit', { provider: decision.provider, model: decision.model });
|
|
131
|
+
return { response: cached, decision, cached: true, costUsd: 0 };
|
|
132
|
+
}
|
|
133
|
+
if (!breaker.canTry(decision.provider) &&
|
|
134
|
+
decision.fallback &&
|
|
135
|
+
breaker.canTry(decision.fallback.provider)) {
|
|
136
|
+
logger_1.log.warn('primary breaker open; routing to fallback', { provider: decision.provider });
|
|
137
|
+
decision.provider = decision.fallback.provider;
|
|
138
|
+
decision.model = decision.fallback.model;
|
|
139
|
+
}
|
|
140
|
+
const provider = (0, provider_1.getProvider)(decision.provider);
|
|
141
|
+
await rateLimit.acquire(decision.provider);
|
|
142
|
+
logger_1.log.debug('calling model', {
|
|
143
|
+
role,
|
|
144
|
+
mode,
|
|
145
|
+
provider: decision.provider,
|
|
146
|
+
model: decision.model,
|
|
147
|
+
});
|
|
148
|
+
try {
|
|
149
|
+
const response = await provider.complete(decision.model, messages, options);
|
|
150
|
+
breaker.reportSuccess(decision.provider);
|
|
151
|
+
cache.store(decision.provider, decision.model, messages, options, response);
|
|
152
|
+
const usd = cost.record(ctx, response);
|
|
153
|
+
return { response, decision, cached: false, costUsd: usd };
|
|
154
|
+
}
|
|
155
|
+
catch (err) {
|
|
156
|
+
breaker.reportFailure(decision.provider);
|
|
157
|
+
if (decision.fallback && breaker.canTry(decision.fallback.provider)) {
|
|
158
|
+
logger_1.log.warn('primary model failed, trying fallback', {
|
|
159
|
+
err: String(err),
|
|
160
|
+
fallback: decision.fallback,
|
|
161
|
+
});
|
|
162
|
+
await rateLimit.acquire(decision.fallback.provider);
|
|
163
|
+
try {
|
|
164
|
+
const fb = (0, provider_1.getProvider)(decision.fallback.provider);
|
|
165
|
+
const response = await fb.complete(decision.fallback.model, messages, options);
|
|
166
|
+
breaker.reportSuccess(decision.fallback.provider);
|
|
167
|
+
cache.store(decision.fallback.provider, decision.fallback.model, messages, options, response);
|
|
168
|
+
const usd = cost.record(ctx, response);
|
|
169
|
+
return {
|
|
170
|
+
response,
|
|
171
|
+
decision: { ...decision, reason: `fallback after error: ${String(err)}` },
|
|
172
|
+
cached: false,
|
|
173
|
+
costUsd: usd,
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
catch (fallbackErr) {
|
|
177
|
+
breaker.reportFailure(decision.fallback.provider);
|
|
178
|
+
throw fallbackErr;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
throw err;
|
|
182
|
+
}
|
|
183
|
+
};
|
|
184
|
+
exports.callModel = callModel;
|
|
185
|
+
//# sourceMappingURL=router.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"router.js","sourceRoot":"","sources":["../../src/models/router.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { OpenAIProvider } from './openai';
|
|
2
|
+
/**
|
|
3
|
+
* vLLM via its OpenAI-compatible server. Default port is 8000.
|
|
4
|
+
*
|
|
5
|
+
* Start one with:
|
|
6
|
+
* vllm serve <model> --port 8000
|
|
7
|
+
*
|
|
8
|
+
* Point Forge elsewhere with `VLLM_ENDPOINT=http://host:port/v1`.
|
|
9
|
+
*/
|
|
10
|
+
export declare class VllmProvider extends OpenAIProvider {
|
|
11
|
+
constructor(endpoint?: string);
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=vllm.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vllm.d.ts","sourceRoot":"","sources":["../../src/models/vllm.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE1C;;;;;;;GAOG;AACH,qBAAa,YAAa,SAAQ,cAAc;gBAClC,QAAQ,GAAE,MAAgE;CAGvF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.VllmProvider = void 0;
|
|
4
|
+
const openai_1 = require("./openai");
|
|
5
|
+
/**
|
|
6
|
+
* vLLM via its OpenAI-compatible server. Default port is 8000.
|
|
7
|
+
*
|
|
8
|
+
* Start one with:
|
|
9
|
+
* vllm serve <model> --port 8000
|
|
10
|
+
*
|
|
11
|
+
* Point Forge elsewhere with `VLLM_ENDPOINT=http://host:port/v1`.
|
|
12
|
+
*/
|
|
13
|
+
class VllmProvider extends openai_1.OpenAIProvider {
|
|
14
|
+
constructor(endpoint = process.env.VLLM_ENDPOINT ?? 'http://127.0.0.1:8000/v1') {
|
|
15
|
+
super(process.env.VLLM_API_KEY, endpoint, 'vllm');
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.VllmProvider = VllmProvider;
|
|
19
|
+
//# sourceMappingURL=vllm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vllm.js","sourceRoot":"","sources":["../../src/models/vllm.ts"],"names":[],"mappings":";;;AAAA,qCAA0C;AAE1C;;;;;;;GAOG;AACH,MAAa,YAAa,SAAQ,uBAAc;IAC9C,YAAY,WAAmB,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,0BAA0B;QACpF,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IACpD,CAAC;CACF;AAJD,oCAIC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../src/notifications/manager.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAY,MAAM,UAAU,CAAC;AAIhD,KAAK,OAAO,GAAG,KAAK,GAAG,IAAI,GAAG,IAAI,CAAC;AAqCnC,eAAO,MAAM,MAAM,GAAI,OAAO,UAAU,EAAE,WAAU,OAAO,EAAY,KAAG,IAqBzE,CAAC"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.notify = void 0;
|
|
7
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
8
|
+
const child_process_1 = require("child_process");
|
|
9
|
+
const loader_1 = require("../config/loader");
|
|
10
|
+
const redact_1 = require("../security/redact");
|
|
11
|
+
const severityPrefix = (s) => {
|
|
12
|
+
switch (s) {
|
|
13
|
+
case 'info':
|
|
14
|
+
return chalk_1.default.blue('ℹ');
|
|
15
|
+
case 'warning':
|
|
16
|
+
return chalk_1.default.yellow('⚠');
|
|
17
|
+
case 'error':
|
|
18
|
+
return chalk_1.default.red('✖');
|
|
19
|
+
case 'critical':
|
|
20
|
+
return chalk_1.default.bgRed.white.bold(' ! ');
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
const sendOsNotification = (title, body) => {
|
|
24
|
+
try {
|
|
25
|
+
if (process.platform === 'darwin') {
|
|
26
|
+
(0, child_process_1.spawn)('osascript', [
|
|
27
|
+
'-e',
|
|
28
|
+
`display notification "${body.replace(/"/g, '\\"')}" with title "${title.replace(/"/g, '\\"')}"`,
|
|
29
|
+
], { detached: true, stdio: 'ignore' }).unref();
|
|
30
|
+
}
|
|
31
|
+
else if (process.platform === 'linux') {
|
|
32
|
+
(0, child_process_1.spawn)('notify-send', [title, body], {
|
|
33
|
+
detached: true,
|
|
34
|
+
stdio: 'ignore',
|
|
35
|
+
}).unref();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
// Non-fatal.
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
const notify = (event, channels = ['cli']) => {
|
|
43
|
+
const cfg = (0, loader_1.loadGlobalConfig)();
|
|
44
|
+
if (!cfg.notifications.enabled)
|
|
45
|
+
return;
|
|
46
|
+
const allow = new Set([...cfg.notifications.channels, ...channels]);
|
|
47
|
+
const sanitized = (0, redact_1.redact)(event.payload);
|
|
48
|
+
if (allow.has('cli') && cfg.notifications.verbosity !== 'minimal') {
|
|
49
|
+
const line = `${severityPrefix(event.severity)} ${chalk_1.default.dim(event.type)} ${event.message}`;
|
|
50
|
+
if (event.severity === 'error' || event.severity === 'critical') {
|
|
51
|
+
process.stderr.write(line + '\n');
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
process.stdout.write(line + '\n');
|
|
55
|
+
}
|
|
56
|
+
if (cfg.notifications.verbosity === 'verbose' && sanitized) {
|
|
57
|
+
process.stdout.write(chalk_1.default.dim(` ${JSON.stringify(sanitized)}\n`));
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
if (allow.has('os') && cfg.notifications.osNotifications) {
|
|
61
|
+
sendOsNotification(event.type, event.message);
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
exports.notify = notify;
|
|
65
|
+
//# sourceMappingURL=manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/notifications/manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { PermissionRequest, PermissionDecision } from '../types';
|
|
2
|
+
export interface PermissionFlags {
|
|
3
|
+
skipRoutine?: boolean;
|
|
4
|
+
allowFiles?: boolean;
|
|
5
|
+
allowShell?: boolean;
|
|
6
|
+
allowNetwork?: boolean;
|
|
7
|
+
allowWeb?: boolean;
|
|
8
|
+
allowMcp?: boolean;
|
|
9
|
+
strict?: boolean;
|
|
10
|
+
nonInteractive?: boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare const requestPermission: (req: PermissionRequest, flags?: PermissionFlags) => Promise<PermissionDecision>;
|
|
13
|
+
export declare const assertAllowed: (req: PermissionRequest, flags?: PermissionFlags) => Promise<void>;
|
|
14
|
+
export declare const clearSession: () => void;
|
|
15
|
+
//# sourceMappingURL=manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../src/permissions/manager.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AA6BjE,MAAM,WAAW,eAAe;IAC9B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B;AA2ED,eAAO,MAAM,iBAAiB,GAC5B,KAAK,iBAAiB,EACtB,QAAO,eAAoB,KAC1B,OAAO,CAAC,kBAAkB,CA0D5B,CAAC;AAEF,eAAO,MAAM,aAAa,GACxB,KAAK,iBAAiB,EACtB,QAAO,eAAoB,KAC1B,OAAO,CAAC,IAAI,CASd,CAAC;AAEF,eAAO,MAAM,YAAY,QAAO,IAI/B,CAAC"}
|