@su-record/vibe 2.7.2 → 2.7.5
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/.env.example +37 -37
- package/CLAUDE.md +222 -222
- package/LICENSE +21 -21
- package/README.md +580 -580
- package/agents/architect-low.md +41 -41
- package/agents/architect-medium.md +59 -59
- package/agents/architect.md +80 -80
- package/agents/build-error-resolver.md +115 -115
- package/agents/compounder.md +261 -261
- package/agents/diagrammer.md +178 -178
- package/agents/docs/api-documenter.md +99 -99
- package/agents/docs/changelog-writer.md +93 -93
- package/agents/e2e-tester.md +266 -266
- package/agents/explorer-low.md +42 -42
- package/agents/explorer-medium.md +59 -59
- package/agents/explorer.md +48 -48
- package/agents/implementer-low.md +43 -43
- package/agents/implementer-medium.md +52 -52
- package/agents/implementer.md +54 -54
- package/agents/junior-mentor.md +141 -141
- package/agents/planning/requirements-analyst.md +84 -84
- package/agents/planning/ux-advisor.md +83 -83
- package/agents/qa/acceptance-tester.md +86 -86
- package/agents/qa/edge-case-finder.md +93 -93
- package/agents/refactor-cleaner.md +143 -143
- package/agents/research/best-practices-agent.md +199 -199
- package/agents/research/codebase-patterns-agent.md +157 -157
- package/agents/research/framework-docs-agent.md +188 -188
- package/agents/research/security-advisory-agent.md +213 -213
- package/agents/review/architecture-reviewer.md +107 -107
- package/agents/review/complexity-reviewer.md +116 -116
- package/agents/review/data-integrity-reviewer.md +88 -88
- package/agents/review/git-history-reviewer.md +103 -103
- package/agents/review/performance-reviewer.md +86 -86
- package/agents/review/python-reviewer.md +150 -150
- package/agents/review/rails-reviewer.md +139 -139
- package/agents/review/react-reviewer.md +144 -144
- package/agents/review/security-reviewer.md +80 -80
- package/agents/review/simplicity-reviewer.md +140 -140
- package/agents/review/test-coverage-reviewer.md +116 -116
- package/agents/review/typescript-reviewer.md +127 -127
- package/agents/searcher.md +54 -54
- package/agents/simplifier.md +120 -120
- package/agents/tester.md +49 -49
- package/agents/ui/ui-a11y-auditor.md +93 -93
- package/agents/ui/ui-antipattern-detector.md +94 -94
- package/agents/ui/ui-dataviz-advisor.md +69 -69
- package/agents/ui/ui-design-system-gen.md +57 -57
- package/agents/ui/ui-industry-analyzer.md +49 -49
- package/agents/ui/ui-layout-architect.md +65 -65
- package/agents/ui/ui-stack-implementer.md +68 -68
- package/agents/ui/ux-compliance-reviewer.md +81 -81
- package/agents/ui-previewer.md +260 -260
- package/commands/vibe.run.md +1 -1
- package/commands/vibe.spec.md +8 -8
- package/commands/vibe.spec.review.md +558 -558
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.voice.md +79 -79
- package/dist/agent/AgentLoop.d.ts +97 -0
- package/dist/agent/AgentLoop.d.ts.map +1 -0
- package/dist/agent/AgentLoop.js +546 -0
- package/dist/agent/AgentLoop.js.map +1 -0
- package/dist/agent/ConversationState.d.ts +29 -0
- package/dist/agent/ConversationState.d.ts.map +1 -0
- package/dist/agent/ConversationState.js +107 -0
- package/dist/agent/ConversationState.js.map +1 -0
- package/dist/agent/ConversationStore.d.ts +31 -0
- package/dist/agent/ConversationStore.d.ts.map +1 -0
- package/dist/agent/ConversationStore.integration.test.d.ts +2 -0
- package/dist/agent/ConversationStore.integration.test.d.ts.map +1 -0
- package/dist/agent/ConversationStore.integration.test.js +162 -0
- package/dist/agent/ConversationStore.integration.test.js.map +1 -0
- package/dist/agent/ConversationStore.js +126 -0
- package/dist/agent/ConversationStore.js.map +1 -0
- package/dist/agent/ConversationStore.test.d.ts +2 -0
- package/dist/agent/ConversationStore.test.d.ts.map +1 -0
- package/dist/agent/ConversationStore.test.js +93 -0
- package/dist/agent/ConversationStore.test.js.map +1 -0
- package/dist/agent/HeadModelSelector.d.ts +36 -0
- package/dist/agent/HeadModelSelector.d.ts.map +1 -0
- package/dist/agent/HeadModelSelector.js +124 -0
- package/dist/agent/HeadModelSelector.js.map +1 -0
- package/dist/agent/RateLimiter.d.ts +44 -0
- package/dist/agent/RateLimiter.d.ts.map +1 -0
- package/dist/agent/RateLimiter.js +71 -0
- package/dist/agent/RateLimiter.js.map +1 -0
- package/dist/agent/SystemPrompt.d.ts +35 -0
- package/dist/agent/SystemPrompt.d.ts.map +1 -0
- package/dist/agent/SystemPrompt.js +151 -0
- package/dist/agent/SystemPrompt.js.map +1 -0
- package/dist/agent/ToolExecutor.d.ts +33 -0
- package/dist/agent/ToolExecutor.d.ts.map +1 -0
- package/dist/agent/ToolExecutor.js +123 -0
- package/dist/agent/ToolExecutor.js.map +1 -0
- package/dist/agent/ToolRegistry.d.ts +37 -0
- package/dist/agent/ToolRegistry.d.ts.map +1 -0
- package/dist/agent/ToolRegistry.js +125 -0
- package/dist/agent/ToolRegistry.js.map +1 -0
- package/dist/agent/__tests__/AgentLoop.test.d.ts +6 -0
- package/dist/agent/__tests__/AgentLoop.test.d.ts.map +1 -0
- package/dist/agent/__tests__/AgentLoop.test.js +208 -0
- package/dist/agent/__tests__/AgentLoop.test.js.map +1 -0
- package/dist/agent/__tests__/ConversationState.test.d.ts +6 -0
- package/dist/agent/__tests__/ConversationState.test.d.ts.map +1 -0
- package/dist/agent/__tests__/ConversationState.test.js +102 -0
- package/dist/agent/__tests__/ConversationState.test.js.map +1 -0
- package/dist/agent/__tests__/HeadModelSelector.test.d.ts +6 -0
- package/dist/agent/__tests__/HeadModelSelector.test.d.ts.map +1 -0
- package/dist/agent/__tests__/HeadModelSelector.test.js +132 -0
- package/dist/agent/__tests__/HeadModelSelector.test.js.map +1 -0
- package/dist/agent/__tests__/JobManager.test.d.ts +6 -0
- package/dist/agent/__tests__/JobManager.test.d.ts.map +1 -0
- package/dist/agent/__tests__/JobManager.test.js +197 -0
- package/dist/agent/__tests__/JobManager.test.js.map +1 -0
- package/dist/agent/__tests__/MediaPreprocessor.test.d.ts +6 -0
- package/dist/agent/__tests__/MediaPreprocessor.test.d.ts.map +1 -0
- package/dist/agent/__tests__/MediaPreprocessor.test.js +163 -0
- package/dist/agent/__tests__/MediaPreprocessor.test.js.map +1 -0
- package/dist/agent/__tests__/ToolExecutor.test.d.ts +6 -0
- package/dist/agent/__tests__/ToolExecutor.test.d.ts.map +1 -0
- package/dist/agent/__tests__/ToolExecutor.test.js +140 -0
- package/dist/agent/__tests__/ToolExecutor.test.js.map +1 -0
- package/dist/agent/__tests__/ToolRegistry.test.d.ts +6 -0
- package/dist/agent/__tests__/ToolRegistry.test.d.ts.map +1 -0
- package/dist/agent/__tests__/ToolRegistry.test.js +172 -0
- package/dist/agent/__tests__/ToolRegistry.test.js.map +1 -0
- package/dist/agent/__tests__/tools.test.d.ts +6 -0
- package/dist/agent/__tests__/tools.test.d.ts.map +1 -0
- package/dist/agent/__tests__/tools.test.js +177 -0
- package/dist/agent/__tests__/tools.test.js.map +1 -0
- package/dist/agent/index.d.ts +19 -0
- package/dist/agent/index.d.ts.map +1 -0
- package/dist/agent/index.js +18 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/jobs/JobManager.d.ts +46 -0
- package/dist/agent/jobs/JobManager.d.ts.map +1 -0
- package/dist/agent/jobs/JobManager.js +213 -0
- package/dist/agent/jobs/JobManager.js.map +1 -0
- package/dist/agent/jobs/ProgressReporter.d.ts +32 -0
- package/dist/agent/jobs/ProgressReporter.d.ts.map +1 -0
- package/dist/agent/jobs/ProgressReporter.js +82 -0
- package/dist/agent/jobs/ProgressReporter.js.map +1 -0
- package/dist/agent/jobs/types.d.ts +32 -0
- package/dist/agent/jobs/types.d.ts.map +1 -0
- package/dist/agent/jobs/types.js +6 -0
- package/dist/agent/jobs/types.js.map +1 -0
- package/dist/agent/policy-integration.test.d.ts +6 -0
- package/dist/agent/policy-integration.test.d.ts.map +1 -0
- package/dist/agent/policy-integration.test.js +148 -0
- package/dist/agent/policy-integration.test.js.map +1 -0
- package/dist/agent/preprocessors/MediaPreprocessor.d.ts +63 -0
- package/dist/agent/preprocessors/MediaPreprocessor.d.ts.map +1 -0
- package/dist/agent/preprocessors/MediaPreprocessor.js +320 -0
- package/dist/agent/preprocessors/MediaPreprocessor.js.map +1 -0
- package/dist/agent/providers/claude-head.d.ts +17 -0
- package/dist/agent/providers/claude-head.d.ts.map +1 -0
- package/dist/agent/providers/claude-head.js +124 -0
- package/dist/agent/providers/claude-head.js.map +1 -0
- package/dist/agent/providers/gpt-head.d.ts +30 -0
- package/dist/agent/providers/gpt-head.d.ts.map +1 -0
- package/dist/agent/providers/gpt-head.js +359 -0
- package/dist/agent/providers/gpt-head.js.map +1 -0
- package/dist/agent/tools/claude-code.d.ts +11 -0
- package/dist/agent/tools/claude-code.d.ts.map +1 -0
- package/dist/agent/tools/claude-code.js +148 -0
- package/dist/agent/tools/claude-code.js.map +1 -0
- package/dist/agent/tools/dm-pair.d.ts +23 -0
- package/dist/agent/tools/dm-pair.d.ts.map +1 -0
- package/dist/agent/tools/dm-pair.js +70 -0
- package/dist/agent/tools/dm-pair.js.map +1 -0
- package/dist/agent/tools/dm-pair.test.d.ts +6 -0
- package/dist/agent/tools/dm-pair.test.d.ts.map +1 -0
- package/dist/agent/tools/dm-pair.test.js +106 -0
- package/dist/agent/tools/dm-pair.test.js.map +1 -0
- package/dist/agent/tools/gemini-stt.d.ts +9 -0
- package/dist/agent/tools/gemini-stt.d.ts.map +1 -0
- package/dist/agent/tools/gemini-stt.js +33 -0
- package/dist/agent/tools/gemini-stt.js.map +1 -0
- package/dist/agent/tools/google-search.d.ts +9 -0
- package/dist/agent/tools/google-search.d.ts.map +1 -0
- package/dist/agent/tools/google-search.js +38 -0
- package/dist/agent/tools/google-search.js.map +1 -0
- package/dist/agent/tools/index.d.ts +22 -0
- package/dist/agent/tools/index.d.ts.map +1 -0
- package/dist/agent/tools/index.js +37 -0
- package/dist/agent/tools/index.js.map +1 -0
- package/dist/agent/tools/kimi-analyze.d.ts +9 -0
- package/dist/agent/tools/kimi-analyze.d.ts.map +1 -0
- package/dist/agent/tools/kimi-analyze.js +49 -0
- package/dist/agent/tools/kimi-analyze.js.map +1 -0
- package/dist/agent/tools/manage-memory.d.ts +10 -0
- package/dist/agent/tools/manage-memory.d.ts.map +1 -0
- package/dist/agent/tools/manage-memory.js +70 -0
- package/dist/agent/tools/manage-memory.js.map +1 -0
- package/dist/agent/tools/send-imessage.d.ts +19 -0
- package/dist/agent/tools/send-imessage.d.ts.map +1 -0
- package/dist/agent/tools/send-imessage.js +67 -0
- package/dist/agent/tools/send-imessage.js.map +1 -0
- package/dist/agent/tools/send-slack.d.ts +21 -0
- package/dist/agent/tools/send-slack.d.ts.map +1 -0
- package/dist/agent/tools/send-slack.js +63 -0
- package/dist/agent/tools/send-slack.js.map +1 -0
- package/dist/agent/tools/send-telegram.d.ts +20 -0
- package/dist/agent/tools/send-telegram.d.ts.map +1 -0
- package/dist/agent/tools/send-telegram.js +58 -0
- package/dist/agent/tools/send-telegram.js.map +1 -0
- package/dist/agent/tools/vision-analyze.d.ts +11 -0
- package/dist/agent/tools/vision-analyze.d.ts.map +1 -0
- package/dist/agent/tools/vision-analyze.js +103 -0
- package/dist/agent/tools/vision-analyze.js.map +1 -0
- package/dist/agent/tools/vision-capture.d.ts +13 -0
- package/dist/agent/tools/vision-capture.d.ts.map +1 -0
- package/dist/agent/tools/vision-capture.js +87 -0
- package/dist/agent/tools/vision-capture.js.map +1 -0
- package/dist/agent/tools/web-browse.d.ts +20 -0
- package/dist/agent/tools/web-browse.d.ts.map +1 -0
- package/dist/agent/tools/web-browse.js +196 -0
- package/dist/agent/tools/web-browse.js.map +1 -0
- package/dist/agent/types.d.ts +151 -0
- package/dist/agent/types.d.ts.map +1 -0
- package/dist/agent/types.js +6 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/bridge/telegram-assistant-bridge.d.ts +10 -0
- package/dist/bridge/telegram-assistant-bridge.d.ts.map +1 -0
- package/dist/bridge/telegram-assistant-bridge.js +274 -0
- package/dist/bridge/telegram-assistant-bridge.js.map +1 -0
- package/dist/bridge/telegram-bridge.d.ts +10 -0
- package/dist/bridge/telegram-bridge.d.ts.map +1 -0
- package/dist/bridge/telegram-bridge.js +154 -0
- package/dist/bridge/telegram-bridge.js.map +1 -0
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/commands/autostart.d.ts +19 -0
- package/dist/cli/commands/autostart.d.ts.map +1 -0
- package/dist/cli/commands/autostart.js +213 -0
- package/dist/cli/commands/autostart.js.map +1 -0
- package/dist/cli/commands/browser.d.ts +12 -0
- package/dist/cli/commands/browser.d.ts.map +1 -0
- package/dist/cli/commands/browser.js +50 -0
- package/dist/cli/commands/browser.js.map +1 -0
- package/dist/cli/commands/daemon.d.ts +16 -0
- package/dist/cli/commands/daemon.d.ts.map +1 -0
- package/dist/cli/commands/daemon.js +277 -0
- package/dist/cli/commands/daemon.js.map +1 -0
- package/dist/cli/commands/device.d.ts +9 -0
- package/dist/cli/commands/device.d.ts.map +1 -0
- package/dist/cli/commands/device.js +56 -0
- package/dist/cli/commands/device.js.map +1 -0
- package/dist/cli/commands/evolution.js +12 -12
- package/dist/cli/commands/google.d.ts +12 -0
- package/dist/cli/commands/google.d.ts.map +1 -0
- package/dist/cli/commands/google.js +83 -0
- package/dist/cli/commands/google.js.map +1 -0
- package/dist/cli/commands/imessage.d.ts +11 -0
- package/dist/cli/commands/imessage.d.ts.map +1 -0
- package/dist/cli/commands/imessage.js +85 -0
- package/dist/cli/commands/imessage.js.map +1 -0
- package/dist/cli/commands/info.js +54 -54
- package/dist/cli/commands/init.js +6 -6
- package/dist/cli/commands/interface.d.ts +15 -0
- package/dist/cli/commands/interface.d.ts.map +1 -0
- package/dist/cli/commands/interface.js +167 -0
- package/dist/cli/commands/interface.js.map +1 -0
- package/dist/cli/commands/job.d.ts +14 -0
- package/dist/cli/commands/job.d.ts.map +1 -0
- package/dist/cli/commands/job.js +170 -0
- package/dist/cli/commands/job.js.map +1 -0
- package/dist/cli/commands/pc.d.ts +12 -0
- package/dist/cli/commands/pc.d.ts.map +1 -0
- package/dist/cli/commands/pc.js +75 -0
- package/dist/cli/commands/pc.js.map +1 -0
- package/dist/cli/commands/policy.d.ts +10 -0
- package/dist/cli/commands/policy.d.ts.map +1 -0
- package/dist/cli/commands/policy.js +75 -0
- package/dist/cli/commands/policy.js.map +1 -0
- package/dist/cli/commands/remove.js +14 -14
- package/dist/cli/commands/sandbox.d.ts +10 -0
- package/dist/cli/commands/sandbox.d.ts.map +1 -0
- package/dist/cli/commands/sandbox.js +53 -0
- package/dist/cli/commands/sandbox.js.map +1 -0
- package/dist/cli/commands/sentinel.js +27 -27
- package/dist/cli/commands/setup.d.ts.map +1 -1
- package/dist/cli/commands/setup.js +1 -25
- package/dist/cli/commands/setup.js.map +1 -1
- package/dist/cli/commands/slack.js +10 -10
- package/dist/cli/commands/sync.d.ts +9 -0
- package/dist/cli/commands/sync.d.ts.map +1 -0
- package/dist/cli/commands/sync.js +167 -0
- package/dist/cli/commands/sync.js.map +1 -0
- package/dist/cli/commands/telegram.js +12 -12
- package/dist/cli/commands/vision.d.ts +12 -0
- package/dist/cli/commands/vision.d.ts.map +1 -0
- package/dist/cli/commands/vision.js +74 -0
- package/dist/cli/commands/vision.js.map +1 -0
- package/dist/cli/commands/voice.d.ts +12 -0
- package/dist/cli/commands/voice.d.ts.map +1 -0
- package/dist/cli/commands/voice.js +67 -0
- package/dist/cli/commands/voice.js.map +1 -0
- package/dist/cli/commands/webhook.d.ts +9 -0
- package/dist/cli/commands/webhook.d.ts.map +1 -0
- package/dist/cli/commands/webhook.js +85 -0
- package/dist/cli/commands/webhook.js.map +1 -0
- package/dist/cli/detect.js +32 -32
- package/dist/cli/hud.d.ts +46 -0
- package/dist/cli/hud.d.ts.map +1 -0
- package/dist/cli/hud.js +392 -0
- package/dist/cli/hud.js.map +1 -0
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +48 -53
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/llm/az-commands.d.ts +12 -0
- package/dist/cli/llm/az-commands.d.ts.map +1 -0
- package/dist/cli/llm/az-commands.js +99 -0
- package/dist/cli/llm/az-commands.js.map +1 -0
- package/dist/cli/llm/claude-commands.js +16 -16
- package/dist/cli/llm/config.js +18 -18
- package/dist/cli/llm/gemini-commands.js +47 -47
- package/dist/cli/llm/gpt-commands.d.ts +6 -13
- package/dist/cli/llm/gpt-commands.d.ts.map +1 -1
- package/dist/cli/llm/gpt-commands.js +47 -117
- package/dist/cli/llm/gpt-commands.js.map +1 -1
- package/dist/cli/llm/help.js +21 -21
- package/dist/cli/llm/kimi-commands.d.ts +12 -0
- package/dist/cli/llm/kimi-commands.d.ts.map +1 -0
- package/dist/cli/llm/kimi-commands.js +100 -0
- package/dist/cli/llm/kimi-commands.js.map +1 -0
- package/dist/cli/llm/nvidia-commands.d.ts +16 -0
- package/dist/cli/llm/nvidia-commands.d.ts.map +1 -0
- package/dist/cli/llm/nvidia-commands.js +105 -0
- package/dist/cli/llm/nvidia-commands.js.map +1 -0
- package/dist/cli/llm/priority-commands.d.ts +18 -0
- package/dist/cli/llm/priority-commands.d.ts.map +1 -0
- package/dist/cli/llm/priority-commands.js +69 -0
- package/dist/cli/llm/priority-commands.js.map +1 -0
- package/dist/cli/postinstall/cursor-agents.js +32 -32
- package/dist/cli/postinstall/cursor-rules.js +83 -83
- package/dist/cli/postinstall/cursor-skills.js +743 -743
- package/dist/cli/postinstall/npmrc.d.ts +9 -0
- package/dist/cli/postinstall/npmrc.d.ts.map +1 -0
- package/dist/cli/postinstall/npmrc.js +80 -0
- package/dist/cli/postinstall/npmrc.js.map +1 -0
- package/dist/cli/types.d.ts +1 -0
- package/dist/cli/types.d.ts.map +1 -1
- package/dist/daemon/DaemonIPC.d.ts +40 -0
- package/dist/daemon/DaemonIPC.d.ts.map +1 -0
- package/dist/daemon/DaemonIPC.js +327 -0
- package/dist/daemon/DaemonIPC.js.map +1 -0
- package/dist/daemon/InterfaceManager.d.ts +62 -0
- package/dist/daemon/InterfaceManager.d.ts.map +1 -0
- package/dist/daemon/InterfaceManager.js +785 -0
- package/dist/daemon/InterfaceManager.js.map +1 -0
- package/dist/daemon/SessionPool.d.ts +80 -0
- package/dist/daemon/SessionPool.d.ts.map +1 -0
- package/dist/daemon/SessionPool.js +414 -0
- package/dist/daemon/SessionPool.js.map +1 -0
- package/dist/daemon/VibeDaemon.d.ts +69 -0
- package/dist/daemon/VibeDaemon.d.ts.map +1 -0
- package/dist/daemon/VibeDaemon.js +400 -0
- package/dist/daemon/VibeDaemon.js.map +1 -0
- package/dist/daemon/daemon.test.d.ts +6 -0
- package/dist/daemon/daemon.test.d.ts.map +1 -0
- package/dist/daemon/daemon.test.js +348 -0
- package/dist/daemon/daemon.test.js.map +1 -0
- package/dist/daemon/index.d.ts +10 -0
- package/dist/daemon/index.d.ts.map +1 -0
- package/dist/daemon/index.js +9 -0
- package/dist/daemon/index.js.map +1 -0
- package/dist/daemon/pipeline.test.d.ts +6 -0
- package/dist/daemon/pipeline.test.d.ts.map +1 -0
- package/dist/daemon/pipeline.test.js +258 -0
- package/dist/daemon/pipeline.test.js.map +1 -0
- package/dist/daemon/preflight.d.ts +23 -0
- package/dist/daemon/preflight.d.ts.map +1 -0
- package/dist/daemon/preflight.js +204 -0
- package/dist/daemon/preflight.js.map +1 -0
- package/dist/daemon/preflight.test.d.ts +6 -0
- package/dist/daemon/preflight.test.d.ts.map +1 -0
- package/dist/daemon/preflight.test.js +88 -0
- package/dist/daemon/preflight.test.js.map +1 -0
- package/dist/daemon/types.d.ts +117 -0
- package/dist/daemon/types.d.ts.map +1 -0
- package/dist/daemon/types.js +15 -0
- package/dist/daemon/types.js.map +1 -0
- package/dist/infra/lib/DeepInit.js +24 -24
- package/dist/infra/lib/IterationTracker.js +11 -11
- package/dist/infra/lib/PythonParser.js +108 -108
- package/dist/infra/lib/ReviewRace.js +96 -96
- package/dist/infra/lib/SkillFrontmatter.js +28 -28
- package/dist/infra/lib/SkillQualityGate.js +9 -9
- package/dist/infra/lib/SkillRepository.js +159 -159
- package/dist/infra/lib/UltraQA.js +99 -99
- package/dist/infra/lib/autonomy/AuditStore.js +41 -41
- package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
- package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
- package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
- package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
- package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
- package/dist/infra/lib/az/auth.d.ts +15 -0
- package/dist/infra/lib/az/auth.d.ts.map +1 -0
- package/dist/infra/lib/az/auth.js +67 -0
- package/dist/infra/lib/az/auth.js.map +1 -0
- package/dist/infra/lib/az/chat.d.ts +26 -0
- package/dist/infra/lib/az/chat.d.ts.map +1 -0
- package/dist/infra/lib/az/chat.js +116 -0
- package/dist/infra/lib/az/chat.js.map +1 -0
- package/dist/infra/lib/az/embedding.d.ts +13 -0
- package/dist/infra/lib/az/embedding.d.ts.map +1 -0
- package/dist/infra/lib/az/embedding.js +60 -0
- package/dist/infra/lib/az/embedding.js.map +1 -0
- package/dist/infra/lib/az/index.d.ts +9 -0
- package/dist/infra/lib/az/index.d.ts.map +1 -0
- package/dist/infra/lib/az/index.js +9 -0
- package/dist/infra/lib/az/index.js.map +1 -0
- package/dist/infra/lib/az/orchestration.d.ts +11 -0
- package/dist/infra/lib/az/orchestration.d.ts.map +1 -0
- package/dist/infra/lib/az/orchestration.js +24 -0
- package/dist/infra/lib/az/orchestration.js.map +1 -0
- package/dist/infra/lib/az/types.d.ts +35 -0
- package/dist/infra/lib/az/types.d.ts.map +1 -0
- package/dist/infra/lib/az/types.js +5 -0
- package/dist/infra/lib/az/types.js.map +1 -0
- package/dist/infra/lib/az-api.d.ts +5 -0
- package/dist/infra/lib/az-api.d.ts.map +1 -0
- package/dist/infra/lib/az-api.js +5 -0
- package/dist/infra/lib/az-api.js.map +1 -0
- package/dist/infra/lib/az-constants.d.ts +44 -0
- package/dist/infra/lib/az-constants.d.ts.map +1 -0
- package/dist/infra/lib/az-constants.js +58 -0
- package/dist/infra/lib/az-constants.js.map +1 -0
- package/dist/infra/lib/az-storage.d.ts +12 -0
- package/dist/infra/lib/az-storage.d.ts.map +1 -0
- package/dist/infra/lib/az-storage.js +59 -0
- package/dist/infra/lib/az-storage.js.map +1 -0
- package/dist/infra/lib/claude-storage.d.ts +12 -0
- package/dist/infra/lib/claude-storage.d.ts.map +1 -0
- package/dist/infra/lib/claude-storage.js +59 -0
- package/dist/infra/lib/claude-storage.js.map +1 -0
- package/dist/infra/lib/embedding/VectorStore.js +22 -22
- package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
- package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
- package/dist/infra/lib/evolution/InsightStore.js +90 -90
- package/dist/infra/lib/evolution/RollbackManager.js +5 -5
- package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
- package/dist/infra/lib/evolution/UsageTracker.js +28 -28
- package/dist/infra/lib/gemini/constants.js +14 -14
- package/dist/infra/lib/gemini/orchestration.js +5 -5
- package/dist/infra/lib/gemini-api.d.ts +13 -0
- package/dist/infra/lib/gemini-api.d.ts.map +1 -0
- package/dist/infra/lib/gemini-api.js +13 -0
- package/dist/infra/lib/gemini-api.js.map +1 -0
- package/dist/infra/lib/gemini-constants.d.ts +19 -0
- package/dist/infra/lib/gemini-constants.d.ts.map +1 -0
- package/dist/infra/lib/gemini-constants.js +34 -0
- package/dist/infra/lib/gemini-constants.js.map +1 -0
- package/dist/infra/lib/gemini-oauth.d.ts +60 -0
- package/dist/infra/lib/gemini-oauth.d.ts.map +1 -0
- package/dist/infra/lib/gemini-oauth.js +386 -0
- package/dist/infra/lib/gemini-oauth.js.map +1 -0
- package/dist/infra/lib/gemini-storage.d.ts +64 -0
- package/dist/infra/lib/gemini-storage.d.ts.map +1 -0
- package/dist/infra/lib/gemini-storage.js +177 -0
- package/dist/infra/lib/gemini-storage.js.map +1 -0
- package/dist/infra/lib/gpt/auth.d.ts +18 -2
- package/dist/infra/lib/gpt/auth.d.ts.map +1 -1
- package/dist/infra/lib/gpt/auth.js +91 -7
- package/dist/infra/lib/gpt/auth.js.map +1 -1
- package/dist/infra/lib/gpt/chat.d.ts.map +1 -1
- package/dist/infra/lib/gpt/chat.js +1 -0
- package/dist/infra/lib/gpt/chat.js.map +1 -1
- package/dist/infra/lib/gpt/oauth.js +44 -44
- package/dist/infra/lib/gpt/orchestration.js +4 -4
- package/dist/infra/lib/gpt/types.d.ts +1 -1
- package/dist/infra/lib/gpt/types.d.ts.map +1 -1
- package/dist/infra/lib/gpt-api.d.ts +13 -0
- package/dist/infra/lib/gpt-api.d.ts.map +1 -0
- package/dist/infra/lib/gpt-api.js +13 -0
- package/dist/infra/lib/gpt-api.js.map +1 -0
- package/dist/infra/lib/gpt-constants.d.ts +12 -0
- package/dist/infra/lib/gpt-constants.d.ts.map +1 -0
- package/dist/infra/lib/gpt-constants.js +18 -0
- package/dist/infra/lib/gpt-constants.js.map +1 -0
- package/dist/infra/lib/gpt-oauth.d.ts +66 -0
- package/dist/infra/lib/gpt-oauth.d.ts.map +1 -0
- package/dist/infra/lib/gpt-oauth.js +389 -0
- package/dist/infra/lib/gpt-oauth.js.map +1 -0
- package/dist/infra/lib/gpt-storage.d.ts +64 -0
- package/dist/infra/lib/gpt-storage.d.ts.map +1 -0
- package/dist/infra/lib/gpt-storage.js +180 -0
- package/dist/infra/lib/gpt-storage.js.map +1 -0
- package/dist/infra/lib/kimi/auth.d.ts +10 -0
- package/dist/infra/lib/kimi/auth.d.ts.map +1 -0
- package/dist/infra/lib/kimi/auth.js +45 -0
- package/dist/infra/lib/kimi/auth.js.map +1 -0
- package/dist/infra/lib/kimi/chat.d.ts +26 -0
- package/dist/infra/lib/kimi/chat.d.ts.map +1 -0
- package/dist/infra/lib/kimi/chat.js +115 -0
- package/dist/infra/lib/kimi/chat.js.map +1 -0
- package/dist/infra/lib/kimi/index.d.ts +8 -0
- package/dist/infra/lib/kimi/index.d.ts.map +1 -0
- package/dist/infra/lib/kimi/index.js +8 -0
- package/dist/infra/lib/kimi/index.js.map +1 -0
- package/dist/infra/lib/kimi/orchestration.d.ts +10 -0
- package/dist/infra/lib/kimi/orchestration.d.ts.map +1 -0
- package/dist/infra/lib/kimi/orchestration.js +22 -0
- package/dist/infra/lib/kimi/orchestration.js.map +1 -0
- package/dist/infra/lib/kimi/types.d.ts +30 -0
- package/dist/infra/lib/kimi/types.d.ts.map +1 -0
- package/dist/infra/lib/kimi/types.js +5 -0
- package/dist/infra/lib/kimi/types.js.map +1 -0
- package/dist/infra/lib/kimi-api.d.ts +5 -0
- package/dist/infra/lib/kimi-api.d.ts.map +1 -0
- package/dist/infra/lib/kimi-api.js +5 -0
- package/dist/infra/lib/kimi-api.js.map +1 -0
- package/dist/infra/lib/kimi-constants.d.ts +27 -0
- package/dist/infra/lib/kimi-constants.d.ts.map +1 -0
- package/dist/infra/lib/kimi-constants.js +31 -0
- package/dist/infra/lib/kimi-constants.js.map +1 -0
- package/dist/infra/lib/kimi-storage.d.ts +12 -0
- package/dist/infra/lib/kimi-storage.d.ts.map +1 -0
- package/dist/infra/lib/kimi-storage.js +59 -0
- package/dist/infra/lib/kimi-storage.js.map +1 -0
- package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
- package/dist/infra/lib/memory/MemorySearch.js +57 -57
- package/dist/infra/lib/memory/MemoryStorage.js +181 -181
- package/dist/infra/lib/memory/ObservationStore.js +28 -28
- package/dist/infra/lib/memory/ReflectionStore.js +30 -30
- package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
- package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
- package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
- package/dist/infra/lib/priority-config.d.ts +39 -0
- package/dist/infra/lib/priority-config.d.ts.map +1 -0
- package/dist/infra/lib/priority-config.js +137 -0
- package/dist/infra/lib/priority-config.js.map +1 -0
- package/dist/infra/lib/sync/constants.d.ts +21 -0
- package/dist/infra/lib/sync/constants.d.ts.map +1 -0
- package/dist/infra/lib/sync/constants.js +78 -0
- package/dist/infra/lib/sync/constants.js.map +1 -0
- package/dist/infra/lib/sync/crypto.d.ts +23 -0
- package/dist/infra/lib/sync/crypto.d.ts.map +1 -0
- package/dist/infra/lib/sync/crypto.js +55 -0
- package/dist/infra/lib/sync/crypto.js.map +1 -0
- package/dist/infra/lib/sync/drive.d.ts +22 -0
- package/dist/infra/lib/sync/drive.d.ts.map +1 -0
- package/dist/infra/lib/sync/drive.js +99 -0
- package/dist/infra/lib/sync/drive.js.map +1 -0
- package/dist/infra/lib/sync/index.d.ts +9 -0
- package/dist/infra/lib/sync/index.d.ts.map +1 -0
- package/dist/infra/lib/sync/index.js +9 -0
- package/dist/infra/lib/sync/index.js.map +1 -0
- package/dist/infra/lib/sync/oauth.d.ts +12 -0
- package/dist/infra/lib/sync/oauth.d.ts.map +1 -0
- package/dist/infra/lib/sync/oauth.js +157 -0
- package/dist/infra/lib/sync/oauth.js.map +1 -0
- package/dist/infra/lib/sync/storage.d.ts +21 -0
- package/dist/infra/lib/sync/storage.d.ts.map +1 -0
- package/dist/infra/lib/sync/storage.js +32 -0
- package/dist/infra/lib/sync/storage.js.map +1 -0
- package/dist/infra/orchestrator/AgentManager.js +12 -12
- package/dist/infra/orchestrator/AgentRegistry.js +65 -65
- package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
- package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
- package/dist/infra/orchestrator/parallelResearch.js +24 -24
- package/dist/infra/policy/Evidence.d.ts +30 -0
- package/dist/infra/policy/Evidence.d.ts.map +1 -0
- package/dist/infra/policy/Evidence.js +134 -0
- package/dist/infra/policy/Evidence.js.map +1 -0
- package/dist/infra/policy/PolicyEngine.d.ts +34 -0
- package/dist/infra/policy/PolicyEngine.d.ts.map +1 -0
- package/dist/infra/policy/PolicyEngine.js +219 -0
- package/dist/infra/policy/PolicyEngine.js.map +1 -0
- package/dist/infra/policy/PolicyStore.d.ts +36 -0
- package/dist/infra/policy/PolicyStore.d.ts.map +1 -0
- package/dist/infra/policy/PolicyStore.js +160 -0
- package/dist/infra/policy/PolicyStore.js.map +1 -0
- package/dist/infra/policy/RiskCalculator.d.ts +20 -0
- package/dist/infra/policy/RiskCalculator.d.ts.map +1 -0
- package/dist/infra/policy/RiskCalculator.js +64 -0
- package/dist/infra/policy/RiskCalculator.js.map +1 -0
- package/dist/infra/policy/default-policies.d.ts +13 -0
- package/dist/infra/policy/default-policies.d.ts.map +1 -0
- package/dist/infra/policy/default-policies.js +99 -0
- package/dist/infra/policy/default-policies.js.map +1 -0
- package/dist/infra/policy/index.d.ts +11 -0
- package/dist/infra/policy/index.d.ts.map +1 -0
- package/dist/infra/policy/index.js +10 -0
- package/dist/infra/policy/index.js.map +1 -0
- package/dist/infra/policy/policy.test.d.ts +5 -0
- package/dist/infra/policy/policy.test.d.ts.map +1 -0
- package/dist/infra/policy/policy.test.js +628 -0
- package/dist/infra/policy/policy.test.js.map +1 -0
- package/dist/infra/policy/types.d.ts +71 -0
- package/dist/infra/policy/types.d.ts.map +1 -0
- package/dist/infra/policy/types.js +18 -0
- package/dist/infra/policy/types.js.map +1 -0
- package/dist/interface/BaseInterface.d.ts +37 -0
- package/dist/interface/BaseInterface.d.ts.map +1 -0
- package/dist/interface/BaseInterface.js +105 -0
- package/dist/interface/BaseInterface.js.map +1 -0
- package/dist/interface/ClaudeCodeBridge.d.ts +38 -0
- package/dist/interface/ClaudeCodeBridge.d.ts.map +1 -0
- package/dist/interface/ClaudeCodeBridge.js +216 -0
- package/dist/interface/ClaudeCodeBridge.js.map +1 -0
- package/dist/interface/imessage/IMessageBot.d.ts +33 -0
- package/dist/interface/imessage/IMessageBot.d.ts.map +1 -0
- package/dist/interface/imessage/IMessageBot.js +222 -0
- package/dist/interface/imessage/IMessageBot.js.map +1 -0
- package/dist/interface/imessage/IMessageFormatter.d.ts +15 -0
- package/dist/interface/imessage/IMessageFormatter.d.ts.map +1 -0
- package/dist/interface/imessage/IMessageFormatter.js +81 -0
- package/dist/interface/imessage/IMessageFormatter.js.map +1 -0
- package/dist/interface/imessage/IMessageRpcClient.d.ts +39 -0
- package/dist/interface/imessage/IMessageRpcClient.d.ts.map +1 -0
- package/dist/interface/imessage/IMessageRpcClient.js +174 -0
- package/dist/interface/imessage/IMessageRpcClient.js.map +1 -0
- package/dist/interface/imessage/IMessageSender.d.ts +19 -0
- package/dist/interface/imessage/IMessageSender.d.ts.map +1 -0
- package/dist/interface/imessage/IMessageSender.js +136 -0
- package/dist/interface/imessage/IMessageSender.js.map +1 -0
- package/dist/interface/imessage/__tests__/IMessageBot.test.d.ts +5 -0
- package/dist/interface/imessage/__tests__/IMessageBot.test.d.ts.map +1 -0
- package/dist/interface/imessage/__tests__/IMessageBot.test.js +60 -0
- package/dist/interface/imessage/__tests__/IMessageBot.test.js.map +1 -0
- package/dist/interface/imessage/__tests__/IMessageFormatter.test.d.ts +5 -0
- package/dist/interface/imessage/__tests__/IMessageFormatter.test.d.ts.map +1 -0
- package/dist/interface/imessage/__tests__/IMessageFormatter.test.js +110 -0
- package/dist/interface/imessage/__tests__/IMessageFormatter.test.js.map +1 -0
- package/dist/interface/imessage/__tests__/IMessageSender.test.d.ts +5 -0
- package/dist/interface/imessage/__tests__/IMessageSender.test.d.ts.map +1 -0
- package/dist/interface/imessage/__tests__/IMessageSender.test.js +67 -0
- package/dist/interface/imessage/__tests__/IMessageSender.test.js.map +1 -0
- package/dist/interface/imessage/index.d.ts +8 -0
- package/dist/interface/imessage/index.d.ts.map +1 -0
- package/dist/interface/imessage/index.js +8 -0
- package/dist/interface/imessage/index.js.map +1 -0
- package/dist/interface/index.d.ts +26 -0
- package/dist/interface/index.d.ts.map +1 -0
- package/dist/interface/index.js +26 -0
- package/dist/interface/index.js.map +1 -0
- package/dist/interface/interface.test.d.ts +5 -0
- package/dist/interface/interface.test.d.ts.map +1 -0
- package/dist/interface/interface.test.js +442 -0
- package/dist/interface/interface.test.js.map +1 -0
- package/dist/interface/slack/SlackBot.d.ts +83 -0
- package/dist/interface/slack/SlackBot.d.ts.map +1 -0
- package/dist/interface/slack/SlackBot.js +563 -0
- package/dist/interface/slack/SlackBot.js.map +1 -0
- package/dist/interface/slack/SlackFormatter.d.ts +19 -0
- package/dist/interface/slack/SlackFormatter.d.ts.map +1 -0
- package/dist/interface/slack/SlackFormatter.js +76 -0
- package/dist/interface/slack/SlackFormatter.js.map +1 -0
- package/dist/interface/slack/__tests__/SlackBot.test.d.ts +5 -0
- package/dist/interface/slack/__tests__/SlackBot.test.d.ts.map +1 -0
- package/dist/interface/slack/__tests__/SlackBot.test.js +37 -0
- package/dist/interface/slack/__tests__/SlackBot.test.js.map +1 -0
- package/dist/interface/slack/__tests__/SlackFormatter.test.d.ts +5 -0
- package/dist/interface/slack/__tests__/SlackFormatter.test.d.ts.map +1 -0
- package/dist/interface/slack/__tests__/SlackFormatter.test.js +93 -0
- package/dist/interface/slack/__tests__/SlackFormatter.test.js.map +1 -0
- package/dist/interface/slack/index.d.ts +7 -0
- package/dist/interface/slack/index.d.ts.map +1 -0
- package/dist/interface/slack/index.js +7 -0
- package/dist/interface/slack/index.js.map +1 -0
- package/dist/interface/telegram/TelegramBot.d.ts +60 -0
- package/dist/interface/telegram/TelegramBot.d.ts.map +1 -0
- package/dist/interface/telegram/TelegramBot.js +400 -0
- package/dist/interface/telegram/TelegramBot.js.map +1 -0
- package/dist/interface/telegram/TelegramFormatter.d.ts +19 -0
- package/dist/interface/telegram/TelegramFormatter.d.ts.map +1 -0
- package/dist/interface/telegram/TelegramFormatter.js +66 -0
- package/dist/interface/telegram/TelegramFormatter.js.map +1 -0
- package/dist/interface/types.d.ts +167 -0
- package/dist/interface/types.d.ts.map +1 -0
- package/dist/interface/types.js +6 -0
- package/dist/interface/types.js.map +1 -0
- package/dist/interface/utils/MessageCombiner.d.ts +14 -0
- package/dist/interface/utils/MessageCombiner.d.ts.map +1 -0
- package/dist/interface/utils/MessageCombiner.js +48 -0
- package/dist/interface/utils/MessageCombiner.js.map +1 -0
- package/dist/interface/vision/AdaptiveFrameSampler.d.ts +44 -0
- package/dist/interface/vision/AdaptiveFrameSampler.d.ts.map +1 -0
- package/dist/interface/vision/AdaptiveFrameSampler.js +109 -0
- package/dist/interface/vision/AdaptiveFrameSampler.js.map +1 -0
- package/dist/interface/vision/AdaptiveFrameSampler.test.d.ts +7 -0
- package/dist/interface/vision/AdaptiveFrameSampler.test.d.ts.map +1 -0
- package/dist/interface/vision/AdaptiveFrameSampler.test.js +113 -0
- package/dist/interface/vision/AdaptiveFrameSampler.test.js.map +1 -0
- package/dist/interface/vision/GeminiLive.d.ts +37 -0
- package/dist/interface/vision/GeminiLive.d.ts.map +1 -0
- package/dist/interface/vision/GeminiLive.js +272 -0
- package/dist/interface/vision/GeminiLive.js.map +1 -0
- package/dist/interface/vision/GeminiLive.test.d.ts +6 -0
- package/dist/interface/vision/GeminiLive.test.d.ts.map +1 -0
- package/dist/interface/vision/GeminiLive.test.js +40 -0
- package/dist/interface/vision/GeminiLive.test.js.map +1 -0
- package/dist/interface/vision/GeminiLiveStream.d.ts +55 -0
- package/dist/interface/vision/GeminiLiveStream.d.ts.map +1 -0
- package/dist/interface/vision/GeminiLiveStream.js +213 -0
- package/dist/interface/vision/GeminiLiveStream.js.map +1 -0
- package/dist/interface/vision/GeminiVision.d.ts +25 -0
- package/dist/interface/vision/GeminiVision.d.ts.map +1 -0
- package/dist/interface/vision/GeminiVision.js +202 -0
- package/dist/interface/vision/GeminiVision.js.map +1 -0
- package/dist/interface/vision/ScreenCapture.d.ts +77 -0
- package/dist/interface/vision/ScreenCapture.d.ts.map +1 -0
- package/dist/interface/vision/ScreenCapture.js +314 -0
- package/dist/interface/vision/ScreenCapture.js.map +1 -0
- package/dist/interface/vision/ScreenCaptureEngine.d.ts +55 -0
- package/dist/interface/vision/ScreenCaptureEngine.d.ts.map +1 -0
- package/dist/interface/vision/ScreenCaptureEngine.js +223 -0
- package/dist/interface/vision/ScreenCaptureEngine.js.map +1 -0
- package/dist/interface/vision/ScreenCaptureEngine.test.d.ts +8 -0
- package/dist/interface/vision/ScreenCaptureEngine.test.d.ts.map +1 -0
- package/dist/interface/vision/ScreenCaptureEngine.test.js +175 -0
- package/dist/interface/vision/ScreenCaptureEngine.test.js.map +1 -0
- package/dist/interface/vision/VisionInterface.d.ts +26 -0
- package/dist/interface/vision/VisionInterface.d.ts.map +1 -0
- package/dist/interface/vision/VisionInterface.js +105 -0
- package/dist/interface/vision/VisionInterface.js.map +1 -0
- package/dist/interface/vision/VisionSession.d.ts +66 -0
- package/dist/interface/vision/VisionSession.d.ts.map +1 -0
- package/dist/interface/vision/VisionSession.js +274 -0
- package/dist/interface/vision/VisionSession.js.map +1 -0
- package/dist/interface/vision/VisionSession.test.d.ts +7 -0
- package/dist/interface/vision/VisionSession.test.d.ts.map +1 -0
- package/dist/interface/vision/VisionSession.test.js +218 -0
- package/dist/interface/vision/VisionSession.test.js.map +1 -0
- package/dist/interface/vision/__tests__/GeminiVision.test.d.ts +5 -0
- package/dist/interface/vision/__tests__/GeminiVision.test.d.ts.map +1 -0
- package/dist/interface/vision/__tests__/GeminiVision.test.js +92 -0
- package/dist/interface/vision/__tests__/GeminiVision.test.js.map +1 -0
- package/dist/interface/vision/__tests__/ScreenCapture.test.d.ts +5 -0
- package/dist/interface/vision/__tests__/ScreenCapture.test.d.ts.map +1 -0
- package/dist/interface/vision/__tests__/ScreenCapture.test.js +24 -0
- package/dist/interface/vision/__tests__/ScreenCapture.test.js.map +1 -0
- package/dist/interface/vision/__tests__/VisionInterface.test.d.ts +5 -0
- package/dist/interface/vision/__tests__/VisionInterface.test.d.ts.map +1 -0
- package/dist/interface/vision/__tests__/VisionInterface.test.js +59 -0
- package/dist/interface/vision/__tests__/VisionInterface.test.js.map +1 -0
- package/dist/interface/vision/index.d.ts +20 -0
- package/dist/interface/vision/index.d.ts.map +1 -0
- package/dist/interface/vision/index.js +16 -0
- package/dist/interface/vision/index.js.map +1 -0
- package/dist/interface/vision/types.d.ts +79 -0
- package/dist/interface/vision/types.d.ts.map +1 -0
- package/dist/interface/vision/types.js +22 -0
- package/dist/interface/vision/types.js.map +1 -0
- package/dist/interface/voice/STTProvider.d.ts +48 -0
- package/dist/interface/voice/STTProvider.d.ts.map +1 -0
- package/dist/interface/voice/STTProvider.js +254 -0
- package/dist/interface/voice/STTProvider.js.map +1 -0
- package/dist/interface/voice/STTProvider.test.d.ts +8 -0
- package/dist/interface/voice/STTProvider.test.d.ts.map +1 -0
- package/dist/interface/voice/STTProvider.test.js +144 -0
- package/dist/interface/voice/STTProvider.test.js.map +1 -0
- package/dist/interface/voice/TTSProvider.d.ts +44 -0
- package/dist/interface/voice/TTSProvider.d.ts.map +1 -0
- package/dist/interface/voice/TTSProvider.js +252 -0
- package/dist/interface/voice/TTSProvider.js.map +1 -0
- package/dist/interface/voice/TTSProvider.test.d.ts +8 -0
- package/dist/interface/voice/TTSProvider.test.d.ts.map +1 -0
- package/dist/interface/voice/TTSProvider.test.js +143 -0
- package/dist/interface/voice/TTSProvider.test.js.map +1 -0
- package/dist/interface/voice/VADProcessor.d.ts +34 -0
- package/dist/interface/voice/VADProcessor.d.ts.map +1 -0
- package/dist/interface/voice/VADProcessor.js +116 -0
- package/dist/interface/voice/VADProcessor.js.map +1 -0
- package/dist/interface/voice/VADProcessor.test.d.ts +8 -0
- package/dist/interface/voice/VADProcessor.test.d.ts.map +1 -0
- package/dist/interface/voice/VADProcessor.test.js +159 -0
- package/dist/interface/voice/VADProcessor.test.js.map +1 -0
- package/dist/interface/voice/VoiceSession.d.ts +77 -0
- package/dist/interface/voice/VoiceSession.d.ts.map +1 -0
- package/dist/interface/voice/VoiceSession.js +249 -0
- package/dist/interface/voice/VoiceSession.js.map +1 -0
- package/dist/interface/voice/VoiceSession.test.d.ts +8 -0
- package/dist/interface/voice/VoiceSession.test.d.ts.map +1 -0
- package/dist/interface/voice/VoiceSession.test.js +260 -0
- package/dist/interface/voice/VoiceSession.test.js.map +1 -0
- package/dist/interface/voice/VoiceWebSocket.d.ts +52 -0
- package/dist/interface/voice/VoiceWebSocket.d.ts.map +1 -0
- package/dist/interface/voice/VoiceWebSocket.js +165 -0
- package/dist/interface/voice/VoiceWebSocket.js.map +1 -0
- package/dist/interface/voice/types.d.ts +144 -0
- package/dist/interface/voice/types.d.ts.map +1 -0
- package/dist/interface/voice/types.js +23 -0
- package/dist/interface/voice/types.js.map +1 -0
- package/dist/interface/voice/types.test.d.ts +8 -0
- package/dist/interface/voice/types.test.d.ts.map +1 -0
- package/dist/interface/voice/types.test.js +90 -0
- package/dist/interface/voice/types.test.js.map +1 -0
- package/dist/interface/web/WebServer.d.ts +80 -0
- package/dist/interface/web/WebServer.d.ts.map +1 -0
- package/dist/interface/web/WebServer.js +999 -0
- package/dist/interface/web/WebServer.js.map +1 -0
- package/dist/interface/web/__tests__/WebServer.test.d.ts +5 -0
- package/dist/interface/web/__tests__/WebServer.test.d.ts.map +1 -0
- package/dist/interface/web/__tests__/WebServer.test.js +345 -0
- package/dist/interface/web/__tests__/WebServer.test.js.map +1 -0
- package/dist/interface/web/types.d.ts +109 -0
- package/dist/interface/web/types.d.ts.map +1 -0
- package/dist/interface/web/types.js +67 -0
- package/dist/interface/web/types.js.map +1 -0
- package/dist/interface/webhook/WebhookHandler.d.ts +45 -0
- package/dist/interface/webhook/WebhookHandler.d.ts.map +1 -0
- package/dist/interface/webhook/WebhookHandler.js +273 -0
- package/dist/interface/webhook/WebhookHandler.js.map +1 -0
- package/dist/job/ActionPlanGenerator.d.ts +21 -0
- package/dist/job/ActionPlanGenerator.d.ts.map +1 -0
- package/dist/job/ActionPlanGenerator.js +153 -0
- package/dist/job/ActionPlanGenerator.js.map +1 -0
- package/dist/job/AgentJobManager.d.ts +46 -0
- package/dist/job/AgentJobManager.d.ts.map +1 -0
- package/dist/job/AgentJobManager.js +213 -0
- package/dist/job/AgentJobManager.js.map +1 -0
- package/dist/job/AgentJobManager.test.d.ts +6 -0
- package/dist/job/AgentJobManager.test.d.ts.map +1 -0
- package/dist/job/AgentJobManager.test.js +197 -0
- package/dist/job/AgentJobManager.test.js.map +1 -0
- package/dist/job/IntentParser.d.ts +21 -0
- package/dist/job/IntentParser.d.ts.map +1 -0
- package/dist/job/IntentParser.js +142 -0
- package/dist/job/IntentParser.js.map +1 -0
- package/dist/job/JobManager.d.ts +54 -0
- package/dist/job/JobManager.d.ts.map +1 -0
- package/dist/job/JobManager.js +220 -0
- package/dist/job/JobManager.js.map +1 -0
- package/dist/job/JobQueue.d.ts +41 -0
- package/dist/job/JobQueue.d.ts.map +1 -0
- package/dist/job/JobQueue.js +153 -0
- package/dist/job/JobQueue.js.map +1 -0
- package/dist/job/JobStore.d.ts +36 -0
- package/dist/job/JobStore.d.ts.map +1 -0
- package/dist/job/JobStore.js +260 -0
- package/dist/job/JobStore.js.map +1 -0
- package/dist/job/ProgressReporter.d.ts +32 -0
- package/dist/job/ProgressReporter.d.ts.map +1 -0
- package/dist/job/ProgressReporter.js +82 -0
- package/dist/job/ProgressReporter.js.map +1 -0
- package/dist/job/agent-job-types.d.ts +32 -0
- package/dist/job/agent-job-types.d.ts.map +1 -0
- package/dist/job/agent-job-types.js +6 -0
- package/dist/job/agent-job-types.js.map +1 -0
- package/dist/job/index.d.ts +15 -0
- package/dist/job/index.d.ts.map +1 -0
- package/dist/job/index.js +15 -0
- package/dist/job/index.js.map +1 -0
- package/dist/job/job.test.d.ts +5 -0
- package/dist/job/job.test.d.ts.map +1 -0
- package/dist/job/job.test.js +303 -0
- package/dist/job/job.test.js.map +1 -0
- package/dist/job/types.d.ts +82 -0
- package/dist/job/types.d.ts.map +1 -0
- package/dist/job/types.js +40 -0
- package/dist/job/types.js.map +1 -0
- package/dist/orchestrator/AgentAnnouncer.d.ts +64 -0
- package/dist/orchestrator/AgentAnnouncer.d.ts.map +1 -0
- package/dist/orchestrator/AgentAnnouncer.js +127 -0
- package/dist/orchestrator/AgentAnnouncer.js.map +1 -0
- package/dist/orchestrator/AgentAnnouncer.test.d.ts +5 -0
- package/dist/orchestrator/AgentAnnouncer.test.d.ts.map +1 -0
- package/dist/orchestrator/AgentAnnouncer.test.js +119 -0
- package/dist/orchestrator/AgentAnnouncer.test.js.map +1 -0
- package/dist/orchestrator/AgentExecutor.d.ts +23 -0
- package/dist/orchestrator/AgentExecutor.d.ts.map +1 -0
- package/dist/orchestrator/AgentExecutor.js +231 -0
- package/dist/orchestrator/AgentExecutor.js.map +1 -0
- package/dist/orchestrator/AgentManager.d.ts +73 -0
- package/dist/orchestrator/AgentManager.d.ts.map +1 -0
- package/dist/orchestrator/AgentManager.js +184 -0
- package/dist/orchestrator/AgentManager.js.map +1 -0
- package/dist/orchestrator/AgentRegistry.d.ts +76 -0
- package/dist/orchestrator/AgentRegistry.d.ts.map +1 -0
- package/dist/orchestrator/AgentRegistry.js +217 -0
- package/dist/orchestrator/AgentRegistry.js.map +1 -0
- package/dist/orchestrator/AgentRegistry.test.d.ts +5 -0
- package/dist/orchestrator/AgentRegistry.test.d.ts.map +1 -0
- package/dist/orchestrator/AgentRegistry.test.js +122 -0
- package/dist/orchestrator/AgentRegistry.test.js.map +1 -0
- package/dist/orchestrator/BackgroundManager.d.ts +114 -0
- package/dist/orchestrator/BackgroundManager.d.ts.map +1 -0
- package/dist/orchestrator/BackgroundManager.js +517 -0
- package/dist/orchestrator/BackgroundManager.js.map +1 -0
- package/dist/orchestrator/BackgroundManager.test.d.ts +6 -0
- package/dist/orchestrator/BackgroundManager.test.d.ts.map +1 -0
- package/dist/orchestrator/BackgroundManager.test.js +162 -0
- package/dist/orchestrator/BackgroundManager.test.js.map +1 -0
- package/dist/orchestrator/CheckpointManager.d.ts +54 -0
- package/dist/orchestrator/CheckpointManager.d.ts.map +1 -0
- package/dist/orchestrator/CheckpointManager.js +121 -0
- package/dist/orchestrator/CheckpointManager.js.map +1 -0
- package/dist/orchestrator/LLMCluster.d.ts +91 -0
- package/dist/orchestrator/LLMCluster.d.ts.map +1 -0
- package/dist/orchestrator/LLMCluster.js +124 -0
- package/dist/orchestrator/LLMCluster.js.map +1 -0
- package/dist/orchestrator/MultiLlmResearch.d.ts +27 -0
- package/dist/orchestrator/MultiLlmResearch.d.ts.map +1 -0
- package/dist/orchestrator/MultiLlmResearch.js +145 -0
- package/dist/orchestrator/MultiLlmResearch.js.map +1 -0
- package/dist/orchestrator/PhasePipeline.d.ts +123 -0
- package/dist/orchestrator/PhasePipeline.d.ts.map +1 -0
- package/dist/orchestrator/PhasePipeline.js +382 -0
- package/dist/orchestrator/PhasePipeline.js.map +1 -0
- package/dist/orchestrator/PhaseResultStore.d.ts +39 -0
- package/dist/orchestrator/PhaseResultStore.d.ts.map +1 -0
- package/dist/orchestrator/PhaseResultStore.js +151 -0
- package/dist/orchestrator/PhaseResultStore.js.map +1 -0
- package/dist/orchestrator/SessionStore.d.ts +41 -0
- package/dist/orchestrator/SessionStore.d.ts.map +1 -0
- package/dist/orchestrator/SessionStore.js +117 -0
- package/dist/orchestrator/SessionStore.js.map +1 -0
- package/dist/orchestrator/SmartRouter.d.ts +77 -0
- package/dist/orchestrator/SmartRouter.d.ts.map +1 -0
- package/dist/orchestrator/SmartRouter.js +305 -0
- package/dist/orchestrator/SmartRouter.js.map +1 -0
- package/dist/orchestrator/SwarmOrchestrator.d.ts +144 -0
- package/dist/orchestrator/SwarmOrchestrator.d.ts.map +1 -0
- package/dist/orchestrator/SwarmOrchestrator.js +361 -0
- package/dist/orchestrator/SwarmOrchestrator.js.map +1 -0
- package/dist/orchestrator/SwarmOrchestrator.test.d.ts +5 -0
- package/dist/orchestrator/SwarmOrchestrator.test.d.ts.map +1 -0
- package/dist/orchestrator/SwarmOrchestrator.test.js +95 -0
- package/dist/orchestrator/SwarmOrchestrator.test.js.map +1 -0
- package/dist/orchestrator/agentDiscovery.d.ts +18 -0
- package/dist/orchestrator/agentDiscovery.d.ts.map +1 -0
- package/dist/orchestrator/agentDiscovery.js +175 -0
- package/dist/orchestrator/agentDiscovery.js.map +1 -0
- package/dist/orchestrator/backgroundAgent.d.ts +15 -0
- package/dist/orchestrator/backgroundAgent.d.ts.map +1 -0
- package/dist/orchestrator/backgroundAgent.js +16 -0
- package/dist/orchestrator/backgroundAgent.js.map +1 -0
- package/dist/orchestrator/index.d.ts +213 -0
- package/dist/orchestrator/index.d.ts.map +1 -0
- package/dist/orchestrator/index.js +391 -0
- package/dist/orchestrator/index.js.map +1 -0
- package/dist/orchestrator/orchestrator.d.ts +63 -0
- package/dist/orchestrator/orchestrator.d.ts.map +1 -0
- package/dist/orchestrator/orchestrator.js +217 -0
- package/dist/orchestrator/orchestrator.js.map +1 -0
- package/dist/orchestrator/parallelResearch.d.ts +30 -0
- package/dist/orchestrator/parallelResearch.d.ts.map +1 -0
- package/dist/orchestrator/parallelResearch.js +247 -0
- package/dist/orchestrator/parallelResearch.js.map +1 -0
- package/dist/orchestrator/types.d.ts +185 -0
- package/dist/orchestrator/types.d.ts.map +1 -0
- package/dist/orchestrator/types.js +21 -0
- package/dist/orchestrator/types.js.map +1 -0
- package/dist/pc/CommandDispatcher.d.ts +31 -0
- package/dist/pc/CommandDispatcher.d.ts.map +1 -0
- package/dist/pc/CommandDispatcher.js +132 -0
- package/dist/pc/CommandDispatcher.js.map +1 -0
- package/dist/pc/CommandDispatcher.test.d.ts +2 -0
- package/dist/pc/CommandDispatcher.test.d.ts.map +1 -0
- package/dist/pc/CommandDispatcher.test.js +360 -0
- package/dist/pc/CommandDispatcher.test.js.map +1 -0
- package/dist/pc/ModuleRegistry.d.ts +40 -0
- package/dist/pc/ModuleRegistry.d.ts.map +1 -0
- package/dist/pc/ModuleRegistry.js +163 -0
- package/dist/pc/ModuleRegistry.js.map +1 -0
- package/dist/pc/ResultFormatter.d.ts +27 -0
- package/dist/pc/ResultFormatter.d.ts.map +1 -0
- package/dist/pc/ResultFormatter.js +128 -0
- package/dist/pc/ResultFormatter.js.map +1 -0
- package/dist/pc/ResultFormatter.test.d.ts +2 -0
- package/dist/pc/ResultFormatter.test.d.ts.map +1 -0
- package/dist/pc/ResultFormatter.test.js +115 -0
- package/dist/pc/ResultFormatter.test.js.map +1 -0
- package/dist/pc/SecurityGate.d.ts +53 -0
- package/dist/pc/SecurityGate.d.ts.map +1 -0
- package/dist/pc/SecurityGate.js +142 -0
- package/dist/pc/SecurityGate.js.map +1 -0
- package/dist/pc/SecurityGate.test.d.ts +2 -0
- package/dist/pc/SecurityGate.test.d.ts.map +1 -0
- package/dist/pc/SecurityGate.test.js +160 -0
- package/dist/pc/SecurityGate.test.js.map +1 -0
- package/dist/pc/SessionContext.d.ts +31 -0
- package/dist/pc/SessionContext.d.ts.map +1 -0
- package/dist/pc/SessionContext.js +108 -0
- package/dist/pc/SessionContext.js.map +1 -0
- package/dist/pc/browser/BrowserActions.d.ts +22 -0
- package/dist/pc/browser/BrowserActions.d.ts.map +1 -0
- package/dist/pc/browser/BrowserActions.js +223 -0
- package/dist/pc/browser/BrowserActions.js.map +1 -0
- package/dist/pc/browser/BrowserActions.test.d.ts +7 -0
- package/dist/pc/browser/BrowserActions.test.d.ts.map +1 -0
- package/dist/pc/browser/BrowserActions.test.js +150 -0
- package/dist/pc/browser/BrowserActions.test.js.map +1 -0
- package/dist/pc/browser/BrowserService.d.ts +66 -0
- package/dist/pc/browser/BrowserService.d.ts.map +1 -0
- package/dist/pc/browser/BrowserService.js +319 -0
- package/dist/pc/browser/BrowserService.js.map +1 -0
- package/dist/pc/browser/BrowserService.test.d.ts +7 -0
- package/dist/pc/browser/BrowserService.test.d.ts.map +1 -0
- package/dist/pc/browser/BrowserService.test.js +160 -0
- package/dist/pc/browser/BrowserService.test.js.map +1 -0
- package/dist/pc/browser/RefLocator.d.ts +39 -0
- package/dist/pc/browser/RefLocator.d.ts.map +1 -0
- package/dist/pc/browser/RefLocator.js +88 -0
- package/dist/pc/browser/RefLocator.js.map +1 -0
- package/dist/pc/browser/RoleSnapshotManager.d.ts +22 -0
- package/dist/pc/browser/RoleSnapshotManager.d.ts.map +1 -0
- package/dist/pc/browser/RoleSnapshotManager.js +143 -0
- package/dist/pc/browser/RoleSnapshotManager.js.map +1 -0
- package/dist/pc/browser/RoleSnapshotManager.test.d.ts +7 -0
- package/dist/pc/browser/RoleSnapshotManager.test.d.ts.map +1 -0
- package/dist/pc/browser/RoleSnapshotManager.test.js +152 -0
- package/dist/pc/browser/RoleSnapshotManager.test.js.map +1 -0
- package/dist/pc/browser/Security.test.d.ts +7 -0
- package/dist/pc/browser/Security.test.d.ts.map +1 -0
- package/dist/pc/browser/Security.test.js +171 -0
- package/dist/pc/browser/Security.test.js.map +1 -0
- package/dist/pc/browser/types.d.ts +142 -0
- package/dist/pc/browser/types.d.ts.map +1 -0
- package/dist/pc/browser/types.js +60 -0
- package/dist/pc/browser/types.js.map +1 -0
- package/dist/pc/google/OAuthFlow.d.ts +58 -0
- package/dist/pc/google/OAuthFlow.d.ts.map +1 -0
- package/dist/pc/google/OAuthFlow.js +322 -0
- package/dist/pc/google/OAuthFlow.js.map +1 -0
- package/dist/pc/google/OAuthFlow.test.d.ts +7 -0
- package/dist/pc/google/OAuthFlow.test.d.ts.map +1 -0
- package/dist/pc/google/OAuthFlow.test.js +178 -0
- package/dist/pc/google/OAuthFlow.test.js.map +1 -0
- package/dist/pc/google/ScopeManager.d.ts +28 -0
- package/dist/pc/google/ScopeManager.d.ts.map +1 -0
- package/dist/pc/google/ScopeManager.js +75 -0
- package/dist/pc/google/ScopeManager.js.map +1 -0
- package/dist/pc/google/TokenStore.d.ts +49 -0
- package/dist/pc/google/TokenStore.d.ts.map +1 -0
- package/dist/pc/google/TokenStore.js +324 -0
- package/dist/pc/google/TokenStore.js.map +1 -0
- package/dist/pc/google/TokenStore.test.d.ts +7 -0
- package/dist/pc/google/TokenStore.test.d.ts.map +1 -0
- package/dist/pc/google/TokenStore.test.js +134 -0
- package/dist/pc/google/TokenStore.test.js.map +1 -0
- package/dist/pc/google/services/CalendarService.d.ts +45 -0
- package/dist/pc/google/services/CalendarService.d.ts.map +1 -0
- package/dist/pc/google/services/CalendarService.js +148 -0
- package/dist/pc/google/services/CalendarService.js.map +1 -0
- package/dist/pc/google/services/DriveService.d.ts +33 -0
- package/dist/pc/google/services/DriveService.d.ts.map +1 -0
- package/dist/pc/google/services/DriveService.js +199 -0
- package/dist/pc/google/services/DriveService.js.map +1 -0
- package/dist/pc/google/services/GmailService.d.ts +50 -0
- package/dist/pc/google/services/GmailService.d.ts.map +1 -0
- package/dist/pc/google/services/GmailService.js +177 -0
- package/dist/pc/google/services/GmailService.js.map +1 -0
- package/dist/pc/google/services/Services.test.d.ts +8 -0
- package/dist/pc/google/services/Services.test.d.ts.map +1 -0
- package/dist/pc/google/services/Services.test.js +148 -0
- package/dist/pc/google/services/Services.test.js.map +1 -0
- package/dist/pc/google/services/SheetsService.d.ts +27 -0
- package/dist/pc/google/services/SheetsService.d.ts.map +1 -0
- package/dist/pc/google/services/SheetsService.js +107 -0
- package/dist/pc/google/services/SheetsService.js.map +1 -0
- package/dist/pc/google/types.d.ts +97 -0
- package/dist/pc/google/types.d.ts.map +1 -0
- package/dist/pc/google/types.js +39 -0
- package/dist/pc/google/types.js.map +1 -0
- package/dist/pc/google/types.test.d.ts +8 -0
- package/dist/pc/google/types.test.d.ts.map +1 -0
- package/dist/pc/google/types.test.js +131 -0
- package/dist/pc/google/types.test.js.map +1 -0
- package/dist/pc/sandbox/ContainerConfig.d.ts +24 -0
- package/dist/pc/sandbox/ContainerConfig.d.ts.map +1 -0
- package/dist/pc/sandbox/ContainerConfig.js +103 -0
- package/dist/pc/sandbox/ContainerConfig.js.map +1 -0
- package/dist/pc/sandbox/ContainerManager.d.ts +31 -0
- package/dist/pc/sandbox/ContainerManager.d.ts.map +1 -0
- package/dist/pc/sandbox/ContainerManager.js +245 -0
- package/dist/pc/sandbox/ContainerManager.js.map +1 -0
- package/dist/pc/sandbox/ContainerManager.test.d.ts +2 -0
- package/dist/pc/sandbox/ContainerManager.test.d.ts.map +1 -0
- package/dist/pc/sandbox/ContainerManager.test.js +249 -0
- package/dist/pc/sandbox/ContainerManager.test.js.map +1 -0
- package/dist/pc/sandbox/ExecAllowlist.d.ts +35 -0
- package/dist/pc/sandbox/ExecAllowlist.d.ts.map +1 -0
- package/dist/pc/sandbox/ExecAllowlist.js +148 -0
- package/dist/pc/sandbox/ExecAllowlist.js.map +1 -0
- package/dist/pc/sandbox/ExecAllowlist.test.d.ts +2 -0
- package/dist/pc/sandbox/ExecAllowlist.test.d.ts.map +1 -0
- package/dist/pc/sandbox/ExecAllowlist.test.js +210 -0
- package/dist/pc/sandbox/ExecAllowlist.test.js.map +1 -0
- package/dist/pc/sandbox/SandboxBrowser.d.ts +29 -0
- package/dist/pc/sandbox/SandboxBrowser.d.ts.map +1 -0
- package/dist/pc/sandbox/SandboxBrowser.js +72 -0
- package/dist/pc/sandbox/SandboxBrowser.js.map +1 -0
- package/dist/pc/sandbox/ToolPolicy.d.ts +24 -0
- package/dist/pc/sandbox/ToolPolicy.d.ts.map +1 -0
- package/dist/pc/sandbox/ToolPolicy.js +127 -0
- package/dist/pc/sandbox/ToolPolicy.js.map +1 -0
- package/dist/pc/sandbox/ToolPolicy.test.d.ts +2 -0
- package/dist/pc/sandbox/ToolPolicy.test.d.ts.map +1 -0
- package/dist/pc/sandbox/ToolPolicy.test.js +189 -0
- package/dist/pc/sandbox/ToolPolicy.test.js.map +1 -0
- package/dist/pc/sandbox/types.d.ts +109 -0
- package/dist/pc/sandbox/types.d.ts.map +1 -0
- package/dist/pc/sandbox/types.js +26 -0
- package/dist/pc/sandbox/types.js.map +1 -0
- package/dist/pc/types.d.ts +84 -0
- package/dist/pc/types.d.ts.map +1 -0
- package/dist/pc/types.js +7 -0
- package/dist/pc/types.js.map +1 -0
- package/dist/policy/Evidence.d.ts +30 -0
- package/dist/policy/Evidence.d.ts.map +1 -0
- package/dist/policy/Evidence.js +134 -0
- package/dist/policy/Evidence.js.map +1 -0
- package/dist/policy/PolicyEngine.d.ts +34 -0
- package/dist/policy/PolicyEngine.d.ts.map +1 -0
- package/dist/policy/PolicyEngine.js +219 -0
- package/dist/policy/PolicyEngine.js.map +1 -0
- package/dist/policy/PolicyStore.d.ts +36 -0
- package/dist/policy/PolicyStore.d.ts.map +1 -0
- package/dist/policy/PolicyStore.js +160 -0
- package/dist/policy/PolicyStore.js.map +1 -0
- package/dist/policy/RiskCalculator.d.ts +20 -0
- package/dist/policy/RiskCalculator.d.ts.map +1 -0
- package/dist/policy/RiskCalculator.js +64 -0
- package/dist/policy/RiskCalculator.js.map +1 -0
- package/dist/policy/default-policies.d.ts +13 -0
- package/dist/policy/default-policies.d.ts.map +1 -0
- package/dist/policy/default-policies.js +99 -0
- package/dist/policy/default-policies.js.map +1 -0
- package/dist/policy/index.d.ts +11 -0
- package/dist/policy/index.d.ts.map +1 -0
- package/dist/policy/index.js +10 -0
- package/dist/policy/index.js.map +1 -0
- package/dist/policy/policy.test.d.ts +5 -0
- package/dist/policy/policy.test.d.ts.map +1 -0
- package/dist/policy/policy.test.js +628 -0
- package/dist/policy/policy.test.js.map +1 -0
- package/dist/policy/types.d.ts +71 -0
- package/dist/policy/types.d.ts.map +1 -0
- package/dist/policy/types.js +18 -0
- package/dist/policy/types.js.map +1 -0
- package/dist/router/ModelARouter.d.ts +79 -0
- package/dist/router/ModelARouter.d.ts.map +1 -0
- package/dist/router/ModelARouter.js +325 -0
- package/dist/router/ModelARouter.js.map +1 -0
- package/dist/router/ModelARouter.test.d.ts +6 -0
- package/dist/router/ModelARouter.test.d.ts.map +1 -0
- package/dist/router/ModelARouter.test.js +100 -0
- package/dist/router/ModelARouter.test.js.map +1 -0
- package/dist/router/MultiChannelRouter.d.ts +54 -0
- package/dist/router/MultiChannelRouter.d.ts.map +1 -0
- package/dist/router/MultiChannelRouter.js +138 -0
- package/dist/router/MultiChannelRouter.js.map +1 -0
- package/dist/router/RouteRegistry.d.ts +23 -0
- package/dist/router/RouteRegistry.d.ts.map +1 -0
- package/dist/router/RouteRegistry.js +42 -0
- package/dist/router/RouteRegistry.js.map +1 -0
- package/dist/router/browser/BrowserAgent.d.ts +30 -0
- package/dist/router/browser/BrowserAgent.d.ts.map +1 -0
- package/dist/router/browser/BrowserAgent.js +232 -0
- package/dist/router/browser/BrowserAgent.js.map +1 -0
- package/dist/router/browser/BrowserManager.d.ts +36 -0
- package/dist/router/browser/BrowserManager.d.ts.map +1 -0
- package/dist/router/browser/BrowserManager.js +106 -0
- package/dist/router/browser/BrowserManager.js.map +1 -0
- package/dist/router/browser/BrowserPool.d.ts +37 -0
- package/dist/router/browser/BrowserPool.d.ts.map +1 -0
- package/dist/router/browser/BrowserPool.js +114 -0
- package/dist/router/browser/BrowserPool.js.map +1 -0
- package/dist/router/handlers/GitOpsHandler.d.ts +24 -0
- package/dist/router/handlers/GitOpsHandler.d.ts.map +1 -0
- package/dist/router/handlers/GitOpsHandler.js +66 -0
- package/dist/router/handlers/GitOpsHandler.js.map +1 -0
- package/dist/router/index.d.ts +22 -0
- package/dist/router/index.d.ts.map +1 -0
- package/dist/router/index.js +29 -0
- package/dist/router/index.js.map +1 -0
- package/dist/router/index.test.d.ts +2 -0
- package/dist/router/index.test.d.ts.map +1 -0
- package/dist/router/index.test.js +78 -0
- package/dist/router/index.test.js.map +1 -0
- package/dist/router/notifications/NotificationManager.d.ts +37 -0
- package/dist/router/notifications/NotificationManager.d.ts.map +1 -0
- package/dist/router/notifications/NotificationManager.js +118 -0
- package/dist/router/notifications/NotificationManager.js.map +1 -0
- package/dist/router/planner/TaskExecutor.d.ts +48 -0
- package/dist/router/planner/TaskExecutor.d.ts.map +1 -0
- package/dist/router/planner/TaskExecutor.js +160 -0
- package/dist/router/planner/TaskExecutor.js.map +1 -0
- package/dist/router/planner/TaskExecutor.test.d.ts +6 -0
- package/dist/router/planner/TaskExecutor.test.d.ts.map +1 -0
- package/dist/router/planner/TaskExecutor.test.js +121 -0
- package/dist/router/planner/TaskExecutor.test.js.map +1 -0
- package/dist/router/planner/TaskPlanner.d.ts +37 -0
- package/dist/router/planner/TaskPlanner.d.ts.map +1 -0
- package/dist/router/planner/TaskPlanner.js +176 -0
- package/dist/router/planner/TaskPlanner.js.map +1 -0
- package/dist/router/planner/TaskPlanner.test.d.ts +6 -0
- package/dist/router/planner/TaskPlanner.test.d.ts.map +1 -0
- package/dist/router/planner/TaskPlanner.test.js +119 -0
- package/dist/router/planner/TaskPlanner.test.js.map +1 -0
- package/dist/router/qa/TelegramQABridge.d.ts +37 -0
- package/dist/router/qa/TelegramQABridge.d.ts.map +1 -0
- package/dist/router/qa/TelegramQABridge.js +147 -0
- package/dist/router/qa/TelegramQABridge.js.map +1 -0
- package/dist/router/qa/TelegramQABridge.test.d.ts +6 -0
- package/dist/router/qa/TelegramQABridge.test.d.ts.map +1 -0
- package/dist/router/qa/TelegramQABridge.test.js +143 -0
- package/dist/router/qa/TelegramQABridge.test.js.map +1 -0
- package/dist/router/resolvers/RepoResolver.d.ts +29 -0
- package/dist/router/resolvers/RepoResolver.d.ts.map +1 -0
- package/dist/router/resolvers/RepoResolver.js +105 -0
- package/dist/router/resolvers/RepoResolver.js.map +1 -0
- package/dist/router/resolvers/RepoResolver.test.d.ts +6 -0
- package/dist/router/resolvers/RepoResolver.test.d.ts.map +1 -0
- package/dist/router/resolvers/RepoResolver.test.js +92 -0
- package/dist/router/resolvers/RepoResolver.test.js.map +1 -0
- package/dist/router/routes/BaseRoute.d.ts +22 -0
- package/dist/router/routes/BaseRoute.d.ts.map +1 -0
- package/dist/router/routes/BaseRoute.js +55 -0
- package/dist/router/routes/BaseRoute.js.map +1 -0
- package/dist/router/routes/BrowseRoute.d.ts +21 -0
- package/dist/router/routes/BrowseRoute.d.ts.map +1 -0
- package/dist/router/routes/BrowseRoute.js +121 -0
- package/dist/router/routes/BrowseRoute.js.map +1 -0
- package/dist/router/routes/CompositeRoute.d.ts +28 -0
- package/dist/router/routes/CompositeRoute.d.ts.map +1 -0
- package/dist/router/routes/CompositeRoute.js +125 -0
- package/dist/router/routes/CompositeRoute.js.map +1 -0
- package/dist/router/routes/CompositeRoute.test.d.ts +6 -0
- package/dist/router/routes/CompositeRoute.test.d.ts.map +1 -0
- package/dist/router/routes/CompositeRoute.test.js +82 -0
- package/dist/router/routes/CompositeRoute.test.js.map +1 -0
- package/dist/router/routes/DevRoute.d.ts +26 -0
- package/dist/router/routes/DevRoute.d.ts.map +1 -0
- package/dist/router/routes/DevRoute.js +118 -0
- package/dist/router/routes/DevRoute.js.map +1 -0
- package/dist/router/routes/GoogleRoute.d.ts +46 -0
- package/dist/router/routes/GoogleRoute.d.ts.map +1 -0
- package/dist/router/routes/GoogleRoute.js +293 -0
- package/dist/router/routes/GoogleRoute.js.map +1 -0
- package/dist/router/routes/GoogleRoute.test.d.ts +6 -0
- package/dist/router/routes/GoogleRoute.test.d.ts.map +1 -0
- package/dist/router/routes/GoogleRoute.test.js +171 -0
- package/dist/router/routes/GoogleRoute.test.js.map +1 -0
- package/dist/router/routes/MonitorRoute.d.ts +25 -0
- package/dist/router/routes/MonitorRoute.d.ts.map +1 -0
- package/dist/router/routes/MonitorRoute.js +112 -0
- package/dist/router/routes/MonitorRoute.js.map +1 -0
- package/dist/router/routes/MonitorRoute.test.d.ts +6 -0
- package/dist/router/routes/MonitorRoute.test.d.ts.map +1 -0
- package/dist/router/routes/MonitorRoute.test.js +97 -0
- package/dist/router/routes/MonitorRoute.test.js.map +1 -0
- package/dist/router/routes/ResearchRoute.d.ts +25 -0
- package/dist/router/routes/ResearchRoute.d.ts.map +1 -0
- package/dist/router/routes/ResearchRoute.js +113 -0
- package/dist/router/routes/ResearchRoute.js.map +1 -0
- package/dist/router/routes/ResearchRoute.test.d.ts +6 -0
- package/dist/router/routes/ResearchRoute.test.d.ts.map +1 -0
- package/dist/router/routes/ResearchRoute.test.js +104 -0
- package/dist/router/routes/ResearchRoute.test.js.map +1 -0
- package/dist/router/routes/UtilityRoute.d.ts +32 -0
- package/dist/router/routes/UtilityRoute.d.ts.map +1 -0
- package/dist/router/routes/UtilityRoute.js +144 -0
- package/dist/router/routes/UtilityRoute.js.map +1 -0
- package/dist/router/routes/UtilityRoute.test.d.ts +6 -0
- package/dist/router/routes/UtilityRoute.test.d.ts.map +1 -0
- package/dist/router/routes/UtilityRoute.test.js +134 -0
- package/dist/router/routes/UtilityRoute.test.js.map +1 -0
- package/dist/router/services/BookmarkService.d.ts +34 -0
- package/dist/router/services/BookmarkService.d.ts.map +1 -0
- package/dist/router/services/BookmarkService.js +86 -0
- package/dist/router/services/BookmarkService.js.map +1 -0
- package/dist/router/services/BookmarkService.test.d.ts +6 -0
- package/dist/router/services/BookmarkService.test.d.ts.map +1 -0
- package/dist/router/services/BookmarkService.test.js +82 -0
- package/dist/router/services/BookmarkService.test.js.map +1 -0
- package/dist/router/services/CalendarService.d.ts +30 -0
- package/dist/router/services/CalendarService.d.ts.map +1 -0
- package/dist/router/services/CalendarService.js +168 -0
- package/dist/router/services/CalendarService.js.map +1 -0
- package/dist/router/services/CalendarService.test.d.ts +6 -0
- package/dist/router/services/CalendarService.test.d.ts.map +1 -0
- package/dist/router/services/CalendarService.test.js +107 -0
- package/dist/router/services/CalendarService.test.js.map +1 -0
- package/dist/router/services/ContentSummarizer.d.ts +32 -0
- package/dist/router/services/ContentSummarizer.d.ts.map +1 -0
- package/dist/router/services/ContentSummarizer.js +108 -0
- package/dist/router/services/ContentSummarizer.js.map +1 -0
- package/dist/router/services/ContentSummarizer.test.d.ts +6 -0
- package/dist/router/services/ContentSummarizer.test.d.ts.map +1 -0
- package/dist/router/services/ContentSummarizer.test.js +82 -0
- package/dist/router/services/ContentSummarizer.test.js.map +1 -0
- package/dist/router/services/DailyReportGenerator.d.ts +34 -0
- package/dist/router/services/DailyReportGenerator.d.ts.map +1 -0
- package/dist/router/services/DailyReportGenerator.js +110 -0
- package/dist/router/services/DailyReportGenerator.js.map +1 -0
- package/dist/router/services/DocumentGenerator.d.ts +20 -0
- package/dist/router/services/DocumentGenerator.d.ts.map +1 -0
- package/dist/router/services/DocumentGenerator.js +34 -0
- package/dist/router/services/DocumentGenerator.js.map +1 -0
- package/dist/router/services/DriveService.d.ts +29 -0
- package/dist/router/services/DriveService.d.ts.map +1 -0
- package/dist/router/services/DriveService.js +176 -0
- package/dist/router/services/DriveService.js.map +1 -0
- package/dist/router/services/DriveService.test.d.ts +6 -0
- package/dist/router/services/DriveService.test.d.ts.map +1 -0
- package/dist/router/services/DriveService.test.js +83 -0
- package/dist/router/services/DriveService.test.js.map +1 -0
- package/dist/router/services/FileAnalyzer.d.ts +26 -0
- package/dist/router/services/FileAnalyzer.d.ts.map +1 -0
- package/dist/router/services/FileAnalyzer.js +82 -0
- package/dist/router/services/FileAnalyzer.js.map +1 -0
- package/dist/router/services/GitHubMonitor.d.ts +38 -0
- package/dist/router/services/GitHubMonitor.d.ts.map +1 -0
- package/dist/router/services/GitHubMonitor.js +82 -0
- package/dist/router/services/GitHubMonitor.js.map +1 -0
- package/dist/router/services/GitHubMonitor.test.d.ts +6 -0
- package/dist/router/services/GitHubMonitor.test.d.ts.map +1 -0
- package/dist/router/services/GitHubMonitor.test.js +103 -0
- package/dist/router/services/GitHubMonitor.test.js.map +1 -0
- package/dist/router/services/GmailService.d.ts +28 -0
- package/dist/router/services/GmailService.d.ts.map +1 -0
- package/dist/router/services/GmailService.js +169 -0
- package/dist/router/services/GmailService.js.map +1 -0
- package/dist/router/services/GmailService.test.d.ts +6 -0
- package/dist/router/services/GmailService.test.d.ts.map +1 -0
- package/dist/router/services/GmailService.test.js +113 -0
- package/dist/router/services/GmailService.test.js.map +1 -0
- package/dist/router/services/GoogleAuthManager.d.ts +31 -0
- package/dist/router/services/GoogleAuthManager.d.ts.map +1 -0
- package/dist/router/services/GoogleAuthManager.js +219 -0
- package/dist/router/services/GoogleAuthManager.js.map +1 -0
- package/dist/router/services/GoogleAuthManager.test.d.ts +6 -0
- package/dist/router/services/GoogleAuthManager.test.d.ts.map +1 -0
- package/dist/router/services/GoogleAuthManager.test.js +153 -0
- package/dist/router/services/GoogleAuthManager.test.js.map +1 -0
- package/dist/router/services/ImageGenerator.d.ts +20 -0
- package/dist/router/services/ImageGenerator.d.ts.map +1 -0
- package/dist/router/services/ImageGenerator.js +41 -0
- package/dist/router/services/ImageGenerator.js.map +1 -0
- package/dist/router/services/NoteService.d.ts +36 -0
- package/dist/router/services/NoteService.d.ts.map +1 -0
- package/dist/router/services/NoteService.js +125 -0
- package/dist/router/services/NoteService.js.map +1 -0
- package/dist/router/services/NoteService.test.d.ts +6 -0
- package/dist/router/services/NoteService.test.d.ts.map +1 -0
- package/dist/router/services/NoteService.test.js +90 -0
- package/dist/router/services/NoteService.test.js.map +1 -0
- package/dist/router/services/ProgressReporter.d.ts +32 -0
- package/dist/router/services/ProgressReporter.d.ts.map +1 -0
- package/dist/router/services/ProgressReporter.js +81 -0
- package/dist/router/services/ProgressReporter.js.map +1 -0
- package/dist/router/services/SchedulerEngine.d.ts +55 -0
- package/dist/router/services/SchedulerEngine.d.ts.map +1 -0
- package/dist/router/services/SchedulerEngine.js +215 -0
- package/dist/router/services/SchedulerEngine.js.map +1 -0
- package/dist/router/services/SchedulerEngine.test.d.ts +6 -0
- package/dist/router/services/SchedulerEngine.test.d.ts.map +1 -0
- package/dist/router/services/SchedulerEngine.test.js +102 -0
- package/dist/router/services/SchedulerEngine.test.js.map +1 -0
- package/dist/router/services/ScreenshotService.d.ts +22 -0
- package/dist/router/services/ScreenshotService.d.ts.map +1 -0
- package/dist/router/services/ScreenshotService.js +39 -0
- package/dist/router/services/ScreenshotService.js.map +1 -0
- package/dist/router/services/SheetsService.d.ts +27 -0
- package/dist/router/services/SheetsService.d.ts.map +1 -0
- package/dist/router/services/SheetsService.js +91 -0
- package/dist/router/services/SheetsService.js.map +1 -0
- package/dist/router/services/SheetsService.test.d.ts +6 -0
- package/dist/router/services/SheetsService.test.d.ts.map +1 -0
- package/dist/router/services/SheetsService.test.js +86 -0
- package/dist/router/services/SheetsService.test.js.map +1 -0
- package/dist/router/services/TranslationService.d.ts +21 -0
- package/dist/router/services/TranslationService.d.ts.map +1 -0
- package/dist/router/services/TranslationService.js +76 -0
- package/dist/router/services/TranslationService.js.map +1 -0
- package/dist/router/services/TranslationService.test.d.ts +6 -0
- package/dist/router/services/TranslationService.test.d.ts.map +1 -0
- package/dist/router/services/TranslationService.test.js +61 -0
- package/dist/router/services/TranslationService.test.js.map +1 -0
- package/dist/router/services/WebSearchService.d.ts +24 -0
- package/dist/router/services/WebSearchService.d.ts.map +1 -0
- package/dist/router/services/WebSearchService.js +78 -0
- package/dist/router/services/WebSearchService.js.map +1 -0
- package/dist/router/services/WebSearchService.test.d.ts +6 -0
- package/dist/router/services/WebSearchService.test.d.ts.map +1 -0
- package/dist/router/services/WebSearchService.test.js +75 -0
- package/dist/router/services/WebSearchService.test.js.map +1 -0
- package/dist/router/services/YouTubeService.d.ts +30 -0
- package/dist/router/services/YouTubeService.d.ts.map +1 -0
- package/dist/router/services/YouTubeService.js +145 -0
- package/dist/router/services/YouTubeService.js.map +1 -0
- package/dist/router/services/YouTubeService.test.d.ts +6 -0
- package/dist/router/services/YouTubeService.test.d.ts.map +1 -0
- package/dist/router/services/YouTubeService.test.js +128 -0
- package/dist/router/services/YouTubeService.test.js.map +1 -0
- package/dist/router/services/google-types.d.ts +222 -0
- package/dist/router/services/google-types.d.ts.map +1 -0
- package/dist/router/services/google-types.js +6 -0
- package/dist/router/services/google-types.js.map +1 -0
- package/dist/router/sessions/DevSessionManager.d.ts +39 -0
- package/dist/router/sessions/DevSessionManager.d.ts.map +1 -0
- package/dist/router/sessions/DevSessionManager.js +151 -0
- package/dist/router/sessions/DevSessionManager.js.map +1 -0
- package/dist/router/types.d.ts +117 -0
- package/dist/router/types.d.ts.map +1 -0
- package/dist/router/types.js +25 -0
- package/dist/router/types.js.map +1 -0
- package/dist/sync/ConflictResolver.d.ts +29 -0
- package/dist/sync/ConflictResolver.d.ts.map +1 -0
- package/dist/sync/ConflictResolver.js +106 -0
- package/dist/sync/ConflictResolver.js.map +1 -0
- package/dist/sync/DataSerializer.d.ts +33 -0
- package/dist/sync/DataSerializer.d.ts.map +1 -0
- package/dist/sync/DataSerializer.js +207 -0
- package/dist/sync/DataSerializer.js.map +1 -0
- package/dist/sync/DeviceManager.d.ts +31 -0
- package/dist/sync/DeviceManager.d.ts.map +1 -0
- package/dist/sync/DeviceManager.js +141 -0
- package/dist/sync/DeviceManager.js.map +1 -0
- package/dist/sync/SyncEngine.d.ts +56 -0
- package/dist/sync/SyncEngine.d.ts.map +1 -0
- package/dist/sync/SyncEngine.js +172 -0
- package/dist/sync/SyncEngine.js.map +1 -0
- package/dist/sync/SyncStore.d.ts +46 -0
- package/dist/sync/SyncStore.d.ts.map +1 -0
- package/dist/sync/SyncStore.js +219 -0
- package/dist/sync/SyncStore.js.map +1 -0
- package/dist/sync/index.d.ts +12 -0
- package/dist/sync/index.d.ts.map +1 -0
- package/dist/sync/index.js +11 -0
- package/dist/sync/index.js.map +1 -0
- package/dist/sync/sync.test.d.ts +5 -0
- package/dist/sync/sync.test.d.ts.map +1 -0
- package/dist/sync/sync.test.js +416 -0
- package/dist/sync/sync.test.js.map +1 -0
- package/dist/sync/types.d.ts +80 -0
- package/dist/sync/types.d.ts.map +1 -0
- package/dist/sync/types.js +12 -0
- package/dist/sync/types.js.map +1 -0
- package/dist/tools/browser/index.d.ts +47 -0
- package/dist/tools/browser/index.d.ts.map +1 -0
- package/dist/tools/browser/index.js +413 -0
- package/dist/tools/browser/index.js.map +1 -0
- package/dist/tools/convention/analyzeComplexity.test.js +115 -115
- package/dist/tools/convention/validateCodeQuality.test.js +104 -104
- package/dist/tools/google/index.d.ts +84 -0
- package/dist/tools/google/index.d.ts.map +1 -0
- package/dist/tools/google/index.js +508 -0
- package/dist/tools/google/index.js.map +1 -0
- package/dist/tools/integration/index.d.ts +24 -0
- package/dist/tools/integration/index.d.ts.map +1 -0
- package/dist/tools/integration/index.js +223 -0
- package/dist/tools/integration/index.js.map +1 -0
- package/dist/tools/memory/createMemoryTimeline.js +10 -10
- package/dist/tools/memory/getMemoryGraph.js +12 -12
- package/dist/tools/memory/getSessionContext.js +9 -9
- package/dist/tools/memory/linkMemories.js +14 -14
- package/dist/tools/memory/listMemories.js +4 -4
- package/dist/tools/memory/recallMemory.js +4 -4
- package/dist/tools/memory/saveMemory.js +4 -4
- package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
- package/dist/tools/sandbox/index.d.ts +25 -0
- package/dist/tools/sandbox/index.d.ts.map +1 -0
- package/dist/tools/sandbox/index.js +255 -0
- package/dist/tools/sandbox/index.js.map +1 -0
- package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
- package/dist/tools/semantic/astGrep.d.ts +2 -0
- package/dist/tools/semantic/astGrep.d.ts.map +1 -1
- package/dist/tools/semantic/astGrep.js +61 -35
- package/dist/tools/semantic/astGrep.js.map +1 -1
- package/dist/tools/semantic/astGrep.test.js +15 -7
- package/dist/tools/semantic/astGrep.test.js.map +1 -1
- package/dist/tools/spec/prdParser.test.js +171 -171
- package/dist/tools/spec/specGenerator.js +169 -169
- package/dist/tools/spec/traceabilityMatrix.js +64 -64
- package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
- package/dist/tools/vision/index.d.ts +45 -0
- package/dist/tools/vision/index.d.ts.map +1 -0
- package/dist/tools/vision/index.js +328 -0
- package/dist/tools/vision/index.js.map +1 -0
- package/dist/tools/voice/index.d.ts +24 -0
- package/dist/tools/voice/index.d.ts.map +1 -0
- package/dist/tools/voice/index.js +204 -0
- package/dist/tools/voice/index.js.map +1 -0
- package/dist/types/tool.d.ts +64 -0
- package/dist/types/tool.d.ts.map +1 -0
- package/dist/types/tool.js +3 -0
- package/dist/types/tool.js.map +1 -0
- package/hooks/hooks.json +137 -137
- package/hooks/scripts/code-check.js +70 -70
- package/hooks/scripts/context-save.js +200 -200
- package/hooks/scripts/hud-status.js +291 -291
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/llm-orchestrate.js +646 -511
- package/hooks/scripts/post-edit.js +32 -32
- package/hooks/scripts/pre-tool-guard.js +125 -125
- package/hooks/scripts/prompt-dispatcher.js +185 -185
- package/hooks/scripts/sentinel-guard.js +104 -104
- package/hooks/scripts/session-start.js +106 -106
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +100 -100
- package/languages/csharp-unity.md +515 -515
- package/languages/gdscript-godot.md +470 -470
- package/languages/ruby-rails.md +489 -489
- package/languages/typescript-angular.md +433 -433
- package/languages/typescript-astro.md +416 -416
- package/languages/typescript-electron.md +406 -406
- package/languages/typescript-nestjs.md +524 -524
- package/languages/typescript-svelte.md +407 -407
- package/languages/typescript-tauri.md +365 -365
- package/package.json +121 -119
- package/skills/brand-assets/SKILL.md +138 -138
- package/skills/commerce-patterns/SKILL.md +361 -361
- package/skills/commit-push-pr/SKILL.md +118 -118
- package/skills/context7-usage/SKILL.md +105 -105
- package/skills/e2e-commerce/SKILL.md +304 -304
- package/skills/frontend-design/SKILL.md +92 -92
- package/skills/git-worktree/SKILL.md +184 -184
- package/skills/handoff/SKILL.md +101 -101
- package/skills/priority-todos/SKILL.md +242 -242
- package/skills/seo-checklist/SKILL.md +244 -244
- package/skills/techdebt/SKILL.md +122 -122
- package/skills/tool-fallback/SKILL.md +193 -193
- package/skills/typescript-advanced-types/SKILL.md +720 -720
- package/skills/ui-ux-pro-max/SKILL.md +386 -386
- package/skills/vercel-react-best-practices/SKILL.md +304 -304
- package/vibe/config.json +29 -29
- package/vibe/constitution.md +227 -227
- package/vibe/rules/principles/communication-guide.md +98 -98
- package/vibe/rules/principles/development-philosophy.md +52 -52
- package/vibe/rules/principles/quick-start.md +102 -102
- package/vibe/rules/quality/bdd-contract-testing.md +393 -393
- package/vibe/rules/quality/checklist.md +276 -276
- package/vibe/rules/quality/performance.md +236 -236
- package/vibe/rules/quality/testing-strategy.md +440 -440
- package/vibe/rules/standards/anti-patterns.md +541 -541
- package/vibe/rules/standards/code-structure.md +291 -291
- package/vibe/rules/standards/complexity-metrics.md +313 -313
- package/vibe/rules/standards/git-workflow.md +237 -237
- package/vibe/rules/standards/naming-conventions.md +198 -198
- package/vibe/rules/standards/security.md +305 -305
- package/vibe/rules/writing/document-style.md +74 -74
- package/vibe/setup.sh +31 -31
- package/vibe/templates/constitution-template.md +252 -252
- package/vibe/templates/contract-backend-template.md +526 -526
- package/vibe/templates/contract-frontend-template.md +599 -599
- package/vibe/templates/feature-template.md +96 -96
- package/vibe/templates/spec-template.md +221 -221
- package/vibe/ui-ux-data/charts.csv +26 -26
- package/vibe/ui-ux-data/colors.csv +97 -97
- package/vibe/ui-ux-data/icons.csv +101 -101
- package/vibe/ui-ux-data/landing.csv +31 -31
- package/vibe/ui-ux-data/products.csv +96 -96
- package/vibe/ui-ux-data/react-performance.csv +45 -45
- package/vibe/ui-ux-data/stacks/astro.csv +54 -54
- package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
- package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
- package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
- package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
- package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
- package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
- package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
- package/vibe/ui-ux-data/stacks/react.csv +54 -54
- package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
- package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
- package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
- package/vibe/ui-ux-data/stacks/vue.csv +50 -50
- package/vibe/ui-ux-data/styles.csv +68 -68
- package/vibe/ui-ux-data/typography.csv +57 -57
- package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
- package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
- package/vibe/ui-ux-data/version.json +31 -31
- package/vibe/ui-ux-data/web-interface.csv +31 -31
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TelegramQABridge Tests
|
|
3
|
+
* Auto-approve, manual approve, timeout behavior
|
|
4
|
+
*/
|
|
5
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
6
|
+
import { TelegramQABridge } from './TelegramQABridge.js';
|
|
7
|
+
const mockLogger = vi.fn();
|
|
8
|
+
function createConfig(overrides) {
|
|
9
|
+
return {
|
|
10
|
+
autoApproveTools: ['Read', 'Glob', 'Grep', 'WebSearch', 'WebFetch', 'Ls'],
|
|
11
|
+
maxWaitSeconds: 1, // Short timeout for tests
|
|
12
|
+
readOnTimeout: 'approve',
|
|
13
|
+
writeOnTimeout: 'deny',
|
|
14
|
+
...overrides,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
function createRequest(tool, description = 'test operation') {
|
|
18
|
+
return {
|
|
19
|
+
jobId: 'job-1',
|
|
20
|
+
sessionId: 'session-1',
|
|
21
|
+
tool,
|
|
22
|
+
description,
|
|
23
|
+
timestamp: new Date().toISOString(),
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
function createMockServices() {
|
|
27
|
+
return {
|
|
28
|
+
logger: mockLogger,
|
|
29
|
+
sendTelegram: vi.fn().mockResolvedValue(undefined),
|
|
30
|
+
sendTelegramInlineKeyboard: vi.fn().mockResolvedValue(123),
|
|
31
|
+
registerCallbackHandler: vi.fn(),
|
|
32
|
+
unregisterCallbackHandler: vi.fn(),
|
|
33
|
+
router: {
|
|
34
|
+
handleMessage: vi.fn(),
|
|
35
|
+
getSmartRouter: vi.fn(),
|
|
36
|
+
},
|
|
37
|
+
config: {
|
|
38
|
+
repos: { aliases: {}, basePaths: [] },
|
|
39
|
+
qa: createConfig(),
|
|
40
|
+
notifications: { quietHoursStart: 23, quietHoursEnd: 7, minIntervalMs: 10000 },
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
describe('TelegramQABridge', () => {
|
|
45
|
+
let bridge;
|
|
46
|
+
beforeEach(() => {
|
|
47
|
+
mockLogger.mockClear();
|
|
48
|
+
});
|
|
49
|
+
describe('Auto-approve (read-only tools)', () => {
|
|
50
|
+
it('should auto-approve Read tool', async () => {
|
|
51
|
+
bridge = new TelegramQABridge(mockLogger, createConfig(), 'chat-1');
|
|
52
|
+
const result = await bridge.handlePermissionRequest(createRequest('Read'));
|
|
53
|
+
expect(result).toBe(true);
|
|
54
|
+
});
|
|
55
|
+
it('should auto-approve Glob tool', async () => {
|
|
56
|
+
bridge = new TelegramQABridge(mockLogger, createConfig(), 'chat-1');
|
|
57
|
+
const result = await bridge.handlePermissionRequest(createRequest('Glob'));
|
|
58
|
+
expect(result).toBe(true);
|
|
59
|
+
});
|
|
60
|
+
it('should auto-approve Grep tool', async () => {
|
|
61
|
+
bridge = new TelegramQABridge(mockLogger, createConfig(), 'chat-1');
|
|
62
|
+
const result = await bridge.handlePermissionRequest(createRequest('Grep'));
|
|
63
|
+
expect(result).toBe(true);
|
|
64
|
+
});
|
|
65
|
+
it('should auto-approve WebSearch tool', async () => {
|
|
66
|
+
bridge = new TelegramQABridge(mockLogger, createConfig(), 'chat-1');
|
|
67
|
+
const result = await bridge.handlePermissionRequest(createRequest('WebSearch'));
|
|
68
|
+
expect(result).toBe(true);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
describe('Manual approve (write tools)', () => {
|
|
72
|
+
it('should send inline keyboard for Edit tool', async () => {
|
|
73
|
+
const config = createConfig({ maxWaitSeconds: 5 });
|
|
74
|
+
bridge = new TelegramQABridge(mockLogger, config, 'chat-1');
|
|
75
|
+
const services = createMockServices();
|
|
76
|
+
bridge.setServices(services);
|
|
77
|
+
// Start the permission request but handle it immediately
|
|
78
|
+
const promise = bridge.handlePermissionRequest(createRequest('Edit'));
|
|
79
|
+
// Simulate user clicking approve
|
|
80
|
+
await new Promise((r) => setTimeout(r, 100));
|
|
81
|
+
bridge.handleCallbackResponse('approve');
|
|
82
|
+
const result = await promise;
|
|
83
|
+
expect(result).toBe(true);
|
|
84
|
+
});
|
|
85
|
+
it('should deny when user clicks deny button', async () => {
|
|
86
|
+
const config = createConfig({ maxWaitSeconds: 5 });
|
|
87
|
+
bridge = new TelegramQABridge(mockLogger, config, 'chat-1');
|
|
88
|
+
const services = createMockServices();
|
|
89
|
+
bridge.setServices(services);
|
|
90
|
+
const promise = bridge.handlePermissionRequest(createRequest('Write'));
|
|
91
|
+
await new Promise((r) => setTimeout(r, 100));
|
|
92
|
+
bridge.handleCallbackResponse('deny');
|
|
93
|
+
const result = await promise;
|
|
94
|
+
expect(result).toBe(false);
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
describe('Timeout behavior', () => {
|
|
98
|
+
it('should deny on timeout for write tools (default)', async () => {
|
|
99
|
+
const config = createConfig({ maxWaitSeconds: 1, writeOnTimeout: 'deny' });
|
|
100
|
+
bridge = new TelegramQABridge(mockLogger, config, 'chat-1');
|
|
101
|
+
const services = createMockServices();
|
|
102
|
+
bridge.setServices(services);
|
|
103
|
+
const result = await bridge.handlePermissionRequest(createRequest('Write'));
|
|
104
|
+
expect(result).toBe(false);
|
|
105
|
+
}, 3000);
|
|
106
|
+
it('should auto-decide on timeout when ai_decide is configured', async () => {
|
|
107
|
+
const config = createConfig({
|
|
108
|
+
maxWaitSeconds: 1,
|
|
109
|
+
writeOnTimeout: 'ai_decide',
|
|
110
|
+
});
|
|
111
|
+
bridge = new TelegramQABridge(mockLogger, config, 'chat-1');
|
|
112
|
+
const services = createMockServices();
|
|
113
|
+
bridge.setServices(services);
|
|
114
|
+
const result = await bridge.handlePermissionRequest(createRequest('Edit', 'editing a file'));
|
|
115
|
+
expect(result).toBe(true);
|
|
116
|
+
}, 3000);
|
|
117
|
+
it('should deny destructive commands even with ai_decide', async () => {
|
|
118
|
+
const config = createConfig({
|
|
119
|
+
maxWaitSeconds: 1,
|
|
120
|
+
writeOnTimeout: 'ai_decide',
|
|
121
|
+
});
|
|
122
|
+
bridge = new TelegramQABridge(mockLogger, config, 'chat-1');
|
|
123
|
+
const services = createMockServices();
|
|
124
|
+
bridge.setServices(services);
|
|
125
|
+
const result = await bridge.handlePermissionRequest(createRequest('Bash', 'rm -rf /'));
|
|
126
|
+
expect(result).toBe(false);
|
|
127
|
+
}, 3000);
|
|
128
|
+
});
|
|
129
|
+
describe('Cleanup', () => {
|
|
130
|
+
it('should deny all pending requests on cleanup', async () => {
|
|
131
|
+
const config = createConfig({ maxWaitSeconds: 60 });
|
|
132
|
+
bridge = new TelegramQABridge(mockLogger, config, 'chat-1');
|
|
133
|
+
const services = createMockServices();
|
|
134
|
+
bridge.setServices(services);
|
|
135
|
+
const promise = bridge.handlePermissionRequest(createRequest('Write'));
|
|
136
|
+
await new Promise((r) => setTimeout(r, 50));
|
|
137
|
+
bridge.cleanup();
|
|
138
|
+
const result = await promise;
|
|
139
|
+
expect(result).toBe(false);
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
//# sourceMappingURL=TelegramQABridge.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TelegramQABridge.test.js","sourceRoot":"","sources":["../../../src/router/qa/TelegramQABridge.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* RepoResolver - 3-stage project path resolution
|
|
3
|
+
* 1. Alias matching (from config)
|
|
4
|
+
* 2. WorkSpace scanning (basePaths)
|
|
5
|
+
* 3. Absolute path (direct)
|
|
6
|
+
*/
|
|
7
|
+
import { InterfaceLogger } from '../../interface/types.js';
|
|
8
|
+
import { RepoConfig } from '../types.js';
|
|
9
|
+
export declare class RepoResolver {
|
|
10
|
+
private logger;
|
|
11
|
+
private config;
|
|
12
|
+
private cache;
|
|
13
|
+
constructor(logger: InterfaceLogger, config: RepoConfig);
|
|
14
|
+
/** Update config (e.g., after reload) */
|
|
15
|
+
updateConfig(config: RepoConfig): void;
|
|
16
|
+
/** Resolve a project name/path to an absolute path */
|
|
17
|
+
resolve(query: string): string | null;
|
|
18
|
+
/** Stage 1: Match alias from config */
|
|
19
|
+
private matchAlias;
|
|
20
|
+
/** Stage 2: Scan base paths for matching directory */
|
|
21
|
+
private scanBasePaths;
|
|
22
|
+
/** Stage 3: Check if query is an absolute path */
|
|
23
|
+
private checkAbsolutePath;
|
|
24
|
+
/** Get from cache (with TTL check) */
|
|
25
|
+
private getFromCache;
|
|
26
|
+
/** Cache and return */
|
|
27
|
+
private cacheAndReturn;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=RepoResolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RepoResolver.d.ts","sourceRoot":"","sources":["../../../src/router/resolvers/RepoResolver.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AASzC,qBAAa,YAAY;IACvB,OAAO,CAAC,MAAM,CAAkB;IAChC,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,KAAK,CAAsC;gBAEvC,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,UAAU;IAKvD,yCAAyC;IACzC,YAAY,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI;IAKtC,sDAAsD;IACtD,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAqBrC,uCAAuC;IACvC,OAAO,CAAC,UAAU;IAYlB,sDAAsD;IACtD,OAAO,CAAC,aAAa;IAqBrB,kDAAkD;IAClD,OAAO,CAAC,iBAAiB;IAMzB,sCAAsC;IACtC,OAAO,CAAC,YAAY;IAUpB,uBAAuB;IACvB,OAAO,CAAC,cAAc;CAKvB"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* RepoResolver - 3-stage project path resolution
|
|
3
|
+
* 1. Alias matching (from config)
|
|
4
|
+
* 2. WorkSpace scanning (basePaths)
|
|
5
|
+
* 3. Absolute path (direct)
|
|
6
|
+
*/
|
|
7
|
+
import * as fs from 'node:fs';
|
|
8
|
+
import * as path from 'node:path';
|
|
9
|
+
const CACHE_TTL_MS = 5 * 60 * 1000; // 5 minutes
|
|
10
|
+
export class RepoResolver {
|
|
11
|
+
logger;
|
|
12
|
+
config;
|
|
13
|
+
cache = new Map();
|
|
14
|
+
constructor(logger, config) {
|
|
15
|
+
this.logger = logger;
|
|
16
|
+
this.config = config;
|
|
17
|
+
}
|
|
18
|
+
/** Update config (e.g., after reload) */
|
|
19
|
+
updateConfig(config) {
|
|
20
|
+
this.config = config;
|
|
21
|
+
this.cache.clear();
|
|
22
|
+
}
|
|
23
|
+
/** Resolve a project name/path to an absolute path */
|
|
24
|
+
resolve(query) {
|
|
25
|
+
// Check cache
|
|
26
|
+
const cached = this.getFromCache(query);
|
|
27
|
+
if (cached)
|
|
28
|
+
return cached;
|
|
29
|
+
// Stage 1: Alias matching
|
|
30
|
+
const aliasResult = this.matchAlias(query);
|
|
31
|
+
if (aliasResult)
|
|
32
|
+
return this.cacheAndReturn(query, aliasResult);
|
|
33
|
+
// Stage 2: WorkSpace scan
|
|
34
|
+
const scanResult = this.scanBasePaths(query);
|
|
35
|
+
if (scanResult)
|
|
36
|
+
return this.cacheAndReturn(query, scanResult);
|
|
37
|
+
// Stage 3: Absolute path
|
|
38
|
+
const absResult = this.checkAbsolutePath(query);
|
|
39
|
+
if (absResult)
|
|
40
|
+
return this.cacheAndReturn(query, absResult);
|
|
41
|
+
this.logger('warn', `RepoResolver: could not resolve "${query}"`);
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
/** Stage 1: Match alias from config */
|
|
45
|
+
matchAlias(query) {
|
|
46
|
+
const lower = query.toLowerCase();
|
|
47
|
+
for (const [alias, repoPath] of Object.entries(this.config.aliases)) {
|
|
48
|
+
if (alias.toLowerCase() === lower) {
|
|
49
|
+
const resolved = path.resolve(repoPath);
|
|
50
|
+
if (fs.existsSync(resolved))
|
|
51
|
+
return resolved;
|
|
52
|
+
this.logger('warn', `Alias "${alias}" points to non-existent path: ${repoPath}`);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
/** Stage 2: Scan base paths for matching directory */
|
|
58
|
+
scanBasePaths(query) {
|
|
59
|
+
const lower = query.toLowerCase();
|
|
60
|
+
for (const basePath of this.config.basePaths) {
|
|
61
|
+
const resolved = path.resolve(basePath);
|
|
62
|
+
if (!fs.existsSync(resolved))
|
|
63
|
+
continue;
|
|
64
|
+
try {
|
|
65
|
+
const entries = fs.readdirSync(resolved, { withFileTypes: true });
|
|
66
|
+
for (const entry of entries) {
|
|
67
|
+
if (!entry.isDirectory())
|
|
68
|
+
continue;
|
|
69
|
+
if (entry.name.toLowerCase().includes(lower)) {
|
|
70
|
+
return path.join(resolved, entry.name);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
catch {
|
|
75
|
+
this.logger('warn', `Failed to scan base path: ${basePath}`);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return null;
|
|
79
|
+
}
|
|
80
|
+
/** Stage 3: Check if query is an absolute path */
|
|
81
|
+
checkAbsolutePath(query) {
|
|
82
|
+
const resolved = path.resolve(query);
|
|
83
|
+
if (fs.existsSync(resolved))
|
|
84
|
+
return resolved;
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
/** Get from cache (with TTL check) */
|
|
88
|
+
getFromCache(query) {
|
|
89
|
+
const entry = this.cache.get(query);
|
|
90
|
+
if (!entry)
|
|
91
|
+
return null;
|
|
92
|
+
if (Date.now() - entry.cachedAt > CACHE_TTL_MS) {
|
|
93
|
+
this.cache.delete(query);
|
|
94
|
+
return null;
|
|
95
|
+
}
|
|
96
|
+
return entry.resolvedPath;
|
|
97
|
+
}
|
|
98
|
+
/** Cache and return */
|
|
99
|
+
cacheAndReturn(query, resolvedPath) {
|
|
100
|
+
this.cache.set(query, { resolvedPath, cachedAt: Date.now() });
|
|
101
|
+
this.logger('debug', `Resolved "${query}" → ${resolvedPath}`);
|
|
102
|
+
return resolvedPath;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
//# sourceMappingURL=RepoResolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RepoResolver.js","sourceRoot":"","sources":["../../../src/router/resolvers/RepoResolver.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RepoResolver.test.d.ts","sourceRoot":"","sources":["../../../src/router/resolvers/RepoResolver.test.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* RepoResolver Tests
|
|
3
|
+
* 3-stage resolution: alias → workspace scan → absolute path
|
|
4
|
+
*/
|
|
5
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
6
|
+
import * as path from 'node:path';
|
|
7
|
+
import * as os from 'node:os';
|
|
8
|
+
import { RepoResolver } from './RepoResolver.js';
|
|
9
|
+
const mockLogger = vi.fn();
|
|
10
|
+
describe('RepoResolver', () => {
|
|
11
|
+
let resolver;
|
|
12
|
+
beforeEach(() => {
|
|
13
|
+
mockLogger.mockClear();
|
|
14
|
+
});
|
|
15
|
+
describe('Stage 1: Alias matching', () => {
|
|
16
|
+
it('should resolve known alias to configured path', () => {
|
|
17
|
+
const homedir = os.homedir();
|
|
18
|
+
const testPath = path.join(homedir, 'WorkSpace', 'vibe');
|
|
19
|
+
resolver = new RepoResolver(mockLogger, {
|
|
20
|
+
aliases: { vibe: testPath },
|
|
21
|
+
basePaths: [],
|
|
22
|
+
});
|
|
23
|
+
const result = resolver.resolve('vibe');
|
|
24
|
+
expect(result).toBe(path.resolve(testPath));
|
|
25
|
+
});
|
|
26
|
+
it('should return null for unknown alias with no basePaths', () => {
|
|
27
|
+
resolver = new RepoResolver(mockLogger, {
|
|
28
|
+
aliases: {},
|
|
29
|
+
basePaths: [],
|
|
30
|
+
});
|
|
31
|
+
const result = resolver.resolve('nonexistent');
|
|
32
|
+
expect(result).toBeNull();
|
|
33
|
+
});
|
|
34
|
+
it('should be case-insensitive for aliases', () => {
|
|
35
|
+
const homedir = os.homedir();
|
|
36
|
+
const testPath = path.join(homedir, 'WorkSpace', 'vibe');
|
|
37
|
+
resolver = new RepoResolver(mockLogger, {
|
|
38
|
+
aliases: { VIBE: testPath },
|
|
39
|
+
basePaths: [],
|
|
40
|
+
});
|
|
41
|
+
const result = resolver.resolve('vibe');
|
|
42
|
+
expect(result).toBe(path.resolve(testPath));
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
describe('Stage 2: WorkSpace scan', () => {
|
|
46
|
+
it('should find directory by partial name in basePaths', () => {
|
|
47
|
+
const homedir = os.homedir();
|
|
48
|
+
const workspacePath = path.join(homedir, 'WorkSpace');
|
|
49
|
+
resolver = new RepoResolver(mockLogger, {
|
|
50
|
+
aliases: {},
|
|
51
|
+
basePaths: [workspacePath],
|
|
52
|
+
});
|
|
53
|
+
// 'vibe' directory should exist in WorkSpace
|
|
54
|
+
const result = resolver.resolve('vibe');
|
|
55
|
+
if (result) {
|
|
56
|
+
expect(result).toContain('vibe');
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
describe('Stage 3: Absolute path', () => {
|
|
61
|
+
it('should resolve absolute path if directory exists', () => {
|
|
62
|
+
const testPath = os.tmpdir();
|
|
63
|
+
resolver = new RepoResolver(mockLogger, {
|
|
64
|
+
aliases: {},
|
|
65
|
+
basePaths: [],
|
|
66
|
+
});
|
|
67
|
+
const result = resolver.resolve(testPath);
|
|
68
|
+
expect(result).toBe(path.resolve(testPath));
|
|
69
|
+
});
|
|
70
|
+
it('should return null for non-existent absolute path', () => {
|
|
71
|
+
resolver = new RepoResolver(mockLogger, {
|
|
72
|
+
aliases: {},
|
|
73
|
+
basePaths: [],
|
|
74
|
+
});
|
|
75
|
+
const result = resolver.resolve('/this/path/does/not/exist/ever');
|
|
76
|
+
expect(result).toBeNull();
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
describe('Cache', () => {
|
|
80
|
+
it('should cache resolved paths', () => {
|
|
81
|
+
const testPath = os.tmpdir();
|
|
82
|
+
resolver = new RepoResolver(mockLogger, {
|
|
83
|
+
aliases: { temp: testPath },
|
|
84
|
+
basePaths: [],
|
|
85
|
+
});
|
|
86
|
+
const result1 = resolver.resolve('temp');
|
|
87
|
+
const result2 = resolver.resolve('temp');
|
|
88
|
+
expect(result1).toBe(result2);
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
//# sourceMappingURL=RepoResolver.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RepoResolver.test.js","sourceRoot":"","sources":["../../../src/router/resolvers/RepoResolver.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BaseRoute - Abstract class for all routes
|
|
3
|
+
* Strategy Pattern: each route implements canHandle + execute
|
|
4
|
+
*/
|
|
5
|
+
import { InterfaceLogger } from '../../interface/types.js';
|
|
6
|
+
import { ClassifiedIntent, RouteContext, RouteResult } from '../types.js';
|
|
7
|
+
export declare abstract class BaseRoute {
|
|
8
|
+
abstract readonly name: string;
|
|
9
|
+
protected logger: InterfaceLogger;
|
|
10
|
+
protected timeoutMs: number;
|
|
11
|
+
constructor(logger: InterfaceLogger, timeoutMs?: number);
|
|
12
|
+
/** Check if this route can handle the given intent */
|
|
13
|
+
abstract canHandle(intent: ClassifiedIntent): boolean;
|
|
14
|
+
/** Execute the route logic (implemented by subclasses) */
|
|
15
|
+
protected abstract executeInternal(context: RouteContext): Promise<RouteResult>;
|
|
16
|
+
/** Execute with retry and timeout wrapper */
|
|
17
|
+
execute(context: RouteContext): Promise<RouteResult>;
|
|
18
|
+
private executeWithTimeout;
|
|
19
|
+
private createTimeoutPromise;
|
|
20
|
+
private createErrorResult;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=BaseRoute.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BaseRoute.d.ts","sourceRoot":"","sources":["../../../src/router/routes/BaseRoute.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAM1E,8BAAsB,SAAS;IAC7B,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IAC/B,SAAS,CAAC,MAAM,EAAE,eAAe,CAAC;IAClC,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC;gBAEhB,MAAM,EAAE,eAAe,EAAE,SAAS,GAAE,MAA2B;IAK3E,sDAAsD;IACtD,QAAQ,CAAC,SAAS,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO;IAErD,0DAA0D;IAC1D,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;IAE/E,6CAA6C;IACvC,OAAO,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;YAqB5C,kBAAkB;IAOhC,OAAO,CAAC,oBAAoB;IAM5B,OAAO,CAAC,iBAAiB;CAM1B"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BaseRoute - Abstract class for all routes
|
|
3
|
+
* Strategy Pattern: each route implements canHandle + execute
|
|
4
|
+
*/
|
|
5
|
+
const MAX_RETRIES = 3;
|
|
6
|
+
const BASE_BACKOFF_MS = 1000;
|
|
7
|
+
const DEFAULT_TIMEOUT_MS = 120_000;
|
|
8
|
+
export class BaseRoute {
|
|
9
|
+
logger;
|
|
10
|
+
timeoutMs;
|
|
11
|
+
constructor(logger, timeoutMs = DEFAULT_TIMEOUT_MS) {
|
|
12
|
+
this.logger = logger;
|
|
13
|
+
this.timeoutMs = timeoutMs;
|
|
14
|
+
}
|
|
15
|
+
/** Execute with retry and timeout wrapper */
|
|
16
|
+
async execute(context) {
|
|
17
|
+
for (let attempt = 1; attempt <= MAX_RETRIES; attempt++) {
|
|
18
|
+
try {
|
|
19
|
+
const result = await this.executeWithTimeout(context);
|
|
20
|
+
return result;
|
|
21
|
+
}
|
|
22
|
+
catch (err) {
|
|
23
|
+
const error = err instanceof Error ? err : new Error(String(err));
|
|
24
|
+
this.logger('warn', `${this.name} attempt ${attempt}/${MAX_RETRIES} failed: ${error.message}`);
|
|
25
|
+
if (attempt === MAX_RETRIES) {
|
|
26
|
+
return this.createErrorResult(error);
|
|
27
|
+
}
|
|
28
|
+
const delay = BASE_BACKOFF_MS * Math.pow(2, attempt - 1);
|
|
29
|
+
await sleep(delay);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
return { success: false, error: 'Max retries exceeded' };
|
|
33
|
+
}
|
|
34
|
+
async executeWithTimeout(context) {
|
|
35
|
+
return Promise.race([
|
|
36
|
+
this.executeInternal(context),
|
|
37
|
+
this.createTimeoutPromise(),
|
|
38
|
+
]);
|
|
39
|
+
}
|
|
40
|
+
createTimeoutPromise() {
|
|
41
|
+
return new Promise((_, reject) => {
|
|
42
|
+
setTimeout(() => reject(new Error(`Route ${this.name} timed out after ${this.timeoutMs}ms`)), this.timeoutMs);
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
createErrorResult(error) {
|
|
46
|
+
return {
|
|
47
|
+
success: false,
|
|
48
|
+
error: error.message,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
function sleep(ms) {
|
|
53
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=BaseRoute.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BaseRoute.js","sourceRoot":"","sources":["../../../src/router/routes/BaseRoute.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAKH,MAAM,WAAW,GAAG,CAAC,CAAC;AACtB,MAAM,eAAe,GAAG,IAAI,CAAC;AAC7B,MAAM,kBAAkB,GAAG,OAAO,CAAC;AAEnC,MAAM,OAAgB,SAAS;IAEnB,MAAM,CAAkB;IACxB,SAAS,CAAS;IAE5B,YAAY,MAAuB,EAAE,YAAoB,kBAAkB;QACzE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;IAQD,6CAA6C;IAC7C,KAAK,CAAC,OAAO,CAAC,OAAqB;QACjC,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC;YACxD,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;gBACtD,OAAO,MAAM,CAAC;YAChB,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,KAAK,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;gBAClE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,YAAY,OAAO,IAAI,WAAW,YAAY,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;gBAE/F,IAAI,OAAO,KAAK,WAAW,EAAE,CAAC;oBAC5B,OAAO,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;gBACvC,CAAC;gBAED,MAAM,KAAK,GAAG,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,GAAG,CAAC,CAAC,CAAC;gBACzD,MAAM,KAAK,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC;QACH,CAAC;QAED,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,sBAAsB,EAAE,CAAC;IAC3D,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAAC,OAAqB;QACpD,OAAO,OAAO,CAAC,IAAI,CAAC;YAClB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC;YAC7B,IAAI,CAAC,oBAAoB,EAAE;SAC5B,CAAC,CAAC;IACL,CAAC;IAEO,oBAAoB;QAC1B,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE;YAC/B,UAAU,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,SAAS,IAAI,CAAC,IAAI,oBAAoB,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAChH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,iBAAiB,CAAC,KAAY;QACpC,OAAO;YACL,OAAO,EAAE,KAAK;YACd,KAAK,EAAE,KAAK,CAAC,OAAO;SACrB,CAAC;IACJ,CAAC;CACF;AAED,SAAS,KAAK,CAAC,EAAU;IACvB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BrowseRoute - Browser automation route
|
|
3
|
+
* Opens Chrome with user's profile, performs LLM-driven web tasks
|
|
4
|
+
* Requires explicit user consent before accessing Chrome profile
|
|
5
|
+
*/
|
|
6
|
+
import { InterfaceLogger } from '../../interface/types.js';
|
|
7
|
+
import { ClassifiedIntent, RouteContext, RouteResult } from '../types.js';
|
|
8
|
+
import { BaseRoute } from './BaseRoute.js';
|
|
9
|
+
import { BrowserAgent } from '../browser/BrowserAgent.js';
|
|
10
|
+
export declare class BrowseRoute extends BaseRoute {
|
|
11
|
+
readonly name = "browse";
|
|
12
|
+
private agent;
|
|
13
|
+
constructor(logger: InterfaceLogger, agent: BrowserAgent);
|
|
14
|
+
canHandle(intent: ClassifiedIntent): boolean;
|
|
15
|
+
protected executeInternal(context: RouteContext): Promise<RouteResult>;
|
|
16
|
+
/** Check if user has granted browser consent */
|
|
17
|
+
private hasBrowserConsent;
|
|
18
|
+
/** Save browser consent to telegram config */
|
|
19
|
+
private saveBrowserConsent;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=BrowseRoute.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BrowseRoute.d.ts","sourceRoot":"","sources":["../../../src/router/routes/BrowseRoute.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAmC1D,qBAAa,WAAY,SAAQ,SAAS;IACxC,QAAQ,CAAC,IAAI,YAAY;IACzB,OAAO,CAAC,KAAK,CAAe;gBAEhB,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,YAAY;IAKxD,SAAS,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO;cAI5B,eAAe,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;IAyD5E,gDAAgD;IAChD,OAAO,CAAC,iBAAiB;IAYzB,8CAA8C;IAC9C,OAAO,CAAC,kBAAkB;CAqB3B"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BrowseRoute - Browser automation route
|
|
3
|
+
* Opens Chrome with user's profile, performs LLM-driven web tasks
|
|
4
|
+
* Requires explicit user consent before accessing Chrome profile
|
|
5
|
+
*/
|
|
6
|
+
import * as fs from 'node:fs';
|
|
7
|
+
import * as path from 'node:path';
|
|
8
|
+
import * as os from 'node:os';
|
|
9
|
+
import { BaseRoute } from './BaseRoute.js';
|
|
10
|
+
const VIBE_DIR = path.join(os.homedir(), '.vibe');
|
|
11
|
+
const TELEGRAM_CONFIG_PATH = path.join(VIBE_DIR, 'telegram.json');
|
|
12
|
+
const CONSENT_PHRASES = [
|
|
13
|
+
'브라우저 동의', '브라우저동의', '동의합니다', '동의',
|
|
14
|
+
'browser consent', 'i agree', 'agree',
|
|
15
|
+
];
|
|
16
|
+
const CONSENT_MESSAGE = [
|
|
17
|
+
'🔐 브라우저 접근 동의가 필요합니다\n',
|
|
18
|
+
'이 기능은 컴퓨터에 설치된 Chrome 브라우저의 사용자 프로필을 사용합니다.',
|
|
19
|
+
'이를 통해 다음 정보에 접근할 수 있습니다:\n',
|
|
20
|
+
'• Chrome에 로그인된 계정 세션 (Google, GitHub 등)',
|
|
21
|
+
'• 저장된 쿠키 및 사이트 데이터',
|
|
22
|
+
'• 브라우저 방문 기록\n',
|
|
23
|
+
'봇은 사용자의 요청에 따라 웹페이지를 탐색하고 정보를 추출합니다.',
|
|
24
|
+
'비밀번호나 결제 정보에는 직접 접근하지 않습니다.\n',
|
|
25
|
+
'동의하시려면 "브라우저 동의"라고 입력해주세요.',
|
|
26
|
+
'동의는 언제든 "브라우저 동의 철회"로 취소할 수 있습니다.',
|
|
27
|
+
].join('\n');
|
|
28
|
+
const REVOKE_PHRASES = [
|
|
29
|
+
'브라우저 동의 철회', '브라우저 철회', '동의 철회', '동의철회',
|
|
30
|
+
'revoke browser consent', 'revoke consent',
|
|
31
|
+
];
|
|
32
|
+
export class BrowseRoute extends BaseRoute {
|
|
33
|
+
name = 'browse';
|
|
34
|
+
agent;
|
|
35
|
+
constructor(logger, agent) {
|
|
36
|
+
super(logger);
|
|
37
|
+
this.agent = agent;
|
|
38
|
+
}
|
|
39
|
+
canHandle(intent) {
|
|
40
|
+
return intent.category === 'browse';
|
|
41
|
+
}
|
|
42
|
+
async executeInternal(context) {
|
|
43
|
+
const query = context.intent.rawQuery.trim();
|
|
44
|
+
const lower = query.toLowerCase();
|
|
45
|
+
// Handle consent revocation
|
|
46
|
+
if (REVOKE_PHRASES.some((p) => lower.includes(p))) {
|
|
47
|
+
this.saveBrowserConsent(false);
|
|
48
|
+
return { success: true, data: '브라우저 접근 동의가 철회되었습니다.' };
|
|
49
|
+
}
|
|
50
|
+
// Handle consent grant
|
|
51
|
+
if (CONSENT_PHRASES.some((p) => lower.includes(p))) {
|
|
52
|
+
this.saveBrowserConsent(true);
|
|
53
|
+
return {
|
|
54
|
+
success: true,
|
|
55
|
+
data: '브라우저 접근에 동의하셨습니다. 이제 브라우저 명령을 사용할 수 있습니다.',
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
// Check consent before executing browser tasks
|
|
59
|
+
if (!this.hasBrowserConsent()) {
|
|
60
|
+
await context.services.sendTelegram(context.chatId, CONSENT_MESSAGE);
|
|
61
|
+
return {
|
|
62
|
+
success: true,
|
|
63
|
+
data: '브라우저 사용을 위해 먼저 동의가 필요합니다.',
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
// Notify user that browser is starting
|
|
67
|
+
await context.services.sendTelegram(context.chatId, '브라우저를 열고 작업을 시작합니다...');
|
|
68
|
+
try {
|
|
69
|
+
const result = await this.agent.execute(query);
|
|
70
|
+
if (result.success) {
|
|
71
|
+
return {
|
|
72
|
+
success: true,
|
|
73
|
+
data: `${result.data}\n\n(${result.steps}단계, ${result.url ?? ''})`,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
return { success: false, error: result.data };
|
|
77
|
+
}
|
|
78
|
+
catch (err) {
|
|
79
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
80
|
+
if (msg.includes('Playwright')) {
|
|
81
|
+
return {
|
|
82
|
+
success: false,
|
|
83
|
+
error: 'Playwright가 설치되어 있지 않습니다. vibe telegram start를 다시 실행해주세요.',
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
return { success: false, error: `브라우저 작업 실패: ${msg}` };
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/** Check if user has granted browser consent */
|
|
90
|
+
hasBrowserConsent() {
|
|
91
|
+
try {
|
|
92
|
+
if (!fs.existsSync(TELEGRAM_CONFIG_PATH))
|
|
93
|
+
return false;
|
|
94
|
+
const config = JSON.parse(fs.readFileSync(TELEGRAM_CONFIG_PATH, 'utf-8'));
|
|
95
|
+
return config.browserConsent === true;
|
|
96
|
+
}
|
|
97
|
+
catch {
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
/** Save browser consent to telegram config */
|
|
102
|
+
saveBrowserConsent(granted) {
|
|
103
|
+
try {
|
|
104
|
+
let config = {};
|
|
105
|
+
if (fs.existsSync(TELEGRAM_CONFIG_PATH)) {
|
|
106
|
+
config = JSON.parse(fs.readFileSync(TELEGRAM_CONFIG_PATH, 'utf-8'));
|
|
107
|
+
}
|
|
108
|
+
config.browserConsent = granted;
|
|
109
|
+
config.browserConsentAt = granted ? new Date().toISOString() : undefined;
|
|
110
|
+
if (!fs.existsSync(VIBE_DIR)) {
|
|
111
|
+
fs.mkdirSync(VIBE_DIR, { recursive: true });
|
|
112
|
+
}
|
|
113
|
+
fs.writeFileSync(TELEGRAM_CONFIG_PATH, JSON.stringify(config, null, 2), 'utf-8');
|
|
114
|
+
this.logger('info', `브라우저 동의 ${granted ? '승인' : '철회'}`);
|
|
115
|
+
}
|
|
116
|
+
catch (err) {
|
|
117
|
+
this.logger('warn', `브라우저 동의 저장 실패: ${err instanceof Error ? err.message : String(err)}`);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
//# sourceMappingURL=BrowseRoute.js.map
|