@shuyhere/takotako 0.0.1
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/CONTRIBUTING.md +84 -0
- package/LICENSE +21 -0
- package/README.md +171 -0
- package/dist/agents/communication.d.ts +48 -0
- package/dist/agents/communication.d.ts.map +1 -0
- package/dist/agents/communication.js +123 -0
- package/dist/agents/communication.js.map +1 -0
- package/dist/agents/config.d.ts +52 -0
- package/dist/agents/config.d.ts.map +1 -0
- package/dist/agents/config.js +65 -0
- package/dist/agents/config.js.map +1 -0
- package/dist/agents/model-catalog.d.ts +49 -0
- package/dist/agents/model-catalog.d.ts.map +1 -0
- package/dist/agents/model-catalog.js +79 -0
- package/dist/agents/model-catalog.js.map +1 -0
- package/dist/agents/registry.d.ts +71 -0
- package/dist/agents/registry.d.ts.map +1 -0
- package/dist/agents/registry.js +297 -0
- package/dist/agents/registry.js.map +1 -0
- package/dist/agents/roles.d.ts +79 -0
- package/dist/agents/roles.d.ts.map +1 -0
- package/dist/agents/roles.js +174 -0
- package/dist/agents/roles.js.map +1 -0
- package/dist/agents/subagent.d.ts +124 -0
- package/dist/agents/subagent.d.ts.map +1 -0
- package/dist/agents/subagent.js +352 -0
- package/dist/agents/subagent.js.map +1 -0
- package/dist/agents/templates.d.ts +18 -0
- package/dist/agents/templates.d.ts.map +1 -0
- package/dist/agents/templates.js +341 -0
- package/dist/agents/templates.js.map +1 -0
- package/dist/agents/thread-binding.d.ts +77 -0
- package/dist/agents/thread-binding.d.ts.map +1 -0
- package/dist/agents/thread-binding.js +167 -0
- package/dist/agents/thread-binding.js.map +1 -0
- package/dist/auth/agent-profiles.d.ts +46 -0
- package/dist/auth/agent-profiles.d.ts.map +1 -0
- package/dist/auth/agent-profiles.js +97 -0
- package/dist/auth/agent-profiles.js.map +1 -0
- package/dist/auth/allow-from.d.ts +27 -0
- package/dist/auth/allow-from.d.ts.map +1 -0
- package/dist/auth/allow-from.js +118 -0
- package/dist/auth/allow-from.js.map +1 -0
- package/dist/auth/oauth.d.ts +66 -0
- package/dist/auth/oauth.d.ts.map +1 -0
- package/dist/auth/oauth.js +253 -0
- package/dist/auth/oauth.js.map +1 -0
- package/dist/auth/storage.d.ts +69 -0
- package/dist/auth/storage.d.ts.map +1 -0
- package/dist/auth/storage.js +157 -0
- package/dist/auth/storage.js.map +1 -0
- package/dist/cache/file-cache.d.ts +68 -0
- package/dist/cache/file-cache.d.ts.map +1 -0
- package/dist/cache/file-cache.js +176 -0
- package/dist/cache/file-cache.js.map +1 -0
- package/dist/cache/manager.d.ts +69 -0
- package/dist/cache/manager.d.ts.map +1 -0
- package/dist/cache/manager.js +117 -0
- package/dist/cache/manager.js.map +1 -0
- package/dist/cache/symbol-index.d.ts +75 -0
- package/dist/cache/symbol-index.d.ts.map +1 -0
- package/dist/cache/symbol-index.js +267 -0
- package/dist/cache/symbol-index.js.map +1 -0
- package/dist/cache/tool-cache.d.ts +75 -0
- package/dist/cache/tool-cache.d.ts.map +1 -0
- package/dist/cache/tool-cache.js +173 -0
- package/dist/cache/tool-cache.js.map +1 -0
- package/dist/channels/channel.d.ts +156 -0
- package/dist/channels/channel.d.ts.map +1 -0
- package/dist/channels/channel.js +25 -0
- package/dist/channels/channel.js.map +1 -0
- package/dist/channels/cli.d.ts +35 -0
- package/dist/channels/cli.d.ts.map +1 -0
- package/dist/channels/cli.js +94 -0
- package/dist/channels/cli.js.map +1 -0
- package/dist/channels/delivery-queue.d.ts +31 -0
- package/dist/channels/delivery-queue.d.ts.map +1 -0
- package/dist/channels/delivery-queue.js +127 -0
- package/dist/channels/delivery-queue.js.map +1 -0
- package/dist/channels/discord.d.ts +124 -0
- package/dist/channels/discord.d.ts.map +1 -0
- package/dist/channels/discord.js +664 -0
- package/dist/channels/discord.js.map +1 -0
- package/dist/channels/retry.d.ts +31 -0
- package/dist/channels/retry.d.ts.map +1 -0
- package/dist/channels/retry.js +94 -0
- package/dist/channels/retry.js.map +1 -0
- package/dist/channels/telegram.d.ts +69 -0
- package/dist/channels/telegram.d.ts.map +1 -0
- package/dist/channels/telegram.js +499 -0
- package/dist/channels/telegram.js.map +1 -0
- package/dist/channels/tui.d.ts +42 -0
- package/dist/channels/tui.d.ts.map +1 -0
- package/dist/channels/tui.js +126 -0
- package/dist/channels/tui.js.map +1 -0
- package/dist/cli/acp.d.ts +10 -0
- package/dist/cli/acp.d.ts.map +1 -0
- package/dist/cli/acp.js +69 -0
- package/dist/cli/acp.js.map +1 -0
- package/dist/cli/audit.d.ts +11 -0
- package/dist/cli/audit.d.ts.map +1 -0
- package/dist/cli/audit.js +55 -0
- package/dist/cli/audit.js.map +1 -0
- package/dist/cli/cache.d.ts +10 -0
- package/dist/cli/cache.d.ts.map +1 -0
- package/dist/cli/cache.js +77 -0
- package/dist/cli/cache.js.map +1 -0
- package/dist/cli/config.d.ts +5 -0
- package/dist/cli/config.d.ts.map +1 -0
- package/dist/cli/config.js +168 -0
- package/dist/cli/config.js.map +1 -0
- package/dist/cli/cron.d.ts +5 -0
- package/dist/cli/cron.d.ts.map +1 -0
- package/dist/cli/cron.js +192 -0
- package/dist/cli/cron.js.map +1 -0
- package/dist/cli/extensions.d.ts +5 -0
- package/dist/cli/extensions.d.ts.map +1 -0
- package/dist/cli/extensions.js +53 -0
- package/dist/cli/extensions.js.map +1 -0
- package/dist/cli/logs.d.ts +5 -0
- package/dist/cli/logs.d.ts.map +1 -0
- package/dist/cli/logs.js +49 -0
- package/dist/cli/logs.js.map +1 -0
- package/dist/cli/memory.d.ts +5 -0
- package/dist/cli/memory.d.ts.map +1 -0
- package/dist/cli/memory.js +78 -0
- package/dist/cli/memory.js.map +1 -0
- package/dist/cli/message.d.ts +5 -0
- package/dist/cli/message.d.ts.map +1 -0
- package/dist/cli/message.js +69 -0
- package/dist/cli/message.js.map +1 -0
- package/dist/cli/service.d.ts +14 -0
- package/dist/cli/service.d.ts.map +1 -0
- package/dist/cli/service.js +181 -0
- package/dist/cli/service.js.map +1 -0
- package/dist/cli/symphony.d.ts +5 -0
- package/dist/cli/symphony.d.ts.map +1 -0
- package/dist/cli/symphony.js +114 -0
- package/dist/cli/symphony.js.map +1 -0
- package/dist/cli/update.d.ts +5 -0
- package/dist/cli/update.d.ts.map +1 -0
- package/dist/cli/update.js +48 -0
- package/dist/cli/update.js.map +1 -0
- package/dist/commands/channel-setup.d.ts +31 -0
- package/dist/commands/channel-setup.d.ts.map +1 -0
- package/dist/commands/channel-setup.js +138 -0
- package/dist/commands/channel-setup.js.map +1 -0
- package/dist/commands/dispatch.d.ts +48 -0
- package/dist/commands/dispatch.d.ts.map +1 -0
- package/dist/commands/dispatch.js +68 -0
- package/dist/commands/dispatch.js.map +1 -0
- package/dist/commands/model-picker.d.ts +16 -0
- package/dist/commands/model-picker.d.ts.map +1 -0
- package/dist/commands/model-picker.js +120 -0
- package/dist/commands/model-picker.js.map +1 -0
- package/dist/commands/parser.d.ts +32 -0
- package/dist/commands/parser.d.ts.map +1 -0
- package/dist/commands/parser.js +39 -0
- package/dist/commands/parser.js.map +1 -0
- package/dist/commands/registry.d.ts +76 -0
- package/dist/commands/registry.d.ts.map +1 -0
- package/dist/commands/registry.js +351 -0
- package/dist/commands/registry.js.map +1 -0
- package/dist/commands/skill-commands.d.ts +35 -0
- package/dist/commands/skill-commands.d.ts.map +1 -0
- package/dist/commands/skill-commands.js +61 -0
- package/dist/commands/skill-commands.js.map +1 -0
- package/dist/config/resolve.d.ts +25 -0
- package/dist/config/resolve.d.ts.map +1 -0
- package/dist/config/resolve.js +289 -0
- package/dist/config/resolve.js.map +1 -0
- package/dist/config/schema.d.ts +520 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +123 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/core/agent-loop.d.ts +137 -0
- package/dist/core/agent-loop.d.ts.map +1 -0
- package/dist/core/agent-loop.js +700 -0
- package/dist/core/agent-loop.js.map +1 -0
- package/dist/core/audit.d.ts +87 -0
- package/dist/core/audit.d.ts.map +1 -0
- package/dist/core/audit.js +224 -0
- package/dist/core/audit.js.map +1 -0
- package/dist/core/bootstrap.d.ts +23 -0
- package/dist/core/bootstrap.d.ts.map +1 -0
- package/dist/core/bootstrap.js +162 -0
- package/dist/core/bootstrap.js.map +1 -0
- package/dist/core/context.d.ts +44 -0
- package/dist/core/context.d.ts.map +1 -0
- package/dist/core/context.js +65 -0
- package/dist/core/context.js.map +1 -0
- package/dist/core/cron.d.ts +111 -0
- package/dist/core/cron.d.ts.map +1 -0
- package/dist/core/cron.js +284 -0
- package/dist/core/cron.js.map +1 -0
- package/dist/core/exec-approvals.d.ts +50 -0
- package/dist/core/exec-approvals.d.ts.map +1 -0
- package/dist/core/exec-approvals.js +187 -0
- package/dist/core/exec-approvals.js.map +1 -0
- package/dist/core/heartbeat.d.ts +71 -0
- package/dist/core/heartbeat.d.ts.map +1 -0
- package/dist/core/heartbeat.js +214 -0
- package/dist/core/heartbeat.js.map +1 -0
- package/dist/core/message-queue.d.ts +60 -0
- package/dist/core/message-queue.d.ts.map +1 -0
- package/dist/core/message-queue.js +182 -0
- package/dist/core/message-queue.js.map +1 -0
- package/dist/core/network-policy.d.ts +39 -0
- package/dist/core/network-policy.d.ts.map +1 -0
- package/dist/core/network-policy.js +121 -0
- package/dist/core/network-policy.js.map +1 -0
- package/dist/core/progress.d.ts +48 -0
- package/dist/core/progress.d.ts.map +1 -0
- package/dist/core/progress.js +81 -0
- package/dist/core/progress.js.map +1 -0
- package/dist/core/prompt.d.ts +105 -0
- package/dist/core/prompt.d.ts.map +1 -0
- package/dist/core/prompt.js +411 -0
- package/dist/core/prompt.js.map +1 -0
- package/dist/core/pruning.d.ts +40 -0
- package/dist/core/pruning.d.ts.map +1 -0
- package/dist/core/pruning.js +165 -0
- package/dist/core/pruning.js.map +1 -0
- package/dist/core/rate-limiter.d.ts +64 -0
- package/dist/core/rate-limiter.d.ts.map +1 -0
- package/dist/core/rate-limiter.js +142 -0
- package/dist/core/rate-limiter.js.map +1 -0
- package/dist/core/reactions.d.ts +31 -0
- package/dist/core/reactions.d.ts.map +1 -0
- package/dist/core/reactions.js +67 -0
- package/dist/core/reactions.js.map +1 -0
- package/dist/core/retry-queue.d.ts +56 -0
- package/dist/core/retry-queue.d.ts.map +1 -0
- package/dist/core/retry-queue.js +106 -0
- package/dist/core/retry-queue.js.map +1 -0
- package/dist/core/sanitizer.d.ts +38 -0
- package/dist/core/sanitizer.d.ts.map +1 -0
- package/dist/core/sanitizer.js +181 -0
- package/dist/core/sanitizer.js.map +1 -0
- package/dist/core/secret-scanner.d.ts +39 -0
- package/dist/core/secret-scanner.d.ts.map +1 -0
- package/dist/core/secret-scanner.js +96 -0
- package/dist/core/secret-scanner.js.map +1 -0
- package/dist/core/secrets.d.ts +38 -0
- package/dist/core/secrets.d.ts.map +1 -0
- package/dist/core/secrets.js +137 -0
- package/dist/core/secrets.js.map +1 -0
- package/dist/core/security.d.ts +58 -0
- package/dist/core/security.d.ts.map +1 -0
- package/dist/core/security.js +120 -0
- package/dist/core/security.js.map +1 -0
- package/dist/core/self-awareness.d.ts +19 -0
- package/dist/core/self-awareness.d.ts.map +1 -0
- package/dist/core/self-awareness.js +124 -0
- package/dist/core/self-awareness.js.map +1 -0
- package/dist/core/session-init.d.ts +34 -0
- package/dist/core/session-init.d.ts.map +1 -0
- package/dist/core/session-init.js +68 -0
- package/dist/core/session-init.js.map +1 -0
- package/dist/core/streaming.d.ts +82 -0
- package/dist/core/streaming.d.ts.map +1 -0
- package/dist/core/streaming.js +264 -0
- package/dist/core/streaming.js.map +1 -0
- package/dist/core/symphony/orchestrator.d.ts +61 -0
- package/dist/core/symphony/orchestrator.d.ts.map +1 -0
- package/dist/core/symphony/orchestrator.js +476 -0
- package/dist/core/symphony/orchestrator.js.map +1 -0
- package/dist/core/symphony/status.d.ts +11 -0
- package/dist/core/symphony/status.d.ts.map +1 -0
- package/dist/core/symphony/status.js +133 -0
- package/dist/core/symphony/status.js.map +1 -0
- package/dist/core/symphony/types.d.ts +84 -0
- package/dist/core/symphony/types.d.ts.map +1 -0
- package/dist/core/symphony/types.js +5 -0
- package/dist/core/symphony/types.js.map +1 -0
- package/dist/core/symphony/workflow.d.ts +18 -0
- package/dist/core/symphony/workflow.d.ts.map +1 -0
- package/dist/core/symphony/workflow.js +149 -0
- package/dist/core/symphony/workflow.js.map +1 -0
- package/dist/core/symphony/workspace.d.ts +24 -0
- package/dist/core/symphony/workspace.d.ts.map +1 -0
- package/dist/core/symphony/workspace.js +94 -0
- package/dist/core/symphony/workspace.js.map +1 -0
- package/dist/core/thinking.d.ts +27 -0
- package/dist/core/thinking.d.ts.map +1 -0
- package/dist/core/thinking.js +83 -0
- package/dist/core/thinking.js.map +1 -0
- package/dist/core/thread-bindings.d.ts +47 -0
- package/dist/core/thread-bindings.d.ts.map +1 -0
- package/dist/core/thread-bindings.js +94 -0
- package/dist/core/thread-bindings.js.map +1 -0
- package/dist/core/timezone.d.ts +28 -0
- package/dist/core/timezone.d.ts.map +1 -0
- package/dist/core/timezone.js +72 -0
- package/dist/core/timezone.js.map +1 -0
- package/dist/core/tool-loop-detector.d.ts +41 -0
- package/dist/core/tool-loop-detector.d.ts.map +1 -0
- package/dist/core/tool-loop-detector.js +83 -0
- package/dist/core/tool-loop-detector.js.map +1 -0
- package/dist/core/tool-validator.d.ts +44 -0
- package/dist/core/tool-validator.d.ts.map +1 -0
- package/dist/core/tool-validator.js +175 -0
- package/dist/core/tool-validator.js.map +1 -0
- package/dist/core/typing.d.ts +25 -0
- package/dist/core/typing.d.ts.map +1 -0
- package/dist/core/typing.js +48 -0
- package/dist/core/typing.js.map +1 -0
- package/dist/core/usage-tracker.d.ts +66 -0
- package/dist/core/usage-tracker.d.ts.map +1 -0
- package/dist/core/usage-tracker.js +163 -0
- package/dist/core/usage-tracker.js.map +1 -0
- package/dist/daemon/commands.d.ts +16 -0
- package/dist/daemon/commands.d.ts.map +1 -0
- package/dist/daemon/commands.js +445 -0
- package/dist/daemon/commands.js.map +1 -0
- package/dist/daemon/pid.d.ts +30 -0
- package/dist/daemon/pid.d.ts.map +1 -0
- package/dist/daemon/pid.js +62 -0
- package/dist/daemon/pid.js.map +1 -0
- package/dist/doctor/checks/browser.d.ts +9 -0
- package/dist/doctor/checks/browser.d.ts.map +1 -0
- package/dist/doctor/checks/browser.js +54 -0
- package/dist/doctor/checks/browser.js.map +1 -0
- package/dist/doctor/checks/channels.d.ts +9 -0
- package/dist/doctor/checks/channels.d.ts.map +1 -0
- package/dist/doctor/checks/channels.js +90 -0
- package/dist/doctor/checks/channels.js.map +1 -0
- package/dist/doctor/checks/config.d.ts +10 -0
- package/dist/doctor/checks/config.d.ts.map +1 -0
- package/dist/doctor/checks/config.js +89 -0
- package/dist/doctor/checks/config.js.map +1 -0
- package/dist/doctor/checks/memory.d.ts +10 -0
- package/dist/doctor/checks/memory.d.ts.map +1 -0
- package/dist/doctor/checks/memory.js +82 -0
- package/dist/doctor/checks/memory.js.map +1 -0
- package/dist/doctor/checks/permissions.d.ts +9 -0
- package/dist/doctor/checks/permissions.d.ts.map +1 -0
- package/dist/doctor/checks/permissions.js +53 -0
- package/dist/doctor/checks/permissions.js.map +1 -0
- package/dist/doctor/checks/providers.d.ts +10 -0
- package/dist/doctor/checks/providers.d.ts.map +1 -0
- package/dist/doctor/checks/providers.js +93 -0
- package/dist/doctor/checks/providers.js.map +1 -0
- package/dist/doctor/checks/sessions.d.ts +10 -0
- package/dist/doctor/checks/sessions.d.ts.map +1 -0
- package/dist/doctor/checks/sessions.js +86 -0
- package/dist/doctor/checks/sessions.js.map +1 -0
- package/dist/doctor/doctor.d.ts +35 -0
- package/dist/doctor/doctor.d.ts.map +1 -0
- package/dist/doctor/doctor.js +51 -0
- package/dist/doctor/doctor.js.map +1 -0
- package/dist/doctor/repairs.d.ts +14 -0
- package/dist/doctor/repairs.d.ts.map +1 -0
- package/dist/doctor/repairs.js +34 -0
- package/dist/doctor/repairs.js.map +1 -0
- package/dist/gateway/compaction.d.ts +63 -0
- package/dist/gateway/compaction.d.ts.map +1 -0
- package/dist/gateway/compaction.js +235 -0
- package/dist/gateway/compaction.js.map +1 -0
- package/dist/gateway/gateway.d.ts +94 -0
- package/dist/gateway/gateway.d.ts.map +1 -0
- package/dist/gateway/gateway.js +466 -0
- package/dist/gateway/gateway.js.map +1 -0
- package/dist/gateway/lock.d.ts +24 -0
- package/dist/gateway/lock.d.ts.map +1 -0
- package/dist/gateway/lock.js +88 -0
- package/dist/gateway/lock.js.map +1 -0
- package/dist/gateway/protocol.d.ts +117 -0
- package/dist/gateway/protocol.d.ts.map +1 -0
- package/dist/gateway/protocol.js +5 -0
- package/dist/gateway/protocol.js.map +1 -0
- package/dist/gateway/session.d.ts +123 -0
- package/dist/gateway/session.d.ts.map +1 -0
- package/dist/gateway/session.js +573 -0
- package/dist/gateway/session.js.map +1 -0
- package/dist/hooks/hooks.d.ts +18 -0
- package/dist/hooks/hooks.d.ts.map +1 -0
- package/dist/hooks/hooks.js +45 -0
- package/dist/hooks/hooks.js.map +1 -0
- package/dist/hooks/types.d.ts +112 -0
- package/dist/hooks/types.d.ts.map +1 -0
- package/dist/hooks/types.js +23 -0
- package/dist/hooks/types.js.map +1 -0
- package/dist/index.d.ts +27 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2900 -0
- package/dist/index.js.map +1 -0
- package/dist/media/storage.d.ts +25 -0
- package/dist/media/storage.d.ts.map +1 -0
- package/dist/media/storage.js +97 -0
- package/dist/media/storage.js.map +1 -0
- package/dist/memory/embeddings.d.ts +46 -0
- package/dist/memory/embeddings.d.ts.map +1 -0
- package/dist/memory/embeddings.js +118 -0
- package/dist/memory/embeddings.js.map +1 -0
- package/dist/memory/hybrid.d.ts +35 -0
- package/dist/memory/hybrid.d.ts.map +1 -0
- package/dist/memory/hybrid.js +156 -0
- package/dist/memory/hybrid.js.map +1 -0
- package/dist/memory/markdown.d.ts +48 -0
- package/dist/memory/markdown.d.ts.map +1 -0
- package/dist/memory/markdown.js +228 -0
- package/dist/memory/markdown.js.map +1 -0
- package/dist/memory/store.d.ts +88 -0
- package/dist/memory/store.d.ts.map +1 -0
- package/dist/memory/store.js +21 -0
- package/dist/memory/store.js.map +1 -0
- package/dist/memory/vector.d.ts +24 -0
- package/dist/memory/vector.d.ts.map +1 -0
- package/dist/memory/vector.js +63 -0
- package/dist/memory/vector.js.map +1 -0
- package/dist/mods/mod.d.ts +100 -0
- package/dist/mods/mod.d.ts.map +1 -0
- package/dist/mods/mod.js +242 -0
- package/dist/mods/mod.js.map +1 -0
- package/dist/onboard/channels.d.ts +12 -0
- package/dist/onboard/channels.d.ts.map +1 -0
- package/dist/onboard/channels.js +283 -0
- package/dist/onboard/channels.js.map +1 -0
- package/dist/onboard/models.d.ts +13 -0
- package/dist/onboard/models.d.ts.map +1 -0
- package/dist/onboard/models.js +491 -0
- package/dist/onboard/models.js.map +1 -0
- package/dist/onboard/onboard.d.ts +12 -0
- package/dist/onboard/onboard.d.ts.map +1 -0
- package/dist/onboard/onboard.js +1137 -0
- package/dist/onboard/onboard.js.map +1 -0
- package/dist/providers/anthropic.d.ts +83 -0
- package/dist/providers/anthropic.d.ts.map +1 -0
- package/dist/providers/anthropic.js +583 -0
- package/dist/providers/anthropic.js.map +1 -0
- package/dist/providers/failover.d.ts +46 -0
- package/dist/providers/failover.d.ts.map +1 -0
- package/dist/providers/failover.js +149 -0
- package/dist/providers/failover.js.map +1 -0
- package/dist/providers/litellm.d.ts +38 -0
- package/dist/providers/litellm.d.ts.map +1 -0
- package/dist/providers/litellm.js +349 -0
- package/dist/providers/litellm.js.map +1 -0
- package/dist/providers/openai.d.ts +28 -0
- package/dist/providers/openai.d.ts.map +1 -0
- package/dist/providers/openai.js +321 -0
- package/dist/providers/openai.js.map +1 -0
- package/dist/providers/prompt-cache.d.ts +50 -0
- package/dist/providers/prompt-cache.d.ts.map +1 -0
- package/dist/providers/prompt-cache.js +96 -0
- package/dist/providers/prompt-cache.js.map +1 -0
- package/dist/providers/provider.d.ts +173 -0
- package/dist/providers/provider.d.ts.map +1 -0
- package/dist/providers/provider.js +22 -0
- package/dist/providers/provider.js.map +1 -0
- package/dist/sandbox/config.d.ts +42 -0
- package/dist/sandbox/config.d.ts.map +1 -0
- package/dist/sandbox/config.js +20 -0
- package/dist/sandbox/config.js.map +1 -0
- package/dist/sandbox/container.d.ts +71 -0
- package/dist/sandbox/container.d.ts.map +1 -0
- package/dist/sandbox/container.js +193 -0
- package/dist/sandbox/container.js.map +1 -0
- package/dist/sandbox/sandbox.d.ts +82 -0
- package/dist/sandbox/sandbox.d.ts.map +1 -0
- package/dist/sandbox/sandbox.js +176 -0
- package/dist/sandbox/sandbox.js.map +1 -0
- package/dist/skills/channel-loader.d.ts +18 -0
- package/dist/skills/channel-loader.d.ts.map +1 -0
- package/dist/skills/channel-loader.js +35 -0
- package/dist/skills/channel-loader.js.map +1 -0
- package/dist/skills/extension-loader.d.ts +15 -0
- package/dist/skills/extension-loader.d.ts.map +1 -0
- package/dist/skills/extension-loader.js +63 -0
- package/dist/skills/extension-loader.js.map +1 -0
- package/dist/skills/extension-registry.d.ts +32 -0
- package/dist/skills/extension-registry.d.ts.map +1 -0
- package/dist/skills/extension-registry.js +57 -0
- package/dist/skills/extension-registry.js.map +1 -0
- package/dist/skills/extensions.d.ts +91 -0
- package/dist/skills/extensions.d.ts.map +1 -0
- package/dist/skills/extensions.js +14 -0
- package/dist/skills/extensions.js.map +1 -0
- package/dist/skills/loader.d.ts +64 -0
- package/dist/skills/loader.d.ts.map +1 -0
- package/dist/skills/loader.js +382 -0
- package/dist/skills/loader.js.map +1 -0
- package/dist/skills/marketplace.d.ts +56 -0
- package/dist/skills/marketplace.d.ts.map +1 -0
- package/dist/skills/marketplace.js +183 -0
- package/dist/skills/marketplace.js.map +1 -0
- package/dist/skills/types.d.ts +94 -0
- package/dist/skills/types.d.ts.map +1 -0
- package/dist/skills/types.js +9 -0
- package/dist/skills/types.js.map +1 -0
- package/dist/tools/acp-sessions.d.ts +89 -0
- package/dist/tools/acp-sessions.d.ts.map +1 -0
- package/dist/tools/acp-sessions.js +391 -0
- package/dist/tools/acp-sessions.js.map +1 -0
- package/dist/tools/acp.d.ts +18 -0
- package/dist/tools/acp.d.ts.map +1 -0
- package/dist/tools/acp.js +102 -0
- package/dist/tools/acp.js.map +1 -0
- package/dist/tools/agent-tools.d.ts +24 -0
- package/dist/tools/agent-tools.d.ts.map +1 -0
- package/dist/tools/agent-tools.js +611 -0
- package/dist/tools/agent-tools.js.map +1 -0
- package/dist/tools/browser.d.ts +26 -0
- package/dist/tools/browser.d.ts.map +1 -0
- package/dist/tools/browser.js +242 -0
- package/dist/tools/browser.js.map +1 -0
- package/dist/tools/comms.d.ts +8 -0
- package/dist/tools/comms.d.ts.map +1 -0
- package/dist/tools/comms.js +39 -0
- package/dist/tools/comms.js.map +1 -0
- package/dist/tools/cron-tools.d.ts +9 -0
- package/dist/tools/cron-tools.d.ts.map +1 -0
- package/dist/tools/cron-tools.js +117 -0
- package/dist/tools/cron-tools.js.map +1 -0
- package/dist/tools/exec-safety.d.ts +71 -0
- package/dist/tools/exec-safety.d.ts.map +1 -0
- package/dist/tools/exec-safety.js +141 -0
- package/dist/tools/exec-safety.js.map +1 -0
- package/dist/tools/exec.d.ts +24 -0
- package/dist/tools/exec.d.ts.map +1 -0
- package/dist/tools/exec.js +191 -0
- package/dist/tools/exec.js.map +1 -0
- package/dist/tools/fs.d.ts +15 -0
- package/dist/tools/fs.d.ts.map +1 -0
- package/dist/tools/fs.js +249 -0
- package/dist/tools/fs.js.map +1 -0
- package/dist/tools/git.d.ts +9 -0
- package/dist/tools/git.d.ts.map +1 -0
- package/dist/tools/git.js +56 -0
- package/dist/tools/git.js.map +1 -0
- package/dist/tools/image.d.ts +15 -0
- package/dist/tools/image.d.ts.map +1 -0
- package/dist/tools/image.js +106 -0
- package/dist/tools/image.js.map +1 -0
- package/dist/tools/introspect.d.ts +22 -0
- package/dist/tools/introspect.d.ts.map +1 -0
- package/dist/tools/introspect.js +223 -0
- package/dist/tools/introspect.js.map +1 -0
- package/dist/tools/memory.d.ts +11 -0
- package/dist/tools/memory.d.ts.map +1 -0
- package/dist/tools/memory.js +101 -0
- package/dist/tools/memory.js.map +1 -0
- package/dist/tools/message.d.ts +24 -0
- package/dist/tools/message.d.ts.map +1 -0
- package/dist/tools/message.js +205 -0
- package/dist/tools/message.js.map +1 -0
- package/dist/tools/model.d.ts +14 -0
- package/dist/tools/model.d.ts.map +1 -0
- package/dist/tools/model.js +62 -0
- package/dist/tools/model.js.map +1 -0
- package/dist/tools/policy.d.ts +101 -0
- package/dist/tools/policy.d.ts.map +1 -0
- package/dist/tools/policy.js +168 -0
- package/dist/tools/policy.js.map +1 -0
- package/dist/tools/registry.d.ts +52 -0
- package/dist/tools/registry.d.ts.map +1 -0
- package/dist/tools/registry.js +154 -0
- package/dist/tools/registry.js.map +1 -0
- package/dist/tools/search.d.ts +10 -0
- package/dist/tools/search.d.ts.map +1 -0
- package/dist/tools/search.js +78 -0
- package/dist/tools/search.js.map +1 -0
- package/dist/tools/session.d.ts +13 -0
- package/dist/tools/session.d.ts.map +1 -0
- package/dist/tools/session.js +142 -0
- package/dist/tools/session.js.map +1 -0
- package/dist/tools/spawn.d.ts +10 -0
- package/dist/tools/spawn.d.ts.map +1 -0
- package/dist/tools/spawn.js +72 -0
- package/dist/tools/spawn.js.map +1 -0
- package/dist/tools/symphony.d.ts +12 -0
- package/dist/tools/symphony.d.ts.map +1 -0
- package/dist/tools/symphony.js +142 -0
- package/dist/tools/symphony.js.map +1 -0
- package/dist/tools/system-tools.d.ts +11 -0
- package/dist/tools/system-tools.d.ts.map +1 -0
- package/dist/tools/system-tools.js +39 -0
- package/dist/tools/system-tools.js.map +1 -0
- package/dist/tools/tool.d.ts +119 -0
- package/dist/tools/tool.d.ts.map +1 -0
- package/dist/tools/tool.js +29 -0
- package/dist/tools/tool.js.map +1 -0
- package/dist/tools/web.d.ts +10 -0
- package/dist/tools/web.d.ts.map +1 -0
- package/dist/tools/web.js +105 -0
- package/dist/tools/web.js.map +1 -0
- package/dist/tui/App.d.ts +43 -0
- package/dist/tui/App.d.ts.map +1 -0
- package/dist/tui/App.js +265 -0
- package/dist/tui/App.js.map +1 -0
- package/dist/tui/bridge.d.ts +40 -0
- package/dist/tui/bridge.d.ts.map +1 -0
- package/dist/tui/bridge.js +29 -0
- package/dist/tui/bridge.js.map +1 -0
- package/dist/tui/components/Header.d.ts +14 -0
- package/dist/tui/components/Header.d.ts.map +1 -0
- package/dist/tui/components/Header.js +7 -0
- package/dist/tui/components/Header.js.map +1 -0
- package/dist/tui/components/InputBar.d.ts +10 -0
- package/dist/tui/components/InputBar.d.ts.map +1 -0
- package/dist/tui/components/InputBar.js +121 -0
- package/dist/tui/components/InputBar.js.map +1 -0
- package/dist/tui/components/MessageList.d.ts +18 -0
- package/dist/tui/components/MessageList.d.ts.map +1 -0
- package/dist/tui/components/MessageList.js +34 -0
- package/dist/tui/components/MessageList.js.map +1 -0
- package/dist/tui/components/Spinner.d.ts +9 -0
- package/dist/tui/components/Spinner.d.ts.map +1 -0
- package/dist/tui/components/Spinner.js +18 -0
- package/dist/tui/components/Spinner.js.map +1 -0
- package/dist/tui/components/StatusBar.d.ts +16 -0
- package/dist/tui/components/StatusBar.d.ts.map +1 -0
- package/dist/tui/components/StatusBar.js +15 -0
- package/dist/tui/components/StatusBar.js.map +1 -0
- package/dist/tui/components/ToolCallBox.d.ts +12 -0
- package/dist/tui/components/ToolCallBox.d.ts.map +1 -0
- package/dist/tui/components/ToolCallBox.js +12 -0
- package/dist/tui/components/ToolCallBox.js.map +1 -0
- package/dist/tui/theme.d.ts +58 -0
- package/dist/tui/theme.d.ts.map +1 -0
- package/dist/tui/theme.js +80 -0
- package/dist/tui/theme.js.map +1 -0
- package/dist/utils/logger.d.ts +16 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +70 -0
- package/dist/utils/logger.js.map +1 -0
- package/docs/DEVELOPMENT.md +74 -0
- package/docs/INSTALL.md +161 -0
- package/docs/USAGE.md +94 -0
- package/docs/architecture.md +128 -0
- package/docs/channels.md +140 -0
- package/docs/configuration.md +209 -0
- package/docs/io-system.md +430 -0
- package/docs/providers.md +99 -0
- package/docs/skill-channels.md +113 -0
- package/docs/skills.md +246 -0
- package/package.json +89 -0
- package/skills/acp-router/SKILL.md +41 -0
- package/skills/acp-router/tools/acp-router.mjs +239 -0
- package/skills/find-skills/SKILL.md +133 -0
- package/skills/security-audit/SKILL.md +181 -0
- package/skills/security-audit/audit.sh +67 -0
- package/skills/skill-creator/SKILL.md +479 -0
- package/skills/skill-security-audit/.clawhub/origin.json +7 -0
- package/skills/skill-security-audit/SKILL.md +196 -0
- package/skills/skill-security-audit/_meta.json +6 -0
- package/skills/skill-security-audit/references/prompt-injection-patterns.md +276 -0
- package/skills/skill-security-audit/references/vulnerability-patterns.md +348 -0
- package/skills/symphony/README.md +53 -0
- package/skills/symphony/SKILL.md +75 -0
- package/skills/symphony/tools/symphony-orchestrator.ts +8 -0
- package/tako.example.json +33 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Thread binding manager — maps Discord threads to sub-agent sessions.
|
|
3
|
+
*
|
|
4
|
+
* When a sub-agent spawns with `thread: true`, a Discord thread is created
|
|
5
|
+
* and bound to that agent's session. Messages in the thread route to the
|
|
6
|
+
* sub-agent instead of the main agent. After 24h idle the thread is unbound
|
|
7
|
+
* and auto-archived.
|
|
8
|
+
*
|
|
9
|
+
* Session key format: agent:<agentId>:<channelId>:thread:<threadId>
|
|
10
|
+
*/
|
|
11
|
+
import { readFile, writeFile, mkdir } from 'node:fs/promises';
|
|
12
|
+
import { dirname } from 'node:path';
|
|
13
|
+
// ─── Constants ──────────────────────────────────────────────────────
|
|
14
|
+
export const THREAD_IDLE_TIMEOUT_MS = 24 * 60 * 60 * 1000; // 24 hours
|
|
15
|
+
// ─── Manager ────────────────────────────────────────────────────────
|
|
16
|
+
export class ThreadBindingManager {
|
|
17
|
+
bindings = new Map();
|
|
18
|
+
persistPath;
|
|
19
|
+
constructor(persistPath) {
|
|
20
|
+
this.persistPath = persistPath;
|
|
21
|
+
}
|
|
22
|
+
/** Bind a thread to a sub-agent session. */
|
|
23
|
+
bind(threadId, binding) {
|
|
24
|
+
const now = Date.now();
|
|
25
|
+
this.bindings.set(threadId, {
|
|
26
|
+
...binding,
|
|
27
|
+
createdAt: now,
|
|
28
|
+
lastActiveAt: now,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
/** Unbind a thread. */
|
|
32
|
+
unbind(threadId) {
|
|
33
|
+
this.bindings.delete(threadId);
|
|
34
|
+
}
|
|
35
|
+
/** Get the binding for a thread, if any. */
|
|
36
|
+
getBinding(threadId) {
|
|
37
|
+
return this.bindings.get(threadId);
|
|
38
|
+
}
|
|
39
|
+
/** Update lastActiveAt for a thread. */
|
|
40
|
+
touch(threadId) {
|
|
41
|
+
const binding = this.bindings.get(threadId);
|
|
42
|
+
if (binding) {
|
|
43
|
+
binding.lastActiveAt = Date.now();
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
/** Sweep expired bindings (idle > 24h). Returns the expired bindings. */
|
|
47
|
+
sweepExpired() {
|
|
48
|
+
const now = Date.now();
|
|
49
|
+
const expired = [];
|
|
50
|
+
for (const [threadId, binding] of this.bindings) {
|
|
51
|
+
if (now - binding.lastActiveAt > THREAD_IDLE_TIMEOUT_MS) {
|
|
52
|
+
expired.push(binding);
|
|
53
|
+
this.bindings.delete(threadId);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return expired;
|
|
57
|
+
}
|
|
58
|
+
/** Number of active bindings. */
|
|
59
|
+
get size() {
|
|
60
|
+
return this.bindings.size;
|
|
61
|
+
}
|
|
62
|
+
/** Save bindings to disk. */
|
|
63
|
+
async save() {
|
|
64
|
+
const data = {};
|
|
65
|
+
for (const [threadId, binding] of this.bindings) {
|
|
66
|
+
data[threadId] = binding;
|
|
67
|
+
}
|
|
68
|
+
try {
|
|
69
|
+
await mkdir(dirname(this.persistPath), { recursive: true });
|
|
70
|
+
await writeFile(this.persistPath, JSON.stringify({ bindings: data }, null, 2), 'utf-8');
|
|
71
|
+
}
|
|
72
|
+
catch (err) {
|
|
73
|
+
console.error('[tako] Failed to save thread bindings:', err instanceof Error ? err.message : err);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
/** Load bindings from disk. */
|
|
77
|
+
async load() {
|
|
78
|
+
try {
|
|
79
|
+
const raw = await readFile(this.persistPath, 'utf-8');
|
|
80
|
+
const parsed = JSON.parse(raw);
|
|
81
|
+
this.bindings.clear();
|
|
82
|
+
for (const [threadId, binding] of Object.entries(parsed.bindings)) {
|
|
83
|
+
this.bindings.set(threadId, binding);
|
|
84
|
+
}
|
|
85
|
+
if (this.bindings.size > 0) {
|
|
86
|
+
console.log(`[tako] Loaded ${this.bindings.size} thread binding(s)`);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
catch {
|
|
90
|
+
// File doesn't exist yet — that's fine
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=thread-bindings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"thread-bindings.js","sourceRoot":"","sources":["../../src/core/thread-bindings.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Timezone — provide timezone context to the agent.
|
|
3
|
+
*
|
|
4
|
+
* Auto-detects from the system or uses a configured IANA timezone.
|
|
5
|
+
* Generates a human-readable context string for system prompt injection.
|
|
6
|
+
*/
|
|
7
|
+
export interface TimezoneConfig {
|
|
8
|
+
/** User's timezone (IANA format, e.g. 'Asia/Riyadh'). */
|
|
9
|
+
timezone?: string;
|
|
10
|
+
/** Auto-detect from system (default: true). */
|
|
11
|
+
autoDetect: boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare class TimezoneManager {
|
|
14
|
+
private tz;
|
|
15
|
+
constructor(config?: Partial<TimezoneConfig>);
|
|
16
|
+
/** Get current timezone. */
|
|
17
|
+
getTimezone(): string;
|
|
18
|
+
/** Get current time formatted for the agent. */
|
|
19
|
+
getCurrentTime(): string;
|
|
20
|
+
/** Format a date in the user's timezone. */
|
|
21
|
+
format(date: Date, fmt?: string): string;
|
|
22
|
+
/**
|
|
23
|
+
* Get timezone context string for system prompt injection.
|
|
24
|
+
* Returns: "Current date/time: Saturday, March 7th, 2026 — 2:09 PM (Asia/Riyadh)"
|
|
25
|
+
*/
|
|
26
|
+
getContextString(): string;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=timezone.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timezone.d.ts","sourceRoot":"","sources":["../../src/core/timezone.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,MAAM,WAAW,cAAc;IAC7B,yDAAyD;IACzD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,+CAA+C;IAC/C,UAAU,EAAE,OAAO,CAAC;CACrB;AAID,qBAAa,eAAe;IAC1B,OAAO,CAAC,EAAE,CAAS;gBAEP,MAAM,GAAE,OAAO,CAAC,cAAc,CAAM;IAUhD,4BAA4B;IAC5B,WAAW,IAAI,MAAM;IAIrB,gDAAgD;IAChD,cAAc,IAAI,MAAM;IAIxB,4CAA4C;IAC5C,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM;IAqCxC;;;OAGG;IACH,gBAAgB,IAAI,MAAM;CAI3B"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Timezone — provide timezone context to the agent.
|
|
3
|
+
*
|
|
4
|
+
* Auto-detects from the system or uses a configured IANA timezone.
|
|
5
|
+
* Generates a human-readable context string for system prompt injection.
|
|
6
|
+
*/
|
|
7
|
+
// ─── Implementation ─────────────────────────────────────────────────
|
|
8
|
+
export class TimezoneManager {
|
|
9
|
+
tz;
|
|
10
|
+
constructor(config = {}) {
|
|
11
|
+
if (config.timezone) {
|
|
12
|
+
this.tz = config.timezone;
|
|
13
|
+
}
|
|
14
|
+
else if (config.autoDetect !== false) {
|
|
15
|
+
this.tz = Intl.DateTimeFormat().resolvedOptions().timeZone;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
this.tz = 'UTC';
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
/** Get current timezone. */
|
|
22
|
+
getTimezone() {
|
|
23
|
+
return this.tz;
|
|
24
|
+
}
|
|
25
|
+
/** Get current time formatted for the agent. */
|
|
26
|
+
getCurrentTime() {
|
|
27
|
+
return this.format(new Date());
|
|
28
|
+
}
|
|
29
|
+
/** Format a date in the user's timezone. */
|
|
30
|
+
format(date, fmt) {
|
|
31
|
+
if (fmt === 'iso') {
|
|
32
|
+
return date.toLocaleString('sv-SE', { timeZone: this.tz }).replace(' ', 'T');
|
|
33
|
+
}
|
|
34
|
+
if (fmt === 'time') {
|
|
35
|
+
return date.toLocaleTimeString('en-US', {
|
|
36
|
+
timeZone: this.tz,
|
|
37
|
+
hour: '2-digit',
|
|
38
|
+
minute: '2-digit',
|
|
39
|
+
hour12: true,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
if (fmt === 'date') {
|
|
43
|
+
return date.toLocaleDateString('en-US', {
|
|
44
|
+
timeZone: this.tz,
|
|
45
|
+
weekday: 'long',
|
|
46
|
+
year: 'numeric',
|
|
47
|
+
month: 'long',
|
|
48
|
+
day: 'numeric',
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
// Default: full human-readable format
|
|
52
|
+
return date.toLocaleString('en-US', {
|
|
53
|
+
timeZone: this.tz,
|
|
54
|
+
weekday: 'long',
|
|
55
|
+
year: 'numeric',
|
|
56
|
+
month: 'long',
|
|
57
|
+
day: 'numeric',
|
|
58
|
+
hour: 'numeric',
|
|
59
|
+
minute: '2-digit',
|
|
60
|
+
hour12: true,
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Get timezone context string for system prompt injection.
|
|
65
|
+
* Returns: "Current date/time: Saturday, March 7th, 2026 — 2:09 PM (Asia/Riyadh)"
|
|
66
|
+
*/
|
|
67
|
+
getContextString() {
|
|
68
|
+
const formatted = this.format(new Date());
|
|
69
|
+
return `Current date/time: ${formatted} (${this.tz})`;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=timezone.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timezone.js","sourceRoot":"","sources":["../../src/core/timezone.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAWH,uEAAuE;AAEvE,MAAM,OAAO,eAAe;IAClB,EAAE,CAAS;IAEnB,YAAY,SAAkC,EAAE;QAC9C,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YACpB,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAC;QAC5B,CAAC;aAAM,IAAI,MAAM,CAAC,UAAU,KAAK,KAAK,EAAE,CAAC;YACvC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;QAC7D,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,EAAE,GAAG,KAAK,CAAC;QAClB,CAAC;IACH,CAAC;IAED,4BAA4B;IAC5B,WAAW;QACT,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;IAED,gDAAgD;IAChD,cAAc;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;IACjC,CAAC;IAED,4CAA4C;IAC5C,MAAM,CAAC,IAAU,EAAE,GAAY;QAC7B,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/E,CAAC;QAED,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE;gBACtC,QAAQ,EAAE,IAAI,CAAC,EAAE;gBACjB,IAAI,EAAE,SAAS;gBACf,MAAM,EAAE,SAAS;gBACjB,MAAM,EAAE,IAAI;aACb,CAAC,CAAC;QACL,CAAC;QAED,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE;gBACtC,QAAQ,EAAE,IAAI,CAAC,EAAE;gBACjB,OAAO,EAAE,MAAM;gBACf,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,MAAM;gBACb,GAAG,EAAE,SAAS;aACf,CAAC,CAAC;QACL,CAAC;QAED,sCAAsC;QACtC,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE;YAClC,QAAQ,EAAE,IAAI,CAAC,EAAE;YACjB,OAAO,EAAE,MAAM;YACf,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,MAAM;YACb,GAAG,EAAE,SAAS;YACd,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,SAAS;YACjB,MAAM,EAAE,IAAI;SACb,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACH,gBAAgB;QACd,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAC1C,OAAO,sBAAsB,SAAS,KAAK,IAAI,CAAC,EAAE,GAAG,CAAC;IACxD,CAAC;CACF"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tool loop detector — detect when agent is stuck calling the same tool repeatedly.
|
|
3
|
+
*
|
|
4
|
+
* Monitors tool call patterns within a session turn. If the same tool is called
|
|
5
|
+
* with similar arguments more than N times, it breaks the loop by injecting
|
|
6
|
+
* a warning into the context.
|
|
7
|
+
*/
|
|
8
|
+
export interface LoopDetectorConfig {
|
|
9
|
+
/** Enable loop detection (default: true) */
|
|
10
|
+
enabled: boolean;
|
|
11
|
+
/** Max identical tool calls before breaking (default: 3) */
|
|
12
|
+
maxRepetitions: number;
|
|
13
|
+
/** Max similar tool calls (same tool, different args) before warning (default: 5) */
|
|
14
|
+
maxSimilarCalls: number;
|
|
15
|
+
/** Window of recent tool calls to consider (default: 10) */
|
|
16
|
+
windowSize: number;
|
|
17
|
+
}
|
|
18
|
+
export declare class ToolLoopDetector {
|
|
19
|
+
private config;
|
|
20
|
+
private history;
|
|
21
|
+
constructor(config?: Partial<LoopDetectorConfig>);
|
|
22
|
+
/**
|
|
23
|
+
* Record a tool call and check for loops.
|
|
24
|
+
* Returns a warning message if a loop is detected, null otherwise.
|
|
25
|
+
*/
|
|
26
|
+
recordAndCheck(sessionId: string, toolName: string, args: Record<string, unknown>): string | null;
|
|
27
|
+
/** Clear history for a session (on new turn). */
|
|
28
|
+
clearSession(sessionId: string): void;
|
|
29
|
+
/** Clear all history. */
|
|
30
|
+
clear(): void;
|
|
31
|
+
/** Get loop stats for a session. */
|
|
32
|
+
stats(sessionId: string): {
|
|
33
|
+
totalCalls: number;
|
|
34
|
+
uniqueTools: number;
|
|
35
|
+
repetitions: Map<string, number>;
|
|
36
|
+
};
|
|
37
|
+
private hashArgs;
|
|
38
|
+
private checkIdenticalLoop;
|
|
39
|
+
private checkSimilarLoop;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=tool-loop-detector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-loop-detector.d.ts","sourceRoot":"","sources":["../../src/core/tool-loop-detector.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAIH,MAAM,WAAW,kBAAkB;IACjC,4CAA4C;IAC5C,OAAO,EAAE,OAAO,CAAC;IACjB,4DAA4D;IAC5D,cAAc,EAAE,MAAM,CAAC;IACvB,qFAAqF;IACrF,eAAe,EAAE,MAAM,CAAC;IACxB,4DAA4D;IAC5D,UAAU,EAAE,MAAM,CAAC;CACpB;AAeD,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,MAAM,CAAqB;IACnC,OAAO,CAAC,OAAO,CAA4C;gBAE/C,MAAM,CAAC,EAAE,OAAO,CAAC,kBAAkB,CAAC;IAIhD;;;OAGG;IACH,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,GAAG,IAAI;IA+BjG,iDAAiD;IACjD,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAIrC,yBAAyB;IACzB,KAAK,IAAI,IAAI;IAIb,oCAAoC;IACpC,KAAK,CAAC,SAAS,EAAE,MAAM,GAAG;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;KAAE;IAavG,OAAO,CAAC,QAAQ;IAKhB,OAAO,CAAC,kBAAkB;IAK1B,OAAO,CAAC,gBAAgB;CAIzB"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tool loop detector — detect when agent is stuck calling the same tool repeatedly.
|
|
3
|
+
*
|
|
4
|
+
* Monitors tool call patterns within a session turn. If the same tool is called
|
|
5
|
+
* with similar arguments more than N times, it breaks the loop by injecting
|
|
6
|
+
* a warning into the context.
|
|
7
|
+
*/
|
|
8
|
+
import { createHash } from 'node:crypto';
|
|
9
|
+
const DEFAULT_CONFIG = {
|
|
10
|
+
enabled: true,
|
|
11
|
+
maxRepetitions: 3,
|
|
12
|
+
maxSimilarCalls: 5,
|
|
13
|
+
windowSize: 10,
|
|
14
|
+
};
|
|
15
|
+
export class ToolLoopDetector {
|
|
16
|
+
config;
|
|
17
|
+
history = new Map();
|
|
18
|
+
constructor(config) {
|
|
19
|
+
this.config = { ...DEFAULT_CONFIG, ...config };
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Record a tool call and check for loops.
|
|
23
|
+
* Returns a warning message if a loop is detected, null otherwise.
|
|
24
|
+
*/
|
|
25
|
+
recordAndCheck(sessionId, toolName, args) {
|
|
26
|
+
if (!this.config.enabled)
|
|
27
|
+
return null;
|
|
28
|
+
const records = this.history.get(sessionId) ?? [];
|
|
29
|
+
const argsHash = this.hashArgs(args);
|
|
30
|
+
// Add new record
|
|
31
|
+
records.push({ toolName, argsHash, timestamp: Date.now() });
|
|
32
|
+
// Trim to window size
|
|
33
|
+
if (records.length > this.config.windowSize) {
|
|
34
|
+
records.splice(0, records.length - this.config.windowSize);
|
|
35
|
+
}
|
|
36
|
+
this.history.set(sessionId, records);
|
|
37
|
+
// Check for identical loop (same tool + same args)
|
|
38
|
+
if (this.checkIdenticalLoop(records, toolName, argsHash)) {
|
|
39
|
+
const count = records.filter((r) => r.toolName === toolName && r.argsHash === argsHash).length;
|
|
40
|
+
return `⚠️ Tool loop detected: you've called \`${toolName}\` ${count} times with identical arguments. This suggests you're stuck. Try a different approach or ask the user for help.`;
|
|
41
|
+
}
|
|
42
|
+
// Check for similar loop (same tool, different args)
|
|
43
|
+
if (this.checkSimilarLoop(records, toolName)) {
|
|
44
|
+
const count = records.filter((r) => r.toolName === toolName).length;
|
|
45
|
+
return `⚠️ Tool loop detected: you've called \`${toolName}\` ${count} times in the recent window. Consider whether you're making progress or if you should try a different approach.`;
|
|
46
|
+
}
|
|
47
|
+
return null;
|
|
48
|
+
}
|
|
49
|
+
/** Clear history for a session (on new turn). */
|
|
50
|
+
clearSession(sessionId) {
|
|
51
|
+
this.history.delete(sessionId);
|
|
52
|
+
}
|
|
53
|
+
/** Clear all history. */
|
|
54
|
+
clear() {
|
|
55
|
+
this.history.clear();
|
|
56
|
+
}
|
|
57
|
+
/** Get loop stats for a session. */
|
|
58
|
+
stats(sessionId) {
|
|
59
|
+
const records = this.history.get(sessionId) ?? [];
|
|
60
|
+
const repetitions = new Map();
|
|
61
|
+
for (const r of records) {
|
|
62
|
+
repetitions.set(r.toolName, (repetitions.get(r.toolName) ?? 0) + 1);
|
|
63
|
+
}
|
|
64
|
+
return {
|
|
65
|
+
totalCalls: records.length,
|
|
66
|
+
uniqueTools: repetitions.size,
|
|
67
|
+
repetitions,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
hashArgs(args) {
|
|
71
|
+
const sorted = JSON.stringify(args, Object.keys(args).sort());
|
|
72
|
+
return createHash('sha256').update(sorted).digest('hex').slice(0, 16);
|
|
73
|
+
}
|
|
74
|
+
checkIdenticalLoop(records, toolName, argsHash) {
|
|
75
|
+
const count = records.filter((r) => r.toolName === toolName && r.argsHash === argsHash).length;
|
|
76
|
+
return count >= this.config.maxRepetitions;
|
|
77
|
+
}
|
|
78
|
+
checkSimilarLoop(records, toolName) {
|
|
79
|
+
const count = records.filter((r) => r.toolName === toolName).length;
|
|
80
|
+
return count >= this.config.maxSimilarCalls;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=tool-loop-detector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-loop-detector.js","sourceRoot":"","sources":["../../src/core/tool-loop-detector.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tool Argument Validator — validates tool arguments before execution.
|
|
3
|
+
*
|
|
4
|
+
* Checks:
|
|
5
|
+
* - File paths: block path traversal (../ outside workspace)
|
|
6
|
+
* - Shell commands: warn on dangerous patterns
|
|
7
|
+
* - URLs: block private/internal IPs
|
|
8
|
+
* - Regex: timeout protection for ReDoS
|
|
9
|
+
*/
|
|
10
|
+
export type ValidationLevel = 'strict' | 'warn' | 'off';
|
|
11
|
+
export interface ToolValidatorConfig {
|
|
12
|
+
/** Validation level: 'strict' blocks, 'warn' logs + allows, 'off' disables. */
|
|
13
|
+
level: ValidationLevel;
|
|
14
|
+
}
|
|
15
|
+
export interface ValidationResult {
|
|
16
|
+
/** Whether the tool call is allowed. */
|
|
17
|
+
allowed: boolean;
|
|
18
|
+
/** Validation warnings (even if allowed). */
|
|
19
|
+
warnings: string[];
|
|
20
|
+
/** Reason for blocking (if allowed=false). */
|
|
21
|
+
blockReason?: string;
|
|
22
|
+
}
|
|
23
|
+
export declare class ToolValidator {
|
|
24
|
+
private config;
|
|
25
|
+
private workspaceRoot;
|
|
26
|
+
constructor(config: ToolValidatorConfig, workspaceRoot: string);
|
|
27
|
+
/**
|
|
28
|
+
* Validate a file path argument.
|
|
29
|
+
*/
|
|
30
|
+
validatePath(path: string, workDir: string, allowWrite: boolean): ValidationResult;
|
|
31
|
+
/**
|
|
32
|
+
* Validate a shell command argument.
|
|
33
|
+
*/
|
|
34
|
+
validateCommand(command: string): ValidationResult;
|
|
35
|
+
/**
|
|
36
|
+
* Validate a URL argument (block private/internal IPs).
|
|
37
|
+
*/
|
|
38
|
+
validateUrl(urlStr: string): ValidationResult;
|
|
39
|
+
/**
|
|
40
|
+
* Validate a regex pattern for ReDoS potential.
|
|
41
|
+
*/
|
|
42
|
+
validateRegex(pattern: string, timeoutMs?: number): ValidationResult;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=tool-validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-validator.d.ts","sourceRoot":"","sources":["../../src/core/tool-validator.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAMH,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,MAAM,GAAG,KAAK,CAAC;AAExD,MAAM,WAAW,mBAAmB;IAClC,+EAA+E;IAC/E,KAAK,EAAE,eAAe,CAAC;CACxB;AAED,MAAM,WAAW,gBAAgB;IAC/B,wCAAwC;IACxC,OAAO,EAAE,OAAO,CAAC;IACjB,6CAA6C;IAC7C,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,8CAA8C;IAC9C,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAsCD,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAAsB;IACpC,OAAO,CAAC,aAAa,CAAS;gBAElB,MAAM,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM;IAK9D;;OAEG;IACH,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,GAAG,gBAAgB;IAqClF;;OAEG;IACH,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,gBAAgB;IAoBlD;;OAEG;IACH,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,gBAAgB;IA8C7C;;OAEG;IACH,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,SAAM,GAAG,gBAAgB;CA0BlE"}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tool Argument Validator — validates tool arguments before execution.
|
|
3
|
+
*
|
|
4
|
+
* Checks:
|
|
5
|
+
* - File paths: block path traversal (../ outside workspace)
|
|
6
|
+
* - Shell commands: warn on dangerous patterns
|
|
7
|
+
* - URLs: block private/internal IPs
|
|
8
|
+
* - Regex: timeout protection for ReDoS
|
|
9
|
+
*/
|
|
10
|
+
import { resolve, relative, isAbsolute } from 'node:path';
|
|
11
|
+
// ─── Dangerous command patterns ─────────────────────────────────────
|
|
12
|
+
const DANGEROUS_COMMANDS = [
|
|
13
|
+
{ pattern: /rm\s+(-[a-zA-Z]*f[a-zA-Z]*\s+)?\/(?!tmp)/i, description: 'Destructive rm on root paths' },
|
|
14
|
+
{ pattern: /rm\s+-[a-zA-Z]*r[a-zA-Z]*f[a-zA-Z]*\s+\//i, description: 'Recursive forced delete on root' },
|
|
15
|
+
{ pattern: /mkfs\./i, description: 'Filesystem format command' },
|
|
16
|
+
{ pattern: /dd\s+.*of=\/dev\//i, description: 'Direct disk write' },
|
|
17
|
+
{ pattern: /chmod\s+777\s/i, description: 'Overly permissive chmod' },
|
|
18
|
+
{ pattern: /curl\s+[^|]*\|\s*(sh|bash|zsh)/i, description: 'Pipe remote script to shell' },
|
|
19
|
+
{ pattern: /wget\s+[^|]*\|\s*(sh|bash|zsh)/i, description: 'Pipe remote download to shell' },
|
|
20
|
+
{ pattern: />\s*\/etc\//i, description: 'Writing to /etc/' },
|
|
21
|
+
{ pattern: />\s*\/proc\//i, description: 'Writing to /proc/' },
|
|
22
|
+
{ pattern: /:\(\)\s*\{\s*:\|:&\s*\}\s*;/i, description: 'Fork bomb' },
|
|
23
|
+
{ pattern: /shutdown|reboot|poweroff|init\s+[06]/i, description: 'System shutdown/reboot' },
|
|
24
|
+
{ pattern: /iptables\s+-F/i, description: 'Flushing firewall rules' },
|
|
25
|
+
];
|
|
26
|
+
// ─── Private IP patterns ────────────────────────────────────────────
|
|
27
|
+
const PRIVATE_IP_PATTERNS = [
|
|
28
|
+
/^127\.\d+\.\d+\.\d+/,
|
|
29
|
+
/^10\.\d+\.\d+\.\d+/,
|
|
30
|
+
/^172\.(1[6-9]|2\d|3[01])\.\d+\.\d+/,
|
|
31
|
+
/^192\.168\.\d+\.\d+/,
|
|
32
|
+
/^169\.254\.\d+\.\d+/,
|
|
33
|
+
/^0\.0\.0\.0/,
|
|
34
|
+
/^::1$/,
|
|
35
|
+
/^fc00:/i,
|
|
36
|
+
/^fd[0-9a-f]{2}:/i,
|
|
37
|
+
/^fe80:/i,
|
|
38
|
+
];
|
|
39
|
+
const PRIVATE_HOSTNAMES = ['localhost', 'host.docker.internal', '*.local', 'metadata.google.internal'];
|
|
40
|
+
// ─── Validator ──────────────────────────────────────────────────────
|
|
41
|
+
export class ToolValidator {
|
|
42
|
+
config;
|
|
43
|
+
workspaceRoot;
|
|
44
|
+
constructor(config, workspaceRoot) {
|
|
45
|
+
this.config = config;
|
|
46
|
+
this.workspaceRoot = workspaceRoot;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Validate a file path argument.
|
|
50
|
+
*/
|
|
51
|
+
validatePath(path, workDir, allowWrite) {
|
|
52
|
+
if (this.config.level === 'off') {
|
|
53
|
+
return { allowed: true, warnings: [] };
|
|
54
|
+
}
|
|
55
|
+
const warnings = [];
|
|
56
|
+
const fullPath = isAbsolute(path) ? path : resolve(workDir, path);
|
|
57
|
+
const rel = relative(this.workspaceRoot, fullPath);
|
|
58
|
+
// Check for path traversal outside workspace
|
|
59
|
+
if (rel.startsWith('..') || isAbsolute(rel)) {
|
|
60
|
+
if (allowWrite) {
|
|
61
|
+
const msg = `Path traversal outside workspace: ${path} resolves to ${fullPath}`;
|
|
62
|
+
if (this.config.level === 'strict') {
|
|
63
|
+
return { allowed: false, warnings: [], blockReason: msg };
|
|
64
|
+
}
|
|
65
|
+
warnings.push(msg);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
// Block writing to sensitive system paths
|
|
69
|
+
if (allowWrite) {
|
|
70
|
+
const sensitiveRoots = ['/etc', '/usr', '/bin', '/sbin', '/boot', '/proc', '/sys', '/dev'];
|
|
71
|
+
for (const root of sensitiveRoots) {
|
|
72
|
+
if (fullPath.startsWith(root + '/') || fullPath === root) {
|
|
73
|
+
const msg = `Writing to system path: ${fullPath}`;
|
|
74
|
+
if (this.config.level === 'strict') {
|
|
75
|
+
return { allowed: false, warnings: [], blockReason: msg };
|
|
76
|
+
}
|
|
77
|
+
warnings.push(msg);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return { allowed: true, warnings };
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Validate a shell command argument.
|
|
85
|
+
*/
|
|
86
|
+
validateCommand(command) {
|
|
87
|
+
if (this.config.level === 'off') {
|
|
88
|
+
return { allowed: true, warnings: [] };
|
|
89
|
+
}
|
|
90
|
+
const warnings = [];
|
|
91
|
+
for (const { pattern, description } of DANGEROUS_COMMANDS) {
|
|
92
|
+
if (pattern.test(command)) {
|
|
93
|
+
const msg = `Dangerous command pattern: ${description}`;
|
|
94
|
+
if (this.config.level === 'strict') {
|
|
95
|
+
return { allowed: false, warnings: [], blockReason: msg };
|
|
96
|
+
}
|
|
97
|
+
warnings.push(msg);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return { allowed: true, warnings };
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Validate a URL argument (block private/internal IPs).
|
|
104
|
+
*/
|
|
105
|
+
validateUrl(urlStr) {
|
|
106
|
+
if (this.config.level === 'off') {
|
|
107
|
+
return { allowed: true, warnings: [] };
|
|
108
|
+
}
|
|
109
|
+
try {
|
|
110
|
+
const url = new URL(urlStr);
|
|
111
|
+
const hostname = url.hostname;
|
|
112
|
+
// Check private IPs
|
|
113
|
+
for (const pattern of PRIVATE_IP_PATTERNS) {
|
|
114
|
+
if (pattern.test(hostname)) {
|
|
115
|
+
const msg = `URL points to private/internal IP: ${hostname}`;
|
|
116
|
+
if (this.config.level === 'strict') {
|
|
117
|
+
return { allowed: false, warnings: [], blockReason: msg };
|
|
118
|
+
}
|
|
119
|
+
return { allowed: true, warnings: [msg] };
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
// Check private hostnames
|
|
123
|
+
for (const pattern of PRIVATE_HOSTNAMES) {
|
|
124
|
+
if (pattern.startsWith('*')) {
|
|
125
|
+
const suffix = pattern.slice(1);
|
|
126
|
+
if (hostname.endsWith(suffix)) {
|
|
127
|
+
const msg = `URL points to internal hostname: ${hostname}`;
|
|
128
|
+
if (this.config.level === 'strict') {
|
|
129
|
+
return { allowed: false, warnings: [], blockReason: msg };
|
|
130
|
+
}
|
|
131
|
+
return { allowed: true, warnings: [msg] };
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
else if (hostname === pattern) {
|
|
135
|
+
const msg = `URL points to internal hostname: ${hostname}`;
|
|
136
|
+
if (this.config.level === 'strict') {
|
|
137
|
+
return { allowed: false, warnings: [], blockReason: msg };
|
|
138
|
+
}
|
|
139
|
+
return { allowed: true, warnings: [msg] };
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
catch {
|
|
144
|
+
// Invalid URL — let the tool handle it
|
|
145
|
+
}
|
|
146
|
+
return { allowed: true, warnings: [] };
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Validate a regex pattern for ReDoS potential.
|
|
150
|
+
*/
|
|
151
|
+
validateRegex(pattern, timeoutMs = 100) {
|
|
152
|
+
if (this.config.level === 'off') {
|
|
153
|
+
return { allowed: true, warnings: [] };
|
|
154
|
+
}
|
|
155
|
+
// Heuristic: check for known ReDoS patterns
|
|
156
|
+
const redosPatterns = [
|
|
157
|
+
/\(.*\+\)\+/, // (a+)+
|
|
158
|
+
/\(.*\*\)\*/, // (a*)*
|
|
159
|
+
/\(.*\+\)\*/, // (a+)*
|
|
160
|
+
/\(.*\*\)\+/, // (a*)+
|
|
161
|
+
/\(.*\{\d+,\}\)\+/, // (a{2,})+
|
|
162
|
+
];
|
|
163
|
+
for (const redos of redosPatterns) {
|
|
164
|
+
if (redos.test(pattern)) {
|
|
165
|
+
const msg = `Potential ReDoS pattern detected: ${pattern.slice(0, 50)}`;
|
|
166
|
+
if (this.config.level === 'strict') {
|
|
167
|
+
return { allowed: false, warnings: [], blockReason: msg };
|
|
168
|
+
}
|
|
169
|
+
return { allowed: true, warnings: [msg] };
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
return { allowed: true, warnings: [] };
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
//# sourceMappingURL=tool-validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-validator.js","sourceRoot":"","sources":["../../src/core/tool-validator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Typing indicator manager — show "typing..." while agent is processing.
|
|
3
|
+
*
|
|
4
|
+
* Sends platform-specific typing indicators at regular intervals
|
|
5
|
+
* while the agent is thinking or executing tools.
|
|
6
|
+
*/
|
|
7
|
+
import type { Channel } from '../channels/channel.js';
|
|
8
|
+
export interface TypingConfig {
|
|
9
|
+
/** Enable typing indicators (default: true) */
|
|
10
|
+
enabled: boolean;
|
|
11
|
+
/** Interval to re-send typing indicator in ms (default: 5000) */
|
|
12
|
+
intervalMs: number;
|
|
13
|
+
}
|
|
14
|
+
export declare class TypingManager {
|
|
15
|
+
private intervals;
|
|
16
|
+
private config;
|
|
17
|
+
constructor(config?: Partial<TypingConfig>);
|
|
18
|
+
/** Start showing typing indicator for a chat. */
|
|
19
|
+
start(channel: Channel, chatId: string): void;
|
|
20
|
+
/** Stop showing typing indicator for a chat. */
|
|
21
|
+
stop(chatId: string): void;
|
|
22
|
+
/** Stop all typing indicators. */
|
|
23
|
+
stopAll(): void;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=typing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typing.d.ts","sourceRoot":"","sources":["../../src/core/typing.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEtD,MAAM,WAAW,YAAY;IAC3B,+CAA+C;IAC/C,OAAO,EAAE,OAAO,CAAC;IACjB,iEAAiE;IACjE,UAAU,EAAE,MAAM,CAAC;CACpB;AAOD,qBAAa,aAAa;IACxB,OAAO,CAAC,SAAS,CAA0D;IAC3E,OAAO,CAAC,MAAM,CAAe;gBAEjB,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC;IAI1C,iDAAiD;IACjD,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAkB7C,gDAAgD;IAChD,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAQ1B,kCAAkC;IAClC,OAAO,IAAI,IAAI;CAKhB"}
|