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 @@
|
|
|
1
|
+
{"version":3,"file":"session-end.d.ts","sourceRoot":"","sources":["../../src.legacy/hooks/session-end.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAaH,wBAAsB,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,CA+CvD"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `opensquid hook session-end` — Claude Code SessionEnd hook handler.
|
|
3
|
+
*
|
|
4
|
+
* Fires when a Claude Code session terminates. Wipes the session's
|
|
5
|
+
* honesty-ledger state (turn-ledger.jsonl + broken-promises.jsonl) so
|
|
6
|
+
* the ledger doesn't grow unbounded across all-time sessions.
|
|
7
|
+
*
|
|
8
|
+
* Without this hook, every Claude Code session creates a
|
|
9
|
+
* <data-root>/sessions/<id>/ directory with two JSONL files that
|
|
10
|
+
* never get cleaned up. Disk usage grows linearly with session count.
|
|
11
|
+
*
|
|
12
|
+
* Exit 0 always — SessionEnd is cleanup, not blocking.
|
|
13
|
+
*/
|
|
14
|
+
import { runDriftCatalogScan } from "./drift-catalog.js";
|
|
15
|
+
import { clearSession } from "./honesty-ledger.js";
|
|
16
|
+
export async function runSessionEndHook() {
|
|
17
|
+
let raw = "";
|
|
18
|
+
for await (const chunk of process.stdin) {
|
|
19
|
+
raw += chunk;
|
|
20
|
+
}
|
|
21
|
+
if (!raw.trim())
|
|
22
|
+
process.exit(0);
|
|
23
|
+
let payload;
|
|
24
|
+
try {
|
|
25
|
+
payload = JSON.parse(raw);
|
|
26
|
+
}
|
|
27
|
+
catch {
|
|
28
|
+
process.exit(0);
|
|
29
|
+
}
|
|
30
|
+
const sessionId = payload.session_id;
|
|
31
|
+
if (!sessionId)
|
|
32
|
+
process.exit(0);
|
|
33
|
+
// 0.7.22 / D10 — automated drift catalog. Scan the transcript for
|
|
34
|
+
// drift markers (user corrections, locked-rule citations, agent
|
|
35
|
+
// mea-culpas) and append to the project's drift-catalog.jsonl. Runs
|
|
36
|
+
// BEFORE clearSession so any session-scoped state used for context
|
|
37
|
+
// is still available.
|
|
38
|
+
try {
|
|
39
|
+
const count = await runDriftCatalogScan({
|
|
40
|
+
sessionId,
|
|
41
|
+
transcriptPath: payload.transcript_path,
|
|
42
|
+
cwd: payload.cwd,
|
|
43
|
+
});
|
|
44
|
+
if (count > 0) {
|
|
45
|
+
process.stderr.write(`🦑 [opensquid drift-catalog] recorded ${count} drift marker(s)\n`);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
catch (err) {
|
|
49
|
+
process.stderr.write(`[opensquid hook session-end] drift-catalog scan failed (non-fatal): ${err instanceof Error ? err.message : err}\n`);
|
|
50
|
+
}
|
|
51
|
+
try {
|
|
52
|
+
await clearSession(sessionId);
|
|
53
|
+
}
|
|
54
|
+
catch (err) {
|
|
55
|
+
// Cleanup failure is non-fatal — disk-space leak, not a correctness bug.
|
|
56
|
+
process.stderr.write(`[opensquid hook session-end] clearSession failed: ${err instanceof Error ? err.message : err}\n`);
|
|
57
|
+
}
|
|
58
|
+
process.exit(0);
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=session-end.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-end.js","sourceRoot":"","sources":["../../src.legacy/hooks/session-end.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAUnD,MAAM,CAAC,KAAK,UAAU,iBAAiB;IACrC,IAAI,GAAG,GAAG,EAAE,CAAC;IACb,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;QACxC,GAAG,IAAI,KAAK,CAAC;IACf,CAAC;IACD,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE;QAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAEjC,IAAI,OAAwB,CAAC;IAC7B,IAAI,CAAC;QACH,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,SAAS,GAAG,OAAO,CAAC,UAAU,CAAC;IACrC,IAAI,CAAC,SAAS;QAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAEhC,kEAAkE;IAClE,gEAAgE;IAChE,oEAAoE;IACpE,mEAAmE;IACnE,sBAAsB;IACtB,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,MAAM,mBAAmB,CAAC;YACtC,SAAS;YACT,cAAc,EAAE,OAAO,CAAC,eAAe;YACvC,GAAG,EAAE,OAAO,CAAC,GAAG;SACjB,CAAC,CAAC;QACH,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;YACd,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,yCAAyC,KAAK,oBAAoB,CAAC,CAAC;QAC3F,CAAC;IACH,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,uEAAuE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CACpH,CAAC;IACJ,CAAC;IAED,IAAI,CAAC;QACH,MAAM,YAAY,CAAC,SAAS,CAAC,CAAC;IAChC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,yEAAyE;QACzE,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,qDAAqD,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAClG,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import * as crypto from "node:crypto";
|
|
2
|
+
import { promises as fs } from "node:fs";
|
|
3
|
+
import * as os from "node:os";
|
|
4
|
+
import * as path from "node:path";
|
|
5
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
6
|
+
import { clearSession, readBrokenPromises, readTurnLedger, recordBrokenPromise, recordToolCall, } from "./honesty-ledger.js";
|
|
7
|
+
let tmpRoot;
|
|
8
|
+
const SESSION = "session-end-test";
|
|
9
|
+
beforeEach(async () => {
|
|
10
|
+
tmpRoot = path.join(os.tmpdir(), `oscli-session-end-${crypto.randomUUID()}`);
|
|
11
|
+
await fs.mkdir(tmpRoot, { recursive: true });
|
|
12
|
+
});
|
|
13
|
+
afterEach(async () => {
|
|
14
|
+
await fs.rm(tmpRoot, { recursive: true, force: true });
|
|
15
|
+
});
|
|
16
|
+
describe("SessionEnd cleanup (clearSession via the hook)", () => {
|
|
17
|
+
it("wipes both ledger and broken-promises after population", async () => {
|
|
18
|
+
await recordToolCall(SESSION, "Bash", "npm test", { dataRoot: tmpRoot });
|
|
19
|
+
await recordToolCall(SESSION, "Bash", "git commit -m foo", { dataRoot: tmpRoot });
|
|
20
|
+
await recordBrokenPromise(SESSION, {
|
|
21
|
+
ts: "2026-05-15T00:00:00Z",
|
|
22
|
+
claim_id: "fake",
|
|
23
|
+
claim_label: "x",
|
|
24
|
+
matched_text: "y",
|
|
25
|
+
reason: "z",
|
|
26
|
+
}, { dataRoot: tmpRoot });
|
|
27
|
+
// Sanity-check the precondition.
|
|
28
|
+
expect((await readTurnLedger(SESSION, { dataRoot: tmpRoot })).length).toBe(2);
|
|
29
|
+
expect((await readBrokenPromises(SESSION, { dataRoot: tmpRoot })).length).toBe(1);
|
|
30
|
+
// SessionEnd action.
|
|
31
|
+
await clearSession(SESSION, { dataRoot: tmpRoot });
|
|
32
|
+
expect(await readTurnLedger(SESSION, { dataRoot: tmpRoot })).toEqual([]);
|
|
33
|
+
expect(await readBrokenPromises(SESSION, { dataRoot: tmpRoot })).toEqual([]);
|
|
34
|
+
});
|
|
35
|
+
it("session directory remains, just empty of ledger files", async () => {
|
|
36
|
+
await recordToolCall(SESSION, "Bash", "ls", { dataRoot: tmpRoot });
|
|
37
|
+
await clearSession(SESSION, { dataRoot: tmpRoot });
|
|
38
|
+
// The sessions/<id>/ directory itself is preserved (cheap),
|
|
39
|
+
// only the JSONL files inside are removed.
|
|
40
|
+
const dir = path.join(tmpRoot, "sessions", SESSION);
|
|
41
|
+
await expect(fs.access(dir)).resolves.toBeUndefined();
|
|
42
|
+
const entries = await fs.readdir(dir);
|
|
43
|
+
expect(entries).toEqual([]);
|
|
44
|
+
});
|
|
45
|
+
it("does NOT touch other sessions' ledgers", async () => {
|
|
46
|
+
await recordToolCall(SESSION, "Bash", "ls", { dataRoot: tmpRoot });
|
|
47
|
+
await recordToolCall("other-session", "Bash", "ls", { dataRoot: tmpRoot });
|
|
48
|
+
await clearSession(SESSION, { dataRoot: tmpRoot });
|
|
49
|
+
expect((await readTurnLedger(SESSION, { dataRoot: tmpRoot })).length).toBe(0);
|
|
50
|
+
expect((await readTurnLedger("other-session", { dataRoot: tmpRoot })).length).toBe(1);
|
|
51
|
+
});
|
|
52
|
+
});
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `opensquid hook stop` — Claude Code Stop hook handler.
|
|
3
|
+
*
|
|
4
|
+
* Fires at the end of every assistant turn. Two responsibilities:
|
|
5
|
+
*
|
|
6
|
+
* 1. Honesty ledger reconciliation: cross-reference the assistant's
|
|
7
|
+
* final message against the session's accumulated tool-call ledger.
|
|
8
|
+
* Any unfulfilled claim is recorded as a broken promise that the
|
|
9
|
+
* next turn's UserPromptSubmit hook surfaces back to the agent.
|
|
10
|
+
*
|
|
11
|
+
* 2. Token-threshold heartbeat: estimate transcript token count, and
|
|
12
|
+
* if the conversation has grown past the configured threshold
|
|
13
|
+
* since the last checkpoint, arm a pending heartbeat marker so
|
|
14
|
+
* the next UserPromptSubmit hook injects a re-anchor nudge into
|
|
15
|
+
* the agent's context. The agent (already authenticated and in
|
|
16
|
+
* the loop) does the actual recall + classify work inline.
|
|
17
|
+
*
|
|
18
|
+
* Exit 0 always — Stop hook is observational, not blocking.
|
|
19
|
+
*
|
|
20
|
+
* Wired in ~/.claude/settings.json:
|
|
21
|
+
*
|
|
22
|
+
* "Stop": [
|
|
23
|
+
* { "hooks": [{
|
|
24
|
+
* "type": "command",
|
|
25
|
+
* "command": "node /path/to/opensquid/dist/index.js hook stop"
|
|
26
|
+
* }] }
|
|
27
|
+
* ]
|
|
28
|
+
*
|
|
29
|
+
* Pre-#124: this hook also spawned a detached LLM-classifier subprocess.
|
|
30
|
+
* Removed in favor of the heartbeat path — opensquid stays in-MCP-ecosystem
|
|
31
|
+
* (no external LLM dependency, no subprocess), and the agent does the
|
|
32
|
+
* classification work inline per CLAUDE.md classify-and-act rules.
|
|
33
|
+
*/
|
|
34
|
+
export declare function runStopHook(): Promise<void>;
|
|
35
|
+
//# sourceMappingURL=stop.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stop.d.ts","sourceRoot":"","sources":["../../src.legacy/hooks/stop.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AAmBH,wBAAsB,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC,CA4GjD"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `opensquid hook stop` — Claude Code Stop hook handler.
|
|
3
|
+
*
|
|
4
|
+
* Fires at the end of every assistant turn. Two responsibilities:
|
|
5
|
+
*
|
|
6
|
+
* 1. Honesty ledger reconciliation: cross-reference the assistant's
|
|
7
|
+
* final message against the session's accumulated tool-call ledger.
|
|
8
|
+
* Any unfulfilled claim is recorded as a broken promise that the
|
|
9
|
+
* next turn's UserPromptSubmit hook surfaces back to the agent.
|
|
10
|
+
*
|
|
11
|
+
* 2. Token-threshold heartbeat: estimate transcript token count, and
|
|
12
|
+
* if the conversation has grown past the configured threshold
|
|
13
|
+
* since the last checkpoint, arm a pending heartbeat marker so
|
|
14
|
+
* the next UserPromptSubmit hook injects a re-anchor nudge into
|
|
15
|
+
* the agent's context. The agent (already authenticated and in
|
|
16
|
+
* the loop) does the actual recall + classify work inline.
|
|
17
|
+
*
|
|
18
|
+
* Exit 0 always — Stop hook is observational, not blocking.
|
|
19
|
+
*
|
|
20
|
+
* Wired in ~/.claude/settings.json:
|
|
21
|
+
*
|
|
22
|
+
* "Stop": [
|
|
23
|
+
* { "hooks": [{
|
|
24
|
+
* "type": "command",
|
|
25
|
+
* "command": "node /path/to/opensquid/dist/index.js hook stop"
|
|
26
|
+
* }] }
|
|
27
|
+
* ]
|
|
28
|
+
*
|
|
29
|
+
* Pre-#124: this hook also spawned a detached LLM-classifier subprocess.
|
|
30
|
+
* Removed in favor of the heartbeat path — opensquid stays in-MCP-ecosystem
|
|
31
|
+
* (no external LLM dependency, no subprocess), and the agent does the
|
|
32
|
+
* classification work inline per CLAUDE.md classify-and-act rules.
|
|
33
|
+
*/
|
|
34
|
+
import { clearTurnLedger, reconcile, readBrokenPromises, readTurnLedger, recordBrokenPromise, } from "./honesty-ledger.js";
|
|
35
|
+
import { checkAndMaybeArm } from "./heartbeat.js";
|
|
36
|
+
import { checkInlineReportFormat } from "./inline-report-check.js";
|
|
37
|
+
import { readLastAssistantText } from "./transcript.js";
|
|
38
|
+
export async function runStopHook() {
|
|
39
|
+
let raw = "";
|
|
40
|
+
for await (const chunk of process.stdin) {
|
|
41
|
+
raw += chunk;
|
|
42
|
+
}
|
|
43
|
+
if (!raw.trim()) {
|
|
44
|
+
process.exit(0);
|
|
45
|
+
}
|
|
46
|
+
let payload;
|
|
47
|
+
try {
|
|
48
|
+
payload = JSON.parse(raw);
|
|
49
|
+
}
|
|
50
|
+
catch {
|
|
51
|
+
process.stderr.write("[opensquid hook stop] malformed input — proceeding\n");
|
|
52
|
+
process.exit(0);
|
|
53
|
+
}
|
|
54
|
+
const sessionId = payload.session_id;
|
|
55
|
+
if (!sessionId)
|
|
56
|
+
process.exit(0);
|
|
57
|
+
// -- (1) Honesty-ledger reconcile ----------------------------------
|
|
58
|
+
const assistantText = payload.transcript_path
|
|
59
|
+
? await readLastAssistantText(payload.transcript_path)
|
|
60
|
+
: "";
|
|
61
|
+
const ledger = await readTurnLedger(sessionId);
|
|
62
|
+
const broken = reconcile(assistantText, ledger);
|
|
63
|
+
const existing = await readBrokenPromises(sessionId);
|
|
64
|
+
const existingKeys = new Set(existing.map((p) => `${p.claim_id}|${p.matched_text}`));
|
|
65
|
+
const fresh = [];
|
|
66
|
+
for (const promise of broken) {
|
|
67
|
+
const key = `${promise.claim_id}|${promise.matched_text}`;
|
|
68
|
+
if (existingKeys.has(key))
|
|
69
|
+
continue;
|
|
70
|
+
fresh.push(promise);
|
|
71
|
+
try {
|
|
72
|
+
await recordBrokenPromise(sessionId, promise);
|
|
73
|
+
}
|
|
74
|
+
catch (err) {
|
|
75
|
+
process.stderr.write(`[opensquid hook stop] failed to record promise: ${err instanceof Error ? err.message : err}\n`);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
if (fresh.length > 0) {
|
|
79
|
+
for (const p of fresh) {
|
|
80
|
+
process.stderr.write(`🦑 [opensquid honesty] ${p.claim_id}: ${p.reason}\n`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
// 0.7.30 / D3 follow-up — when the agent writes a completion-report-
|
|
84
|
+
// shaped status update inline (vs. via mcp__opensquid__chat_send),
|
|
85
|
+
// D3's chat_send check doesn't fire. Catch the inline case here at
|
|
86
|
+
// Stop time and surface as a broken-promise next turn.
|
|
87
|
+
if (assistantText) {
|
|
88
|
+
const inlineViolation = checkInlineReportFormat(assistantText);
|
|
89
|
+
if (inlineViolation) {
|
|
90
|
+
const broken = {
|
|
91
|
+
ts: new Date().toISOString(),
|
|
92
|
+
claim_id: "inline-report-missing-phases",
|
|
93
|
+
claim_label: "PHASES block per [[feedback_telegram_reports]]",
|
|
94
|
+
matched_text: inlineViolation.matched_text,
|
|
95
|
+
reason: `inline message shape suggests a completion report ` +
|
|
96
|
+
`(version_refs=${inlineViolation.signals.version_refs}, ` +
|
|
97
|
+
`commit_hashes=${inlineViolation.signals.hash_refs}) but the ` +
|
|
98
|
+
`PHASES heading is missing. Catches D3 inline variant.`,
|
|
99
|
+
};
|
|
100
|
+
try {
|
|
101
|
+
await recordBrokenPromise(sessionId, broken);
|
|
102
|
+
process.stderr.write(`🦑 [opensquid honesty] ${broken.claim_id}: ${broken.reason}\n`);
|
|
103
|
+
}
|
|
104
|
+
catch (err) {
|
|
105
|
+
process.stderr.write(`[opensquid hook stop] inline-report check write failed: ${err instanceof Error ? err.message : err}\n`);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
// 0.7.8 (#162): clear the turn-ledger AFTER reconciliation so the
|
|
110
|
+
// next turn's claims reconcile against ONLY that turn's tool calls.
|
|
111
|
+
// Previously the ledger only cleared at SessionEnd, which meant
|
|
112
|
+
// yesterday's git push satisfied today's "I'll push" claim on long
|
|
113
|
+
// resumed sessions — the load-bearing #160 finding for ledger drift.
|
|
114
|
+
try {
|
|
115
|
+
await clearTurnLedger(sessionId);
|
|
116
|
+
}
|
|
117
|
+
catch (err) {
|
|
118
|
+
process.stderr.write(`[opensquid hook stop] turn-ledger clear failed (non-fatal): ${err instanceof Error ? err.message : err}\n`);
|
|
119
|
+
}
|
|
120
|
+
// -- (2) Token-threshold heartbeat ---------------------------------
|
|
121
|
+
if (payload.transcript_path) {
|
|
122
|
+
try {
|
|
123
|
+
const armed = await checkAndMaybeArm(sessionId, payload.transcript_path);
|
|
124
|
+
if (armed) {
|
|
125
|
+
// Surface to stderr too so the user sees that opensquid noticed
|
|
126
|
+
// drift (in addition to the agent seeing it next turn via UPS).
|
|
127
|
+
process.stderr.write(`🦑 [opensquid heartbeat-armed] ${armed}\n`);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
catch (err) {
|
|
131
|
+
process.stderr.write(`[opensquid hook stop] heartbeat check failed (non-fatal): ${err instanceof Error ? err.message : err}\n`);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
process.exit(0);
|
|
135
|
+
}
|
|
136
|
+
//# sourceMappingURL=stop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stop.js","sourceRoot":"","sources":["../../src.legacy/hooks/stop.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AAEH,OAAO,EACL,eAAe,EACf,SAAS,EACT,kBAAkB,EAClB,cAAc,EACd,mBAAmB,GAEpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAOxD,MAAM,CAAC,KAAK,UAAU,WAAW;IAC/B,IAAI,GAAG,GAAG,EAAE,CAAC;IACb,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;QACxC,GAAG,IAAI,KAAK,CAAC;IACf,CAAC;IACD,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC;QAChB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IACD,IAAI,OAAsB,CAAC;IAC3B,IAAI,CAAC;QACH,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC7E,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,SAAS,GAAG,OAAO,CAAC,UAAU,CAAC;IACrC,IAAI,CAAC,SAAS;QAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAEhC,qEAAqE;IACrE,MAAM,aAAa,GAAG,OAAO,CAAC,eAAe;QAC3C,CAAC,CAAC,MAAM,qBAAqB,CAAC,OAAO,CAAC,eAAe,CAAC;QACtD,CAAC,CAAC,EAAE,CAAC;IAEP,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,SAAS,CAAC,CAAC;IAC/C,MAAM,MAAM,GAAG,SAAS,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;IAEhD,MAAM,QAAQ,GAAG,MAAM,kBAAkB,CAAC,SAAS,CAAC,CAAC;IACrD,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;IACrF,MAAM,KAAK,GAAoB,EAAE,CAAC;IAClC,KAAK,MAAM,OAAO,IAAI,MAAM,EAAE,CAAC;QAC7B,MAAM,GAAG,GAAG,GAAG,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;QAC1D,IAAI,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC;YAAE,SAAS;QACpC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpB,IAAI,CAAC;YACH,MAAM,mBAAmB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAChD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,mDAAmD,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAChG,CAAC;QACJ,CAAC;IACH,CAAC;IAED,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrB,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;YACtB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC;QAC9E,CAAC;IACH,CAAC;IAED,qEAAqE;IACrE,mEAAmE;IACnE,mEAAmE;IACnE,uDAAuD;IACvD,IAAI,aAAa,EAAE,CAAC;QAClB,MAAM,eAAe,GAAG,uBAAuB,CAAC,aAAa,CAAC,CAAC;QAC/D,IAAI,eAAe,EAAE,CAAC;YACpB,MAAM,MAAM,GAAkB;gBAC5B,EAAE,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBAC5B,QAAQ,EAAE,8BAA8B;gBACxC,WAAW,EAAE,gDAAgD;gBAC7D,YAAY,EAAE,eAAe,CAAC,YAAY;gBAC1C,MAAM,EACJ,oDAAoD;oBACpD,iBAAiB,eAAe,CAAC,OAAO,CAAC,YAAY,IAAI;oBACzD,iBAAiB,eAAe,CAAC,OAAO,CAAC,SAAS,YAAY;oBAC9D,uDAAuD;aAC1D,CAAC;YACF,IAAI,CAAC;gBACH,MAAM,mBAAmB,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;gBAC7C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,MAAM,CAAC,QAAQ,KAAK,MAAM,CAAC,MAAM,IAAI,CAAC,CAAC;YACxF,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,2DAA2D,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CACxG,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC;IAED,kEAAkE;IAClE,oEAAoE;IACpE,gEAAgE;IAChE,mEAAmE;IACnE,qEAAqE;IACrE,IAAI,CAAC;QACH,MAAM,eAAe,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,+DAA+D,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAC5G,CAAC;IACJ,CAAC;IAED,qEAAqE;IACrE,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;QAC5B,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,MAAM,gBAAgB,CAAC,SAAS,EAAE,OAAO,CAAC,eAAe,CAAC,CAAC;YACzE,IAAI,KAAK,EAAE,CAAC;gBACV,gEAAgE;gBAChE,gEAAgE;gBAChE,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,kCAAkC,KAAK,IAAI,CAAC,CAAC;YACpE,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,6DAA6D,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAC1G,CAAC;QACJ,CAAC;IACH,CAAC;IAED,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,342 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for `readActiveTaskId` — the transcript-walking helper that
|
|
3
|
+
* finds the most-recent TodoWrite in_progress task id. Used by the
|
|
4
|
+
* workflow gate to figure out which task's phase ledger to query.
|
|
5
|
+
*/
|
|
6
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
7
|
+
import * as crypto from "node:crypto";
|
|
8
|
+
import { promises as fs } from "node:fs";
|
|
9
|
+
import * as os from "node:os";
|
|
10
|
+
import * as path from "node:path";
|
|
11
|
+
import { fileURLToPath } from "node:url";
|
|
12
|
+
import { readActiveTaskId } from "./transcript.js";
|
|
13
|
+
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
14
|
+
let tmpDir;
|
|
15
|
+
let transcriptPath;
|
|
16
|
+
beforeEach(async () => {
|
|
17
|
+
tmpDir = path.join(os.tmpdir(), `opensquid-tx-${crypto.randomUUID()}`);
|
|
18
|
+
await fs.mkdir(tmpDir, { recursive: true });
|
|
19
|
+
transcriptPath = path.join(tmpDir, "transcript.jsonl");
|
|
20
|
+
});
|
|
21
|
+
afterEach(async () => {
|
|
22
|
+
await fs.rm(tmpDir, { recursive: true, force: true });
|
|
23
|
+
});
|
|
24
|
+
async function writeEvents(events) {
|
|
25
|
+
const lines = events.map((e) => JSON.stringify(e)).join("\n") + "\n";
|
|
26
|
+
await fs.writeFile(transcriptPath, lines, "utf8");
|
|
27
|
+
}
|
|
28
|
+
function todoWriteEvent(todos) {
|
|
29
|
+
return {
|
|
30
|
+
type: "assistant",
|
|
31
|
+
message: {
|
|
32
|
+
role: "assistant",
|
|
33
|
+
content: [
|
|
34
|
+
{
|
|
35
|
+
type: "tool_use",
|
|
36
|
+
name: "TodoWrite",
|
|
37
|
+
input: { todos },
|
|
38
|
+
},
|
|
39
|
+
],
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
describe("readActiveTaskId", () => {
|
|
44
|
+
it("returns null when transcript doesn't exist", async () => {
|
|
45
|
+
expect(await readActiveTaskId(path.join(tmpDir, "missing.jsonl"))).toBeNull();
|
|
46
|
+
});
|
|
47
|
+
it("returns null when transcript is empty", async () => {
|
|
48
|
+
await fs.writeFile(transcriptPath, "", "utf8");
|
|
49
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
50
|
+
});
|
|
51
|
+
it("returns null when no TodoWrite block exists", async () => {
|
|
52
|
+
await writeEvents([
|
|
53
|
+
{ type: "user", message: { role: "user", content: "hi" } },
|
|
54
|
+
{ type: "assistant", message: { role: "assistant", content: "hello" } },
|
|
55
|
+
]);
|
|
56
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
57
|
+
});
|
|
58
|
+
it("returns null when TodoWrite has no in_progress items", async () => {
|
|
59
|
+
await writeEvents([
|
|
60
|
+
todoWriteEvent([
|
|
61
|
+
{ id: "1", status: "completed" },
|
|
62
|
+
{ id: "2", status: "pending" },
|
|
63
|
+
]),
|
|
64
|
+
]);
|
|
65
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
66
|
+
});
|
|
67
|
+
it("returns the in_progress task id from a single TodoWrite", async () => {
|
|
68
|
+
await writeEvents([
|
|
69
|
+
todoWriteEvent([
|
|
70
|
+
{ id: "1", status: "completed" },
|
|
71
|
+
{ id: "2", status: "in_progress" },
|
|
72
|
+
{ id: "3", status: "pending" },
|
|
73
|
+
]),
|
|
74
|
+
]);
|
|
75
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("2");
|
|
76
|
+
});
|
|
77
|
+
it("prefers the MOST RECENT TodoWrite when multiple exist", async () => {
|
|
78
|
+
await writeEvents([
|
|
79
|
+
todoWriteEvent([{ id: "old-task", status: "in_progress" }]),
|
|
80
|
+
todoWriteEvent([{ id: "newer-task", status: "in_progress" }]),
|
|
81
|
+
]);
|
|
82
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("newer-task");
|
|
83
|
+
});
|
|
84
|
+
it("stops at the most-recent TodoWrite even if its in_progress is null", async () => {
|
|
85
|
+
// The MOST RECENT TodoWrite has no in_progress (all completed).
|
|
86
|
+
// We must NOT fall back to an OLDER TodoWrite's in_progress that
|
|
87
|
+
// may have been overwritten. Returns null.
|
|
88
|
+
await writeEvents([
|
|
89
|
+
todoWriteEvent([{ id: "stale-task", status: "in_progress" }]),
|
|
90
|
+
todoWriteEvent([
|
|
91
|
+
{ id: "stale-task", status: "completed" },
|
|
92
|
+
{ id: "all-done", status: "completed" },
|
|
93
|
+
]),
|
|
94
|
+
]);
|
|
95
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
96
|
+
});
|
|
97
|
+
it("ignores non-assistant events between TodoWrites", async () => {
|
|
98
|
+
await writeEvents([
|
|
99
|
+
{ type: "user", message: { role: "user", content: "do thing" } },
|
|
100
|
+
todoWriteEvent([{ id: "active", status: "in_progress" }]),
|
|
101
|
+
{ type: "user", message: { role: "user", content: "now go" } },
|
|
102
|
+
]);
|
|
103
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("active");
|
|
104
|
+
});
|
|
105
|
+
it("ignores assistant text events without tool_use blocks", async () => {
|
|
106
|
+
await writeEvents([
|
|
107
|
+
todoWriteEvent([{ id: "real-active", status: "in_progress" }]),
|
|
108
|
+
{
|
|
109
|
+
type: "assistant",
|
|
110
|
+
message: {
|
|
111
|
+
role: "assistant",
|
|
112
|
+
content: [{ type: "text", text: "thinking..." }],
|
|
113
|
+
},
|
|
114
|
+
},
|
|
115
|
+
]);
|
|
116
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("real-active");
|
|
117
|
+
});
|
|
118
|
+
it("ignores other tool_use events (Bash, Edit, etc.)", async () => {
|
|
119
|
+
await writeEvents([
|
|
120
|
+
todoWriteEvent([{ id: "active", status: "in_progress" }]),
|
|
121
|
+
{
|
|
122
|
+
type: "assistant",
|
|
123
|
+
message: {
|
|
124
|
+
role: "assistant",
|
|
125
|
+
content: [{ type: "tool_use", name: "Bash", input: { command: "ls" } }],
|
|
126
|
+
},
|
|
127
|
+
},
|
|
128
|
+
]);
|
|
129
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("active");
|
|
130
|
+
});
|
|
131
|
+
it("coerces numeric ids to strings", async () => {
|
|
132
|
+
await writeEvents([
|
|
133
|
+
todoWriteEvent([
|
|
134
|
+
// Some serializations encode id as number.
|
|
135
|
+
{ id: 127, status: "in_progress" },
|
|
136
|
+
]),
|
|
137
|
+
]);
|
|
138
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("127");
|
|
139
|
+
});
|
|
140
|
+
it("handles malformed JSON lines gracefully", async () => {
|
|
141
|
+
await fs.writeFile(transcriptPath, [
|
|
142
|
+
"{ malformed",
|
|
143
|
+
JSON.stringify(todoWriteEvent([{ id: "active", status: "in_progress" }])),
|
|
144
|
+
"still bad json",
|
|
145
|
+
].join("\n"), "utf8");
|
|
146
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("active");
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
// =====================================================================
|
|
150
|
+
// v0.6.2 — TaskCreate + TaskUpdate recognition (the real-world Claude
|
|
151
|
+
// Code shape; TodoWrite was the v0.6.1 shape). My own dogfood session
|
|
152
|
+
// today used TaskCreate/TaskUpdate exclusively → workflow gate silent-
|
|
153
|
+
// allowed every commit because readActiveTaskId only recognized
|
|
154
|
+
// TodoWrite. This block is the regression coverage for the fix.
|
|
155
|
+
// =====================================================================
|
|
156
|
+
function assistantToolUse(name, blockId, input) {
|
|
157
|
+
return {
|
|
158
|
+
type: "assistant",
|
|
159
|
+
message: {
|
|
160
|
+
role: "assistant",
|
|
161
|
+
content: [
|
|
162
|
+
{
|
|
163
|
+
type: "tool_use",
|
|
164
|
+
id: blockId,
|
|
165
|
+
name,
|
|
166
|
+
input,
|
|
167
|
+
caller: { type: "direct" },
|
|
168
|
+
},
|
|
169
|
+
],
|
|
170
|
+
},
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
function toolResult(toolUseId, content) {
|
|
174
|
+
return {
|
|
175
|
+
type: "user",
|
|
176
|
+
message: {
|
|
177
|
+
role: "user",
|
|
178
|
+
content: [
|
|
179
|
+
{
|
|
180
|
+
type: "tool_result",
|
|
181
|
+
tool_use_id: toolUseId,
|
|
182
|
+
content,
|
|
183
|
+
},
|
|
184
|
+
],
|
|
185
|
+
},
|
|
186
|
+
};
|
|
187
|
+
}
|
|
188
|
+
describe("readActiveTaskId — TaskUpdate (v0.6.2 fix)", () => {
|
|
189
|
+
it("returns the taskId from TaskUpdate(status=in_progress)", async () => {
|
|
190
|
+
await writeEvents([
|
|
191
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: "131", status: "in_progress" }),
|
|
192
|
+
]);
|
|
193
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("131");
|
|
194
|
+
});
|
|
195
|
+
it("does not return tasks marked completed by a later TaskUpdate", async () => {
|
|
196
|
+
await writeEvents([
|
|
197
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: "131", status: "in_progress" }),
|
|
198
|
+
assistantToolUse("TaskUpdate", "tu-2", { taskId: "131", status: "completed" }),
|
|
199
|
+
]);
|
|
200
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
201
|
+
});
|
|
202
|
+
it("picks the most-recently-touched in_progress task when multiple are active", async () => {
|
|
203
|
+
await writeEvents([
|
|
204
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: "100", status: "in_progress" }),
|
|
205
|
+
assistantToolUse("TaskUpdate", "tu-2", { taskId: "200", status: "in_progress" }),
|
|
206
|
+
assistantToolUse("TaskUpdate", "tu-3", { taskId: "300", status: "in_progress" }),
|
|
207
|
+
]);
|
|
208
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("300");
|
|
209
|
+
});
|
|
210
|
+
it("coerces numeric taskId to string", async () => {
|
|
211
|
+
await writeEvents([
|
|
212
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: 131, status: "in_progress" }),
|
|
213
|
+
]);
|
|
214
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("131");
|
|
215
|
+
});
|
|
216
|
+
it("ignores TaskUpdate with deleted status", async () => {
|
|
217
|
+
await writeEvents([
|
|
218
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: "131", status: "in_progress" }),
|
|
219
|
+
assistantToolUse("TaskUpdate", "tu-2", { taskId: "131", status: "deleted" }),
|
|
220
|
+
]);
|
|
221
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
222
|
+
});
|
|
223
|
+
});
|
|
224
|
+
describe("readActiveTaskId — TaskCreate (v0.6.2 fix)", () => {
|
|
225
|
+
it("does NOT return TaskCreate'd tasks (default status = pending, not in_progress)", async () => {
|
|
226
|
+
// TaskCreate alone leaves the task as pending. Active-task detection
|
|
227
|
+
// requires an explicit TaskUpdate(in_progress) — otherwise no gate
|
|
228
|
+
// for tasks that were created but never started.
|
|
229
|
+
await writeEvents([
|
|
230
|
+
assistantToolUse("TaskCreate", "tc-1", {
|
|
231
|
+
subject: "Some task",
|
|
232
|
+
description: "...",
|
|
233
|
+
}),
|
|
234
|
+
toolResult("tc-1", "Task #131 created successfully: Some task"),
|
|
235
|
+
]);
|
|
236
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
237
|
+
});
|
|
238
|
+
it("returns the assigned id when TaskCreate is followed by TaskUpdate(in_progress)", async () => {
|
|
239
|
+
await writeEvents([
|
|
240
|
+
assistantToolUse("TaskCreate", "tc-1", { subject: "X", description: "..." }),
|
|
241
|
+
toolResult("tc-1", "Task #131 created successfully: X"),
|
|
242
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: "131", status: "in_progress" }),
|
|
243
|
+
]);
|
|
244
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("131");
|
|
245
|
+
});
|
|
246
|
+
it("handles TaskCreate without a matching tool_result (truncated transcript)", async () => {
|
|
247
|
+
await writeEvents([
|
|
248
|
+
assistantToolUse("TaskCreate", "tc-1", { subject: "X", description: "..." }),
|
|
249
|
+
// No tool_result follows
|
|
250
|
+
]);
|
|
251
|
+
// No id assigned, no in_progress → null.
|
|
252
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
253
|
+
});
|
|
254
|
+
});
|
|
255
|
+
// =====================================================================
|
|
256
|
+
// Real-world fixture — captured from an actual Claude Code session.
|
|
257
|
+
// The fixture lives at __fixtures__/real-task-shape.jsonl. If Claude
|
|
258
|
+
// Code ever changes the wire format for TaskCreate / TaskUpdate, this
|
|
259
|
+
// test fails BEFORE the workflow gate silently regresses in
|
|
260
|
+
// production. Earlier audit recommendation (v0.6.2 audit MED): synthesized
|
|
261
|
+
// tests passed in v0.6.1 but real-world shape didn't match — the same
|
|
262
|
+
// failure mode would have been caught here.
|
|
263
|
+
// =====================================================================
|
|
264
|
+
describe("readActiveTaskId — real Claude Code transcript fixture", () => {
|
|
265
|
+
it("recognizes TaskCreate + tool_result + TaskUpdate captured from a real session", async () => {
|
|
266
|
+
const fixturePath = path.resolve(__dirname, "__fixtures__", "real-task-shape.jsonl");
|
|
267
|
+
// The fixture is 3 events: TaskCreate "X" → tool_result "Task #1 created" →
|
|
268
|
+
// TaskUpdate(taskId=1, status=in_progress). Expected active task: "1".
|
|
269
|
+
const active = await readActiveTaskId(fixturePath);
|
|
270
|
+
expect(active).toBe("1");
|
|
271
|
+
});
|
|
272
|
+
});
|
|
273
|
+
// =====================================================================
|
|
274
|
+
// 0.7.9 (#163) — stale in_progress demotion
|
|
275
|
+
// =====================================================================
|
|
276
|
+
function assistantToolUseAt(name, blockId, input, timestamp) {
|
|
277
|
+
return {
|
|
278
|
+
type: "assistant",
|
|
279
|
+
timestamp,
|
|
280
|
+
message: {
|
|
281
|
+
role: "assistant",
|
|
282
|
+
content: [{ type: "tool_use", id: blockId, name, input, caller: { type: "direct" } }],
|
|
283
|
+
},
|
|
284
|
+
};
|
|
285
|
+
}
|
|
286
|
+
function userEventAt(timestamp, text = "hello") {
|
|
287
|
+
return { type: "user", timestamp, message: { role: "user", content: text } };
|
|
288
|
+
}
|
|
289
|
+
describe("readActiveTaskId — stale-task demotion (#163)", () => {
|
|
290
|
+
const oldDay = "2026-05-16T08:00:00Z"; // ~24h before latest
|
|
291
|
+
const today = "2026-05-17T08:00:00Z"; // latest activity
|
|
292
|
+
it("returns null when the only in_progress task is >1hr stale relative to latest activity", async () => {
|
|
293
|
+
await writeEvents([
|
|
294
|
+
assistantToolUseAt("TaskUpdate", "tu-1", { taskId: "999", status: "in_progress" }, oldDay),
|
|
295
|
+
// Many later events with newer timestamps — none touch task 999.
|
|
296
|
+
userEventAt(today, "new conversation today"),
|
|
297
|
+
]);
|
|
298
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
299
|
+
});
|
|
300
|
+
it("keeps the in_progress task when it was recently touched", async () => {
|
|
301
|
+
const recent = "2026-05-17T07:30:00Z"; // 30 min before latest
|
|
302
|
+
await writeEvents([
|
|
303
|
+
assistantToolUseAt("TaskUpdate", "tu-1", { taskId: "42", status: "in_progress" }, recent),
|
|
304
|
+
userEventAt(today),
|
|
305
|
+
]);
|
|
306
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("42");
|
|
307
|
+
});
|
|
308
|
+
it("picks the more-recent in_progress when two exist (one stale, one fresh)", async () => {
|
|
309
|
+
const recent = "2026-05-17T07:45:00Z";
|
|
310
|
+
await writeEvents([
|
|
311
|
+
assistantToolUseAt("TaskUpdate", "tu-1", { taskId: "X", status: "in_progress" }, oldDay),
|
|
312
|
+
assistantToolUseAt("TaskUpdate", "tu-2", { taskId: "Y", status: "in_progress" }, recent),
|
|
313
|
+
userEventAt(today),
|
|
314
|
+
]);
|
|
315
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("Y");
|
|
316
|
+
});
|
|
317
|
+
it("falls back to line-idx pick (no demotion) when events have no timestamps", async () => {
|
|
318
|
+
// Pre-existing behavior preserved when timestamps aren't available.
|
|
319
|
+
await writeEvents([
|
|
320
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: "no-ts", status: "in_progress" }),
|
|
321
|
+
]);
|
|
322
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("no-ts");
|
|
323
|
+
});
|
|
324
|
+
});
|
|
325
|
+
describe("readActiveTaskId — mixed TodoWrite + TaskUpdate", () => {
|
|
326
|
+
it("latest write wins per id, regardless of which tool", async () => {
|
|
327
|
+
// TodoWrite snapshot says id=5 is in_progress; later TaskUpdate
|
|
328
|
+
// marks id=5 completed. TaskUpdate is later → wins.
|
|
329
|
+
await writeEvents([
|
|
330
|
+
todoWriteEvent([{ id: "5", status: "in_progress" }]),
|
|
331
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: "5", status: "completed" }),
|
|
332
|
+
]);
|
|
333
|
+
expect(await readActiveTaskId(transcriptPath)).toBeNull();
|
|
334
|
+
});
|
|
335
|
+
it("TodoWrite snapshot can revive an id that TaskUpdate marked completed if it comes later", async () => {
|
|
336
|
+
await writeEvents([
|
|
337
|
+
assistantToolUse("TaskUpdate", "tu-1", { taskId: "5", status: "completed" }),
|
|
338
|
+
todoWriteEvent([{ id: "5", status: "in_progress" }]),
|
|
339
|
+
]);
|
|
340
|
+
expect(await readActiveTaskId(transcriptPath)).toBe("5");
|
|
341
|
+
});
|
|
342
|
+
});
|