opensquid 0.5.395
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +330 -0
- package/dist/anti-drift/evaluator.d.ts +88 -0
- package/dist/anti-drift/evaluator.d.ts.map +1 -0
- package/dist/anti-drift/evaluator.js +417 -0
- package/dist/anti-drift/evaluator.js.map +1 -0
- package/dist/anti-drift/evaluator.test.js +78 -0
- package/dist/anti-drift/rules.d.ts +80 -0
- package/dist/anti-drift/rules.d.ts.map +1 -0
- package/dist/anti-drift/rules.js +368 -0
- package/dist/anti-drift/rules.js.map +1 -0
- package/dist/anti-drift/rules.test.js +213 -0
- package/dist/anti-drift/state.d.ts +107 -0
- package/dist/anti-drift/state.d.ts.map +1 -0
- package/dist/anti-drift/state.js +177 -0
- package/dist/anti-drift/state.js.map +1 -0
- package/dist/anti-drift/state.test.js +120 -0
- package/dist/channels/adapters/discord.d.ts +45 -0
- package/dist/channels/adapters/discord.d.ts.map +1 -0
- package/dist/channels/adapters/discord.js +220 -0
- package/dist/channels/adapters/discord.js.map +1 -0
- package/dist/channels/adapters/slack.d.ts +63 -0
- package/dist/channels/adapters/slack.d.ts.map +1 -0
- package/dist/channels/adapters/slack.js +216 -0
- package/dist/channels/adapters/slack.js.map +1 -0
- package/dist/channels/adapters/telegram.d.ts +89 -0
- package/dist/channels/adapters/telegram.d.ts.map +1 -0
- package/dist/channels/adapters/telegram.js +400 -0
- package/dist/channels/adapters/telegram.js.map +1 -0
- package/dist/channels/adapters/webhook.d.ts +53 -0
- package/dist/channels/adapters/webhook.d.ts.map +1 -0
- package/dist/channels/adapters/webhook.js +98 -0
- package/dist/channels/adapters/webhook.js.map +1 -0
- package/dist/channels/chat.d.ts +18 -0
- package/dist/channels/chat.d.ts.map +1 -0
- package/dist/channels/chat.js +35 -0
- package/dist/channels/chat.js.map +1 -0
- package/dist/channels/config.d.ts +110 -0
- package/dist/channels/config.d.ts.map +1 -0
- package/dist/channels/config.js +223 -0
- package/dist/channels/config.js.map +1 -0
- package/dist/channels/daemon/autospawn.d.ts +64 -0
- package/dist/channels/daemon/autospawn.d.ts.map +1 -0
- package/dist/channels/daemon/autospawn.js +145 -0
- package/dist/channels/daemon/autospawn.js.map +1 -0
- package/dist/channels/daemon/cli.d.ts +38 -0
- package/dist/channels/daemon/cli.d.ts.map +1 -0
- package/dist/channels/daemon/cli.js +98 -0
- package/dist/channels/daemon/cli.js.map +1 -0
- package/dist/channels/daemon/lifecycle.d.ts +68 -0
- package/dist/channels/daemon/lifecycle.d.ts.map +1 -0
- package/dist/channels/daemon/lifecycle.js +182 -0
- package/dist/channels/daemon/lifecycle.js.map +1 -0
- package/dist/channels/daemon/protocol.d.ts +118 -0
- package/dist/channels/daemon/protocol.d.ts.map +1 -0
- package/dist/channels/daemon/protocol.js +61 -0
- package/dist/channels/daemon/protocol.js.map +1 -0
- package/dist/channels/daemon/rpc_server.d.ts +48 -0
- package/dist/channels/daemon/rpc_server.d.ts.map +1 -0
- package/dist/channels/daemon/rpc_server.js +229 -0
- package/dist/channels/daemon/rpc_server.js.map +1 -0
- package/dist/channels/daemon/worker.d.ts +48 -0
- package/dist/channels/daemon/worker.d.ts.map +1 -0
- package/dist/channels/daemon/worker.js +218 -0
- package/dist/channels/daemon/worker.js.map +1 -0
- package/dist/channels/env-token.d.ts +71 -0
- package/dist/channels/env-token.d.ts.map +1 -0
- package/dist/channels/env-token.js +150 -0
- package/dist/channels/env-token.js.map +1 -0
- package/dist/channels/factory.d.ts +52 -0
- package/dist/channels/factory.d.ts.map +1 -0
- package/dist/channels/factory.js +88 -0
- package/dist/channels/factory.js.map +1 -0
- package/dist/channels/gateway.d.ts +109 -0
- package/dist/channels/gateway.d.ts.map +1 -0
- package/dist/channels/gateway.js +142 -0
- package/dist/channels/gateway.js.map +1 -0
- package/dist/channels/inbound_router.d.ts +110 -0
- package/dist/channels/inbound_router.d.ts.map +1 -0
- package/dist/channels/inbound_router.js +182 -0
- package/dist/channels/inbound_router.js.map +1 -0
- package/dist/channels/index.d.ts +20 -0
- package/dist/channels/index.d.ts.map +1 -0
- package/dist/channels/index.js +19 -0
- package/dist/channels/index.js.map +1 -0
- package/dist/channels/migrate.d.ts +133 -0
- package/dist/channels/migrate.d.ts.map +1 -0
- package/dist/channels/migrate.js +0 -0
- package/dist/channels/migrate.js.map +1 -0
- package/dist/channels/router.d.ts +54 -0
- package/dist/channels/router.d.ts.map +1 -0
- package/dist/channels/router.js +80 -0
- package/dist/channels/router.js.map +1 -0
- package/dist/channels/routing.d.ts +281 -0
- package/dist/channels/routing.d.ts.map +1 -0
- package/dist/channels/routing.js +206 -0
- package/dist/channels/routing.js.map +1 -0
- package/dist/channels/transport_inbox.d.ts +75 -0
- package/dist/channels/transport_inbox.d.ts.map +1 -0
- package/dist/channels/transport_inbox.js +97 -0
- package/dist/channels/transport_inbox.js.map +1 -0
- package/dist/channels/types.d.ts +149 -0
- package/dist/channels/types.d.ts.map +1 -0
- package/dist/channels/types.js +10 -0
- package/dist/channels/types.js.map +1 -0
- package/dist/chat/adapters/discord.d.ts +41 -0
- package/dist/chat/adapters/discord.d.ts.map +1 -0
- package/dist/chat/adapters/discord.js +176 -0
- package/dist/chat/adapters/discord.js.map +1 -0
- package/dist/chat/adapters/discord.test.js +25 -0
- package/dist/chat/adapters/slack.d.ts +43 -0
- package/dist/chat/adapters/slack.d.ts.map +1 -0
- package/dist/chat/adapters/slack.js +172 -0
- package/dist/chat/adapters/slack.js.map +1 -0
- package/dist/chat/adapters/slack.test.js +30 -0
- package/dist/chat/adapters/telegram.d.ts +148 -0
- package/dist/chat/adapters/telegram.d.ts.map +1 -0
- package/dist/chat/adapters/telegram.js +498 -0
- package/dist/chat/adapters/telegram.js.map +1 -0
- package/dist/chat/adapters/telegram.test.js +94 -0
- package/dist/chat/config.d.ts +98 -0
- package/dist/chat/config.d.ts.map +1 -0
- package/dist/chat/config.js +185 -0
- package/dist/chat/config.js.map +1 -0
- package/dist/chat/daemon/active-project.d.ts +17 -0
- package/dist/chat/daemon/active-project.d.ts.map +1 -0
- package/dist/chat/daemon/active-project.js +23 -0
- package/dist/chat/daemon/active-project.js.map +1 -0
- package/dist/chat/daemon/autospawn.d.ts +40 -0
- package/dist/chat/daemon/autospawn.d.ts.map +1 -0
- package/dist/chat/daemon/autospawn.js +129 -0
- package/dist/chat/daemon/autospawn.js.map +1 -0
- package/dist/chat/daemon/autospawn.test.js +112 -0
- package/dist/chat/daemon/cli.d.ts +18 -0
- package/dist/chat/daemon/cli.d.ts.map +1 -0
- package/dist/chat/daemon/cli.js +71 -0
- package/dist/chat/daemon/cli.js.map +1 -0
- package/dist/chat/daemon/collisions.js +384 -0
- package/dist/chat/daemon/health-check.d.ts +69 -0
- package/dist/chat/daemon/health-check.d.ts.map +1 -0
- package/dist/chat/daemon/health-check.js +112 -0
- package/dist/chat/daemon/health-check.js.map +1 -0
- package/dist/chat/daemon/inbox-read.d.ts +35 -0
- package/dist/chat/daemon/inbox-read.d.ts.map +1 -0
- package/dist/chat/daemon/inbox-read.js +75 -0
- package/dist/chat/daemon/inbox-read.js.map +1 -0
- package/dist/chat/daemon/inbox-read.test.js +97 -0
- package/dist/chat/daemon/inbox.d.ts +63 -0
- package/dist/chat/daemon/inbox.d.ts.map +1 -0
- package/dist/chat/daemon/inbox.js +56 -0
- package/dist/chat/daemon/inbox.js.map +1 -0
- package/dist/chat/daemon/inbox.test.js +110 -0
- package/dist/chat/daemon/lifecycle.d.ts +71 -0
- package/dist/chat/daemon/lifecycle.d.ts.map +1 -0
- package/dist/chat/daemon/lifecycle.js +221 -0
- package/dist/chat/daemon/lifecycle.js.map +1 -0
- package/dist/chat/daemon/lifecycle.test.js +163 -0
- package/dist/chat/daemon/protocol.d.ts +107 -0
- package/dist/chat/daemon/protocol.d.ts.map +1 -0
- package/dist/chat/daemon/protocol.js +54 -0
- package/dist/chat/daemon/protocol.js.map +1 -0
- package/dist/chat/daemon/routing.d.ts +140 -0
- package/dist/chat/daemon/routing.d.ts.map +1 -0
- package/dist/chat/daemon/routing.js +198 -0
- package/dist/chat/daemon/routing.js.map +1 -0
- package/dist/chat/daemon/routing.test.js +259 -0
- package/dist/chat/daemon/rpc-client.d.ts +45 -0
- package/dist/chat/daemon/rpc-client.d.ts.map +1 -0
- package/dist/chat/daemon/rpc-client.js +133 -0
- package/dist/chat/daemon/rpc-client.js.map +1 -0
- package/dist/chat/daemon/rpc-server.d.ts +39 -0
- package/dist/chat/daemon/rpc-server.d.ts.map +1 -0
- package/dist/chat/daemon/rpc-server.js +385 -0
- package/dist/chat/daemon/rpc-server.js.map +1 -0
- package/dist/chat/daemon/rpc.test.js +177 -0
- package/dist/chat/daemon/subscribers.js +257 -0
- package/dist/chat/daemon/worker.d.ts +27 -0
- package/dist/chat/daemon/worker.d.ts.map +1 -0
- package/dist/chat/daemon/worker.js +313 -0
- package/dist/chat/daemon/worker.js.map +1 -0
- package/dist/chat/daemon/workspace-topic.js +324 -0
- package/dist/chat/env-token.d.ts +60 -0
- package/dist/chat/env-token.d.ts.map +1 -0
- package/dist/chat/env-token.js +137 -0
- package/dist/chat/env-token.js.map +1 -0
- package/dist/chat/env-token.test.js +160 -0
- package/dist/chat/factory.d.ts +30 -0
- package/dist/chat/factory.d.ts.map +1 -0
- package/dist/chat/factory.js +50 -0
- package/dist/chat/factory.js.map +1 -0
- package/dist/chat/factory.test.js +55 -0
- package/dist/chat/gateway.d.ts +176 -0
- package/dist/chat/gateway.d.ts.map +1 -0
- package/dist/chat/gateway.js +146 -0
- package/dist/chat/gateway.js.map +1 -0
- package/dist/chat/gateway.test.js +192 -0
- package/dist/chat_daemon/client.d.ts +61 -0
- package/dist/chat_daemon/client.d.ts.map +1 -0
- package/dist/chat_daemon/client.js +122 -0
- package/dist/chat_daemon/client.js.map +1 -0
- package/dist/claude-md.d.ts +39 -0
- package/dist/claude-md.d.ts.map +1 -0
- package/dist/claude-md.js +113 -0
- package/dist/claude-md.js.map +1 -0
- package/dist/claude-md.test.js +91 -0
- package/dist/cli/pack.d.ts +14 -0
- package/dist/cli/pack.d.ts.map +1 -0
- package/dist/cli/pack.js +232 -0
- package/dist/cli/pack.js.map +1 -0
- package/dist/cli.d.ts +18 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +317 -0
- package/dist/cli.js.map +1 -0
- package/dist/codex/activate.d.ts +66 -0
- package/dist/codex/activate.d.ts.map +1 -0
- package/dist/codex/activate.js +329 -0
- package/dist/codex/activate.js.map +1 -0
- package/dist/codex/activate.test.js +229 -0
- package/dist/codex/bundled-default/bundled-default.test.js +161 -0
- package/dist/codex/cli-publish.test.js +133 -0
- package/dist/codex/cli.d.ts +35 -0
- package/dist/codex/cli.d.ts.map +1 -0
- package/dist/codex/cli.js +554 -0
- package/dist/codex/cli.js.map +1 -0
- package/dist/codex/cli.test.js +277 -0
- package/dist/codex/import-skill-md.d.ts +53 -0
- package/dist/codex/import-skill-md.d.ts.map +1 -0
- package/dist/codex/import-skill-md.js +236 -0
- package/dist/codex/import-skill-md.js.map +1 -0
- package/dist/codex/import-skill-md.test.js +225 -0
- package/dist/codex/loader.d.ts +27 -0
- package/dist/codex/loader.d.ts.map +1 -0
- package/dist/codex/loader.js +86 -0
- package/dist/codex/loader.js.map +1 -0
- package/dist/codex/loader.test.js +75 -0
- package/dist/codex/parse.d.ts +28 -0
- package/dist/codex/parse.d.ts.map +1 -0
- package/dist/codex/parse.js +309 -0
- package/dist/codex/parse.js.map +1 -0
- package/dist/codex/parse.test.js +241 -0
- package/dist/codex/store.d.ts +87 -0
- package/dist/codex/store.d.ts.map +1 -0
- package/dist/codex/store.js +205 -0
- package/dist/codex/store.js.map +1 -0
- package/dist/codex/store.test.js +242 -0
- package/dist/codex/types.d.ts +398 -0
- package/dist/codex/types.d.ts.map +1 -0
- package/dist/codex/types.js +21 -0
- package/dist/codex/types.js.map +1 -0
- package/dist/config.d.ts +53 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +202 -0
- package/dist/config.js.map +1 -0
- package/dist/config.test.js +117 -0
- package/dist/engine/cli.d.ts +14 -0
- package/dist/engine/cli.d.ts.map +1 -0
- package/dist/engine/cli.js +171 -0
- package/dist/engine/cli.js.map +1 -0
- package/dist/engine/client.d.ts +219 -0
- package/dist/engine/client.d.ts.map +1 -0
- package/dist/engine/client.js +312 -0
- package/dist/engine/client.js.map +1 -0
- package/dist/engine/config.d.ts +62 -0
- package/dist/engine/config.d.ts.map +1 -0
- package/dist/engine/config.js +223 -0
- package/dist/engine/config.js.map +1 -0
- package/dist/engine/index.d.ts +17 -0
- package/dist/engine/index.d.ts.map +1 -0
- package/dist/engine/index.js +16 -0
- package/dist/engine/index.js.map +1 -0
- package/dist/engine/resolver.d.ts +62 -0
- package/dist/engine/resolver.d.ts.map +1 -0
- package/dist/engine/resolver.js +103 -0
- package/dist/engine/resolver.js.map +1 -0
- package/dist/engine/singleton.d.ts +95 -0
- package/dist/engine/singleton.d.ts.map +1 -0
- package/dist/engine/singleton.js +325 -0
- package/dist/engine/singleton.js.map +1 -0
- package/dist/engine/types.d.ts +402 -0
- package/dist/engine/types.d.ts.map +1 -0
- package/dist/engine/types.js +22 -0
- package/dist/engine/types.js.map +1 -0
- package/dist/engine-binary-resolver.js +110 -0
- package/dist/engine-binary-resolver.test.js +61 -0
- package/dist/engine-cli.js +60 -0
- package/dist/engine-client.js +301 -0
- package/dist/engine-client.test.js +118 -0
- package/dist/functions/active_task.d.ts +90 -0
- package/dist/functions/active_task.d.ts.map +1 -0
- package/dist/functions/active_task.js +203 -0
- package/dist/functions/active_task.js.map +1 -0
- package/dist/functions/cached_audit.d.ts +33 -0
- package/dist/functions/cached_audit.d.ts.map +1 -0
- package/dist/functions/cached_audit.js +143 -0
- package/dist/functions/cached_audit.js.map +1 -0
- package/dist/functions/chain_state.d.ts +51 -0
- package/dist/functions/chain_state.d.ts.map +1 -0
- package/dist/functions/chain_state.js +59 -0
- package/dist/functions/chain_state.js.map +1 -0
- package/dist/functions/chat_watcher_autostart.d.ts +33 -0
- package/dist/functions/chat_watcher_autostart.d.ts.map +1 -0
- package/dist/functions/chat_watcher_autostart.js +59 -0
- package/dist/functions/chat_watcher_autostart.js.map +1 -0
- package/dist/functions/check_chat_connection.d.ts +49 -0
- package/dist/functions/check_chat_connection.d.ts.map +1 -0
- package/dist/functions/check_chat_connection.js +124 -0
- package/dist/functions/check_chat_connection.js.map +1 -0
- package/dist/functions/check_flow_health.d.ts +43 -0
- package/dist/functions/check_flow_health.d.ts.map +1 -0
- package/dist/functions/check_flow_health.js +93 -0
- package/dist/functions/check_flow_health.js.map +1 -0
- package/dist/functions/destination_check.d.ts +49 -0
- package/dist/functions/destination_check.d.ts.map +1 -0
- package/dist/functions/destination_check.js +136 -0
- package/dist/functions/destination_check.js.map +1 -0
- package/dist/functions/effective_content.d.ts +31 -0
- package/dist/functions/effective_content.d.ts.map +1 -0
- package/dist/functions/effective_content.js +74 -0
- package/dist/functions/effective_content.js.map +1 -0
- package/dist/functions/ensure_umbrella_topic.d.ts +66 -0
- package/dist/functions/ensure_umbrella_topic.d.ts.map +1 -0
- package/dist/functions/ensure_umbrella_topic.js +148 -0
- package/dist/functions/ensure_umbrella_topic.js.map +1 -0
- package/dist/functions/event.d.ts +34 -0
- package/dist/functions/event.d.ts.map +1 -0
- package/dist/functions/event.js +164 -0
- package/dist/functions/event.js.map +1 -0
- package/dist/functions/file_write.d.ts +35 -0
- package/dist/functions/file_write.d.ts.map +1 -0
- package/dist/functions/file_write.js +86 -0
- package/dist/functions/file_write.js.map +1 -0
- package/dist/functions/fsm.d.ts +3 -0
- package/dist/functions/fsm.d.ts.map +1 -0
- package/dist/functions/fsm.js +62 -0
- package/dist/functions/fsm.js.map +1 -0
- package/dist/functions/handoff_session_start.d.ts +26 -0
- package/dist/functions/handoff_session_start.d.ts.map +1 -0
- package/dist/functions/handoff_session_start.js +81 -0
- package/dist/functions/handoff_session_start.js.map +1 -0
- package/dist/functions/http_request.d.ts +23 -0
- package/dist/functions/http_request.d.ts.map +1 -0
- package/dist/functions/http_request.js +59 -0
- package/dist/functions/http_request.js.map +1 -0
- package/dist/functions/index.d.ts +24 -0
- package/dist/functions/index.d.ts.map +1 -0
- package/dist/functions/index.js +28 -0
- package/dist/functions/index.js.map +1 -0
- package/dist/functions/is_automation_mode.d.ts +42 -0
- package/dist/functions/is_automation_mode.d.ts.map +1 -0
- package/dist/functions/is_automation_mode.js +53 -0
- package/dist/functions/is_automation_mode.js.map +1 -0
- package/dist/functions/lessons.d.ts +84 -0
- package/dist/functions/lessons.d.ts.map +1 -0
- package/dist/functions/lessons.js +241 -0
- package/dist/functions/lessons.js.map +1 -0
- package/dist/functions/llm.d.ts +44 -0
- package/dist/functions/llm.d.ts.map +1 -0
- package/dist/functions/llm.js +160 -0
- package/dist/functions/llm.js.map +1 -0
- package/dist/functions/path_exists.d.ts +60 -0
- package/dist/functions/path_exists.d.ts.map +1 -0
- package/dist/functions/path_exists.js +129 -0
- package/dist/functions/path_exists.js.map +1 -0
- package/dist/functions/rag.d.ts +39 -0
- package/dist/functions/rag.d.ts.map +1 -0
- package/dist/functions/rag.js +142 -0
- package/dist/functions/rag.js.map +1 -0
- package/dist/functions/recall_pre_inject.d.ts +40 -0
- package/dist/functions/recall_pre_inject.d.ts.map +1 -0
- package/dist/functions/recall_pre_inject.js +180 -0
- package/dist/functions/recall_pre_inject.js.map +1 -0
- package/dist/functions/registry.d.ts +90 -0
- package/dist/functions/registry.d.ts.map +1 -0
- package/dist/functions/registry.js +90 -0
- package/dist/functions/registry.js.map +1 -0
- package/dist/functions/scope_dwell.d.ts +33 -0
- package/dist/functions/scope_dwell.d.ts.map +1 -0
- package/dist/functions/scope_dwell.js +76 -0
- package/dist/functions/scope_dwell.js.map +1 -0
- package/dist/functions/session_status_manifest.d.ts +47 -0
- package/dist/functions/session_status_manifest.d.ts.map +1 -0
- package/dist/functions/session_status_manifest.js +148 -0
- package/dist/functions/session_status_manifest.js.map +1 -0
- package/dist/functions/session_tool_history.d.ts +46 -0
- package/dist/functions/session_tool_history.d.ts.map +1 -0
- package/dist/functions/session_tool_history.js +52 -0
- package/dist/functions/session_tool_history.js.map +1 -0
- package/dist/functions/shell_exec.d.ts +23 -0
- package/dist/functions/shell_exec.d.ts.map +1 -0
- package/dist/functions/shell_exec.js +58 -0
- package/dist/functions/shell_exec.js.map +1 -0
- package/dist/functions/state.d.ts +29 -0
- package/dist/functions/state.d.ts.map +1 -0
- package/dist/functions/state.js +165 -0
- package/dist/functions/state.js.map +1 -0
- package/dist/functions/subagent.d.ts +107 -0
- package/dist/functions/subagent.d.ts.map +1 -0
- package/dist/functions/subagent.js +202 -0
- package/dist/functions/subagent.js.map +1 -0
- package/dist/functions/text_pattern_match.d.ts +54 -0
- package/dist/functions/text_pattern_match.d.ts.map +1 -0
- package/dist/functions/text_pattern_match.js +89 -0
- package/dist/functions/text_pattern_match.js.map +1 -0
- package/dist/functions/verdict.d.ts +39 -0
- package/dist/functions/verdict.d.ts.map +1 -0
- package/dist/functions/verdict.js +105 -0
- package/dist/functions/verdict.js.map +1 -0
- package/dist/hooks/drift-catalog.d.ts +68 -0
- package/dist/hooks/drift-catalog.d.ts.map +1 -0
- package/dist/hooks/drift-catalog.js +184 -0
- package/dist/hooks/drift-catalog.js.map +1 -0
- package/dist/hooks/drift-catalog.test.js +154 -0
- package/dist/hooks/drift-patterns.d.ts +110 -0
- package/dist/hooks/drift-patterns.d.ts.map +1 -0
- package/dist/hooks/drift-patterns.js +289 -0
- package/dist/hooks/drift-patterns.js.map +1 -0
- package/dist/hooks/drift-patterns.test.js +325 -0
- package/dist/hooks/engine-vocab-gate.d.ts +108 -0
- package/dist/hooks/engine-vocab-gate.d.ts.map +1 -0
- package/dist/hooks/engine-vocab-gate.js +225 -0
- package/dist/hooks/engine-vocab-gate.js.map +1 -0
- package/dist/hooks/engine-vocab-gate.test.js +170 -0
- package/dist/hooks/heartbeat.d.ts +107 -0
- package/dist/hooks/heartbeat.d.ts.map +1 -0
- package/dist/hooks/heartbeat.js +316 -0
- package/dist/hooks/heartbeat.js.map +1 -0
- package/dist/hooks/heartbeat.test.js +393 -0
- package/dist/hooks/honesty-ledger-session-scope.test.js +100 -0
- package/dist/hooks/honesty-ledger.d.ts +123 -0
- package/dist/hooks/honesty-ledger.d.ts.map +1 -0
- package/dist/hooks/honesty-ledger.js +226 -0
- package/dist/hooks/honesty-ledger.js.map +1 -0
- package/dist/hooks/honesty-ledger.test.js +466 -0
- package/dist/hooks/inline-report-check.d.ts +63 -0
- package/dist/hooks/inline-report-check.d.ts.map +1 -0
- package/dist/hooks/inline-report-check.js +88 -0
- package/dist/hooks/inline-report-check.js.map +1 -0
- package/dist/hooks/inline-report-check.test.js +96 -0
- package/dist/hooks/pre-tool-use.d.ts +62 -0
- package/dist/hooks/pre-tool-use.d.ts.map +1 -0
- package/dist/hooks/pre-tool-use.js +342 -0
- package/dist/hooks/pre-tool-use.js.map +1 -0
- package/dist/hooks/pre-tool-use.test.js +134 -0
- package/dist/hooks/session-end.d.ts +15 -0
- package/dist/hooks/session-end.d.ts.map +1 -0
- package/dist/hooks/session-end.js +60 -0
- package/dist/hooks/session-end.js.map +1 -0
- package/dist/hooks/session-end.test.js +52 -0
- package/dist/hooks/stop.d.ts +35 -0
- package/dist/hooks/stop.d.ts.map +1 -0
- package/dist/hooks/stop.js +136 -0
- package/dist/hooks/stop.js.map +1 -0
- package/dist/hooks/transcript-active-task.test.js +342 -0
- package/dist/hooks/transcript.d.ts +26 -0
- package/dist/hooks/transcript.d.ts.map +1 -0
- package/dist/hooks/transcript.js +266 -0
- package/dist/hooks/transcript.js.map +1 -0
- package/dist/hooks/transcript.test.js +103 -0
- package/dist/hooks/user-prompt-submit.d.ts +74 -0
- package/dist/hooks/user-prompt-submit.d.ts.map +1 -0
- package/dist/hooks/user-prompt-submit.js +256 -0
- package/dist/hooks/user-prompt-submit.js.map +1 -0
- package/dist/hooks/user-prompt-submit.test.js +118 -0
- package/dist/hooks/versioning-gate.d.ts +101 -0
- package/dist/hooks/versioning-gate.d.ts.map +1 -0
- package/dist/hooks/versioning-gate.js +245 -0
- package/dist/hooks/versioning-gate.js.map +1 -0
- package/dist/hooks/versioning-gate.test.js +368 -0
- package/dist/hooks/workflow-gate.d.ts +64 -0
- package/dist/hooks/workflow-gate.d.ts.map +1 -0
- package/dist/hooks/workflow-gate.js +152 -0
- package/dist/hooks/workflow-gate.js.map +1 -0
- package/dist/hooks/workflow-gate.test.js +197 -0
- package/dist/hooks-cli.d.ts +25 -0
- package/dist/hooks-cli.d.ts.map +1 -0
- package/dist/hooks-cli.js +286 -0
- package/dist/hooks-cli.js.map +1 -0
- package/dist/hooks-cli.test.js +148 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/anchor.d.ts +20 -0
- package/dist/mcp/anchor.d.ts.map +1 -0
- package/dist/mcp/anchor.js +25 -0
- package/dist/mcp/anchor.js.map +1 -0
- package/dist/mcp/chat-bridge-server.d.ts +45 -0
- package/dist/mcp/chat-bridge-server.d.ts.map +1 -0
- package/dist/mcp/chat-bridge-server.js +475 -0
- package/dist/mcp/chat-bridge-server.js.map +1 -0
- package/dist/mcp/chat_bridge_subscriber.d.ts +101 -0
- package/dist/mcp/chat_bridge_subscriber.d.ts.map +1 -0
- package/dist/mcp/chat_bridge_subscriber.js +227 -0
- package/dist/mcp/chat_bridge_subscriber.js.map +1 -0
- package/dist/mcp/index.d.ts +21 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +18 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/server.d.ts +39 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +298 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/forget.d.ts +45 -0
- package/dist/mcp/tools/forget.d.ts.map +1 -0
- package/dist/mcp/tools/forget.js +45 -0
- package/dist/mcp/tools/forget.js.map +1 -0
- package/dist/mcp/tools/inspect-skill.d.ts +28 -0
- package/dist/mcp/tools/inspect-skill.d.ts.map +1 -0
- package/dist/mcp/tools/inspect-skill.js +70 -0
- package/dist/mcp/tools/inspect-skill.js.map +1 -0
- package/dist/mcp/tools/list-drift-events.d.ts +27 -0
- package/dist/mcp/tools/list-drift-events.d.ts.map +1 -0
- package/dist/mcp/tools/list-drift-events.js +38 -0
- package/dist/mcp/tools/list-drift-events.js.map +1 -0
- package/dist/mcp/tools/list-packs.d.ts +18 -0
- package/dist/mcp/tools/list-packs.d.ts.map +1 -0
- package/dist/mcp/tools/list-packs.js +29 -0
- package/dist/mcp/tools/list-packs.js.map +1 -0
- package/dist/mcp/tools/list-skills.d.ts +22 -0
- package/dist/mcp/tools/list-skills.d.ts.map +1 -0
- package/dist/mcp/tools/list-skills.js +42 -0
- package/dist/mcp/tools/list-skills.js.map +1 -0
- package/dist/mcp/tools/log_phase.d.ts +49 -0
- package/dist/mcp/tools/log_phase.d.ts.map +1 -0
- package/dist/mcp/tools/log_phase.js +67 -0
- package/dist/mcp/tools/log_phase.js.map +1 -0
- package/dist/mcp/tools/memorize.d.ts +79 -0
- package/dist/mcp/tools/memorize.d.ts.map +1 -0
- package/dist/mcp/tools/memorize.js +133 -0
- package/dist/mcp/tools/memorize.js.map +1 -0
- package/dist/mcp/tools/read-state.d.ts +24 -0
- package/dist/mcp/tools/read-state.d.ts.map +1 -0
- package/dist/mcp/tools/read-state.js +41 -0
- package/dist/mcp/tools/read-state.js.map +1 -0
- package/dist/mcp/tools/read-violations.d.ts +19 -0
- package/dist/mcp/tools/read-violations.d.ts.map +1 -0
- package/dist/mcp/tools/read-violations.js +36 -0
- package/dist/mcp/tools/read-violations.js.map +1 -0
- package/dist/mcp/tools/recall.d.ts +39 -0
- package/dist/mcp/tools/recall.d.ts.map +1 -0
- package/dist/mcp/tools/recall.js +54 -0
- package/dist/mcp/tools/recall.js.map +1 -0
- package/dist/mcp/tools/store-lesson.d.ts +49 -0
- package/dist/mcp/tools/store-lesson.d.ts.map +1 -0
- package/dist/mcp/tools/store-lesson.js +53 -0
- package/dist/mcp/tools/store-lesson.js.map +1 -0
- package/dist/mcp/tools/workgraph.d.ts +74 -0
- package/dist/mcp/tools/workgraph.d.ts.map +1 -0
- package/dist/mcp/tools/workgraph.js +43 -0
- package/dist/mcp/tools/workgraph.js.map +1 -0
- package/dist/models/cost_router.d.ts +116 -0
- package/dist/models/cost_router.d.ts.map +1 -0
- package/dist/models/cost_router.js +127 -0
- package/dist/models/cost_router.js.map +1 -0
- package/dist/models/dispatcher.d.ts +38 -0
- package/dist/models/dispatcher.d.ts.map +1 -0
- package/dist/models/dispatcher.js +76 -0
- package/dist/models/dispatcher.js.map +1 -0
- package/dist/models/index.d.ts +12 -0
- package/dist/models/index.d.ts.map +1 -0
- package/dist/models/index.js +5 -0
- package/dist/models/index.js.map +1 -0
- package/dist/models/load_config.d.ts +51 -0
- package/dist/models/load_config.d.ts.map +1 -0
- package/dist/models/load_config.js +99 -0
- package/dist/models/load_config.js.map +1 -0
- package/dist/models/strategies/_stub.d.ts +23 -0
- package/dist/models/strategies/_stub.d.ts.map +1 -0
- package/dist/models/strategies/_stub.js +30 -0
- package/dist/models/strategies/_stub.js.map +1 -0
- package/dist/models/strategies/api_anthropic.d.ts +68 -0
- package/dist/models/strategies/api_anthropic.d.ts.map +1 -0
- package/dist/models/strategies/api_anthropic.js +99 -0
- package/dist/models/strategies/api_anthropic.js.map +1 -0
- package/dist/models/strategies/api_openai.d.ts +57 -0
- package/dist/models/strategies/api_openai.d.ts.map +1 -0
- package/dist/models/strategies/api_openai.js +83 -0
- package/dist/models/strategies/api_openai.js.map +1 -0
- package/dist/models/strategies/local_ollama.d.ts +41 -0
- package/dist/models/strategies/local_ollama.d.ts.map +1 -0
- package/dist/models/strategies/local_ollama.js +60 -0
- package/dist/models/strategies/local_ollama.js.map +1 -0
- package/dist/models/strategies/mcp.d.ts +65 -0
- package/dist/models/strategies/mcp.d.ts.map +1 -0
- package/dist/models/strategies/mcp.js +86 -0
- package/dist/models/strategies/mcp.js.map +1 -0
- package/dist/models/strategies/subscription_cli.d.ts +48 -0
- package/dist/models/strategies/subscription_cli.d.ts.map +1 -0
- package/dist/models/strategies/subscription_cli.js +122 -0
- package/dist/models/strategies/subscription_cli.js.map +1 -0
- package/dist/models/strategies/subscription_sdk.d.ts +50 -0
- package/dist/models/strategies/subscription_sdk.d.ts.map +1 -0
- package/dist/models/strategies/subscription_sdk.js +65 -0
- package/dist/models/strategies/subscription_sdk.js.map +1 -0
- package/dist/models/types.d.ts +42 -0
- package/dist/models/types.d.ts.map +1 -0
- package/dist/models/types.js +23 -0
- package/dist/models/types.js.map +1 -0
- package/dist/origin.d.ts +16 -0
- package/dist/origin.d.ts.map +1 -0
- package/dist/origin.js +92 -0
- package/dist/origin.js.map +1 -0
- package/dist/packs/apply_extends.d.ts +47 -0
- package/dist/packs/apply_extends.d.ts.map +1 -0
- package/dist/packs/apply_extends.js +96 -0
- package/dist/packs/apply_extends.js.map +1 -0
- package/dist/packs/composite_resolver.d.ts +14 -0
- package/dist/packs/composite_resolver.d.ts.map +1 -0
- package/dist/packs/composite_resolver.js +131 -0
- package/dist/packs/composite_resolver.js.map +1 -0
- package/dist/packs/discovery.d.ts +98 -0
- package/dist/packs/discovery.d.ts.map +1 -0
- package/dist/packs/discovery.js +255 -0
- package/dist/packs/discovery.js.map +1 -0
- package/dist/packs/flows_compiler.d.ts +37 -0
- package/dist/packs/flows_compiler.d.ts.map +1 -0
- package/dist/packs/flows_compiler.js +55 -0
- package/dist/packs/flows_compiler.js.map +1 -0
- package/dist/packs/guards_compiler.d.ts +51 -0
- package/dist/packs/guards_compiler.d.ts.map +1 -0
- package/dist/packs/guards_compiler.js +56 -0
- package/dist/packs/guards_compiler.js.map +1 -0
- package/dist/packs/index.d.ts +18 -0
- package/dist/packs/index.d.ts.map +1 -0
- package/dist/packs/index.js +33 -0
- package/dist/packs/index.js.map +1 -0
- package/dist/packs/living_pack.d.ts +17 -0
- package/dist/packs/living_pack.d.ts.map +1 -0
- package/dist/packs/living_pack.js +41 -0
- package/dist/packs/living_pack.js.map +1 -0
- package/dist/packs/load_order.d.ts +32 -0
- package/dist/packs/load_order.d.ts.map +1 -0
- package/dist/packs/load_order.js +51 -0
- package/dist/packs/load_order.js.map +1 -0
- package/dist/packs/loader.d.ts +48 -0
- package/dist/packs/loader.d.ts.map +1 -0
- package/dist/packs/loader.js +357 -0
- package/dist/packs/loader.js.map +1 -0
- package/dist/packs/personal_revision.d.ts +82 -0
- package/dist/packs/personal_revision.d.ts.map +1 -0
- package/dist/packs/personal_revision.js +158 -0
- package/dist/packs/personal_revision.js.map +1 -0
- package/dist/packs/schemas/channels.d.ts +30 -0
- package/dist/packs/schemas/channels.d.ts.map +1 -0
- package/dist/packs/schemas/channels.js +44 -0
- package/dist/packs/schemas/channels.js.map +1 -0
- package/dist/packs/schemas/chat_agent.d.ts +78 -0
- package/dist/packs/schemas/chat_agent.d.ts.map +1 -0
- package/dist/packs/schemas/chat_agent.js +88 -0
- package/dist/packs/schemas/chat_agent.js.map +1 -0
- package/dist/packs/schemas/drift_response.d.ts +47 -0
- package/dist/packs/schemas/drift_response.d.ts.map +1 -0
- package/dist/packs/schemas/drift_response.js +65 -0
- package/dist/packs/schemas/drift_response.js.map +1 -0
- package/dist/packs/schemas/index.d.ts +39 -0
- package/dist/packs/schemas/index.d.ts.map +1 -0
- package/dist/packs/schemas/index.js +39 -0
- package/dist/packs/schemas/index.js.map +1 -0
- package/dist/packs/schemas/manifest.d.ts +1907 -0
- package/dist/packs/schemas/manifest.d.ts.map +1 -0
- package/dist/packs/schemas/manifest.js +532 -0
- package/dist/packs/schemas/manifest.js.map +1 -0
- package/dist/packs/schemas/models.d.ts +108 -0
- package/dist/packs/schemas/models.d.ts.map +1 -0
- package/dist/packs/schemas/models.js +67 -0
- package/dist/packs/schemas/models.js.map +1 -0
- package/dist/packs/schemas/notifications.d.ts +44 -0
- package/dist/packs/schemas/notifications.d.ts.map +1 -0
- package/dist/packs/schemas/notifications.js +66 -0
- package/dist/packs/schemas/notifications.js.map +1 -0
- package/dist/packs/schemas/skill.d.ts +740 -0
- package/dist/packs/schemas/skill.d.ts.map +1 -0
- package/dist/packs/schemas/skill.js +292 -0
- package/dist/packs/schemas/skill.js.map +1 -0
- package/dist/packs/schemas/team.d.ts +99 -0
- package/dist/packs/schemas/team.d.ts.map +1 -0
- package/dist/packs/schemas/team.js +63 -0
- package/dist/packs/schemas/team.js.map +1 -0
- package/dist/packs/seed_lessons_ingest.d.ts +30 -0
- package/dist/packs/seed_lessons_ingest.d.ts.map +1 -0
- package/dist/packs/seed_lessons_ingest.js +107 -0
- package/dist/packs/seed_lessons_ingest.js.map +1 -0
- package/dist/packs/validate_functions.d.ts +26 -0
- package/dist/packs/validate_functions.d.ts.map +1 -0
- package/dist/packs/validate_functions.js +91 -0
- package/dist/packs/validate_functions.js.map +1 -0
- package/dist/packs/validate_uniqueness.d.ts +16 -0
- package/dist/packs/validate_uniqueness.d.ts.map +1 -0
- package/dist/packs/validate_uniqueness.js +33 -0
- package/dist/packs/validate_uniqueness.js.map +1 -0
- package/dist/packs/verify_gates_compiler.d.ts +47 -0
- package/dist/packs/verify_gates_compiler.d.ts.map +1 -0
- package/dist/packs/verify_gates_compiler.js +59 -0
- package/dist/packs/verify_gates_compiler.js.map +1 -0
- package/dist/packs/yaml.d.ts +39 -0
- package/dist/packs/yaml.d.ts.map +1 -0
- package/dist/packs/yaml.js +79 -0
- package/dist/packs/yaml.js.map +1 -0
- package/dist/project-cli.d.ts +7 -0
- package/dist/project-cli.d.ts.map +1 -0
- package/dist/project-cli.js +145 -0
- package/dist/project-cli.js.map +1 -0
- package/dist/project.d.ts +127 -0
- package/dist/project.d.ts.map +1 -0
- package/dist/project.js +281 -0
- package/dist/project.js.map +1 -0
- package/dist/project.test.js +287 -0
- package/dist/rag/backend_factory.d.ts +59 -0
- package/dist/rag/backend_factory.d.ts.map +1 -0
- package/dist/rag/backend_factory.js +125 -0
- package/dist/rag/backend_factory.js.map +1 -0
- package/dist/rag/backends/claude_auto_memory.d.ts +46 -0
- package/dist/rag/backends/claude_auto_memory.d.ts.map +1 -0
- package/dist/rag/backends/claude_auto_memory.js +152 -0
- package/dist/rag/backends/claude_auto_memory.js.map +1 -0
- package/dist/rag/backends/libsql_lexical.d.ts +33 -0
- package/dist/rag/backends/libsql_lexical.d.ts.map +1 -0
- package/dist/rag/backends/libsql_lexical.js +164 -0
- package/dist/rag/backends/libsql_lexical.js.map +1 -0
- package/dist/rag/backends/libsql_qwen3.d.ts +8 -0
- package/dist/rag/backends/libsql_qwen3.d.ts.map +1 -0
- package/dist/rag/backends/libsql_qwen3.js +23 -0
- package/dist/rag/backends/libsql_qwen3.js.map +1 -0
- package/dist/rag/backends/libsql_store.d.ts +28 -0
- package/dist/rag/backends/libsql_store.d.ts.map +1 -0
- package/dist/rag/backends/libsql_store.js +246 -0
- package/dist/rag/backends/libsql_store.js.map +1 -0
- package/dist/rag/backends/loop_engine.d.ts +61 -0
- package/dist/rag/backends/loop_engine.d.ts.map +1 -0
- package/dist/rag/backends/loop_engine.js +160 -0
- package/dist/rag/backends/loop_engine.js.map +1 -0
- package/dist/rag/backends/perfile_source.d.ts +8 -0
- package/dist/rag/backends/perfile_source.d.ts.map +1 -0
- package/dist/rag/backends/perfile_source.js +78 -0
- package/dist/rag/backends/perfile_source.js.map +1 -0
- package/dist/rag/config.d.ts +38 -0
- package/dist/rag/config.d.ts.map +1 -0
- package/dist/rag/config.js +127 -0
- package/dist/rag/config.js.map +1 -0
- package/dist/rag/embedders/fastembed.d.ts +3 -0
- package/dist/rag/embedders/fastembed.d.ts.map +1 -0
- package/dist/rag/embedders/fastembed.js +51 -0
- package/dist/rag/embedders/fastembed.js.map +1 -0
- package/dist/rag/embedders/ollama_qwen3.d.ts +6 -0
- package/dist/rag/embedders/ollama_qwen3.d.ts.map +1 -0
- package/dist/rag/embedders/ollama_qwen3.js +30 -0
- package/dist/rag/embedders/ollama_qwen3.js.map +1 -0
- package/dist/rag/embedders/types.d.ts +20 -0
- package/dist/rag/embedders/types.d.ts.map +1 -0
- package/dist/rag/embedders/types.js +2 -0
- package/dist/rag/embedders/types.js.map +1 -0
- package/dist/rag/index.d.ts +18 -0
- package/dist/rag/index.d.ts.map +1 -0
- package/dist/rag/index.js +16 -0
- package/dist/rag/index.js.map +1 -0
- package/dist/rag/memory/compress.d.ts +36 -0
- package/dist/rag/memory/compress.d.ts.map +1 -0
- package/dist/rag/memory/compress.js +158 -0
- package/dist/rag/memory/compress.js.map +1 -0
- package/dist/rag/memory/consolidate.d.ts +32 -0
- package/dist/rag/memory/consolidate.d.ts.map +1 -0
- package/dist/rag/memory/consolidate.js +77 -0
- package/dist/rag/memory/consolidate.js.map +1 -0
- package/dist/rag/memory/cycle.d.ts +24 -0
- package/dist/rag/memory/cycle.d.ts.map +1 -0
- package/dist/rag/memory/cycle.js +50 -0
- package/dist/rag/memory/cycle.js.map +1 -0
- package/dist/rag/memory/store.d.ts +48 -0
- package/dist/rag/memory/store.d.ts.map +1 -0
- package/dist/rag/memory/store.js +126 -0
- package/dist/rag/memory/store.js.map +1 -0
- package/dist/rag/migrate_memories.d.ts +22 -0
- package/dist/rag/migrate_memories.d.ts.map +1 -0
- package/dist/rag/migrate_memories.js +53 -0
- package/dist/rag/migrate_memories.js.map +1 -0
- package/dist/rag/ollama_client.d.ts +28 -0
- package/dist/rag/ollama_client.d.ts.map +1 -0
- package/dist/rag/ollama_client.js +43 -0
- package/dist/rag/ollama_client.js.map +1 -0
- package/dist/rag/rrf.d.ts +20 -0
- package/dist/rag/rrf.d.ts.map +1 -0
- package/dist/rag/rrf.js +37 -0
- package/dist/rag/rrf.js.map +1 -0
- package/dist/rag/scope.d.ts +10 -0
- package/dist/rag/scope.d.ts.map +1 -0
- package/dist/rag/scope.js +45 -0
- package/dist/rag/scope.js.map +1 -0
- package/dist/rag/types.d.ts +76 -0
- package/dist/rag/types.d.ts.map +1 -0
- package/dist/rag/types.js +43 -0
- package/dist/rag/types.js.map +1 -0
- package/dist/rag/wedge/gate.d.ts +69 -0
- package/dist/rag/wedge/gate.d.ts.map +1 -0
- package/dist/rag/wedge/gate.js +104 -0
- package/dist/rag/wedge/gate.js.map +1 -0
- package/dist/rag/wedge/migrate.d.ts +7 -0
- package/dist/rag/wedge/migrate.d.ts.map +1 -0
- package/dist/rag/wedge/migrate.js +21 -0
- package/dist/rag/wedge/migrate.js.map +1 -0
- package/dist/rag/wedge/paths.d.ts +3 -0
- package/dist/rag/wedge/paths.d.ts.map +1 -0
- package/dist/rag/wedge/paths.js +13 -0
- package/dist/rag/wedge/paths.js.map +1 -0
- package/dist/rag/wedge/source.d.ts +11 -0
- package/dist/rag/wedge/source.d.ts.map +1 -0
- package/dist/rag/wedge/source.js +111 -0
- package/dist/rag/wedge/source.js.map +1 -0
- package/dist/rag/wedge/store.d.ts +64 -0
- package/dist/rag/wedge/store.d.ts.map +1 -0
- package/dist/rag/wedge/store.js +255 -0
- package/dist/rag/wedge/store.js.map +1 -0
- package/dist/recall.d.ts +82 -0
- package/dist/recall.d.ts.map +1 -0
- package/dist/recall.js +81 -0
- package/dist/recall.js.map +1 -0
- package/dist/runtime/agent_bridge/agent_loop.d.ts +151 -0
- package/dist/runtime/agent_bridge/agent_loop.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/agent_loop.js +229 -0
- package/dist/runtime/agent_bridge/agent_loop.js.map +1 -0
- package/dist/runtime/agent_bridge/agent_loop_subscription.d.ts +144 -0
- package/dist/runtime/agent_bridge/agent_loop_subscription.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/agent_loop_subscription.js +224 -0
- package/dist/runtime/agent_bridge/agent_loop_subscription.js.map +1 -0
- package/dist/runtime/agent_bridge/autospawn.d.ts +131 -0
- package/dist/runtime/agent_bridge/autospawn.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/autospawn.js +251 -0
- package/dist/runtime/agent_bridge/autospawn.js.map +1 -0
- package/dist/runtime/agent_bridge/batch.d.ts +135 -0
- package/dist/runtime/agent_bridge/batch.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/batch.js +197 -0
- package/dist/runtime/agent_bridge/batch.js.map +1 -0
- package/dist/runtime/agent_bridge/cli.d.ts +54 -0
- package/dist/runtime/agent_bridge/cli.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/cli.js +272 -0
- package/dist/runtime/agent_bridge/cli.js.map +1 -0
- package/dist/runtime/agent_bridge/daemon.d.ts +198 -0
- package/dist/runtime/agent_bridge/daemon.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/daemon.js +452 -0
- package/dist/runtime/agent_bridge/daemon.js.map +1 -0
- package/dist/runtime/agent_bridge/dispatcher.d.ts +170 -0
- package/dist/runtime/agent_bridge/dispatcher.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/dispatcher.js +333 -0
- package/dist/runtime/agent_bridge/dispatcher.js.map +1 -0
- package/dist/runtime/agent_bridge/event_bus.d.ts +44 -0
- package/dist/runtime/agent_bridge/event_bus.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/event_bus.js +56 -0
- package/dist/runtime/agent_bridge/event_bus.js.map +1 -0
- package/dist/runtime/agent_bridge/headless_lease.d.ts +113 -0
- package/dist/runtime/agent_bridge/headless_lease.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/headless_lease.js +190 -0
- package/dist/runtime/agent_bridge/headless_lease.js.map +1 -0
- package/dist/runtime/agent_bridge/index.d.ts +38 -0
- package/dist/runtime/agent_bridge/index.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/index.js +38 -0
- package/dist/runtime/agent_bridge/index.js.map +1 -0
- package/dist/runtime/agent_bridge/mcp_config.d.ts +68 -0
- package/dist/runtime/agent_bridge/mcp_config.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/mcp_config.js +102 -0
- package/dist/runtime/agent_bridge/mcp_config.js.map +1 -0
- package/dist/runtime/agent_bridge/pack_binding.d.ts +84 -0
- package/dist/runtime/agent_bridge/pack_binding.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/pack_binding.js +202 -0
- package/dist/runtime/agent_bridge/pack_binding.js.map +1 -0
- package/dist/runtime/agent_bridge/session_manager.d.ts +133 -0
- package/dist/runtime/agent_bridge/session_manager.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/session_manager.js +226 -0
- package/dist/runtime/agent_bridge/session_manager.js.map +1 -0
- package/dist/runtime/agent_bridge/session_persistence.d.ts +95 -0
- package/dist/runtime/agent_bridge/session_persistence.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/session_persistence.js +178 -0
- package/dist/runtime/agent_bridge/session_persistence.js.map +1 -0
- package/dist/runtime/agent_bridge/tool_dispatcher.d.ts +60 -0
- package/dist/runtime/agent_bridge/tool_dispatcher.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/tool_dispatcher.js +104 -0
- package/dist/runtime/agent_bridge/tool_dispatcher.js.map +1 -0
- package/dist/runtime/agent_bridge/tools/chat_send.d.ts +56 -0
- package/dist/runtime/agent_bridge/tools/chat_send.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/tools/chat_send.js +101 -0
- package/dist/runtime/agent_bridge/tools/chat_send.js.map +1 -0
- package/dist/runtime/agent_bridge/tools/index.d.ts +38 -0
- package/dist/runtime/agent_bridge/tools/index.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/tools/index.js +37 -0
- package/dist/runtime/agent_bridge/tools/index.js.map +1 -0
- package/dist/runtime/agent_bridge/tools/recall.d.ts +38 -0
- package/dist/runtime/agent_bridge/tools/recall.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/tools/recall.js +90 -0
- package/dist/runtime/agent_bridge/tools/recall.js.map +1 -0
- package/dist/runtime/agent_bridge/tools/store_lesson.d.ts +41 -0
- package/dist/runtime/agent_bridge/tools/store_lesson.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/tools/store_lesson.js +103 -0
- package/dist/runtime/agent_bridge/tools/store_lesson.js.map +1 -0
- package/dist/runtime/agent_bridge/transport_bridge.d.ts +133 -0
- package/dist/runtime/agent_bridge/transport_bridge.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/transport_bridge.js +371 -0
- package/dist/runtime/agent_bridge/transport_bridge.js.map +1 -0
- package/dist/runtime/agent_bridge/types.d.ts +320 -0
- package/dist/runtime/agent_bridge/types.d.ts.map +1 -0
- package/dist/runtime/agent_bridge/types.js +157 -0
- package/dist/runtime/agent_bridge/types.js.map +1 -0
- package/dist/runtime/atomic_write.d.ts +15 -0
- package/dist/runtime/atomic_write.d.ts.map +1 -0
- package/dist/runtime/atomic_write.js +23 -0
- package/dist/runtime/atomic_write.js.map +1 -0
- package/dist/runtime/audit_adapters.d.ts +97 -0
- package/dist/runtime/audit_adapters.d.ts.map +1 -0
- package/dist/runtime/audit_adapters.js +190 -0
- package/dist/runtime/audit_adapters.js.map +1 -0
- package/dist/runtime/audit_log.d.ts +85 -0
- package/dist/runtime/audit_log.d.ts.map +1 -0
- package/dist/runtime/audit_log.js +215 -0
- package/dist/runtime/audit_log.js.map +1 -0
- package/dist/runtime/auto_correct.d.ts +67 -0
- package/dist/runtime/auto_correct.d.ts.map +1 -0
- package/dist/runtime/auto_correct.js +122 -0
- package/dist/runtime/auto_correct.js.map +1 -0
- package/dist/runtime/automation_state.d.ts +41 -0
- package/dist/runtime/automation_state.d.ts.map +1 -0
- package/dist/runtime/automation_state.js +68 -0
- package/dist/runtime/automation_state.js.map +1 -0
- package/dist/runtime/bootstrap.d.ts +87 -0
- package/dist/runtime/bootstrap.d.ts.map +1 -0
- package/dist/runtime/bootstrap.js +381 -0
- package/dist/runtime/bootstrap.js.map +1 -0
- package/dist/runtime/builtin_denylist.d.ts +25 -0
- package/dist/runtime/builtin_denylist.d.ts.map +1 -0
- package/dist/runtime/builtin_denylist.js +98 -0
- package/dist/runtime/builtin_denylist.js.map +1 -0
- package/dist/runtime/capability_gate.d.ts +86 -0
- package/dist/runtime/capability_gate.d.ts.map +1 -0
- package/dist/runtime/capability_gate.js +295 -0
- package/dist/runtime/capability_gate.js.map +1 -0
- package/dist/runtime/chain_state.d.ts +124 -0
- package/dist/runtime/chain_state.d.ts.map +1 -0
- package/dist/runtime/chain_state.js +189 -0
- package/dist/runtime/chain_state.js.map +1 -0
- package/dist/runtime/chat/claim_lease.d.ts +35 -0
- package/dist/runtime/chat/claim_lease.d.ts.map +1 -0
- package/dist/runtime/chat/claim_lease.js +65 -0
- package/dist/runtime/chat/claim_lease.js.map +1 -0
- package/dist/runtime/chat/inbound_watch.d.ts +58 -0
- package/dist/runtime/chat/inbound_watch.d.ts.map +1 -0
- package/dist/runtime/chat/inbound_watch.js +194 -0
- package/dist/runtime/chat/inbound_watch.js.map +1 -0
- package/dist/runtime/chat/inbox.d.ts +161 -0
- package/dist/runtime/chat/inbox.d.ts.map +1 -0
- package/dist/runtime/chat/inbox.js +167 -0
- package/dist/runtime/chat/inbox.js.map +1 -0
- package/dist/runtime/chat/inbox_drain.d.ts +43 -0
- package/dist/runtime/chat/inbox_drain.d.ts.map +1 -0
- package/dist/runtime/chat/inbox_drain.js +97 -0
- package/dist/runtime/chat/inbox_drain.js.map +1 -0
- package/dist/runtime/chat/inbox_inject.d.ts +64 -0
- package/dist/runtime/chat/inbox_inject.d.ts.map +1 -0
- package/dist/runtime/chat/inbox_inject.js +120 -0
- package/dist/runtime/chat/inbox_inject.js.map +1 -0
- package/dist/runtime/chat/inbox_writer.d.ts +35 -0
- package/dist/runtime/chat/inbox_writer.d.ts.map +1 -0
- package/dist/runtime/chat/inbox_writer.js +69 -0
- package/dist/runtime/chat/inbox_writer.js.map +1 -0
- package/dist/runtime/chat/live_session_lease.d.ts +66 -0
- package/dist/runtime/chat/live_session_lease.d.ts.map +1 -0
- package/dist/runtime/chat/live_session_lease.js +110 -0
- package/dist/runtime/chat/live_session_lease.js.map +1 -0
- package/dist/runtime/chat/session_routing.d.ts +64 -0
- package/dist/runtime/chat/session_routing.d.ts.map +1 -0
- package/dist/runtime/chat/session_routing.js +95 -0
- package/dist/runtime/chat/session_routing.js.map +1 -0
- package/dist/runtime/chat/watch.d.ts +72 -0
- package/dist/runtime/chat/watch.d.ts.map +1 -0
- package/dist/runtime/chat/watch.js +143 -0
- package/dist/runtime/chat/watch.js.map +1 -0
- package/dist/runtime/chat/watch_cli.d.ts +49 -0
- package/dist/runtime/chat/watch_cli.d.ts.map +1 -0
- package/dist/runtime/chat/watch_cli.js +124 -0
- package/dist/runtime/chat/watch_cli.js.map +1 -0
- package/dist/runtime/compression_orchestrator.d.ts +75 -0
- package/dist/runtime/compression_orchestrator.d.ts.map +1 -0
- package/dist/runtime/compression_orchestrator.js +127 -0
- package/dist/runtime/compression_orchestrator.js.map +1 -0
- package/dist/runtime/context_inherit.d.ts +65 -0
- package/dist/runtime/context_inherit.d.ts.map +1 -0
- package/dist/runtime/context_inherit.js +76 -0
- package/dist/runtime/context_inherit.js.map +1 -0
- package/dist/runtime/daemon.d.ts +184 -0
- package/dist/runtime/daemon.d.ts.map +1 -0
- package/dist/runtime/daemon.js +460 -0
- package/dist/runtime/daemon.js.map +1 -0
- package/dist/runtime/deliver_only.d.ts +68 -0
- package/dist/runtime/deliver_only.d.ts.map +1 -0
- package/dist/runtime/deliver_only.js +98 -0
- package/dist/runtime/deliver_only.js.map +1 -0
- package/dist/runtime/destination_scheduler.d.ts +52 -0
- package/dist/runtime/destination_scheduler.d.ts.map +1 -0
- package/dist/runtime/destination_scheduler.js +156 -0
- package/dist/runtime/destination_scheduler.js.map +1 -0
- package/dist/runtime/detection.d.ts +32 -0
- package/dist/runtime/detection.d.ts.map +1 -0
- package/dist/runtime/detection.js +113 -0
- package/dist/runtime/detection.js.map +1 -0
- package/dist/runtime/drift_catalog.d.ts +69 -0
- package/dist/runtime/drift_catalog.d.ts.map +1 -0
- package/dist/runtime/drift_catalog.js +152 -0
- package/dist/runtime/drift_catalog.js.map +1 -0
- package/dist/runtime/drift_response.d.ts +82 -0
- package/dist/runtime/drift_response.d.ts.map +1 -0
- package/dist/runtime/drift_response.js +108 -0
- package/dist/runtime/drift_response.js.map +1 -0
- package/dist/runtime/durable/canonical_json.d.ts +47 -0
- package/dist/runtime/durable/canonical_json.d.ts.map +1 -0
- package/dist/runtime/durable/canonical_json.js +127 -0
- package/dist/runtime/durable/canonical_json.js.map +1 -0
- package/dist/runtime/durable/checkpoint_store.d.ts +228 -0
- package/dist/runtime/durable/checkpoint_store.d.ts.map +1 -0
- package/dist/runtime/durable/checkpoint_store.js +415 -0
- package/dist/runtime/durable/checkpoint_store.js.map +1 -0
- package/dist/runtime/durable/index.d.ts +36 -0
- package/dist/runtime/durable/index.d.ts.map +1 -0
- package/dist/runtime/durable/index.js +36 -0
- package/dist/runtime/durable/index.js.map +1 -0
- package/dist/runtime/durable/memo_cache.d.ts +195 -0
- package/dist/runtime/durable/memo_cache.d.ts.map +1 -0
- package/dist/runtime/durable/memo_cache.js +364 -0
- package/dist/runtime/durable/memo_cache.js.map +1 -0
- package/dist/runtime/durable/resumer.d.ts +131 -0
- package/dist/runtime/durable/resumer.d.ts.map +1 -0
- package/dist/runtime/durable/resumer.js +190 -0
- package/dist/runtime/durable/resumer.js.map +1 -0
- package/dist/runtime/durable/run_id.d.ts +50 -0
- package/dist/runtime/durable/run_id.d.ts.map +1 -0
- package/dist/runtime/durable/run_id.js +52 -0
- package/dist/runtime/durable/run_id.js.map +1 -0
- package/dist/runtime/escalate.d.ts +89 -0
- package/dist/runtime/escalate.d.ts.map +1 -0
- package/dist/runtime/escalate.js +118 -0
- package/dist/runtime/escalate.js.map +1 -0
- package/dist/runtime/evaluator/expression/ast.d.ts +57 -0
- package/dist/runtime/evaluator/expression/ast.d.ts.map +1 -0
- package/dist/runtime/evaluator/expression/ast.js +156 -0
- package/dist/runtime/evaluator/expression/ast.js.map +1 -0
- package/dist/runtime/evaluator/expression/cache.d.ts +40 -0
- package/dist/runtime/evaluator/expression/cache.d.ts.map +1 -0
- package/dist/runtime/evaluator/expression/cache.js +46 -0
- package/dist/runtime/evaluator/expression/cache.js.map +1 -0
- package/dist/runtime/evaluator/expression/functions.d.ts +61 -0
- package/dist/runtime/evaluator/expression/functions.d.ts.map +1 -0
- package/dist/runtime/evaluator/expression/functions.js +143 -0
- package/dist/runtime/evaluator/expression/functions.js.map +1 -0
- package/dist/runtime/evaluator/expression/index.d.ts +86 -0
- package/dist/runtime/evaluator/expression/index.d.ts.map +1 -0
- package/dist/runtime/evaluator/expression/index.js +144 -0
- package/dist/runtime/evaluator/expression/index.js.map +1 -0
- package/dist/runtime/evaluator/expression/interpreter.d.ts +83 -0
- package/dist/runtime/evaluator/expression/interpreter.d.ts.map +1 -0
- package/dist/runtime/evaluator/expression/interpreter.js +191 -0
- package/dist/runtime/evaluator/expression/interpreter.js.map +1 -0
- package/dist/runtime/evaluator/expression/lexer.d.ts +63 -0
- package/dist/runtime/evaluator/expression/lexer.d.ts.map +1 -0
- package/dist/runtime/evaluator/expression/lexer.js +98 -0
- package/dist/runtime/evaluator/expression/lexer.js.map +1 -0
- package/dist/runtime/evaluator/expression/parser.d.ts +76 -0
- package/dist/runtime/evaluator/expression/parser.d.ts.map +1 -0
- package/dist/runtime/evaluator/expression/parser.js +169 -0
- package/dist/runtime/evaluator/expression/parser.js.map +1 -0
- package/dist/runtime/evaluator.d.ts +112 -0
- package/dist/runtime/evaluator.d.ts.map +1 -0
- package/dist/runtime/evaluator.js +520 -0
- package/dist/runtime/evaluator.js.map +1 -0
- package/dist/runtime/event.d.ts +535 -0
- package/dist/runtime/event.d.ts.map +1 -0
- package/dist/runtime/event.js +303 -0
- package/dist/runtime/event.js.map +1 -0
- package/dist/runtime/failure_handling.d.ts +68 -0
- package/dist/runtime/failure_handling.d.ts.map +1 -0
- package/dist/runtime/failure_handling.js +103 -0
- package/dist/runtime/failure_handling.js.map +1 -0
- package/dist/runtime/fsm.d.ts +120 -0
- package/dist/runtime/fsm.d.ts.map +1 -0
- package/dist/runtime/fsm.js +92 -0
- package/dist/runtime/fsm.js.map +1 -0
- package/dist/runtime/fsm_state.d.ts +42 -0
- package/dist/runtime/fsm_state.d.ts.map +1 -0
- package/dist/runtime/fsm_state.js +114 -0
- package/dist/runtime/fsm_state.js.map +1 -0
- package/dist/runtime/handoff/collect.d.ts +64 -0
- package/dist/runtime/handoff/collect.d.ts.map +1 -0
- package/dist/runtime/handoff/collect.js +211 -0
- package/dist/runtime/handoff/collect.js.map +1 -0
- package/dist/runtime/handoff/index.d.ts +21 -0
- package/dist/runtime/handoff/index.d.ts.map +1 -0
- package/dist/runtime/handoff/index.js +33 -0
- package/dist/runtime/handoff/index.js.map +1 -0
- package/dist/runtime/handoff/narrate.d.ts +19 -0
- package/dist/runtime/handoff/narrate.d.ts.map +1 -0
- package/dist/runtime/handoff/narrate.js +44 -0
- package/dist/runtime/handoff/narrate.js.map +1 -0
- package/dist/runtime/handoff/render.d.ts +25 -0
- package/dist/runtime/handoff/render.d.ts.map +1 -0
- package/dist/runtime/handoff/render.js +162 -0
- package/dist/runtime/handoff/render.js.map +1 -0
- package/dist/runtime/handoff/substance.d.ts +19 -0
- package/dist/runtime/handoff/substance.d.ts.map +1 -0
- package/dist/runtime/handoff/substance.js +48 -0
- package/dist/runtime/handoff/substance.js.map +1 -0
- package/dist/runtime/handoff/write.d.ts +39 -0
- package/dist/runtime/handoff/write.d.ts.map +1 -0
- package/dist/runtime/handoff/write.js +131 -0
- package/dist/runtime/handoff/write.js.map +1 -0
- package/dist/runtime/hooks/active_task_mirror.d.ts +70 -0
- package/dist/runtime/hooks/active_task_mirror.d.ts.map +1 -0
- package/dist/runtime/hooks/active_task_mirror.js +226 -0
- package/dist/runtime/hooks/active_task_mirror.js.map +1 -0
- package/dist/runtime/hooks/apply_patch.d.ts +27 -0
- package/dist/runtime/hooks/apply_patch.d.ts.map +1 -0
- package/dist/runtime/hooks/apply_patch.js +54 -0
- package/dist/runtime/hooks/apply_patch.js.map +1 -0
- package/dist/runtime/hooks/dispatch.d.ts +152 -0
- package/dist/runtime/hooks/dispatch.d.ts.map +1 -0
- package/dist/runtime/hooks/dispatch.js +468 -0
- package/dist/runtime/hooks/dispatch.js.map +1 -0
- package/dist/runtime/hooks/hook_output.d.ts +40 -0
- package/dist/runtime/hooks/hook_output.d.ts.map +1 -0
- package/dist/runtime/hooks/hook_output.js +50 -0
- package/dist/runtime/hooks/hook_output.js.map +1 -0
- package/dist/runtime/hooks/memory_reconcile.d.ts +39 -0
- package/dist/runtime/hooks/memory_reconcile.d.ts.map +1 -0
- package/dist/runtime/hooks/memory_reconcile.js +75 -0
- package/dist/runtime/hooks/memory_reconcile.js.map +1 -0
- package/dist/runtime/hooks/new_project_detect.d.ts +35 -0
- package/dist/runtime/hooks/new_project_detect.d.ts.map +1 -0
- package/dist/runtime/hooks/new_project_detect.js +93 -0
- package/dist/runtime/hooks/new_project_detect.js.map +1 -0
- package/dist/runtime/hooks/permission_decision.d.ts +34 -0
- package/dist/runtime/hooks/permission_decision.d.ts.map +1 -0
- package/dist/runtime/hooks/permission_decision.js +39 -0
- package/dist/runtime/hooks/permission_decision.js.map +1 -0
- package/dist/runtime/hooks/post-tool-use.d.ts +3 -0
- package/dist/runtime/hooks/post-tool-use.d.ts.map +1 -0
- package/dist/runtime/hooks/post-tool-use.js +97 -0
- package/dist/runtime/hooks/post-tool-use.js.map +1 -0
- package/dist/runtime/hooks/pre-tool-use.d.ts +3 -0
- package/dist/runtime/hooks/pre-tool-use.d.ts.map +1 -0
- package/dist/runtime/hooks/pre-tool-use.js +169 -0
- package/dist/runtime/hooks/pre-tool-use.js.map +1 -0
- package/dist/runtime/hooks/profession_resolver.d.ts +65 -0
- package/dist/runtime/hooks/profession_resolver.d.ts.map +1 -0
- package/dist/runtime/hooks/profession_resolver.js +86 -0
- package/dist/runtime/hooks/profession_resolver.js.map +1 -0
- package/dist/runtime/hooks/scope_intent.d.ts +32 -0
- package/dist/runtime/hooks/scope_intent.d.ts.map +1 -0
- package/dist/runtime/hooks/scope_intent.js +32 -0
- package/dist/runtime/hooks/scope_intent.js.map +1 -0
- package/dist/runtime/hooks/session-end.d.ts +3 -0
- package/dist/runtime/hooks/session-end.d.ts.map +1 -0
- package/dist/runtime/hooks/session-end.js +159 -0
- package/dist/runtime/hooks/session-end.js.map +1 -0
- package/dist/runtime/hooks/session-start.d.ts +3 -0
- package/dist/runtime/hooks/session-start.d.ts.map +1 -0
- package/dist/runtime/hooks/session-start.js +116 -0
- package/dist/runtime/hooks/session-start.js.map +1 -0
- package/dist/runtime/hooks/session_id.d.ts +86 -0
- package/dist/runtime/hooks/session_id.d.ts.map +1 -0
- package/dist/runtime/hooks/session_id.js +186 -0
- package/dist/runtime/hooks/session_id.js.map +1 -0
- package/dist/runtime/hooks/session_liveness.d.ts +49 -0
- package/dist/runtime/hooks/session_liveness.d.ts.map +1 -0
- package/dist/runtime/hooks/session_liveness.js +65 -0
- package/dist/runtime/hooks/session_liveness.js.map +1 -0
- package/dist/runtime/hooks/stop.d.ts +3 -0
- package/dist/runtime/hooks/stop.d.ts.map +1 -0
- package/dist/runtime/hooks/stop.js +128 -0
- package/dist/runtime/hooks/stop.js.map +1 -0
- package/dist/runtime/hooks/stop_drive.d.ts +37 -0
- package/dist/runtime/hooks/stop_drive.d.ts.map +1 -0
- package/dist/runtime/hooks/stop_drive.js +86 -0
- package/dist/runtime/hooks/stop_drive.js.map +1 -0
- package/dist/runtime/hooks/stop_stream.d.ts +32 -0
- package/dist/runtime/hooks/stop_stream.d.ts.map +1 -0
- package/dist/runtime/hooks/stop_stream.js +74 -0
- package/dist/runtime/hooks/stop_stream.js.map +1 -0
- package/dist/runtime/hooks/transcript.d.ts +47 -0
- package/dist/runtime/hooks/transcript.d.ts.map +1 -0
- package/dist/runtime/hooks/transcript.js +115 -0
- package/dist/runtime/hooks/transcript.js.map +1 -0
- package/dist/runtime/hooks/transcript_tasks.d.ts +66 -0
- package/dist/runtime/hooks/transcript_tasks.d.ts.map +1 -0
- package/dist/runtime/hooks/transcript_tasks.js +193 -0
- package/dist/runtime/hooks/transcript_tasks.js.map +1 -0
- package/dist/runtime/hooks/user-prompt-submit.d.ts +4 -0
- package/dist/runtime/hooks/user-prompt-submit.d.ts.map +1 -0
- package/dist/runtime/hooks/user-prompt-submit.js +184 -0
- package/dist/runtime/hooks/user-prompt-submit.js.map +1 -0
- package/dist/runtime/index.d.ts +30 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +43 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/load_budget.d.ts +48 -0
- package/dist/runtime/load_budget.d.ts.map +1 -0
- package/dist/runtime/load_budget.js +43 -0
- package/dist/runtime/load_budget.js.map +1 -0
- package/dist/runtime/load_matchers.d.ts +139 -0
- package/dist/runtime/load_matchers.d.ts.map +1 -0
- package/dist/runtime/load_matchers.js +190 -0
- package/dist/runtime/load_matchers.js.map +1 -0
- package/dist/runtime/observability/index.d.ts +21 -0
- package/dist/runtime/observability/index.d.ts.map +1 -0
- package/dist/runtime/observability/index.js +20 -0
- package/dist/runtime/observability/index.js.map +1 -0
- package/dist/runtime/observability/otel_export.d.ts +58 -0
- package/dist/runtime/observability/otel_export.d.ts.map +1 -0
- package/dist/runtime/observability/otel_export.js +74 -0
- package/dist/runtime/observability/otel_export.js.map +1 -0
- package/dist/runtime/observability/trace_reader.d.ts +104 -0
- package/dist/runtime/observability/trace_reader.d.ts.map +1 -0
- package/dist/runtime/observability/trace_reader.js +357 -0
- package/dist/runtime/observability/trace_reader.js.map +1 -0
- package/dist/runtime/observability/trace_types.d.ts +64 -0
- package/dist/runtime/observability/trace_types.d.ts.map +1 -0
- package/dist/runtime/observability/trace_types.js +15 -0
- package/dist/runtime/observability/trace_types.js.map +1 -0
- package/dist/runtime/paths.d.ts +136 -0
- package/dist/runtime/paths.d.ts.map +1 -0
- package/dist/runtime/paths.js +303 -0
- package/dist/runtime/paths.js.map +1 -0
- package/dist/runtime/phase_ledger.d.ts +56 -0
- package/dist/runtime/phase_ledger.d.ts.map +1 -0
- package/dist/runtime/phase_ledger.js +88 -0
- package/dist/runtime/phase_ledger.js.map +1 -0
- package/dist/runtime/pinned_skills.d.ts +63 -0
- package/dist/runtime/pinned_skills.d.ts.map +1 -0
- package/dist/runtime/pinned_skills.js +75 -0
- package/dist/runtime/pinned_skills.js.map +1 -0
- package/dist/runtime/rate_limit.d.ts +109 -0
- package/dist/runtime/rate_limit.d.ts.map +1 -0
- package/dist/runtime/rate_limit.js +222 -0
- package/dist/runtime/rate_limit.js.map +1 -0
- package/dist/runtime/result.d.ts +26 -0
- package/dist/runtime/result.d.ts.map +1 -0
- package/dist/runtime/result.js +17 -0
- package/dist/runtime/result.js.map +1 -0
- package/dist/runtime/satisfaction_probe.d.ts +80 -0
- package/dist/runtime/satisfaction_probe.d.ts.map +1 -0
- package/dist/runtime/satisfaction_probe.js +165 -0
- package/dist/runtime/satisfaction_probe.js.map +1 -0
- package/dist/runtime/schedule_registry.d.ts +64 -0
- package/dist/runtime/schedule_registry.d.ts.map +1 -0
- package/dist/runtime/schedule_registry.js +96 -0
- package/dist/runtime/schedule_registry.js.map +1 -0
- package/dist/runtime/session_state.d.ts +127 -0
- package/dist/runtime/session_state.d.ts.map +1 -0
- package/dist/runtime/session_state.js +335 -0
- package/dist/runtime/session_state.js.map +1 -0
- package/dist/runtime/skill_prefilter.d.ts +60 -0
- package/dist/runtime/skill_prefilter.d.ts.map +1 -0
- package/dist/runtime/skill_prefilter.js +117 -0
- package/dist/runtime/skill_prefilter.js.map +1 -0
- package/dist/runtime/skill_requires.d.ts +77 -0
- package/dist/runtime/skill_requires.d.ts.map +1 -0
- package/dist/runtime/skill_requires.js +124 -0
- package/dist/runtime/skill_requires.js.map +1 -0
- package/dist/runtime/skill_router.d.ts +57 -0
- package/dist/runtime/skill_router.d.ts.map +1 -0
- package/dist/runtime/skill_router.js +97 -0
- package/dist/runtime/skill_router.js.map +1 -0
- package/dist/runtime/tick.d.ts +44 -0
- package/dist/runtime/tick.d.ts.map +1 -0
- package/dist/runtime/tick.js +99 -0
- package/dist/runtime/tick.js.map +1 -0
- package/dist/runtime/triggers/file_watcher.d.ts +100 -0
- package/dist/runtime/triggers/file_watcher.d.ts.map +1 -0
- package/dist/runtime/triggers/file_watcher.js +202 -0
- package/dist/runtime/triggers/file_watcher.js.map +1 -0
- package/dist/runtime/triggers/index.d.ts +17 -0
- package/dist/runtime/triggers/index.d.ts.map +1 -0
- package/dist/runtime/triggers/index.js +17 -0
- package/dist/runtime/triggers/index.js.map +1 -0
- package/dist/runtime/types.d.ts +1988 -0
- package/dist/runtime/types.d.ts.map +1 -0
- package/dist/runtime/types.js +337 -0
- package/dist/runtime/types.js.map +1 -0
- package/dist/runtime/unload_conditions.d.ts +97 -0
- package/dist/runtime/unload_conditions.d.ts.map +1 -0
- package/dist/runtime/unload_conditions.js +96 -0
- package/dist/runtime/unload_conditions.js.map +1 -0
- package/dist/runtime/versioning.d.ts +38 -0
- package/dist/runtime/versioning.d.ts.map +1 -0
- package/dist/runtime/versioning.js +189 -0
- package/dist/runtime/versioning.js.map +1 -0
- package/dist/runtime/webhook_server.d.ts +146 -0
- package/dist/runtime/webhook_server.d.ts.map +1 -0
- package/dist/runtime/webhook_server.js +301 -0
- package/dist/runtime/webhook_server.js.map +1 -0
- package/dist/runtime/webhook_subscriptions.d.ts +178 -0
- package/dist/runtime/webhook_subscriptions.d.ts.map +1 -0
- package/dist/runtime/webhook_subscriptions.js +192 -0
- package/dist/runtime/webhook_subscriptions.js.map +1 -0
- package/dist/runtime/wedge/automation_buffer.d.ts +56 -0
- package/dist/runtime/wedge/automation_buffer.d.ts.map +1 -0
- package/dist/runtime/wedge/automation_buffer.js +202 -0
- package/dist/runtime/wedge/automation_buffer.js.map +1 -0
- package/dist/runtime/wedge/capture.d.ts +40 -0
- package/dist/runtime/wedge/capture.d.ts.map +1 -0
- package/dist/runtime/wedge/capture.js +127 -0
- package/dist/runtime/wedge/capture.js.map +1 -0
- package/dist/runtime/wedge/compress_candidates.d.ts +63 -0
- package/dist/runtime/wedge/compress_candidates.d.ts.map +1 -0
- package/dist/runtime/wedge/compress_candidates.js +109 -0
- package/dist/runtime/wedge/compress_candidates.js.map +1 -0
- package/dist/runtime/wedge/compression_deps.d.ts +12 -0
- package/dist/runtime/wedge/compression_deps.d.ts.map +1 -0
- package/dist/runtime/wedge/compression_deps.js +63 -0
- package/dist/runtime/wedge/compression_deps.js.map +1 -0
- package/dist/runtime/wedge/cost_outcome.d.ts +112 -0
- package/dist/runtime/wedge/cost_outcome.d.ts.map +1 -0
- package/dist/runtime/wedge/cost_outcome.js +85 -0
- package/dist/runtime/wedge/cost_outcome.js.map +1 -0
- package/dist/runtime/wedge/eviction.d.ts +41 -0
- package/dist/runtime/wedge/eviction.d.ts.map +1 -0
- package/dist/runtime/wedge/eviction.js +62 -0
- package/dist/runtime/wedge/eviction.js.map +1 -0
- package/dist/runtime/wedge/index.d.ts +20 -0
- package/dist/runtime/wedge/index.d.ts.map +1 -0
- package/dist/runtime/wedge/index.js +26 -0
- package/dist/runtime/wedge/index.js.map +1 -0
- package/dist/runtime/wedge/mutate_skill.d.ts +30 -0
- package/dist/runtime/wedge/mutate_skill.d.ts.map +1 -0
- package/dist/runtime/wedge/mutate_skill.js +62 -0
- package/dist/runtime/wedge/mutate_skill.js.map +1 -0
- package/dist/runtime/wedge/promote.d.ts +57 -0
- package/dist/runtime/wedge/promote.d.ts.map +1 -0
- package/dist/runtime/wedge/promote.js +66 -0
- package/dist/runtime/wedge/promote.js.map +1 -0
- package/dist/runtime/wedge/schedule_outcome.d.ts +107 -0
- package/dist/runtime/wedge/schedule_outcome.d.ts.map +1 -0
- package/dist/runtime/wedge/schedule_outcome.js +287 -0
- package/dist/runtime/wedge/schedule_outcome.js.map +1 -0
- package/dist/runtime/wedge/types.d.ts +43 -0
- package/dist/runtime/wedge/types.d.ts.map +1 -0
- package/dist/runtime/wedge/types.js +34 -0
- package/dist/runtime/wedge/types.js.map +1 -0
- package/dist/runtime/workflow_fsm.d.ts +21 -0
- package/dist/runtime/workflow_fsm.d.ts.map +1 -0
- package/dist/runtime/workflow_fsm.js +25 -0
- package/dist/runtime/workflow_fsm.js.map +1 -0
- package/dist/runtime/workflow_map.d.ts +26 -0
- package/dist/runtime/workflow_map.d.ts.map +1 -0
- package/dist/runtime/workflow_map.js +38 -0
- package/dist/runtime/workflow_map.js.map +1 -0
- package/dist/runtime/workflow_phases.d.ts +50 -0
- package/dist/runtime/workflow_phases.d.ts.map +1 -0
- package/dist/runtime/workflow_phases.js +92 -0
- package/dist/runtime/workflow_phases.js.map +1 -0
- package/dist/scope.d.ts +48 -0
- package/dist/scope.d.ts.map +1 -0
- package/dist/scope.js +111 -0
- package/dist/scope.js.map +1 -0
- package/dist/secrets/backends/dotenv.d.ts +26 -0
- package/dist/secrets/backends/dotenv.d.ts.map +1 -0
- package/dist/secrets/backends/dotenv.js +65 -0
- package/dist/secrets/backends/dotenv.js.map +1 -0
- package/dist/secrets/backends/keychain.d.ts +59 -0
- package/dist/secrets/backends/keychain.d.ts.map +1 -0
- package/dist/secrets/backends/keychain.js +133 -0
- package/dist/secrets/backends/keychain.js.map +1 -0
- package/dist/secrets/backends/literal.d.ts +19 -0
- package/dist/secrets/backends/literal.d.ts.map +1 -0
- package/dist/secrets/backends/literal.js +25 -0
- package/dist/secrets/backends/literal.js.map +1 -0
- package/dist/secrets/backends/op.d.ts +36 -0
- package/dist/secrets/backends/op.d.ts.map +1 -0
- package/dist/secrets/backends/op.js +69 -0
- package/dist/secrets/backends/op.js.map +1 -0
- package/dist/secrets/index.d.ts +14 -0
- package/dist/secrets/index.d.ts.map +1 -0
- package/dist/secrets/index.js +13 -0
- package/dist/secrets/index.js.map +1 -0
- package/dist/secrets/resolver.d.ts +19 -0
- package/dist/secrets/resolver.d.ts.map +1 -0
- package/dist/secrets/resolver.js +40 -0
- package/dist/secrets/resolver.js.map +1 -0
- package/dist/secrets/types.d.ts +28 -0
- package/dist/secrets/types.d.ts.map +1 -0
- package/dist/secrets/types.js +14 -0
- package/dist/secrets/types.js.map +1 -0
- package/dist/setup/cli/attestations.d.ts +32 -0
- package/dist/setup/cli/attestations.d.ts.map +1 -0
- package/dist/setup/cli/attestations.js +52 -0
- package/dist/setup/cli/attestations.js.map +1 -0
- package/dist/setup/cli/audit.d.ts +30 -0
- package/dist/setup/cli/audit.d.ts.map +1 -0
- package/dist/setup/cli/audit.js +139 -0
- package/dist/setup/cli/audit.js.map +1 -0
- package/dist/setup/cli/audit_actions.d.ts +54 -0
- package/dist/setup/cli/audit_actions.d.ts.map +1 -0
- package/dist/setup/cli/audit_actions.js +200 -0
- package/dist/setup/cli/audit_actions.js.map +1 -0
- package/dist/setup/cli/audit_state.d.ts +27 -0
- package/dist/setup/cli/audit_state.d.ts.map +1 -0
- package/dist/setup/cli/audit_state.js +52 -0
- package/dist/setup/cli/audit_state.js.map +1 -0
- package/dist/setup/cli/automation.d.ts +47 -0
- package/dist/setup/cli/automation.d.ts.map +1 -0
- package/dist/setup/cli/automation.js +156 -0
- package/dist/setup/cli/automation.js.map +1 -0
- package/dist/setup/cli/cache.d.ts +44 -0
- package/dist/setup/cli/cache.d.ts.map +1 -0
- package/dist/setup/cli/cache.js +154 -0
- package/dist/setup/cli/cache.js.map +1 -0
- package/dist/setup/cli/chat.d.ts +69 -0
- package/dist/setup/cli/chat.d.ts.map +1 -0
- package/dist/setup/cli/chat.js +95 -0
- package/dist/setup/cli/chat.js.map +1 -0
- package/dist/setup/cli/chat_actions.d.ts +57 -0
- package/dist/setup/cli/chat_actions.d.ts.map +1 -0
- package/dist/setup/cli/chat_actions.js +358 -0
- package/dist/setup/cli/chat_actions.js.map +1 -0
- package/dist/setup/cli/chat_actions_prompts.d.ts +51 -0
- package/dist/setup/cli/chat_actions_prompts.d.ts.map +1 -0
- package/dist/setup/cli/chat_actions_prompts.js +319 -0
- package/dist/setup/cli/chat_actions_prompts.js.map +1 -0
- package/dist/setup/cli/chat_actions_prompts_alias.d.ts +37 -0
- package/dist/setup/cli/chat_actions_prompts_alias.d.ts.map +1 -0
- package/dist/setup/cli/chat_actions_prompts_alias.js +185 -0
- package/dist/setup/cli/chat_actions_prompts_alias.js.map +1 -0
- package/dist/setup/cli/chat_actions_test_helpers.d.ts +37 -0
- package/dist/setup/cli/chat_actions_test_helpers.d.ts.map +1 -0
- package/dist/setup/cli/chat_actions_test_helpers.js +125 -0
- package/dist/setup/cli/chat_actions_test_helpers.js.map +1 -0
- package/dist/setup/cli/chat_actions_test_step.d.ts +86 -0
- package/dist/setup/cli/chat_actions_test_step.d.ts.map +1 -0
- package/dist/setup/cli/chat_actions_test_step.js +303 -0
- package/dist/setup/cli/chat_actions_test_step.js.map +1 -0
- package/dist/setup/cli/chat_actions_writers.d.ts +140 -0
- package/dist/setup/cli/chat_actions_writers.d.ts.map +1 -0
- package/dist/setup/cli/chat_actions_writers.js +297 -0
- package/dist/setup/cli/chat_actions_writers.js.map +1 -0
- package/dist/setup/cli/chat_state.d.ts +121 -0
- package/dist/setup/cli/chat_state.d.ts.map +1 -0
- package/dist/setup/cli/chat_state.js +310 -0
- package/dist/setup/cli/chat_state.js.map +1 -0
- package/dist/setup/cli/checkpoints.d.ts +47 -0
- package/dist/setup/cli/checkpoints.d.ts.map +1 -0
- package/dist/setup/cli/checkpoints.js +85 -0
- package/dist/setup/cli/checkpoints.js.map +1 -0
- package/dist/setup/cli/checkpoints_actions.d.ts +47 -0
- package/dist/setup/cli/checkpoints_actions.d.ts.map +1 -0
- package/dist/setup/cli/checkpoints_actions.js +153 -0
- package/dist/setup/cli/checkpoints_actions.js.map +1 -0
- package/dist/setup/cli/checkpoints_core.d.ts +57 -0
- package/dist/setup/cli/checkpoints_core.d.ts.map +1 -0
- package/dist/setup/cli/checkpoints_core.js +73 -0
- package/dist/setup/cli/checkpoints_core.js.map +1 -0
- package/dist/setup/cli/checkpoints_render.d.ts +23 -0
- package/dist/setup/cli/checkpoints_render.d.ts.map +1 -0
- package/dist/setup/cli/checkpoints_render.js +65 -0
- package/dist/setup/cli/checkpoints_render.js.map +1 -0
- package/dist/setup/cli/codex_hooks.d.ts +27 -0
- package/dist/setup/cli/codex_hooks.d.ts.map +1 -0
- package/dist/setup/cli/codex_hooks.js +73 -0
- package/dist/setup/cli/codex_hooks.js.map +1 -0
- package/dist/setup/cli/cost.d.ts +29 -0
- package/dist/setup/cli/cost.d.ts.map +1 -0
- package/dist/setup/cli/cost.js +98 -0
- package/dist/setup/cli/cost.js.map +1 -0
- package/dist/setup/cli/cost_state.d.ts +86 -0
- package/dist/setup/cli/cost_state.d.ts.map +1 -0
- package/dist/setup/cli/cost_state.js +223 -0
- package/dist/setup/cli/cost_state.js.map +1 -0
- package/dist/setup/cli/doctor.d.ts +47 -0
- package/dist/setup/cli/doctor.d.ts.map +1 -0
- package/dist/setup/cli/doctor.js +314 -0
- package/dist/setup/cli/doctor.js.map +1 -0
- package/dist/setup/cli/gate.d.ts +71 -0
- package/dist/setup/cli/gate.d.ts.map +1 -0
- package/dist/setup/cli/gate.js +287 -0
- package/dist/setup/cli/gate.js.map +1 -0
- package/dist/setup/cli/hooks.d.ts +69 -0
- package/dist/setup/cli/hooks.d.ts.map +1 -0
- package/dist/setup/cli/hooks.js +104 -0
- package/dist/setup/cli/hooks.js.map +1 -0
- package/dist/setup/cli/index.d.ts +11 -0
- package/dist/setup/cli/index.d.ts.map +1 -0
- package/dist/setup/cli/index.js +11 -0
- package/dist/setup/cli/index.js.map +1 -0
- package/dist/setup/cli/limits.d.ts +30 -0
- package/dist/setup/cli/limits.d.ts.map +1 -0
- package/dist/setup/cli/limits.js +102 -0
- package/dist/setup/cli/limits.js.map +1 -0
- package/dist/setup/cli/limits_state.d.ts +77 -0
- package/dist/setup/cli/limits_state.d.ts.map +1 -0
- package/dist/setup/cli/limits_state.js +170 -0
- package/dist/setup/cli/limits_state.js.map +1 -0
- package/dist/setup/cli/mcp.d.ts +73 -0
- package/dist/setup/cli/mcp.d.ts.map +1 -0
- package/dist/setup/cli/mcp.js +175 -0
- package/dist/setup/cli/mcp.js.map +1 -0
- package/dist/setup/cli/memory.d.ts +55 -0
- package/dist/setup/cli/memory.d.ts.map +1 -0
- package/dist/setup/cli/memory.js +139 -0
- package/dist/setup/cli/memory.js.map +1 -0
- package/dist/setup/cli/permissions.d.ts +49 -0
- package/dist/setup/cli/permissions.d.ts.map +1 -0
- package/dist/setup/cli/permissions.js +77 -0
- package/dist/setup/cli/permissions.js.map +1 -0
- package/dist/setup/cli/permissions_actions.d.ts +72 -0
- package/dist/setup/cli/permissions_actions.d.ts.map +1 -0
- package/dist/setup/cli/permissions_actions.js +208 -0
- package/dist/setup/cli/permissions_actions.js.map +1 -0
- package/dist/setup/cli/permissions_state.d.ts +98 -0
- package/dist/setup/cli/permissions_state.d.ts.map +1 -0
- package/dist/setup/cli/permissions_state.js +202 -0
- package/dist/setup/cli/permissions_state.js.map +1 -0
- package/dist/setup/cli/portability.d.ts +68 -0
- package/dist/setup/cli/portability.d.ts.map +1 -0
- package/dist/setup/cli/portability.js +413 -0
- package/dist/setup/cli/portability.js.map +1 -0
- package/dist/setup/cli/schedule.d.ts +45 -0
- package/dist/setup/cli/schedule.d.ts.map +1 -0
- package/dist/setup/cli/schedule.js +92 -0
- package/dist/setup/cli/schedule.js.map +1 -0
- package/dist/setup/cli/schedule_actions.d.ts +63 -0
- package/dist/setup/cli/schedule_actions.d.ts.map +1 -0
- package/dist/setup/cli/schedule_actions.js +299 -0
- package/dist/setup/cli/schedule_actions.js.map +1 -0
- package/dist/setup/cli/schedule_render.d.ts +18 -0
- package/dist/setup/cli/schedule_render.d.ts.map +1 -0
- package/dist/setup/cli/schedule_render.js +69 -0
- package/dist/setup/cli/schedule_render.js.map +1 -0
- package/dist/setup/cli/schedule_state.d.ts +92 -0
- package/dist/setup/cli/schedule_state.d.ts.map +1 -0
- package/dist/setup/cli/schedule_state.js +291 -0
- package/dist/setup/cli/schedule_state.js.map +1 -0
- package/dist/setup/cli/state_io.d.ts +67 -0
- package/dist/setup/cli/state_io.d.ts.map +1 -0
- package/dist/setup/cli/state_io.js +130 -0
- package/dist/setup/cli/state_io.js.map +1 -0
- package/dist/setup/cli/topic_create_step.d.ts +84 -0
- package/dist/setup/cli/topic_create_step.d.ts.map +1 -0
- package/dist/setup/cli/topic_create_step.js +213 -0
- package/dist/setup/cli/topic_create_step.js.map +1 -0
- package/dist/setup/cli/trace.d.ts +52 -0
- package/dist/setup/cli/trace.d.ts.map +1 -0
- package/dist/setup/cli/trace.js +239 -0
- package/dist/setup/cli/trace.js.map +1 -0
- package/dist/setup/cli/triggers.d.ts +32 -0
- package/dist/setup/cli/triggers.d.ts.map +1 -0
- package/dist/setup/cli/triggers.js +141 -0
- package/dist/setup/cli/triggers.js.map +1 -0
- package/dist/setup/cli/triggers_state.d.ts +47 -0
- package/dist/setup/cli/triggers_state.d.ts.map +1 -0
- package/dist/setup/cli/triggers_state.js +119 -0
- package/dist/setup/cli/triggers_state.js.map +1 -0
- package/dist/setup/cli/triggers_synth.d.ts +19 -0
- package/dist/setup/cli/triggers_synth.d.ts.map +1 -0
- package/dist/setup/cli/triggers_synth.js +70 -0
- package/dist/setup/cli/triggers_synth.js.map +1 -0
- package/dist/setup/cli/webhooks.d.ts +42 -0
- package/dist/setup/cli/webhooks.d.ts.map +1 -0
- package/dist/setup/cli/webhooks.js +77 -0
- package/dist/setup/cli/webhooks.js.map +1 -0
- package/dist/setup/cli/webhooks_actions.d.ts +86 -0
- package/dist/setup/cli/webhooks_actions.d.ts.map +1 -0
- package/dist/setup/cli/webhooks_actions.js +301 -0
- package/dist/setup/cli/webhooks_actions.js.map +1 -0
- package/dist/setup/cli/webhooks_state.d.ts +79 -0
- package/dist/setup/cli/webhooks_state.d.ts.map +1 -0
- package/dist/setup/cli/webhooks_state.js +73 -0
- package/dist/setup/cli/webhooks_state.js.map +1 -0
- package/dist/setup/index.d.ts +9 -0
- package/dist/setup/index.d.ts.map +1 -0
- package/dist/setup/index.js +9 -0
- package/dist/setup/index.js.map +1 -0
- package/dist/setup/migrate/auto_memory_importer.d.ts +101 -0
- package/dist/setup/migrate/auto_memory_importer.d.ts.map +1 -0
- package/dist/setup/migrate/auto_memory_importer.js +163 -0
- package/dist/setup/migrate/auto_memory_importer.js.map +1 -0
- package/dist/setup/migrate/auto_memory_reader.d.ts +84 -0
- package/dist/setup/migrate/auto_memory_reader.d.ts.map +1 -0
- package/dist/setup/migrate/auto_memory_reader.js +99 -0
- package/dist/setup/migrate/auto_memory_reader.js.map +1 -0
- package/dist/setup/migrate/auto_memory_snapshot.d.ts +33 -0
- package/dist/setup/migrate/auto_memory_snapshot.d.ts.map +1 -0
- package/dist/setup/migrate/auto_memory_snapshot.js +67 -0
- package/dist/setup/migrate/auto_memory_snapshot.js.map +1 -0
- package/dist/setup/migrate/memory_drift.d.ts +45 -0
- package/dist/setup/migrate/memory_drift.d.ts.map +1 -0
- package/dist/setup/migrate/memory_drift.js +92 -0
- package/dist/setup/migrate/memory_drift.js.map +1 -0
- package/dist/setup/migrate/memory_store_handle.d.ts +31 -0
- package/dist/setup/migrate/memory_store_handle.d.ts.map +1 -0
- package/dist/setup/migrate/memory_store_handle.js +93 -0
- package/dist/setup/migrate/memory_store_handle.js.map +1 -0
- package/dist/setup/migrate/migrate-scope.d.ts +25 -0
- package/dist/setup/migrate/migrate-scope.d.ts.map +1 -0
- package/dist/setup/migrate/migrate-scope.js +82 -0
- package/dist/setup/migrate/migrate-scope.js.map +1 -0
- package/dist/setup/schedule_nl.d.ts +88 -0
- package/dist/setup/schedule_nl.d.ts.map +1 -0
- package/dist/setup/schedule_nl.js +183 -0
- package/dist/setup/schedule_nl.js.map +1 -0
- package/dist/setup/wizard/codex-hooks-writer.d.ts +67 -0
- package/dist/setup/wizard/codex-hooks-writer.d.ts.map +1 -0
- package/dist/setup/wizard/codex-hooks-writer.js +104 -0
- package/dist/setup/wizard/codex-hooks-writer.js.map +1 -0
- package/dist/setup/wizard/git-hooks.d.ts +49 -0
- package/dist/setup/wizard/git-hooks.d.ts.map +1 -0
- package/dist/setup/wizard/git-hooks.js +106 -0
- package/dist/setup/wizard/git-hooks.js.map +1 -0
- package/dist/setup/wizard/mcp-hosts.d.ts +44 -0
- package/dist/setup/wizard/mcp-hosts.d.ts.map +1 -0
- package/dist/setup/wizard/mcp-hosts.js +87 -0
- package/dist/setup/wizard/mcp-hosts.js.map +1 -0
- package/dist/setup/wizard/mcp-writer.d.ts +81 -0
- package/dist/setup/wizard/mcp-writer.d.ts.map +1 -0
- package/dist/setup/wizard/mcp-writer.js +115 -0
- package/dist/setup/wizard/mcp-writer.js.map +1 -0
- package/dist/setup/wizard/settings-reader.d.ts +74 -0
- package/dist/setup/wizard/settings-reader.d.ts.map +1 -0
- package/dist/setup/wizard/settings-reader.js +81 -0
- package/dist/setup/wizard/settings-reader.js.map +1 -0
- package/dist/setup/wizard/settings-writer.d.ts +95 -0
- package/dist/setup/wizard/settings-writer.d.ts.map +1 -0
- package/dist/setup/wizard/settings-writer.js +154 -0
- package/dist/setup/wizard/settings-writer.js.map +1 -0
- package/dist/storage/atomic_file.d.ts +3 -0
- package/dist/storage/atomic_file.d.ts.map +1 -0
- package/dist/storage/atomic_file.js +27 -0
- package/dist/storage/atomic_file.js.map +1 -0
- package/dist/system-export.d.ts +65 -0
- package/dist/system-export.d.ts.map +1 -0
- package/dist/system-export.js +194 -0
- package/dist/system-export.js.map +1 -0
- package/dist/utterance/classifier.d.ts +53 -0
- package/dist/utterance/classifier.d.ts.map +1 -0
- package/dist/utterance/classifier.js +184 -0
- package/dist/utterance/classifier.js.map +1 -0
- package/dist/utterance/classifier.test.js +147 -0
- package/dist/workgraph/events.d.ts +12 -0
- package/dist/workgraph/events.d.ts.map +1 -0
- package/dist/workgraph/events.js +90 -0
- package/dist/workgraph/events.js.map +1 -0
- package/dist/workgraph/store.d.ts +15 -0
- package/dist/workgraph/store.d.ts.map +1 -0
- package/dist/workgraph/store.js +195 -0
- package/dist/workgraph/store.js.map +1 -0
- package/dist/workgraph/types.d.ts +49 -0
- package/dist/workgraph/types.d.ts.map +1 -0
- package/dist/workgraph/types.js +2 -0
- package/dist/workgraph/types.js.map +1 -0
- package/docs/load-budget.md +98 -0
- package/docs/pack-runtime.md +1205 -0
- package/docs/skill-grammar-guide.md +646 -0
- package/package.json +145 -0
- package/packs/builtin/coding-flow/PROFILES.md +39 -0
- package/packs/builtin/coding-flow/fsm.yaml +52 -0
- package/packs/builtin/coding-flow/manifest.yaml +29 -0
- package/packs/builtin/coding-flow/skills/entry-and-handoffs/skill.yaml +246 -0
- package/packs/builtin/coding-flow/skills/execute-gate/skill.yaml +71 -0
- package/packs/builtin/coding-flow/skills/flow-health-check/skill.yaml +42 -0
- package/packs/builtin/coding-flow/skills/pause-prevention/skill.yaml +73 -0
- package/packs/builtin/coding-flow/skills/pause-stop-guard/skill.yaml +67 -0
- package/packs/builtin/coding-flow/skills/phase-advance/skill.yaml +28 -0
- package/packs/builtin/coding-flow/skills/phase-audit/skill.yaml +68 -0
- package/packs/builtin/coding-flow/skills/scope-lifecycle/skill.yaml +362 -0
- package/packs/builtin/coding-flow/skills/task-start/skill.yaml +42 -0
- package/packs/builtin/cycle-pack/manifest.yaml +20 -0
- package/packs/builtin/cycle-pack/skills/lesson-capture/prose.md +34 -0
- package/packs/builtin/cycle-pack/skills/lesson-capture/skill.yaml +57 -0
- package/packs/builtin/default-discipline/channels.yaml +8 -0
- package/packs/builtin/default-discipline/drift_response.yaml +51 -0
- package/packs/builtin/default-discipline/manifest.yaml +297 -0
- package/packs/builtin/default-discipline/models.yaml +8 -0
- package/packs/builtin/default-discipline/notifications.yaml +12 -0
- package/packs/builtin/default-discipline/skills/d9-guard/skill.yaml +82 -0
- package/packs/builtin/default-discipline/skills/inbound-greeter/SKILL.md +38 -0
- package/packs/builtin/default-discipline/skills/inbound-greeter/skill.yaml +36 -0
- package/packs/builtin/default-discipline/skills/session-connection-check/SKILL.md +45 -0
- package/packs/builtin/default-discipline/skills/session-connection-check/skill.yaml +55 -0
- package/packs/builtin/default-discipline/skills/workflow/skill.yaml +65 -0
- package/packs/builtin/examples/file-pattern-guard/BEFORE.md +70 -0
- package/packs/builtin/examples/file-pattern-guard/SKILL.md +79 -0
- package/packs/builtin/examples/file-pattern-guard/fixtures/edit_node_modules.expected.json +3 -0
- package/packs/builtin/examples/file-pattern-guard/fixtures/edit_node_modules.input.json +9 -0
- package/packs/builtin/examples/file-pattern-guard/fixtures/edit_src.expected.json +3 -0
- package/packs/builtin/examples/file-pattern-guard/fixtures/edit_src.input.json +9 -0
- package/packs/builtin/examples/file-pattern-guard/manifest.yaml +18 -0
- package/packs/builtin/examples/file-pattern-guard/skills/guard/skill.yaml +33 -0
- package/packs/builtin/examples/multi-clause-drift-detector/BEFORE.md +62 -0
- package/packs/builtin/examples/multi-clause-drift-detector/SKILL.md +90 -0
- package/packs/builtin/examples/multi-clause-drift-detector/fixtures/drift_no_verify.expected.json +3 -0
- package/packs/builtin/examples/multi-clause-drift-detector/fixtures/drift_no_verify.input.json +18 -0
- package/packs/builtin/examples/multi-clause-drift-detector/fixtures/drift_with_verify.expected.json +3 -0
- package/packs/builtin/examples/multi-clause-drift-detector/fixtures/drift_with_verify.input.json +18 -0
- package/packs/builtin/examples/multi-clause-drift-detector/manifest.yaml +18 -0
- package/packs/builtin/examples/multi-clause-drift-detector/skills/drift/skill.yaml +60 -0
- package/packs/builtin/examples/tool-history-correlator/BEFORE.md +73 -0
- package/packs/builtin/examples/tool-history-correlator/SKILL.md +85 -0
- package/packs/builtin/examples/tool-history-correlator/fixtures/few_bash.expected.json +3 -0
- package/packs/builtin/examples/tool-history-correlator/fixtures/few_bash.input.json +10 -0
- package/packs/builtin/examples/tool-history-correlator/fixtures/many_bash.expected.json +3 -0
- package/packs/builtin/examples/tool-history-correlator/fixtures/many_bash.input.json +10 -0
- package/packs/builtin/examples/tool-history-correlator/manifest.yaml +18 -0
- package/packs/builtin/examples/tool-history-correlator/skills/correlator/skill.yaml +46 -0
- package/packs/builtin/focused-atomic-design/README.md +21 -0
- package/packs/builtin/focused-atomic-design/manifest.yaml +151 -0
- package/packs/builtin/focused-react-19/README.md +36 -0
- package/packs/builtin/focused-react-19/manifest.yaml +171 -0
- package/packs/builtin/focused-typescript-strict/README.md +21 -0
- package/packs/builtin/focused-typescript-strict/manifest.yaml +163 -0
- package/packs/builtin/frontend-react-19-atomic/README.md +61 -0
- package/packs/builtin/frontend-react-19-atomic/manifest.yaml +124 -0
- package/packs/builtin/general/chat_agent.yaml +16 -0
- package/packs/builtin/general/manifest.yaml +39 -0
- package/packs/builtin/general/system_prompt.md +11 -0
- package/packs/builtin/pack-architect/SKILL.md +74 -0
- package/packs/builtin/pack-architect/manifest.yaml +53 -0
- package/packs/builtin/pack-architect/skills/fsm-author-walkthrough/skill.yaml +45 -0
- package/packs/builtin/pack-architect/skills/manifest-author-walkthrough/skill.yaml +50 -0
- package/packs/builtin/pack-architect/skills/pack-scope-elicit/skill.yaml +44 -0
- package/packs/builtin/pack-architect/skills/skill-yaml-author-walkthrough/skill.yaml +52 -0
- package/packs/builtin/pack-architect/team.yaml +84 -0
- package/packs/builtin/scope-architect/manifest.yaml +43 -0
- package/packs/builtin/scope-architect/skills/inline-spec-block/skill.yaml +56 -0
- package/packs/builtin/scope-architect/skills/pack-skill-authoring/skill.yaml +83 -0
- package/packs/builtin/scope-architect/skills/pre-research-authoring/skill.yaml +142 -0
- package/packs/builtin/scope-architect/skills/scope-before-code/skill.yaml +34 -0
- package/packs/builtin/scope-architect/skills/scope-detect/skill.yaml +73 -0
- package/packs/builtin/scope-architect/skills/task-list-generated/skill.yaml +28 -0
- package/packs/builtin/scope-architect/skills/taskcreate-spec-required/skill.yaml +27 -0
- package/packs/builtin/scope-architect/team.yaml +65 -0
- package/packs/builtin/seo-aeo-expert/drift_response.yaml +11 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/citation_allow_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/citation_allow_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/citation_cross_section_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/citation_cross_section_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/citation_robots_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/citation_robots_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/training_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/training_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/training_unrelated_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/training_unrelated_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/wildcard_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/wildcard_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/wildcard_path_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/bot-policy-guard/wildcard_path_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ground-truth-gate/no_claims_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ground-truth-gate/no_claims_pass.input.json +14 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ground-truth-gate/offer_no_doc_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ground-truth-gate/offer_no_doc_fire.input.json +14 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ground-truth-gate/offer_with_doc_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ground-truth-gate/offer_with_doc_pass.input.json +14 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/desc_long_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/desc_long_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/desc_ok_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/desc_ok_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/img_alt_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/img_alt_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/img_alt_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/img_alt_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/title_long_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/title_long_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/title_ok_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/meta-quality-gate/title_ok_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/page-removal-guard/rm_other_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/page-removal-guard/rm_other_pass.input.json +6 -0
- package/packs/builtin/seo-aeo-expert/fixtures/page-removal-guard/rm_page_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/page-removal-guard/rm_page_fire.input.json +6 -0
- package/packs/builtin/seo-aeo-expert/fixtures/pre-push-seo-checklist/checklist_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/pre-push-seo-checklist/checklist_fire.input.json +7 -0
- package/packs/builtin/seo-aeo-expert/fixtures/pre-push-seo-checklist/checklist_shipped_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/pre-push-seo-checklist/checklist_shipped_pass.input.json +7 -0
- package/packs/builtin/seo-aeo-expert/fixtures/pre-push-seo-checklist/push_fixing_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/pre-push-seo-checklist/push_fixing_fire.input.json +7 -0
- package/packs/builtin/seo-aeo-expert/fixtures/pre-push-seo-checklist/push_idle_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/pre-push-seo-checklist/push_idle_pass.input.json +7 -0
- package/packs/builtin/seo-aeo-expert/fixtures/run.mjs +123 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/lint_product_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/lint_product_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/lint_product_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/lint_product_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/lint_rating_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/lint_rating_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/lint_rating_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/lint_rating_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/schema_touched_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/schema_touched_fire.input.json +12 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/schema_touched_in_cycle_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/schema_touched_in_cycle_pass.input.json +12 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/validation_run_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/validation_run_fire.input.json +6 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/validation_run_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/schema-validation-gate/validation_run_pass.input.json +6 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ssr-regression-guard/fetch_effect_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ssr-regression-guard/fetch_effect_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ssr-regression-guard/organism_leaf_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ssr-regression-guard/organism_leaf_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ssr-regression-guard/server_page_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ssr-regression-guard/server_page_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ssr-regression-guard/use_client_page_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/ssr-regression-guard/use_client_page_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/stale-tactic-guard/clean_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/stale-tactic-guard/clean_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/stale-tactic-guard/docs_exempt_pass.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/stale-tactic-guard/docs_exempt_pass.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/stale-tactic-guard/faq_schema_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/stale-tactic-guard/faq_schema_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fixtures/stale-tactic-guard/llms_claim_fire.expected.json +3 -0
- package/packs/builtin/seo-aeo-expert/fixtures/stale-tactic-guard/llms_claim_fire.input.json +10 -0
- package/packs/builtin/seo-aeo-expert/fsm.yaml +43 -0
- package/packs/builtin/seo-aeo-expert/lessons/ai-mode-default-fanout/lesson.md +16 -0
- package/packs/builtin/seo-aeo-expert/lessons/bing-is-chatgpt/lesson.md +15 -0
- package/packs/builtin/seo-aeo-expert/lessons/bot-taxonomy-three-classes/lesson.md +21 -0
- package/packs/builtin/seo-aeo-expert/lessons/chunk-shape/lesson.md +18 -0
- package/packs/builtin/seo-aeo-expert/lessons/citation-over-rank/lesson.md +19 -0
- package/packs/builtin/seo-aeo-expert/lessons/cloudflare-default-block/lesson.md +18 -0
- package/packs/builtin/seo-aeo-expert/lessons/deprecated-tactics-2026/lesson.md +32 -0
- package/packs/builtin/seo-aeo-expert/lessons/engine-divergence/lesson.md +22 -0
- package/packs/builtin/seo-aeo-expert/lessons/freehand-schema-forbidden/lesson.md +21 -0
- package/packs/builtin/seo-aeo-expert/lessons/geo-content-levers/lesson.md +20 -0
- package/packs/builtin/seo-aeo-expert/lessons/google-official-ai-guide/lesson.md +17 -0
- package/packs/builtin/seo-aeo-expert/lessons/llms-txt-dead/lesson.md +19 -0
- package/packs/builtin/seo-aeo-expert/lessons/local-ai-gap/lesson.md +20 -0
- package/packs/builtin/seo-aeo-expert/lessons/measurement-discontinuities/lesson.md +29 -0
- package/packs/builtin/seo-aeo-expert/lessons/mentions-beat-backlinks/lesson.md +16 -0
- package/packs/builtin/seo-aeo-expert/lessons/no-js-execution/lesson.md +18 -0
- package/packs/builtin/seo-aeo-expert/lessons/schema-actual-role/lesson.md +22 -0
- package/packs/builtin/seo-aeo-expert/lessons/schema-claims-need-ground-truth/lesson.md +34 -0
- package/packs/builtin/seo-aeo-expert/lessons/ugc-citation-channels/lesson.md +22 -0
- package/packs/builtin/seo-aeo-expert/manifest.yaml +128 -0
- package/packs/builtin/seo-aeo-expert/models.yaml +19 -0
- package/packs/builtin/seo-aeo-expert/skills/bot-policy-guard/skill.yaml +159 -0
- package/packs/builtin/seo-aeo-expert/skills/ground-truth-gate/skill.yaml +66 -0
- package/packs/builtin/seo-aeo-expert/skills/meta-quality-gate/skill.yaml +137 -0
- package/packs/builtin/seo-aeo-expert/skills/page-removal-guard/skill.yaml +30 -0
- package/packs/builtin/seo-aeo-expert/skills/pre-push-seo-checklist/skill.yaml +61 -0
- package/packs/builtin/seo-aeo-expert/skills/schema-validation-gate/skill.yaml +163 -0
- package/packs/builtin/seo-aeo-expert/skills/ssr-regression-guard/skill.yaml +58 -0
- package/packs/builtin/seo-aeo-expert/skills/stale-tactic-guard/skill.yaml +72 -0
- package/packs/builtin/task-spec-author/SKILL.md +469 -0
- package/packs/builtin/task-spec-author/manifest.yaml +41 -0
- package/packs/builtin/task-spec-author/skills-catalog.md +115 -0
- package/packs/builtin/task-spec-author/team.yaml +33 -0
- package/schemas/channels.schema.json +13 -0
- package/schemas/drift_response.schema.json +47 -0
- package/schemas/manifest.schema.json +904 -0
- package/schemas/models.schema.json +68 -0
- package/schemas/notifications.schema.json +64 -0
- package/schemas/skill.schema.json +556 -0
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Session-id resolution for hook binaries + the `.current-session` pointer.
|
|
3
|
+
*
|
|
4
|
+
* ROOT-CAUSE FIX (2026-05-26): the `stop` / `user-prompt-submit` /
|
|
5
|
+
* `pre-tool-use` hooks previously read the session id ONLY from
|
|
6
|
+
* `process.env.CLAUDE_SESSION_ID`, which Claude Code does not reliably set —
|
|
7
|
+
* it delivers `session_id` in the hook's stdin JSON payload (per the CC hook
|
|
8
|
+
* contract). The result: every session collapsed to the literal `'unknown'`
|
|
9
|
+
* bucket, so per-session state (the automation flag, the per-turn tool ledger)
|
|
10
|
+
* never keyed on the real session. `session-end.ts` was the only hook reading
|
|
11
|
+
* stdin correctly. `extractSessionId` centralizes the correct precedence:
|
|
12
|
+
* stdin `session_id` (snake) → `sessionId` (camel) → `CLAUDE_SESSION_ID` env
|
|
13
|
+
* (last-resort) → `'unknown'`.
|
|
14
|
+
*
|
|
15
|
+
* `.current-session` (at `OPENSQUID_HOME()/.current-session`) lets an
|
|
16
|
+
* out-of-band process — notably the `opensquid automation on|off` CLI run from
|
|
17
|
+
* a terminal that never receives the hook stdin — discover the live session id.
|
|
18
|
+
* The `user-prompt-submit` hook records it every turn (best-effort).
|
|
19
|
+
*
|
|
20
|
+
* Imports from: node:fs/promises, node:path, ../paths.js.
|
|
21
|
+
* Imported by: hooks/{stop,user-prompt-submit,pre-tool-use}.ts (resolve +
|
|
22
|
+
* record); setup/cli/automation.ts (read).
|
|
23
|
+
*/
|
|
24
|
+
import { mkdir, readFile, stat, writeFile } from 'node:fs/promises';
|
|
25
|
+
import { dirname, join } from 'node:path';
|
|
26
|
+
import { OPENSQUID_HOME, projectCurrentSessionPath, resolveProjectUuid } from '../paths.js';
|
|
27
|
+
/**
|
|
28
|
+
* Resolve the session id from a hook's raw stdin string. Precedence:
|
|
29
|
+
* stdin `session_id` → stdin `sessionId` → `CLAUDE_SESSION_ID` env → `'unknown'`.
|
|
30
|
+
* Never throws: a malformed/empty payload falls straight through to the env /
|
|
31
|
+
* `'unknown'` fallback so the calling hook stays fail-open.
|
|
32
|
+
*/
|
|
33
|
+
export function extractSessionId(raw) {
|
|
34
|
+
let obj = {};
|
|
35
|
+
try {
|
|
36
|
+
obj = JSON.parse(raw);
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
// fall through to env / 'unknown'
|
|
40
|
+
}
|
|
41
|
+
if (typeof obj.session_id === 'string' && obj.session_id !== '')
|
|
42
|
+
return obj.session_id;
|
|
43
|
+
if (typeof obj.sessionId === 'string' && obj.sessionId !== '')
|
|
44
|
+
return obj.sessionId;
|
|
45
|
+
const env = process.env.CLAUDE_SESSION_ID;
|
|
46
|
+
if (env !== undefined && env !== '')
|
|
47
|
+
return env;
|
|
48
|
+
return 'unknown';
|
|
49
|
+
}
|
|
50
|
+
/** Absolute path of the live-session pointer file. */
|
|
51
|
+
export const currentSessionPath = () => join(OPENSQUID_HOME(), '.current-session');
|
|
52
|
+
/**
|
|
53
|
+
* Record the live session id so out-of-band processes (the automation CLI) can
|
|
54
|
+
* target the session the hooks actually see. Best-effort: never throws, and
|
|
55
|
+
* never records the `'unknown'` sentinel (that would mislead the CLI).
|
|
56
|
+
*/
|
|
57
|
+
export async function recordCurrentSession(sessionId, cwd) {
|
|
58
|
+
// GF.2 — never record the synthetic sentinels: `unknown`/`''` (no real session) and
|
|
59
|
+
// `doctor-probe` (the id `opensquid doctor hooks` spawns its probe events with — it would
|
|
60
|
+
// otherwise CLOBBER the live `.current-session` pointer the git gate resolves against).
|
|
61
|
+
if (sessionId === 'unknown' || sessionId === '' || sessionId === 'doctor-probe')
|
|
62
|
+
return;
|
|
63
|
+
try {
|
|
64
|
+
await mkdir(OPENSQUID_HOME(), { recursive: true });
|
|
65
|
+
// Global pointer — back-compat for the automation CLI + lessons.ts (which
|
|
66
|
+
// read it without a project context). Last-writer-wins across all sessions.
|
|
67
|
+
await writeFile(currentSessionPath(), sessionId, 'utf-8');
|
|
68
|
+
// FU.3: project-scoped pointer — the race-free authority the MCP server
|
|
69
|
+
// reads. A concurrent session in ANOTHER project writes a different uuid's
|
|
70
|
+
// pointer and can't clobber this one. Skipped (no error) for a cwd that
|
|
71
|
+
// isn't inside a uuid-bound project (`.opensquid/project.json` absent).
|
|
72
|
+
if (cwd !== undefined && cwd !== '') {
|
|
73
|
+
const uuid = await resolveProjectUuid({ cwd });
|
|
74
|
+
if (uuid !== null) {
|
|
75
|
+
const scoped = projectCurrentSessionPath(uuid);
|
|
76
|
+
await mkdir(dirname(scoped), { recursive: true });
|
|
77
|
+
await writeFile(scoped, sessionId, 'utf-8');
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
catch {
|
|
82
|
+
// best-effort: a write failure must never break the hook
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
/** Read the global live session id, or `null` if absent/unreadable/empty. */
|
|
86
|
+
export async function readCurrentSession() {
|
|
87
|
+
try {
|
|
88
|
+
const raw = (await readFile(currentSessionPath(), 'utf-8')).trim();
|
|
89
|
+
return raw === '' ? null : raw;
|
|
90
|
+
}
|
|
91
|
+
catch {
|
|
92
|
+
return null;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
/** Read the project-scoped live session id, or `null` if absent/unreadable/empty. */
|
|
96
|
+
export async function readProjectCurrentSession(projectUuid) {
|
|
97
|
+
try {
|
|
98
|
+
const raw = (await readFile(projectCurrentSessionPath(projectUuid), 'utf-8')).trim();
|
|
99
|
+
return raw === '' ? null : raw;
|
|
100
|
+
}
|
|
101
|
+
catch {
|
|
102
|
+
return null;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* FU.7 — does `sessions/<id>/` exist? The existence of the per-session dir
|
|
107
|
+
* (created by the session's own hooks when they first write state) is the
|
|
108
|
+
* signal that an id is a REAL persisted session, not a stale/`--resume` env id.
|
|
109
|
+
* Fail-false on any stat error (absent dir → ENOENT → false).
|
|
110
|
+
*/
|
|
111
|
+
async function sessionDirExists(id) {
|
|
112
|
+
try {
|
|
113
|
+
return (await stat(join(OPENSQUID_HOME(), 'sessions', id))).isDirectory();
|
|
114
|
+
}
|
|
115
|
+
catch {
|
|
116
|
+
return false;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Session resolution for MCP tools (the MCP server is a separate process from
|
|
121
|
+
* the hooks, so it can't read hook stdin).
|
|
122
|
+
*
|
|
123
|
+
* T-RJ-FOLLOWUPS FU.3 (2026-06-01) — CORRECTION to MS.1. MS.1 assumed Claude
|
|
124
|
+
* Code sets `CLAUDE_SESSION_ID` in the MCP server's env; it does NOT — that
|
|
125
|
+
* exact name is never set, so the env step never fired and resolution always
|
|
126
|
+
* fell through to the GLOBAL `.current-session`, which any concurrent session in
|
|
127
|
+
* any project clobbers (last-writer-wins) — silently breaking this session's
|
|
128
|
+
* `log_phase` mid-task.
|
|
129
|
+
*
|
|
130
|
+
* FU.4 correction: CC DOES expose a session-id env var to stdio MCP servers —
|
|
131
|
+
* `CLAUDE_CODE_SESSION_ID` (plus `CLAUDE_PROJECT_DIR`). But it is NOT safe to key
|
|
132
|
+
* on: under `--resume` it holds a NEW id that differs from the persisted /
|
|
133
|
+
* transcript / hook-stdin id the state actually lives under (observed live:
|
|
134
|
+
* env `6c7527de…` while state + transcript were under `1200bc00…`, whose
|
|
135
|
+
* `sessions/<id>/` dir is the real one). So resolving by the env session id
|
|
136
|
+
* would point at an EMPTY session under resume. The project-scoped pointer is
|
|
137
|
+
* correct precisely because the UPS hook writes it with the hook-stdin id — the
|
|
138
|
+
* same id the state uses. (Using `CLAUDE_CODE_SESSION_ID` *guarded by
|
|
139
|
+
* `sessions/<id>/` existence* to also kill the same-project race is FU.7.)
|
|
140
|
+
*
|
|
141
|
+
* Fix: resolve via the PROJECT-SCOPED pointer, keyed by `CLAUDE_PROJECT_DIR`
|
|
142
|
+
* (which CC DOES provide) → `resolveProjectUuid`. A concurrent session in
|
|
143
|
+
* another repo writes a different project's pointer and can't clobber this one.
|
|
144
|
+
*
|
|
145
|
+
* ⚠️ Residual (documented, not solved here): two concurrent CC sessions in the
|
|
146
|
+
* SAME project still share one project pointer and race. Rare; a
|
|
147
|
+
* most-recently-active-task tiebreak is a follow-up.
|
|
148
|
+
*
|
|
149
|
+
* Precedence:
|
|
150
|
+
* 1. `process.env.CLAUDE_SESSION_ID` (kept — harmless if CC ever sets it)
|
|
151
|
+
* 2. `process.env.OPENSQUID_SESSION_ID` (override / test seam)
|
|
152
|
+
* 3. `process.env.CLAUDE_CODE_SESSION_ID` GUARDED by `sessions/<id>/` existence
|
|
153
|
+
* (FU.7) — CC's per-process id. When its session dir exists it is a real
|
|
154
|
+
* persisted session, which disambiguates two concurrent sessions in the
|
|
155
|
+
* SAME repo (distinct per-process ids → distinct dirs). Under `--resume`
|
|
156
|
+
* the env id is NEW and has no dir → the guard fails → fall through (safe).
|
|
157
|
+
* 4. project-scoped pointer via `CLAUDE_PROJECT_DIR`→`resolveProjectUuid`
|
|
158
|
+
* (race-free across projects — the real fix)
|
|
159
|
+
* 5. global `.current-session` (back-compat: single-session / no-project cwd)
|
|
160
|
+
*/
|
|
161
|
+
export async function resolveMcpSessionId() {
|
|
162
|
+
const env = process.env;
|
|
163
|
+
const fromClaudeEnv = env.CLAUDE_SESSION_ID;
|
|
164
|
+
if (fromClaudeEnv !== undefined && fromClaudeEnv.length > 0)
|
|
165
|
+
return fromClaudeEnv;
|
|
166
|
+
const fromOpensquidEnv = env.OPENSQUID_SESSION_ID;
|
|
167
|
+
if (fromOpensquidEnv !== undefined && fromOpensquidEnv.length > 0)
|
|
168
|
+
return fromOpensquidEnv;
|
|
169
|
+
// FU.7 — CC's per-process id, but ONLY when its session dir exists on disk
|
|
170
|
+
// (proves it's the id state actually lives under). Dir-less → --resume's new
|
|
171
|
+
// id → ignore, fall through to the project pointer.
|
|
172
|
+
const ccEnv = env.CLAUDE_CODE_SESSION_ID;
|
|
173
|
+
if (ccEnv !== undefined && ccEnv.length > 0 && (await sessionDirExists(ccEnv)))
|
|
174
|
+
return ccEnv;
|
|
175
|
+
const projectDir = env.CLAUDE_PROJECT_DIR;
|
|
176
|
+
if (projectDir !== undefined && projectDir.length > 0) {
|
|
177
|
+
const uuid = await resolveProjectUuid({ cwd: projectDir, env });
|
|
178
|
+
if (uuid !== null) {
|
|
179
|
+
const scoped = await readProjectCurrentSession(uuid);
|
|
180
|
+
if (scoped !== null)
|
|
181
|
+
return scoped;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
return readCurrentSession();
|
|
185
|
+
}
|
|
186
|
+
//# sourceMappingURL=session_id.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session_id.js","sourceRoot":"","sources":["../../../src/runtime/hooks/session_id.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Plausibility probe for a session id resolved from a stale-prone source
|
|
3
|
+
* (`.current-session` pointer). Stat-driven freshness check over the files
|
|
4
|
+
* the live PreToolUse hook continuously updates — `<home>/sessions/<id>/
|
|
5
|
+
* active-task.json` (mirror) and `state/tool-ledger.json` (per-tool append).
|
|
6
|
+
* Either one modified within `FRESH_MS` = live; both absent / older = stale.
|
|
7
|
+
*
|
|
8
|
+
* Caller (`automation.ts:resolveSessionId`) hard-fails on stale unless the
|
|
9
|
+
* user passes `--force` — the escape hatch for cases where the CLI is run
|
|
10
|
+
* before the first hook fires (otherwise legitimate; the `automation on` /
|
|
11
|
+
* `--session-id <id>` paths already bypass this probe entirely).
|
|
12
|
+
*
|
|
13
|
+
* The probe NEVER throws: an unreadable file is treated as "absent" so the
|
|
14
|
+
* loud-warn path catches a corrupted state dir too. It is also pure —
|
|
15
|
+
* no writes, no side effects, no env reads beyond `FRESH_MS()`.
|
|
16
|
+
*
|
|
17
|
+
* Imports from: node:fs/promises, ../paths.js.
|
|
18
|
+
* Imported by: src/setup/cli/automation.ts (the gate that uses it).
|
|
19
|
+
*/
|
|
20
|
+
/** Default freshness window: 30 minutes (`1_800_000` ms). */
|
|
21
|
+
export declare const DEFAULT_FRESH_MS = 1800000;
|
|
22
|
+
/**
|
|
23
|
+
* Resolve the freshness threshold from env, falling back to `DEFAULT_FRESH_MS`
|
|
24
|
+
* for unset / non-positive / non-numeric values. Read on every call (cheap,
|
|
25
|
+
* lets a wrapper script tune the window mid-session without re-import).
|
|
26
|
+
*/
|
|
27
|
+
export declare function FRESH_MS(): number;
|
|
28
|
+
export interface PlausibilityResult {
|
|
29
|
+
/** `true` iff at least one probed file was modified within the window. */
|
|
30
|
+
plausible: boolean;
|
|
31
|
+
/** Most-recent mtime ms across probed files, or `null` if none readable. */
|
|
32
|
+
newestMtimeMs: number | null;
|
|
33
|
+
/** Absolute paths probed — surfaced in the CLI's stderr for actionability. */
|
|
34
|
+
probedFiles: string[];
|
|
35
|
+
}
|
|
36
|
+
export interface PlausibilityOpts {
|
|
37
|
+
/** Injected clock (tests). Defaults to `Date.now`. */
|
|
38
|
+
nowMs?: () => number;
|
|
39
|
+
/** Override the freshness window for one call (tests). Defaults to `FRESH_MS()`. */
|
|
40
|
+
freshMs?: number;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* "Was this session id alive within the freshness window?" — yes iff any of
|
|
44
|
+
* the probed files has mtime within `freshMs` of `now`. Files missing or
|
|
45
|
+
* unreadable count as absent (NOT as errors); they just don't contribute a
|
|
46
|
+
* mtime.
|
|
47
|
+
*/
|
|
48
|
+
export declare function isSessionPlausible(sessionId: string, opts?: PlausibilityOpts): Promise<PlausibilityResult>;
|
|
49
|
+
//# sourceMappingURL=session_liveness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session_liveness.d.ts","sourceRoot":"","sources":["../../../src/runtime/hooks/session_liveness.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAMH,6DAA6D;AAC7D,eAAO,MAAM,gBAAgB,UAAY,CAAC;AAE1C;;;;GAIG;AACH,wBAAgB,QAAQ,IAAI,MAAM,CAKjC;AAED,MAAM,WAAW,kBAAkB;IACjC,0EAA0E;IAC1E,SAAS,EAAE,OAAO,CAAC;IACnB,4EAA4E;IAC5E,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,8EAA8E;IAC9E,WAAW,EAAE,MAAM,EAAE,CAAC;CACvB;AAED,MAAM,WAAW,gBAAgB;IAC/B,sDAAsD;IACtD,KAAK,CAAC,EAAE,MAAM,MAAM,CAAC;IACrB,oFAAoF;IACpF,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;;;;GAKG;AACH,wBAAsB,kBAAkB,CACtC,SAAS,EAAE,MAAM,EACjB,IAAI,GAAE,gBAAqB,GAC1B,OAAO,CAAC,kBAAkB,CAAC,CAqB7B"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Plausibility probe for a session id resolved from a stale-prone source
|
|
3
|
+
* (`.current-session` pointer). Stat-driven freshness check over the files
|
|
4
|
+
* the live PreToolUse hook continuously updates — `<home>/sessions/<id>/
|
|
5
|
+
* active-task.json` (mirror) and `state/tool-ledger.json` (per-tool append).
|
|
6
|
+
* Either one modified within `FRESH_MS` = live; both absent / older = stale.
|
|
7
|
+
*
|
|
8
|
+
* Caller (`automation.ts:resolveSessionId`) hard-fails on stale unless the
|
|
9
|
+
* user passes `--force` — the escape hatch for cases where the CLI is run
|
|
10
|
+
* before the first hook fires (otherwise legitimate; the `automation on` /
|
|
11
|
+
* `--session-id <id>` paths already bypass this probe entirely).
|
|
12
|
+
*
|
|
13
|
+
* The probe NEVER throws: an unreadable file is treated as "absent" so the
|
|
14
|
+
* loud-warn path catches a corrupted state dir too. It is also pure —
|
|
15
|
+
* no writes, no side effects, no env reads beyond `FRESH_MS()`.
|
|
16
|
+
*
|
|
17
|
+
* Imports from: node:fs/promises, ../paths.js.
|
|
18
|
+
* Imported by: src/setup/cli/automation.ts (the gate that uses it).
|
|
19
|
+
*/
|
|
20
|
+
import { stat } from 'node:fs/promises';
|
|
21
|
+
import { activeTaskFile, sessionStateFile } from '../paths.js';
|
|
22
|
+
/** Default freshness window: 30 minutes (`1_800_000` ms). */
|
|
23
|
+
export const DEFAULT_FRESH_MS = 1_800_000;
|
|
24
|
+
/**
|
|
25
|
+
* Resolve the freshness threshold from env, falling back to `DEFAULT_FRESH_MS`
|
|
26
|
+
* for unset / non-positive / non-numeric values. Read on every call (cheap,
|
|
27
|
+
* lets a wrapper script tune the window mid-session without re-import).
|
|
28
|
+
*/
|
|
29
|
+
export function FRESH_MS() {
|
|
30
|
+
const raw = process.env.OPENSQUID_SESSION_FRESH_MS;
|
|
31
|
+
if (raw === undefined || raw === '')
|
|
32
|
+
return DEFAULT_FRESH_MS;
|
|
33
|
+
const n = Number.parseInt(raw, 10);
|
|
34
|
+
return Number.isFinite(n) && n > 0 ? n : DEFAULT_FRESH_MS;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* "Was this session id alive within the freshness window?" — yes iff any of
|
|
38
|
+
* the probed files has mtime within `freshMs` of `now`. Files missing or
|
|
39
|
+
* unreadable count as absent (NOT as errors); they just don't contribute a
|
|
40
|
+
* mtime.
|
|
41
|
+
*/
|
|
42
|
+
export async function isSessionPlausible(sessionId, opts = {}) {
|
|
43
|
+
const now = (opts.nowMs ?? Date.now)();
|
|
44
|
+
const fresh = opts.freshMs ?? FRESH_MS();
|
|
45
|
+
// `tool-ledger` is written via `sessionStateFile` (suffix `.json`) per
|
|
46
|
+
// `runtime/session_state.ts:50,88` (LEDGER_KEY). It is NOT a JSONL log —
|
|
47
|
+
// do not reach for `sessionLogFile`, that would resolve to `.jsonl` and
|
|
48
|
+
// miss the real file.
|
|
49
|
+
const probedFiles = [activeTaskFile(sessionId), sessionStateFile(sessionId, 'tool-ledger')];
|
|
50
|
+
let newestMtimeMs = null;
|
|
51
|
+
for (const f of probedFiles) {
|
|
52
|
+
try {
|
|
53
|
+
const st = await stat(f);
|
|
54
|
+
const m = st.mtimeMs;
|
|
55
|
+
if (newestMtimeMs === null || m > newestMtimeMs)
|
|
56
|
+
newestMtimeMs = m;
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
// ENOENT / EACCES / etc. — treat as absent.
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
const plausible = newestMtimeMs !== null && now - newestMtimeMs < fresh;
|
|
63
|
+
return { plausible, newestMtimeMs, probedFiles };
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=session_liveness.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session_liveness.js","sourceRoot":"","sources":["../../../src/runtime/hooks/session_liveness.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAExC,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE/D,6DAA6D;AAC7D,MAAM,CAAC,MAAM,gBAAgB,GAAG,SAAS,CAAC;AAE1C;;;;GAIG;AACH,MAAM,UAAU,QAAQ;IACtB,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,0BAA0B,CAAC;IACnD,IAAI,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,EAAE;QAAE,OAAO,gBAAgB,CAAC;IAC7D,MAAM,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACnC,OAAO,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC;AAC5D,CAAC;AAkBD;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,SAAiB,EACjB,OAAyB,EAAE;IAE3B,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;IACvC,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,IAAI,QAAQ,EAAE,CAAC;IACzC,uEAAuE;IACvE,yEAAyE;IACzE,wEAAwE;IACxE,sBAAsB;IACtB,MAAM,WAAW,GAAG,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC,CAAC;IAE5F,IAAI,aAAa,GAAkB,IAAI,CAAC;IACxC,KAAK,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC;QAC5B,IAAI,CAAC;YACH,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC;YACzB,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC;YACrB,IAAI,aAAa,KAAK,IAAI,IAAI,CAAC,GAAG,aAAa;gBAAE,aAAa,GAAG,CAAC,CAAC;QACrE,CAAC;QAAC,MAAM,CAAC;YACP,4CAA4C;QAC9C,CAAC;IACH,CAAC;IACD,MAAM,SAAS,GAAG,aAAa,KAAK,IAAI,IAAI,GAAG,GAAG,aAAa,GAAG,KAAK,CAAC;IACxE,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC;AACnD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stop.d.ts","sourceRoot":"","sources":["../../../src/runtime/hooks/stop.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Claude Code `Stop` hook binary.
|
|
4
|
+
*
|
|
5
|
+
* Fires when the assistant emits a stop turn (end of an assistant message).
|
|
6
|
+
* Payload carries the assistant's final text — used by destination-check
|
|
7
|
+
* rules to evaluate "did the agent stay on the goal."
|
|
8
|
+
*
|
|
9
|
+
* Wired in `~/.claude/settings.json`:
|
|
10
|
+
*
|
|
11
|
+
* { "hooks": { "Stop": [{ "hooks": [{ "type": "command",
|
|
12
|
+
* "command": "opensquid-hook-stop" }] }] } }
|
|
13
|
+
*
|
|
14
|
+
* stdin = stop event JSON. exit 0 = allow (continue session normally),
|
|
15
|
+
* exit 2 = block (in practice this surfaces a warning to the agent; the
|
|
16
|
+
* stop itself can't be "blocked"). Stderr messages are shown.
|
|
17
|
+
*
|
|
18
|
+
* Fail-open on any internal error — see `main().catch()` below.
|
|
19
|
+
*/
|
|
20
|
+
import { buildRegistry, loadActivePacks } from '../bootstrap.js';
|
|
21
|
+
import { Event } from '../types.js';
|
|
22
|
+
import { dispatchEvent } from './dispatch.js';
|
|
23
|
+
import { extractSessionId } from './session_id.js';
|
|
24
|
+
import { emitDriftStderrAndExit, squidPrefix } from './hook_output.js';
|
|
25
|
+
import { claimUmbrellaLeaseForSession } from '../chat/claim_lease.js';
|
|
26
|
+
import { maybeDriveInbound, maybePeekInbound, extractCwd } from './stop_drive.js';
|
|
27
|
+
import { maybeStreamOutput } from './stop_stream.js';
|
|
28
|
+
import { readLastAssistantText } from './transcript.js';
|
|
29
|
+
function parsePayload(raw) {
|
|
30
|
+
const obj = JSON.parse(raw);
|
|
31
|
+
return {
|
|
32
|
+
kind: 'stop',
|
|
33
|
+
// Claude Code's Stop payload field name isn't 100% pinned across versions;
|
|
34
|
+
// accept camelCase, snake_case, or a generic `message` field.
|
|
35
|
+
assistantText: obj.assistantText ?? obj.assistant_text ?? obj.message ?? '',
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
/** Extract the transcript `.jsonl` path from a Stop payload (snake/camel). */
|
|
39
|
+
function extractTranscriptPath(raw) {
|
|
40
|
+
try {
|
|
41
|
+
const obj = JSON.parse(raw);
|
|
42
|
+
const p = obj.transcript_path ?? obj.transcriptPath;
|
|
43
|
+
return typeof p === 'string' && p.length > 0 ? p : null;
|
|
44
|
+
}
|
|
45
|
+
catch {
|
|
46
|
+
return null;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
async function readStdin() {
|
|
50
|
+
let data = '';
|
|
51
|
+
for await (const chunk of process.stdin)
|
|
52
|
+
data += chunk;
|
|
53
|
+
return data;
|
|
54
|
+
}
|
|
55
|
+
async function main() {
|
|
56
|
+
const raw = await readStdin();
|
|
57
|
+
if (!raw.trim()) {
|
|
58
|
+
process.stderr.write('opensquid: empty Stop payload — proceeding\n');
|
|
59
|
+
process.exit(0);
|
|
60
|
+
}
|
|
61
|
+
let normalized;
|
|
62
|
+
try {
|
|
63
|
+
normalized = parsePayload(raw);
|
|
64
|
+
}
|
|
65
|
+
catch (e) {
|
|
66
|
+
process.stderr.write(`opensquid: invalid Stop JSON — ${String(e)}\n`);
|
|
67
|
+
process.exit(0);
|
|
68
|
+
}
|
|
69
|
+
const parsed = Event.safeParse(normalized);
|
|
70
|
+
if (!parsed.success) {
|
|
71
|
+
process.stderr.write('opensquid: invalid Stop payload schema\n');
|
|
72
|
+
process.exit(0);
|
|
73
|
+
}
|
|
74
|
+
// HH7.1: Claude Code omits the assistant response text from Stop stdin, so
|
|
75
|
+
// `assistantText` is empty here. Recover the last assistant message from the
|
|
76
|
+
// transcript `.jsonl` (CC always provides `transcript_path`) so Stop-event
|
|
77
|
+
// gates that read assistantText (honesty-ledger, phase-logging) see what was
|
|
78
|
+
// written instead of an empty string. Fail-open: a transcript-read failure
|
|
79
|
+
// leaves assistantText '' (pre-fix behavior), never crashes the hook.
|
|
80
|
+
// ⚠️ SG.3 caveat: this is off-by-one (returns the PRIOR response if the
|
|
81
|
+
// triggering one isn't flushed yet) — see transcript.ts. recall-consumed was
|
|
82
|
+
// removed for relying on this to judge its own triggering response.
|
|
83
|
+
if (parsed.data.kind === 'stop' && parsed.data.assistantText === '') {
|
|
84
|
+
const transcriptPath = extractTranscriptPath(raw);
|
|
85
|
+
if (transcriptPath !== null) {
|
|
86
|
+
parsed.data.assistantText = await readLastAssistantText(transcriptPath);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
const sessionId = extractSessionId(raw);
|
|
90
|
+
const packs = await loadActivePacks(sessionId);
|
|
91
|
+
const registry = await buildRegistry();
|
|
92
|
+
const { exitCode, stderr } = await dispatchEvent(parsed.data, packs, registry, sessionId);
|
|
93
|
+
const cwd = extractCwd(raw);
|
|
94
|
+
// A drift BLOCK (exit≠0) still takes precedence — the run is NOT driven mid-run, so the
|
|
95
|
+
// no-pause discipline holds. But SURFACE any pending inbound in the drift stderr so a
|
|
96
|
+
// mid-run user message is never invisible (T-CHAT-INBOUND-SURFACE-MIDRUN). The peek is
|
|
97
|
+
// READ-ONLY (unacked), so the same message still DRIVES a proper response turn at the next
|
|
98
|
+
// clean stop (maybeDriveInbound below) — surfacing loses nothing.
|
|
99
|
+
if (exitCode !== 0) {
|
|
100
|
+
const peek = await maybePeekInbound(sessionId, cwd);
|
|
101
|
+
emitDriftStderrAndExit(exitCode, peek === null ? stderr : `${stderr}\n\n${peek}`);
|
|
102
|
+
}
|
|
103
|
+
// Interactive responder: this live session claims its umbrella's chat lease
|
|
104
|
+
// (acquire-if-free) so the drive below owns the turn + the headless stands
|
|
105
|
+
// down. No-op in `responder: headless` mode or when another session holds it.
|
|
106
|
+
await claimUmbrellaLeaseForSession(sessionId, cwd);
|
|
107
|
+
// CAT.3 — "see": if THIS just-completed turn was chat-driven (CAT.2 left the
|
|
108
|
+
// marker), stream the agent's answer back to the source topic automatically
|
|
109
|
+
// (reply-to-source; the agent never picks the channel). No-op otherwise.
|
|
110
|
+
const assistantText = parsed.data.kind === 'stop' ? parsed.data.assistantText : '';
|
|
111
|
+
await maybeStreamOutput(sessionId, cwd, assistantText);
|
|
112
|
+
// CAT.2 — "drive": if this session holds the umbrella's chat lease and has
|
|
113
|
+
// unacked inbound, block the stop and feed the inbound as the next turn so a
|
|
114
|
+
// chat message DRIVES a turn without a keystroke (the remote-terminal "drive").
|
|
115
|
+
const driveReason = await maybeDriveInbound(sessionId, cwd);
|
|
116
|
+
if (driveReason !== null) {
|
|
117
|
+
if (stderr.length > 0)
|
|
118
|
+
process.stderr.write(squidPrefix(stderr) + '\n');
|
|
119
|
+
process.stdout.write(JSON.stringify({ decision: 'block', reason: driveReason }) + '\n');
|
|
120
|
+
process.exit(0);
|
|
121
|
+
}
|
|
122
|
+
emitDriftStderrAndExit(0, stderr);
|
|
123
|
+
}
|
|
124
|
+
main().catch((e) => {
|
|
125
|
+
process.stderr.write(`opensquid hook crash (stop): ${String(e)}\n`);
|
|
126
|
+
process.exit(0);
|
|
127
|
+
});
|
|
128
|
+
//# sourceMappingURL=stop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stop.js","sourceRoot":"","sources":["../../../src/runtime/hooks/stop.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CAT.2 — Stop-hook inbound drive (extracted from the `stop.ts` bin so it is
|
|
3
|
+
* unit-testable; the bin self-runs `main()` on import).
|
|
4
|
+
*
|
|
5
|
+
* `maybeDriveInbound` decides whether a finished turn should be turned back
|
|
6
|
+
* into a new turn by an inbound chat message: it returns the block `reason`
|
|
7
|
+
* (the umbrella inbox envelope) when THIS session holds its umbrella's chat
|
|
8
|
+
* lease AND has unacked inbound; null otherwise. The Stop bin, on a clean
|
|
9
|
+
* (no-drift) stop, emits `{decision:'block', reason}` when this returns
|
|
10
|
+
* non-null — blocking the stop and feeding the inbound as the next turn.
|
|
11
|
+
*
|
|
12
|
+
* Lease gate (invariant #6): only the umbrella's live (lease-holding) session
|
|
13
|
+
* drives — a second same-umbrella session stays local-only, so a chat message
|
|
14
|
+
* drives exactly one session. The drain ACKS-BEFORE-RETURN, so a driven message
|
|
15
|
+
* never re-drives (the durable loop guard). Fail-open: null on any error.
|
|
16
|
+
*
|
|
17
|
+
* Imports from: ../../channels/routing, ../chat/inbox_drain, ../chat/session_routing.
|
|
18
|
+
* Imported by: src/runtime/hooks/stop.ts + tests.
|
|
19
|
+
*/
|
|
20
|
+
/** Extract the session cwd from a Stop payload (Claude Code provides `cwd`). */
|
|
21
|
+
export declare function extractCwd(raw: string): string;
|
|
22
|
+
/**
|
|
23
|
+
* Return the inbound envelope to drive a turn on (block `reason`), or null.
|
|
24
|
+
* See the module header for the lease + ack semantics.
|
|
25
|
+
*/
|
|
26
|
+
export declare function maybeDriveInbound(sessionId: string, cwd: string): Promise<string | null>;
|
|
27
|
+
/**
|
|
28
|
+
* READ-ONLY twin of {@link maybeDriveInbound} (T-CHAT-INBOUND-SURFACE-MIDRUN SF.2).
|
|
29
|
+
* Returns the umbrella inbox envelope for the lease-holding session WITHOUT acking and
|
|
30
|
+
* WITHOUT marking the turn chat-driven — for the Stop hook's drift branch to SURFACE a
|
|
31
|
+
* mid-run user message in the drift stderr while the run continues. Because it does not ack,
|
|
32
|
+
* the message still DRIVES a proper response turn at the next clean stop (via
|
|
33
|
+
* `maybeDriveInbound`). Lease-gated like the drive (only the live session surfaces, so a
|
|
34
|
+
* second same-umbrella session never double-surfaces). Fail-open: null on any error.
|
|
35
|
+
*/
|
|
36
|
+
export declare function maybePeekInbound(sessionId: string, cwd: string): Promise<string | null>;
|
|
37
|
+
//# sourceMappingURL=stop_drive.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stop_drive.d.ts","sourceRoot":"","sources":["../../../src/runtime/hooks/stop_drive.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAQH,gFAAgF;AAChF,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAO9C;AAED;;;GAGG;AACH,wBAAsB,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAiB9F;AAED;;;;;;;;GAQG;AACH,wBAAsB,gBAAgB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAa7F"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CAT.2 — Stop-hook inbound drive (extracted from the `stop.ts` bin so it is
|
|
3
|
+
* unit-testable; the bin self-runs `main()` on import).
|
|
4
|
+
*
|
|
5
|
+
* `maybeDriveInbound` decides whether a finished turn should be turned back
|
|
6
|
+
* into a new turn by an inbound chat message: it returns the block `reason`
|
|
7
|
+
* (the umbrella inbox envelope) when THIS session holds its umbrella's chat
|
|
8
|
+
* lease AND has unacked inbound; null otherwise. The Stop bin, on a clean
|
|
9
|
+
* (no-drift) stop, emits `{decision:'block', reason}` when this returns
|
|
10
|
+
* non-null — blocking the stop and feeding the inbound as the next turn.
|
|
11
|
+
*
|
|
12
|
+
* Lease gate (invariant #6): only the umbrella's live (lease-holding) session
|
|
13
|
+
* drives — a second same-umbrella session stays local-only, so a chat message
|
|
14
|
+
* drives exactly one session. The drain ACKS-BEFORE-RETURN, so a driven message
|
|
15
|
+
* never re-drives (the durable loop guard). Fail-open: null on any error.
|
|
16
|
+
*
|
|
17
|
+
* Imports from: ../../channels/routing, ../chat/inbox_drain, ../chat/session_routing.
|
|
18
|
+
* Imported by: src/runtime/hooks/stop.ts + tests.
|
|
19
|
+
*/
|
|
20
|
+
import { loadChannelsConfig, resolveUmbrellaForCwd } from '../../channels/routing.js';
|
|
21
|
+
import { drainUmbrellaInbox, peekUmbrellaInbox } from '../chat/inbox_drain.js';
|
|
22
|
+
import { resolveLiveSessionId } from '../chat/session_routing.js';
|
|
23
|
+
import { markChatDriven } from './stop_stream.js';
|
|
24
|
+
/** Extract the session cwd from a Stop payload (Claude Code provides `cwd`). */
|
|
25
|
+
export function extractCwd(raw) {
|
|
26
|
+
try {
|
|
27
|
+
const obj = JSON.parse(raw);
|
|
28
|
+
return typeof obj.cwd === 'string' && obj.cwd.length > 0 ? obj.cwd : process.cwd();
|
|
29
|
+
}
|
|
30
|
+
catch {
|
|
31
|
+
return process.cwd();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Return the inbound envelope to drive a turn on (block `reason`), or null.
|
|
36
|
+
* See the module header for the lease + ack semantics.
|
|
37
|
+
*/
|
|
38
|
+
export async function maybeDriveInbound(sessionId, cwd) {
|
|
39
|
+
try {
|
|
40
|
+
const cfg = await loadChannelsConfig().catch(() => null);
|
|
41
|
+
const umbrellaId = cfg === null ? null : resolveUmbrellaForCwd(cfg, cwd);
|
|
42
|
+
if (umbrellaId === null || umbrellaId === '')
|
|
43
|
+
return null;
|
|
44
|
+
// Lease holder = delivery target. Only the umbrella's live session drives.
|
|
45
|
+
const live = await resolveLiveSessionId(umbrellaId);
|
|
46
|
+
if (live !== sessionId)
|
|
47
|
+
return null;
|
|
48
|
+
const envelope = await drainUmbrellaInbox(sessionId, cwd);
|
|
49
|
+
if (envelope.length === 0)
|
|
50
|
+
return null;
|
|
51
|
+
// CAT.3: mark this umbrella's turn chat-driven so the NEXT Stop streams the
|
|
52
|
+
// agent's answer back to the source topic.
|
|
53
|
+
await markChatDriven(umbrellaId, sessionId);
|
|
54
|
+
return envelope;
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* READ-ONLY twin of {@link maybeDriveInbound} (T-CHAT-INBOUND-SURFACE-MIDRUN SF.2).
|
|
62
|
+
* Returns the umbrella inbox envelope for the lease-holding session WITHOUT acking and
|
|
63
|
+
* WITHOUT marking the turn chat-driven — for the Stop hook's drift branch to SURFACE a
|
|
64
|
+
* mid-run user message in the drift stderr while the run continues. Because it does not ack,
|
|
65
|
+
* the message still DRIVES a proper response turn at the next clean stop (via
|
|
66
|
+
* `maybeDriveInbound`). Lease-gated like the drive (only the live session surfaces, so a
|
|
67
|
+
* second same-umbrella session never double-surfaces). Fail-open: null on any error.
|
|
68
|
+
*/
|
|
69
|
+
export async function maybePeekInbound(sessionId, cwd) {
|
|
70
|
+
try {
|
|
71
|
+
const cfg = await loadChannelsConfig().catch(() => null);
|
|
72
|
+
const umbrellaId = cfg === null ? null : resolveUmbrellaForCwd(cfg, cwd);
|
|
73
|
+
if (umbrellaId === null || umbrellaId === '')
|
|
74
|
+
return null;
|
|
75
|
+
// Lease holder = delivery target. Only the umbrella's live session surfaces.
|
|
76
|
+
const live = await resolveLiveSessionId(umbrellaId);
|
|
77
|
+
if (live !== sessionId)
|
|
78
|
+
return null;
|
|
79
|
+
const envelope = await peekUmbrellaInbox(sessionId, cwd);
|
|
80
|
+
return envelope.length === 0 ? null : envelope;
|
|
81
|
+
}
|
|
82
|
+
catch {
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=stop_drive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stop_drive.js","sourceRoot":"","sources":["../../../src/runtime/hooks/stop_drive.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AACtF,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC/E,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAElE,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,gFAAgF;AAChF,MAAM,UAAU,UAAU,CAAC,GAAW;IACpC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAqB,CAAC;QAChD,OAAO,OAAO,GAAG,CAAC,GAAG,KAAK,QAAQ,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;IACrF,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,OAAO,CAAC,GAAG,EAAE,CAAC;IACvB,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,SAAiB,EAAE,GAAW;IACpE,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,kBAAkB,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;QACzD,MAAM,UAAU,GAAG,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,qBAAqB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACzE,IAAI,UAAU,KAAK,IAAI,IAAI,UAAU,KAAK,EAAE;YAAE,OAAO,IAAI,CAAC;QAC1D,2EAA2E;QAC3E,MAAM,IAAI,GAAG,MAAM,oBAAoB,CAAC,UAAU,CAAC,CAAC;QACpD,IAAI,IAAI,KAAK,SAAS;YAAE,OAAO,IAAI,CAAC;QACpC,MAAM,QAAQ,GAAG,MAAM,kBAAkB,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAC1D,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,CAAC;QACvC,4EAA4E;QAC5E,2CAA2C;QAC3C,MAAM,cAAc,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QAC5C,OAAO,QAAQ,CAAC;IAClB,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,SAAiB,EAAE,GAAW;IACnE,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,kBAAkB,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;QACzD,MAAM,UAAU,GAAG,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,qBAAqB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACzE,IAAI,UAAU,KAAK,IAAI,IAAI,UAAU,KAAK,EAAE;YAAE,OAAO,IAAI,CAAC;QAC1D,6EAA6E;QAC7E,MAAM,IAAI,GAAG,MAAM,oBAAoB,CAAC,UAAU,CAAC,CAAC;QACpD,IAAI,IAAI,KAAK,SAAS;YAAE,OAAO,IAAI,CAAC;QACpC,MAAM,QAAQ,GAAG,MAAM,iBAAiB,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QACzD,OAAO,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC;IACjD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CAT.3 — stream a chat-driven turn's OUTPUT back to its source topic.
|
|
3
|
+
*
|
|
4
|
+
* The symmetric half of CAT.2's drive. When CAT.2 drives a turn from an inbound
|
|
5
|
+
* chat message it leaves a marker (`markChatDriven`); when that turn completes,
|
|
6
|
+
* the Stop hook calls `maybeStreamOutput`, which — if the marker matches THIS
|
|
7
|
+
* session — sends the assistant's final text to the umbrella's outbound Telegram
|
|
8
|
+
* target (`resolveOutbound`, reply-to-source — the agent never picks the
|
|
9
|
+
* channel) and consumes the marker. Terminal-driven turns leave no marker, so
|
|
10
|
+
* they don't stream (chat-IN → chat-OUT; terminal-IN stays terminal — no flood).
|
|
11
|
+
*
|
|
12
|
+
* Outbound goes through the SAME daemon `send` RPC as `chat_send`
|
|
13
|
+
* (`defaultDaemonSend`), so it honors the one transport + the border invariant.
|
|
14
|
+
* Fail-open: any error / no umbrella / no marker / empty text → no send.
|
|
15
|
+
*
|
|
16
|
+
* Imports from: node:fs/promises, ../../channels/routing, ../paths,
|
|
17
|
+
* ../agent_bridge/tools/chat_send (the daemon-send seam).
|
|
18
|
+
* Imported by: src/runtime/hooks/{stop,stop_drive}.ts + tests.
|
|
19
|
+
*/
|
|
20
|
+
import type { DaemonSendFn } from '../agent_bridge/tools/chat_send.js';
|
|
21
|
+
/**
|
|
22
|
+
* Mark that the lease-holding `sessionId` just had a turn DRIVEN from chat for
|
|
23
|
+
* `umbrellaId`; the next Stop will stream that turn's output back. Best-effort.
|
|
24
|
+
*/
|
|
25
|
+
export declare function markChatDriven(umbrellaId: string, sessionId: string): Promise<void>;
|
|
26
|
+
/**
|
|
27
|
+
* If this session's just-completed turn was chat-driven, stream `assistantText`
|
|
28
|
+
* to the umbrella's source topic and consume the marker. Returns true iff it
|
|
29
|
+
* sent. `send` is injectable for tests (defaults to the daemon RPC).
|
|
30
|
+
*/
|
|
31
|
+
export declare function maybeStreamOutput(sessionId: string, cwd: string, assistantText: string, send?: DaemonSendFn): Promise<boolean>;
|
|
32
|
+
//# sourceMappingURL=stop_stream.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stop_stream.d.ts","sourceRoot":"","sources":["../../../src/runtime/hooks/stop_stream.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAUH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAIvE;;;GAGG;AACH,wBAAsB,cAAc,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAQzF;AAED;;;;GAIG;AACH,wBAAsB,iBAAiB,CACrC,SAAS,EAAE,MAAM,EACjB,GAAG,EAAE,MAAM,EACX,aAAa,EAAE,MAAM,EACrB,IAAI,GAAE,YAAgC,GACrC,OAAO,CAAC,OAAO,CAAC,CA4BlB"}
|