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,313 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Chat-daemon worker entrypoint (v0.7.1 Phase A).
|
|
3
|
+
*
|
|
4
|
+
* Spawned as a detached child by `lifecycle.startDaemon()`. Owns the
|
|
5
|
+
* single long-poll connection per chat platform. The MCP server side
|
|
6
|
+
* stays out of the polling business entirely — outbound RPC (Phase B)
|
|
7
|
+
* and inbox tailing (Phase C) replace the in-process gateway.
|
|
8
|
+
*
|
|
9
|
+
* Lifecycle inside the worker:
|
|
10
|
+
* 1. Write our PID to ~/.opensquid/chat-daemon.pid
|
|
11
|
+
* 2. Build the chat gateway from ~/.opensquid/config.json
|
|
12
|
+
* 3. Start every configured adapter (their long-poll loops run as
|
|
13
|
+
* side effects of start())
|
|
14
|
+
* 4. Install SIGTERM / SIGINT handlers that stop the gateway and
|
|
15
|
+
* remove the pidfile before exit
|
|
16
|
+
* 5. Park on process.stdin (which is /dev/null in detached mode)
|
|
17
|
+
* so the event loop stays alive
|
|
18
|
+
*
|
|
19
|
+
* Crash behavior: any unhandled exception from gateway.start() prints
|
|
20
|
+
* to the (parent-redirected) log file and exits non-zero. The pidfile
|
|
21
|
+
* is cleaned up in the SIGTERM handler — if we crash before installing
|
|
22
|
+
* it, the pidfile may linger, and the next `status` call will report
|
|
23
|
+
* `stale_pid` (lifecycle.startDaemon cleans up stale pidfiles before
|
|
24
|
+
* spawning).
|
|
25
|
+
*/
|
|
26
|
+
import { promises as fs } from "node:fs";
|
|
27
|
+
import { buildChatGateway } from "../factory.js";
|
|
28
|
+
import { appendToInbox } from "./inbox.js";
|
|
29
|
+
import { daemonPaths } from "./lifecycle.js";
|
|
30
|
+
import { buildRoutingIndex, loadAllProjectChatRouting } from "./routing.js";
|
|
31
|
+
import { RpcServer } from "./rpc-server.js";
|
|
32
|
+
let gateway = null;
|
|
33
|
+
let rpcServer = null;
|
|
34
|
+
let routingIndex = new Map();
|
|
35
|
+
let routingPollTimer = null;
|
|
36
|
+
let pidFile = null;
|
|
37
|
+
let shuttingDown = false;
|
|
38
|
+
export async function runDaemonWorker(dataRoot) {
|
|
39
|
+
const paths = daemonPaths(dataRoot);
|
|
40
|
+
pidFile = paths.pidFile;
|
|
41
|
+
// Write pidfile FIRST so a status check after spawn sees the worker
|
|
42
|
+
// promptly. Truncate-write is the right semantic — any previous
|
|
43
|
+
// pidfile is stale by definition (we already verified no live daemon
|
|
44
|
+
// existed in lifecycle.startDaemon).
|
|
45
|
+
await fs.writeFile(pidFile, `${process.pid}\n`, "utf8");
|
|
46
|
+
log(`[chat-daemon] worker booted pid=${process.pid} cwd=${process.cwd()}`);
|
|
47
|
+
// Build + start the gateway. If config is empty, no adapters
|
|
48
|
+
// activate and the daemon parks idle — useful for testing the
|
|
49
|
+
// lifecycle without configuring a real bot token.
|
|
50
|
+
try {
|
|
51
|
+
// 0.7.5 (#148): log which source each platform's token came from
|
|
52
|
+
// (env / env-file / config-json) so operators can debug "which
|
|
53
|
+
// bot is this daemon actually using" without exposing the secret.
|
|
54
|
+
try {
|
|
55
|
+
const { loadChatConfigWithSources } = await import("../config.js");
|
|
56
|
+
const { sources } = await loadChatConfigWithSources(dataRoot);
|
|
57
|
+
const lines = [];
|
|
58
|
+
if (sources.telegram)
|
|
59
|
+
lines.push(`telegram=${sources.telegram}`);
|
|
60
|
+
if (sources.discord)
|
|
61
|
+
lines.push(`discord=${sources.discord}`);
|
|
62
|
+
if (sources.slack_bot)
|
|
63
|
+
lines.push(`slack_bot=${sources.slack_bot}`);
|
|
64
|
+
if (sources.slack_app)
|
|
65
|
+
lines.push(`slack_app=${sources.slack_app}`);
|
|
66
|
+
if (lines.length) {
|
|
67
|
+
log(`[chat-daemon] token sources: ${lines.join(" ")}${sources.env_file_path ? ` (env-file: ${sources.env_file_path})` : ""}`);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
catch (logErr) {
|
|
71
|
+
log(`[chat-daemon] could not log token sources (non-fatal): ${logErr instanceof Error ? logErr.message : logErr}`);
|
|
72
|
+
}
|
|
73
|
+
const built = await buildChatGateway({ dataRoot });
|
|
74
|
+
gateway = built.gateway;
|
|
75
|
+
log(`[chat-daemon] activating platforms: ${built.activated.join(",") || "(none)"}`);
|
|
76
|
+
if (built.issues.length) {
|
|
77
|
+
for (const i of built.issues) {
|
|
78
|
+
log(`[chat-daemon] config issue ${i.platform}.${i.field}: ${i.problem}`);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
// Phase C: load per-project chat-routing.json files and build the
|
|
82
|
+
// chat_id → project_uuid index BEFORE attaching the inbound
|
|
83
|
+
// handler. The handler uses this index to route messages to
|
|
84
|
+
// per-project inboxes.
|
|
85
|
+
routingIndex = await rebuildRoutingIndex(dataRoot);
|
|
86
|
+
log(`[chat-daemon] routing index built: ${routingIndex.size} inbound channels mapped`);
|
|
87
|
+
gateway.onMessage(async (msg) => {
|
|
88
|
+
// v0.5.94 (WAB.2 Part A / TG.1 (a)): DM-first routing.
|
|
89
|
+
//
|
|
90
|
+
// Key precedence:
|
|
91
|
+
// 1. DM key (`telegram:dm:<user_id>`) when the message is a DM —
|
|
92
|
+
// defined as `msg.channel === "telegram:" + msg.senderId`.
|
|
93
|
+
// The Telegram adapter formats DM chats as `telegram:<chat_id>`
|
|
94
|
+
// where chat_id === from.id, so the equality check is the
|
|
95
|
+
// canonical Telegram private-chat indicator. This also rejects
|
|
96
|
+
// group-message-from-self spoofs (group chat.id is negative
|
|
97
|
+
// for supergroups; senderId is positive; they cannot collide).
|
|
98
|
+
// 2. Topic-specific key (`<channel>:<threadId>`) when the message
|
|
99
|
+
// is in a forum topic.
|
|
100
|
+
// 3. Channel-only key (`<channel>`).
|
|
101
|
+
//
|
|
102
|
+
// Strict topic whitelist preserved per TG.1 (d) — a message in a
|
|
103
|
+
// topic NOT listed by any project's `inbound_topic_ids` will not
|
|
104
|
+
// fall back to the chat-only key (because `collectInboundChannels`
|
|
105
|
+
// does not emit the chat-only key when `inbound_topic_ids` is set
|
|
106
|
+
// on that project). Such messages orphan, which is the documented
|
|
107
|
+
// security-correct default.
|
|
108
|
+
const isDm = msg.platform === 'telegram' && msg.channel === `telegram:${msg.senderId}`;
|
|
109
|
+
const dmKey = isDm ? `telegram:dm:${msg.senderId}` : null;
|
|
110
|
+
const topicKey = msg.threadId ? `${msg.channel}:${msg.threadId}` : null;
|
|
111
|
+
const projectUuid = (dmKey ? routingIndex.get(dmKey) : undefined) ??
|
|
112
|
+
(topicKey ? routingIndex.get(topicKey) : undefined) ??
|
|
113
|
+
routingIndex.get(msg.channel) ??
|
|
114
|
+
null;
|
|
115
|
+
try {
|
|
116
|
+
const r = await appendToInbox(msg, projectUuid, dataRoot);
|
|
117
|
+
log(`[chat-daemon] inbox ← ${msg.channel} (${msg.text.slice(0, 60).replace(/\n/g, " ")}…) → ${r.destination}${r.project_uuid ? "/" + r.project_uuid : ""}`);
|
|
118
|
+
}
|
|
119
|
+
catch (err) {
|
|
120
|
+
log(`[chat-daemon] inbox append failed for ${msg.channel}: ${err instanceof Error ? err.message : err}`);
|
|
121
|
+
}
|
|
122
|
+
// TPS.6 patch 2 (v0.5.126) — broadcast to long-lived UDS
|
|
123
|
+
// subscribers. The JSONL file write above is the durable record;
|
|
124
|
+
// this push is the low-latency delivery. We broadcast on a
|
|
125
|
+
// single key — the most-specific one available: topic-suffixed
|
|
126
|
+
// `<channel>:<threadId>` if present, else bare `<channel>`.
|
|
127
|
+
// This mirrors the routing-index key semantics from
|
|
128
|
+
// `collectInboundChannels`: a project that registers only
|
|
129
|
+
// `chat_id:thread_id` doesn't want to receive messages from
|
|
130
|
+
// other topics in the same supergroup. Wildcard subscribers
|
|
131
|
+
// (chat_ids=[]) see every message regardless of key shape.
|
|
132
|
+
// Fire-and-forget — subscriber write failures are handled by
|
|
133
|
+
// the registry's own socket lifecycle hooks.
|
|
134
|
+
if (rpcServer !== null) {
|
|
135
|
+
const broadcastKey = msg.threadId
|
|
136
|
+
? `${msg.channel}:${msg.threadId}`
|
|
137
|
+
: msg.channel;
|
|
138
|
+
const notif = {
|
|
139
|
+
jsonrpc: "2.0",
|
|
140
|
+
method: "inbound_message",
|
|
141
|
+
params: {
|
|
142
|
+
delivery_id: `del-${Date.now().toString()}-${Math.random().toString(36).slice(2, 10)}`,
|
|
143
|
+
message_id: msg.id,
|
|
144
|
+
platform: msg.platform,
|
|
145
|
+
channel: msg.channel,
|
|
146
|
+
...(msg.threadId !== undefined ? { thread_id: msg.threadId } : {}),
|
|
147
|
+
sender: msg.sender,
|
|
148
|
+
sender_id: msg.senderId,
|
|
149
|
+
text: msg.text,
|
|
150
|
+
received_at: msg.receivedAt.toISOString(),
|
|
151
|
+
mentions_bot: msg.mentionsBot,
|
|
152
|
+
},
|
|
153
|
+
};
|
|
154
|
+
rpcServer.subscribers.broadcast(broadcastKey, notif);
|
|
155
|
+
}
|
|
156
|
+
});
|
|
157
|
+
await gateway.start();
|
|
158
|
+
log(`[chat-daemon] gateway start complete`);
|
|
159
|
+
// v0.5.89 (TG.2) — startup reachability check against each
|
|
160
|
+
// unique inbound chat_id. Catches kicked-from-supergroup (403),
|
|
161
|
+
// stale chat_id (400), and network errors immediately at startup.
|
|
162
|
+
// Best-effort: failures don't block daemon startup, just log
|
|
163
|
+
// warnings so operators can see what's wrong without inspecting
|
|
164
|
+
// hours of empty log noise. The check is Telegram-only for now;
|
|
165
|
+
// Discord/Slack equivalents land in a follow-up if needed.
|
|
166
|
+
try {
|
|
167
|
+
const { verifyTelegramChats, formatReachabilityLine } = await import("./health-check.js");
|
|
168
|
+
const { loadChatConfig } = await import("../config.js");
|
|
169
|
+
const chatConfig = await loadChatConfig(dataRoot);
|
|
170
|
+
const tgToken = chatConfig.telegram?.bot_token;
|
|
171
|
+
// Collect unique chat_ids referenced across all projects' Telegram
|
|
172
|
+
// routing (skip dm: and topic-suffixed keys — getChat takes only
|
|
173
|
+
// the chat_id, no topic).
|
|
174
|
+
const chatIds = new Set();
|
|
175
|
+
const configs = await loadAllProjectChatRouting(dataRoot);
|
|
176
|
+
for (const cfg of configs.values()) {
|
|
177
|
+
for (const id of cfg.telegram?.inbound_chat_ids ?? [])
|
|
178
|
+
chatIds.add(id);
|
|
179
|
+
}
|
|
180
|
+
if (chatIds.size > 0 && tgToken) {
|
|
181
|
+
const results = await verifyTelegramChats(tgToken, [...chatIds]);
|
|
182
|
+
for (const r of results)
|
|
183
|
+
log(formatReachabilityLine(r));
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
catch (err) {
|
|
187
|
+
log(`[chat-daemon] chat-reachability check skipped (non-fatal): ${err instanceof Error ? err.message : err}`);
|
|
188
|
+
}
|
|
189
|
+
// RPC server listens for outbound send() calls from per-project
|
|
190
|
+
// MCP servers. Starting it AFTER gateway.start() means clients
|
|
191
|
+
// that connect successfully are guaranteed a fully-warmed gateway.
|
|
192
|
+
rpcServer = new RpcServer({ gateway, dataRoot, version: "v0.7.1-phase-c" });
|
|
193
|
+
await rpcServer.listen();
|
|
194
|
+
// Poll the routing files every 30s so operators can edit a
|
|
195
|
+
// chat-routing.json and have the daemon pick it up without a full
|
|
196
|
+
// restart. Polling is the most portable option (fs.watch behavior
|
|
197
|
+
// varies across macOS/Linux/Windows + recursive support).
|
|
198
|
+
routingPollTimer = setInterval(() => {
|
|
199
|
+
void (async () => {
|
|
200
|
+
try {
|
|
201
|
+
const next = await rebuildRoutingIndex(dataRoot);
|
|
202
|
+
if (!sameIndex(routingIndex, next)) {
|
|
203
|
+
routingIndex = next;
|
|
204
|
+
log(`[chat-daemon] routing reload: ${routingIndex.size} inbound channels mapped`);
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
catch (err) {
|
|
208
|
+
log(`[chat-daemon] routing reload failed (non-fatal): ${err instanceof Error ? err.message : err}`);
|
|
209
|
+
}
|
|
210
|
+
})();
|
|
211
|
+
}, 30_000);
|
|
212
|
+
log(`[chat-daemon] rpc server listening; entering park loop`);
|
|
213
|
+
}
|
|
214
|
+
catch (err) {
|
|
215
|
+
log(`[chat-daemon] FATAL: gateway start failed: ${err instanceof Error ? err.stack : err}`);
|
|
216
|
+
await cleanup();
|
|
217
|
+
process.exit(1);
|
|
218
|
+
}
|
|
219
|
+
// Signal handlers. SIGTERM = graceful, SIGINT = also graceful (for
|
|
220
|
+
// manual `kill` during dev). Each calls cleanup() exactly once.
|
|
221
|
+
process.on("SIGTERM", () => void shutdown("SIGTERM"));
|
|
222
|
+
process.on("SIGINT", () => void shutdown("SIGINT"));
|
|
223
|
+
// Park forever. process.stdin.resume() does NOT work here because
|
|
224
|
+
// the parent spawned us with `stdio: ['ignore', ...]` — there's no
|
|
225
|
+
// FD 0 to poll. An unresolved Promise alone won't hold the event
|
|
226
|
+
// loop either; Node exits when nothing's scheduled. The reliable
|
|
227
|
+
// pattern is a long-interval no-op timer (~12 days per tick); the
|
|
228
|
+
// tick is a microsecond of CPU and easily survives clock jitter.
|
|
229
|
+
// Signal handlers are independently registered above and still fire.
|
|
230
|
+
setInterval(() => {
|
|
231
|
+
/* keep-alive heartbeat */
|
|
232
|
+
}, 1 << 30);
|
|
233
|
+
// TypeScript demands a return path even though we never reach here.
|
|
234
|
+
return await new Promise(() => {
|
|
235
|
+
/* never resolves; held alive by the heartbeat interval */
|
|
236
|
+
});
|
|
237
|
+
}
|
|
238
|
+
async function shutdown(signal) {
|
|
239
|
+
if (shuttingDown)
|
|
240
|
+
return;
|
|
241
|
+
shuttingDown = true;
|
|
242
|
+
log(`[chat-daemon] ${signal} received, shutting down...`);
|
|
243
|
+
if (routingPollTimer)
|
|
244
|
+
clearInterval(routingPollTimer);
|
|
245
|
+
// TPS.6 patch 2 (v0.5.126) — tell subscribers we're going away
|
|
246
|
+
// BEFORE closing the RPC server. The shutdown notification gives
|
|
247
|
+
// MCP bridges a clean signal to back off their reconnect loop
|
|
248
|
+
// instead of treating the disconnect as transient and immediately
|
|
249
|
+
// retrying.
|
|
250
|
+
try {
|
|
251
|
+
if (rpcServer)
|
|
252
|
+
rpcServer.subscribers.shutdown(signal);
|
|
253
|
+
}
|
|
254
|
+
catch (err) {
|
|
255
|
+
log(`[chat-daemon] subscriber shutdown notify error (non-fatal): ${err instanceof Error ? err.message : err}`);
|
|
256
|
+
}
|
|
257
|
+
try {
|
|
258
|
+
if (rpcServer)
|
|
259
|
+
await rpcServer.close();
|
|
260
|
+
}
|
|
261
|
+
catch (err) {
|
|
262
|
+
log(`[chat-daemon] rpc close error (non-fatal): ${err instanceof Error ? err.message : err}`);
|
|
263
|
+
}
|
|
264
|
+
try {
|
|
265
|
+
if (gateway)
|
|
266
|
+
await gateway.shutdown();
|
|
267
|
+
}
|
|
268
|
+
catch (err) {
|
|
269
|
+
log(`[chat-daemon] gateway.shutdown error (non-fatal): ${err instanceof Error ? err.message : err}`);
|
|
270
|
+
}
|
|
271
|
+
await cleanup();
|
|
272
|
+
log(`[chat-daemon] clean exit`);
|
|
273
|
+
process.exit(0);
|
|
274
|
+
}
|
|
275
|
+
async function cleanup() {
|
|
276
|
+
if (pidFile) {
|
|
277
|
+
try {
|
|
278
|
+
await fs.unlink(pidFile);
|
|
279
|
+
}
|
|
280
|
+
catch {
|
|
281
|
+
/* race-tolerant */
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
function log(line) {
|
|
286
|
+
// stdio is already redirected to the log file by the parent's spawn
|
|
287
|
+
// options; plain console.log lands in the right place.
|
|
288
|
+
process.stdout.write(`${new Date().toISOString()} ${line}\n`);
|
|
289
|
+
}
|
|
290
|
+
async function rebuildRoutingIndex(dataRoot) {
|
|
291
|
+
const cfgs = await loadAllProjectChatRouting(dataRoot);
|
|
292
|
+
const { recordCollision } = await import("./collisions.js");
|
|
293
|
+
return buildRoutingIndex(cfgs, (info) => {
|
|
294
|
+
log(`[chat-daemon] routing collision: ${info.channel_key} existing=${info.existing_uuid} newcomer=${info.newcomer_uuid} (latter wins)`);
|
|
295
|
+
// Fire-and-forget: persist + notify happen async; the routing
|
|
296
|
+
// rebuild must not wait. recordCollision swallows its own errors
|
|
297
|
+
// (stderr-logged) so this `void` is intentional.
|
|
298
|
+
void recordCollision({
|
|
299
|
+
info,
|
|
300
|
+
dataRoot,
|
|
301
|
+
...(gateway !== null ? { gateway } : {}),
|
|
302
|
+
});
|
|
303
|
+
});
|
|
304
|
+
}
|
|
305
|
+
function sameIndex(a, b) {
|
|
306
|
+
if (a.size !== b.size)
|
|
307
|
+
return false;
|
|
308
|
+
for (const [k, v] of a) {
|
|
309
|
+
if (b.get(k) !== v)
|
|
310
|
+
return false;
|
|
311
|
+
}
|
|
312
|
+
return true;
|
|
313
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.js","sourceRoot":"","sources":["../../../src.legacy/chat/daemon/worker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,324 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* workspace-topic.ts — workspace → forum-topic binding primitive
|
|
3
|
+
* (TPS.3 / v0.5.120+).
|
|
4
|
+
*
|
|
5
|
+
* Solves: given a workspace (cwd-resolved uuid + path) and a target
|
|
6
|
+
* supergroup chat_id, ensure the workspace has a bound forum topic +
|
|
7
|
+
* persist the binding to its `chat-routing.json`. Idempotent.
|
|
8
|
+
*
|
|
9
|
+
* Used by:
|
|
10
|
+
* - TPS.4 — `opensquid setup chat` wizard step (mode: "wizard")
|
|
11
|
+
* - TPS.6 — daemon auto-boot on MCP subscribe (mode: "auto-boot")
|
|
12
|
+
*
|
|
13
|
+
* Concurrency: protected by `proper-lockfile` on the per-project
|
|
14
|
+
* `chat-routing.json` so two concurrent invocations for the same
|
|
15
|
+
* workspace can't race-create two topics. The lock window covers
|
|
16
|
+
* (load existing config) → (call createTopic if missing) → (write
|
|
17
|
+
* updated config). Lock retries are bounded; if a stale lock from a
|
|
18
|
+
* crashed prior run blocks acquisition, an `LOCKED` error is thrown
|
|
19
|
+
* upward — callers (wizard, auto-boot) surface this to the user
|
|
20
|
+
* rather than papering over it.
|
|
21
|
+
*
|
|
22
|
+
* Error propagation: this module does NOT swallow errors. RPC failures
|
|
23
|
+
* (bot not admin, network), parse errors, and lock failures all
|
|
24
|
+
* propagate. Callers decide how to surface them (TPS.4 prints to the
|
|
25
|
+
* wizard, TPS.6 logs + falls back to general topic).
|
|
26
|
+
*
|
|
27
|
+
* Rebuild path: same as adapters/telegram.ts — see that file's header
|
|
28
|
+
* for the ad-hoc tsc invocation. `pnpm build` does NOT recompile this
|
|
29
|
+
* file; the chat-daemon worker loads dist/chat/daemon/workspace-topic.js
|
|
30
|
+
* at runtime.
|
|
31
|
+
*/
|
|
32
|
+
import { promises as fs } from "node:fs";
|
|
33
|
+
import { createRequire } from "node:module";
|
|
34
|
+
import * as path from "node:path";
|
|
35
|
+
import * as lockfile from "proper-lockfile";
|
|
36
|
+
// Need synchronous require() to construct the rpc-client lazily without
|
|
37
|
+
// making resolveOrCreateTopic's signature async-on-import. ESM Node 20+
|
|
38
|
+
// exposes createRequire for exactly this case.
|
|
39
|
+
const requireCJS = createRequire(import.meta.url);
|
|
40
|
+
import { loadAllProjectChatRouting, loadProjectChatRouting, projectChatRoutingPath, } from "./routing.js";
|
|
41
|
+
// ---------------------------------------------------------------------
|
|
42
|
+
// Main entrypoint
|
|
43
|
+
// ---------------------------------------------------------------------
|
|
44
|
+
export async function resolveOrCreateTopic(args) {
|
|
45
|
+
const routingPath = projectChatRoutingPath(args.workspaceUuid, args.dataRoot);
|
|
46
|
+
// Lockfile lives next to the routing file; proper-lockfile handles
|
|
47
|
+
// both lock acquisition and the necessary parent-dir creation logic
|
|
48
|
+
// as long as the target exists. Ensure the dir exists first.
|
|
49
|
+
await fs.mkdir(path.dirname(routingPath), { recursive: true });
|
|
50
|
+
// proper-lockfile requires the target file to exist; touch it
|
|
51
|
+
// (empty config) if it doesn't, so the lock can be acquired
|
|
52
|
+
// regardless of whether the workspace has ever had routing set up.
|
|
53
|
+
await ensureRoutingFileExists(routingPath);
|
|
54
|
+
// Retry tuning rationale (TPS.3 pre-research): typical createTopic
|
|
55
|
+
// round-trip is 200-600ms (UDS + HTTPS to api.telegram.org). 8
|
|
56
|
+
// retries with 1.5× backoff at 50ms-800ms gives ~2.4s headroom —
|
|
57
|
+
// plenty for one contender to finish while another waits. Stale is
|
|
58
|
+
// proper-lockfile's default (10s); not setting it explicitly.
|
|
59
|
+
const release = await lockfile.lock(routingPath, {
|
|
60
|
+
retries: { retries: 8, factor: 1.5, minTimeout: 50, maxTimeout: 800 },
|
|
61
|
+
});
|
|
62
|
+
try {
|
|
63
|
+
const existing = await loadProjectChatRouting(args.workspaceUuid, args.dataRoot);
|
|
64
|
+
assertAutoBoundInvariant(existing, routingPath);
|
|
65
|
+
const bound = existing?.telegram?.auto_bound;
|
|
66
|
+
if (bound && Number.isFinite(bound.topic_id) && bound.topic_id > 0) {
|
|
67
|
+
// Idempotent — already bound, return existing.
|
|
68
|
+
// Sanity check: if the auto_bound.workspace_uuid disagrees with
|
|
69
|
+
// the outer uuid (the directory name), log on stderr but trust
|
|
70
|
+
// the outer uuid as authoritative.
|
|
71
|
+
if (bound.workspace_uuid !== args.workspaceUuid) {
|
|
72
|
+
process.stderr.write(`[workspace-topic] auto_bound.workspace_uuid (${bound.workspace_uuid}) ≠ outer uuid (${args.workspaceUuid}) for ${routingPath}; using existing binding\n`);
|
|
73
|
+
}
|
|
74
|
+
return { topicId: bound.topic_id, topicName: bound.topic_name, created: false };
|
|
75
|
+
}
|
|
76
|
+
const name = deriveTopicName(args.workspacePath, args.workspaceUuid);
|
|
77
|
+
const client = args.rpcClient ?? defaultRpcClient(args.dataRoot);
|
|
78
|
+
const created = await client.createTopic({
|
|
79
|
+
platform: "telegram",
|
|
80
|
+
chat_id: args.chatId,
|
|
81
|
+
name,
|
|
82
|
+
});
|
|
83
|
+
const nextAutoBound = {
|
|
84
|
+
workspace_path: args.workspacePath,
|
|
85
|
+
workspace_uuid: args.workspaceUuid,
|
|
86
|
+
topic_id: created.message_thread_id,
|
|
87
|
+
topic_name: created.name,
|
|
88
|
+
created_at: new Date().toISOString(),
|
|
89
|
+
created_by: args.mode,
|
|
90
|
+
};
|
|
91
|
+
const merged = {
|
|
92
|
+
...(existing ?? {}),
|
|
93
|
+
telegram: {
|
|
94
|
+
...(existing?.telegram ?? {}),
|
|
95
|
+
// Persist both auto_bound metadata + the actual routing field
|
|
96
|
+
// (inbound_topic_ids) so the routing index picks up the new
|
|
97
|
+
// binding on its next ~30s hot-reload without separate writes.
|
|
98
|
+
inbound_topic_ids: mergeTopicIds(existing?.telegram?.inbound_topic_ids, created.message_thread_id),
|
|
99
|
+
inbound_chat_ids: mergeChatIds(existing?.telegram?.inbound_chat_ids, args.chatId),
|
|
100
|
+
auto_bound: nextAutoBound,
|
|
101
|
+
},
|
|
102
|
+
};
|
|
103
|
+
try {
|
|
104
|
+
await persistRoutingAtomic(routingPath, merged);
|
|
105
|
+
}
|
|
106
|
+
catch (persistErr) {
|
|
107
|
+
// TPS.3 pre-research, choice #6 partial-failure compensation:
|
|
108
|
+
// createTopic SUCCEEDED but persist FAILED — Telegram has a real
|
|
109
|
+
// topic we cannot reference. Log it to a recovery file so the
|
|
110
|
+
// user can clean up (delete the orphan topic manually) instead
|
|
111
|
+
// of accumulating ghost topics on every retry. Don't try to
|
|
112
|
+
// rollback (delete the topic) here — that requires a second
|
|
113
|
+
// RPC call that could also fail, compounding the problem.
|
|
114
|
+
// The user-facing surface lives in TPS.5 collision channel.
|
|
115
|
+
await recordOrphanTopic(args.dataRoot, {
|
|
116
|
+
chat_id: args.chatId,
|
|
117
|
+
topic_id: created.message_thread_id,
|
|
118
|
+
topic_name: created.name,
|
|
119
|
+
workspace_uuid: args.workspaceUuid,
|
|
120
|
+
workspace_path: args.workspacePath,
|
|
121
|
+
mode: args.mode,
|
|
122
|
+
persist_error: persistErr instanceof Error ? persistErr.message : String(persistErr),
|
|
123
|
+
occurred_at: new Date().toISOString(),
|
|
124
|
+
});
|
|
125
|
+
throw persistErr;
|
|
126
|
+
}
|
|
127
|
+
return {
|
|
128
|
+
topicId: created.message_thread_id,
|
|
129
|
+
topicName: created.name,
|
|
130
|
+
created: true,
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
finally {
|
|
134
|
+
await release();
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
// ---------------------------------------------------------------------
|
|
138
|
+
// Helpers (exported for unit tests)
|
|
139
|
+
// ---------------------------------------------------------------------
|
|
140
|
+
/**
|
|
141
|
+
* Derive a deterministic, human-readable topic name from the workspace
|
|
142
|
+
* path + uuid. The basename of the path is the most user-recognisable
|
|
143
|
+
* part; the uuid prefix disambiguates two workspaces with the same
|
|
144
|
+
* basename. Examples:
|
|
145
|
+
*
|
|
146
|
+
* deriveTopicName("/Users/slee/projects/loop", "da96385b-...") =
|
|
147
|
+
* "loop · da96385b"
|
|
148
|
+
* deriveTopicName("/", "abc12345-...") = "root · abc12345"
|
|
149
|
+
*/
|
|
150
|
+
export function deriveTopicName(workspacePath, workspaceUuid) {
|
|
151
|
+
const basenameRaw = path.basename(workspacePath) || "root";
|
|
152
|
+
// Telegram limit per [aiogram docs](https://docs.aiogram.dev/en/latest/api/methods/create_forum_topic.html)
|
|
153
|
+
// is 1-128 chars. Cap basename at 48 to leave headroom for the
|
|
154
|
+
// " · 12345678" suffix (11 chars) — total max output ~59 chars.
|
|
155
|
+
// 48 is conservative: Telegram client truncates topic-list display
|
|
156
|
+
// at ~30-35 chars anyway. Pre-research verdict #4.
|
|
157
|
+
const basename = basenameRaw.length > 48 ? `${basenameRaw.slice(0, 45)}...` : basenameRaw;
|
|
158
|
+
const uuidShort = workspaceUuid.slice(0, 8);
|
|
159
|
+
return `${basename} · ${uuidShort}`;
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Merge a single new topic_id into an optional existing array. Avoids
|
|
163
|
+
* duplicates while preserving order (existing first, new last).
|
|
164
|
+
*/
|
|
165
|
+
export function mergeTopicIds(existing, newId) {
|
|
166
|
+
if (!existing || existing.length === 0)
|
|
167
|
+
return [newId];
|
|
168
|
+
if (existing.includes(newId))
|
|
169
|
+
return existing;
|
|
170
|
+
return [...existing, newId];
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Same as mergeTopicIds for chat_ids (strings).
|
|
174
|
+
*/
|
|
175
|
+
export function mergeChatIds(existing, newId) {
|
|
176
|
+
if (!existing || existing.length === 0)
|
|
177
|
+
return [newId];
|
|
178
|
+
if (existing.includes(newId))
|
|
179
|
+
return existing;
|
|
180
|
+
return [...existing, newId];
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Clear an existing auto_bound block (TPS.7 stale-topic lifecycle).
|
|
184
|
+
* Leaves `inbound_topic_ids` alone — caller decides whether to also
|
|
185
|
+
* scrub those (typically yes, since the stale topic_id no longer
|
|
186
|
+
* exists). Returns true if a binding was cleared, false if none.
|
|
187
|
+
*/
|
|
188
|
+
export async function clearBinding(args) {
|
|
189
|
+
const routingPath = projectChatRoutingPath(args.workspaceUuid, args.dataRoot);
|
|
190
|
+
await fs.mkdir(path.dirname(routingPath), { recursive: true });
|
|
191
|
+
await ensureRoutingFileExists(routingPath);
|
|
192
|
+
const release = await lockfile.lock(routingPath, {
|
|
193
|
+
retries: { retries: 8, factor: 1.5, minTimeout: 50, maxTimeout: 800 },
|
|
194
|
+
stale: 10_000,
|
|
195
|
+
});
|
|
196
|
+
try {
|
|
197
|
+
const existing = await loadProjectChatRouting(args.workspaceUuid, args.dataRoot);
|
|
198
|
+
if (!existing?.telegram?.auto_bound)
|
|
199
|
+
return false;
|
|
200
|
+
const staleTopicId = existing.telegram.auto_bound.topic_id;
|
|
201
|
+
const next = {
|
|
202
|
+
...existing,
|
|
203
|
+
telegram: {
|
|
204
|
+
...existing.telegram,
|
|
205
|
+
inbound_topic_ids: (existing.telegram.inbound_topic_ids ?? []).filter((t) => t !== staleTopicId),
|
|
206
|
+
auto_bound: undefined,
|
|
207
|
+
},
|
|
208
|
+
};
|
|
209
|
+
// Drop the auto_bound key entirely (don't leave `auto_bound: undefined`
|
|
210
|
+
// in the JSON output).
|
|
211
|
+
if (next.telegram)
|
|
212
|
+
delete next.telegram.auto_bound;
|
|
213
|
+
if (next.telegram?.inbound_topic_ids?.length === 0)
|
|
214
|
+
delete next.telegram.inbound_topic_ids;
|
|
215
|
+
await persistRoutingAtomic(routingPath, next);
|
|
216
|
+
return true;
|
|
217
|
+
}
|
|
218
|
+
finally {
|
|
219
|
+
await release();
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
/**
|
|
223
|
+
* Find the workspace whose `auto_bound` block claims the given
|
|
224
|
+
* (chat_id, topic_id) pair. Used by TPS.7 stale-topic recovery to
|
|
225
|
+
* locate which workspace owned a now-stale binding so we can
|
|
226
|
+
* `clearBinding` for the right uuid.
|
|
227
|
+
*
|
|
228
|
+
* Returns the workspace uuid on match, or null when:
|
|
229
|
+
* - no project has an auto_bound block at all
|
|
230
|
+
* - no auto_bound block matches BOTH chat_id and topic_id
|
|
231
|
+
* - the matching project's routing config was already cleared by a
|
|
232
|
+
* concurrent recovery (race-safe)
|
|
233
|
+
*
|
|
234
|
+
* Match rule: `auto_bound.topic_id === topicId` AND
|
|
235
|
+
* `inbound_chat_ids.includes(chatId)`.
|
|
236
|
+
* The chat_id check guards against the (rare) case of identical topic_id
|
|
237
|
+
* numbers across two different supergroups; without it we could clear
|
|
238
|
+
* the wrong workspace's binding.
|
|
239
|
+
*
|
|
240
|
+
* Lock-free read: this just scans on-disk routing configs. The actual
|
|
241
|
+
* mutation (`clearBinding`) is lockfile-protected on the per-project
|
|
242
|
+
* routing file, so two concurrent recoveries racing to clear the same
|
|
243
|
+
* binding serialize cleanly — first wins, second sees no binding to
|
|
244
|
+
* clear and returns false.
|
|
245
|
+
*/
|
|
246
|
+
export async function findOwnerOfBinding(args) {
|
|
247
|
+
const all = await loadAllProjectChatRouting(args.dataRoot);
|
|
248
|
+
for (const [uuid, cfg] of all) {
|
|
249
|
+
const bound = cfg.telegram?.auto_bound;
|
|
250
|
+
if (!bound)
|
|
251
|
+
continue;
|
|
252
|
+
if (bound.topic_id !== args.topicId)
|
|
253
|
+
continue;
|
|
254
|
+
const inboundChats = cfg.telegram?.inbound_chat_ids ?? [];
|
|
255
|
+
if (!inboundChats.includes(args.chatId))
|
|
256
|
+
continue;
|
|
257
|
+
return uuid;
|
|
258
|
+
}
|
|
259
|
+
return null;
|
|
260
|
+
}
|
|
261
|
+
// ---------------------------------------------------------------------
|
|
262
|
+
// Internal
|
|
263
|
+
// ---------------------------------------------------------------------
|
|
264
|
+
async function ensureRoutingFileExists(routingPath) {
|
|
265
|
+
try {
|
|
266
|
+
await fs.access(routingPath);
|
|
267
|
+
}
|
|
268
|
+
catch {
|
|
269
|
+
await fs.writeFile(routingPath, "{}\n", { flag: "wx" }).catch((err) => {
|
|
270
|
+
// EEXIST is fine — another process touched it in the race window.
|
|
271
|
+
if (err.code !== "EEXIST")
|
|
272
|
+
throw err;
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
async function persistRoutingAtomic(routingPath, cfg) {
|
|
277
|
+
// Write to a sibling tmp + rename for atomicity (rename(2) is atomic
|
|
278
|
+
// on the same filesystem). Avoids partial-write reads from the daemon's
|
|
279
|
+
// 30s reload loop.
|
|
280
|
+
const tmp = `${routingPath}.${process.pid}.tmp`;
|
|
281
|
+
await fs.writeFile(tmp, JSON.stringify(cfg, null, 2) + "\n", "utf8");
|
|
282
|
+
await fs.rename(tmp, routingPath);
|
|
283
|
+
}
|
|
284
|
+
function defaultRpcClient(dataRoot) {
|
|
285
|
+
// No cache: DaemonClient construction is cheap (just stores config)
|
|
286
|
+
// and caching it across calls broke tests that switch OPENSQUID_HOME
|
|
287
|
+
// per test. Construct fresh; pay the ~no-op cost. Pre-research
|
|
288
|
+
// verdict #7.
|
|
289
|
+
const { DaemonClient } = requireCJS("./rpc-client.js");
|
|
290
|
+
return new DaemonClient(dataRoot ? { dataRoot } : {});
|
|
291
|
+
}
|
|
292
|
+
/**
|
|
293
|
+
* Invariant check: if `auto_bound.topic_id` is set, it MUST appear in
|
|
294
|
+
* `inbound_topic_ids`. Pre-research verdict #9: log a warning on
|
|
295
|
+
* mismatch but do NOT auto-repair (preserves user-edited intent).
|
|
296
|
+
*/
|
|
297
|
+
function assertAutoBoundInvariant(cfg, routingPath) {
|
|
298
|
+
const bound = cfg?.telegram?.auto_bound;
|
|
299
|
+
if (!bound)
|
|
300
|
+
return;
|
|
301
|
+
const inboundTopics = cfg?.telegram?.inbound_topic_ids ?? [];
|
|
302
|
+
if (!inboundTopics.includes(bound.topic_id)) {
|
|
303
|
+
process.stderr.write(`[workspace-topic] invariant warning: auto_bound.topic_id=${bound.topic_id} not in inbound_topic_ids=${JSON.stringify(inboundTopics)} for ${routingPath}; not auto-repairing\n`);
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
async function recordOrphanTopic(dataRoot, record) {
|
|
307
|
+
// Pre-research verdict #6: log orphans to a recovery file so the
|
|
308
|
+
// user can clean up (delete the topic manually via Telegram client
|
|
309
|
+
// or via a future TPS.7 cleanup tool) instead of accumulating
|
|
310
|
+
// ghost topics on every retry. Doesn't try to delete the topic
|
|
311
|
+
// (that's a separate RPC call that could ALSO fail, compounding).
|
|
312
|
+
const root = dataRoot ?? process.env.OPENSQUID_HOME;
|
|
313
|
+
if (!root)
|
|
314
|
+
return; // best-effort: nowhere to write
|
|
315
|
+
const recoveryPath = path.join(root, "orphan-topics.jsonl");
|
|
316
|
+
try {
|
|
317
|
+
await fs.mkdir(path.dirname(recoveryPath), { recursive: true });
|
|
318
|
+
await fs.appendFile(recoveryPath, JSON.stringify(record) + "\n", "utf8");
|
|
319
|
+
}
|
|
320
|
+
catch {
|
|
321
|
+
// If even the recovery write fails, give up silently. The original
|
|
322
|
+
// persist error will propagate; that's the load-bearing surface.
|
|
323
|
+
}
|
|
324
|
+
}
|