oh-my-codex 0.13.2 → 0.14.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Cargo.lock +5 -5
- package/Cargo.toml +1 -1
- package/README.md +14 -8
- package/crates/omx-explore/src/main.rs +94 -1
- package/crates/omx-sparkshell/src/codex_bridge.rs +59 -12
- package/crates/omx-sparkshell/tests/execution.rs +48 -0
- package/dist/autoresearch/__tests__/skill-validation.test.d.ts +2 -0
- package/dist/autoresearch/__tests__/skill-validation.test.d.ts.map +1 -0
- package/dist/autoresearch/__tests__/skill-validation.test.js +91 -0
- package/dist/autoresearch/__tests__/skill-validation.test.js.map +1 -0
- package/dist/autoresearch/skill-validation.d.ts +13 -0
- package/dist/autoresearch/skill-validation.d.ts.map +1 -0
- package/dist/autoresearch/skill-validation.js +165 -0
- package/dist/autoresearch/skill-validation.js.map +1 -0
- package/dist/catalog/__tests__/schema.test.js +6 -0
- package/dist/catalog/__tests__/schema.test.js.map +1 -1
- package/dist/cli/__tests__/autoresearch-guided.test.js +236 -273
- package/dist/cli/__tests__/autoresearch-guided.test.js.map +1 -1
- package/dist/cli/__tests__/autoresearch.test.js +64 -653
- package/dist/cli/__tests__/autoresearch.test.js.map +1 -1
- package/dist/cli/__tests__/explore.test.js +33 -1
- package/dist/cli/__tests__/explore.test.js.map +1 -1
- package/dist/cli/__tests__/index.test.js +18 -2
- package/dist/cli/__tests__/index.test.js.map +1 -1
- package/dist/cli/__tests__/nested-help-routing.test.js +2 -1
- package/dist/cli/__tests__/nested-help-routing.test.js.map +1 -1
- package/dist/cli/__tests__/package-bin-contract.test.js +5 -0
- package/dist/cli/__tests__/package-bin-contract.test.js.map +1 -1
- package/dist/cli/__tests__/question.test.d.ts +2 -0
- package/dist/cli/__tests__/question.test.d.ts.map +1 -0
- package/dist/cli/__tests__/question.test.js +166 -0
- package/dist/cli/__tests__/question.test.js.map +1 -0
- package/dist/cli/__tests__/session-search-help.test.js +1 -1
- package/dist/cli/__tests__/session-search-help.test.js.map +1 -1
- package/dist/cli/__tests__/setup-agents-overwrite.test.js +32 -7
- package/dist/cli/__tests__/setup-agents-overwrite.test.js.map +1 -1
- package/dist/cli/__tests__/setup-refresh.test.js +8 -6
- package/dist/cli/__tests__/setup-refresh.test.js.map +1 -1
- package/dist/cli/__tests__/setup-skills-overwrite.test.js +2 -0
- package/dist/cli/__tests__/setup-skills-overwrite.test.js.map +1 -1
- package/dist/cli/__tests__/sparkshell-cli.test.js +23 -0
- package/dist/cli/__tests__/sparkshell-cli.test.js.map +1 -1
- package/dist/cli/__tests__/uninstall.test.js +65 -5
- package/dist/cli/__tests__/uninstall.test.js.map +1 -1
- package/dist/cli/__tests__/update.test.js +360 -26
- package/dist/cli/__tests__/update.test.js.map +1 -1
- package/dist/cli/autoresearch-guided.d.ts +24 -7
- package/dist/cli/autoresearch-guided.d.ts.map +1 -1
- package/dist/cli/autoresearch-guided.js +189 -130
- package/dist/cli/autoresearch-guided.js.map +1 -1
- package/dist/cli/autoresearch.d.ts +3 -2
- package/dist/cli/autoresearch.d.ts.map +1 -1
- package/dist/cli/autoresearch.js +29 -305
- package/dist/cli/autoresearch.js.map +1 -1
- package/dist/cli/doctor.d.ts.map +1 -1
- package/dist/cli/doctor.js +43 -0
- package/dist/cli/doctor.js.map +1 -1
- package/dist/cli/explore.d.ts.map +1 -1
- package/dist/cli/explore.js +18 -3
- package/dist/cli/explore.js.map +1 -1
- package/dist/cli/index.d.ts +2 -1
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +15 -3
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/question.d.ts +3 -0
- package/dist/cli/question.d.ts.map +1 -0
- package/dist/cli/question.js +182 -0
- package/dist/cli/question.js.map +1 -0
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +25 -3
- package/dist/cli/setup.js.map +1 -1
- package/dist/cli/sparkshell.d.ts.map +1 -1
- package/dist/cli/sparkshell.js +11 -1
- package/dist/cli/sparkshell.js.map +1 -1
- package/dist/cli/team.d.ts.map +1 -1
- package/dist/cli/team.js +159 -394
- package/dist/cli/team.js.map +1 -1
- package/dist/cli/uninstall.d.ts.map +1 -1
- package/dist/cli/uninstall.js +3 -1
- package/dist/cli/uninstall.js.map +1 -1
- package/dist/cli/update.d.ts +37 -9
- package/dist/cli/update.d.ts.map +1 -1
- package/dist/cli/update.js +204 -26
- package/dist/cli/update.js.map +1 -1
- package/dist/config/__tests__/generator-idempotent.test.js +51 -14
- package/dist/config/__tests__/generator-idempotent.test.js.map +1 -1
- package/dist/config/__tests__/generator-notify.test.js +35 -10
- package/dist/config/__tests__/generator-notify.test.js.map +1 -1
- package/dist/config/generator.d.ts +1 -0
- package/dist/config/generator.d.ts.map +1 -1
- package/dist/config/generator.js +61 -7
- package/dist/config/generator.js.map +1 -1
- package/dist/hooks/__tests__/analyze-routing-contract.test.js +22 -13
- package/dist/hooks/__tests__/analyze-routing-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/anti-slop-workflow.test.js +3 -3
- package/dist/hooks/__tests__/anti-slop-workflow.test.js.map +1 -1
- package/dist/hooks/__tests__/code-review-skill-contract.test.d.ts +2 -0
- package/dist/hooks/__tests__/code-review-skill-contract.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/code-review-skill-contract.test.js +56 -0
- package/dist/hooks/__tests__/code-review-skill-contract.test.js.map +1 -0
- package/dist/hooks/__tests__/debugger-log-recency-contract.test.js +2 -2
- package/dist/hooks/__tests__/debugger-log-recency-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/deep-interview-contract.test.js +51 -5
- package/dist/hooks/__tests__/deep-interview-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.d.ts +2 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.js +43 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.js.map +1 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.d.ts +2 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.js +38 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.js.map +1 -0
- package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.js +2 -2
- package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/keyword-detector.test.js +308 -17
- package/dist/hooks/__tests__/keyword-detector.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-fallback-watcher.test.js +570 -2
- package/dist/hooks/__tests__/notify-fallback-watcher.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js +717 -16
- package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js +25 -0
- package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js +894 -1
- package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js +34 -0
- package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js +132 -0
- package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-contract.test.js +22 -4
- package/dist/hooks/__tests__/prompt-guidance-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-fragments.test.js +4 -2
- package/dist/hooks/__tests__/prompt-guidance-fragments.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-test-helpers.d.ts +1 -0
- package/dist/hooks/__tests__/prompt-guidance-test-helpers.d.ts.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-test-helpers.js +19 -1
- package/dist/hooks/__tests__/prompt-guidance-test-helpers.js.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js +28 -0
- package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-orchestration-boundary.test.js +5 -4
- package/dist/hooks/__tests__/prompt-orchestration-boundary.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-team-routing.test.js +2 -2
- package/dist/hooks/__tests__/prompt-team-routing.test.js.map +1 -1
- package/dist/hooks/__tests__/triage-config.test.d.ts +2 -0
- package/dist/hooks/__tests__/triage-config.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/triage-config.test.js +211 -0
- package/dist/hooks/__tests__/triage-config.test.js.map +1 -0
- package/dist/hooks/__tests__/triage-heuristic.test.d.ts +2 -0
- package/dist/hooks/__tests__/triage-heuristic.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/triage-heuristic.test.js +230 -0
- package/dist/hooks/__tests__/triage-heuristic.test.js.map +1 -0
- package/dist/hooks/__tests__/triage-state.test.d.ts +2 -0
- package/dist/hooks/__tests__/triage-state.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/triage-state.test.js +426 -0
- package/dist/hooks/__tests__/triage-state.test.js.map +1 -0
- package/dist/hooks/keyword-detector.d.ts +26 -7
- package/dist/hooks/keyword-detector.d.ts.map +1 -1
- package/dist/hooks/keyword-detector.js +97 -26
- package/dist/hooks/keyword-detector.js.map +1 -1
- package/dist/hooks/keyword-registry.d.ts.map +1 -1
- package/dist/hooks/keyword-registry.js +16 -9
- package/dist/hooks/keyword-registry.js.map +1 -1
- package/dist/hooks/prompt-guidance-contract.d.ts.map +1 -1
- package/dist/hooks/prompt-guidance-contract.js +28 -1
- package/dist/hooks/prompt-guidance-contract.js.map +1 -1
- package/dist/hooks/triage-config.d.ts +33 -0
- package/dist/hooks/triage-config.d.ts.map +1 -0
- package/dist/hooks/triage-config.js +87 -0
- package/dist/hooks/triage-config.js.map +1 -0
- package/dist/hooks/triage-heuristic.d.ts +20 -0
- package/dist/hooks/triage-heuristic.d.ts.map +1 -0
- package/dist/hooks/triage-heuristic.js +210 -0
- package/dist/hooks/triage-heuristic.js.map +1 -0
- package/dist/hooks/triage-state.d.ts +63 -0
- package/dist/hooks/triage-state.d.ts.map +1 -0
- package/dist/hooks/triage-state.js +138 -0
- package/dist/hooks/triage-state.js.map +1 -0
- package/dist/hud/__tests__/reconcile.test.js +20 -0
- package/dist/hud/__tests__/reconcile.test.js.map +1 -1
- package/dist/hud/reconcile.d.ts +1 -0
- package/dist/hud/reconcile.d.ts.map +1 -1
- package/dist/hud/reconcile.js +2 -1
- package/dist/hud/reconcile.js.map +1 -1
- package/dist/mcp/__tests__/bootstrap.test.js +5 -24
- package/dist/mcp/__tests__/bootstrap.test.js.map +1 -1
- package/dist/mcp/__tests__/state-server.test.js +127 -0
- package/dist/mcp/__tests__/state-server.test.js.map +1 -1
- package/dist/mcp/bootstrap.d.ts +1 -1
- package/dist/mcp/bootstrap.d.ts.map +1 -1
- package/dist/mcp/bootstrap.js +3 -11
- package/dist/mcp/bootstrap.js.map +1 -1
- package/dist/mcp/state-server.d.ts +25 -0
- package/dist/mcp/state-server.d.ts.map +1 -1
- package/dist/mcp/state-server.js +41 -0
- package/dist/mcp/state-server.js.map +1 -1
- package/dist/modes/__tests__/base-ralph-contract.test.js +15 -0
- package/dist/modes/__tests__/base-ralph-contract.test.js.map +1 -1
- package/dist/modes/base.d.ts +1 -0
- package/dist/modes/base.d.ts.map +1 -1
- package/dist/modes/base.js +22 -6
- package/dist/modes/base.js.map +1 -1
- package/dist/notifications/__tests__/index.test.js +75 -0
- package/dist/notifications/__tests__/index.test.js.map +1 -1
- package/dist/notifications/__tests__/session-status.test.js +90 -0
- package/dist/notifications/__tests__/session-status.test.js.map +1 -1
- package/dist/notifications/index.d.ts.map +1 -1
- package/dist/notifications/index.js +39 -22
- package/dist/notifications/index.js.map +1 -1
- package/dist/notifications/session-status.d.ts +2 -0
- package/dist/notifications/session-status.d.ts.map +1 -1
- package/dist/notifications/session-status.js +19 -4
- package/dist/notifications/session-status.js.map +1 -1
- package/dist/openclaw/index.d.ts +5 -3
- package/dist/openclaw/index.d.ts.map +1 -1
- package/dist/openclaw/index.js +5 -3
- package/dist/openclaw/index.js.map +1 -1
- package/dist/question/__tests__/client.test.d.ts +2 -0
- package/dist/question/__tests__/client.test.d.ts.map +1 -0
- package/dist/question/__tests__/client.test.js +70 -0
- package/dist/question/__tests__/client.test.js.map +1 -0
- package/dist/question/__tests__/deep-interview.test.d.ts +2 -0
- package/dist/question/__tests__/deep-interview.test.d.ts.map +1 -0
- package/dist/question/__tests__/deep-interview.test.js +118 -0
- package/dist/question/__tests__/deep-interview.test.js.map +1 -0
- package/dist/question/__tests__/policy.test.d.ts +2 -0
- package/dist/question/__tests__/policy.test.d.ts.map +1 -0
- package/dist/question/__tests__/policy.test.js +107 -0
- package/dist/question/__tests__/policy.test.js.map +1 -0
- package/dist/question/__tests__/renderer.test.d.ts +2 -0
- package/dist/question/__tests__/renderer.test.d.ts.map +1 -0
- package/dist/question/__tests__/renderer.test.js +238 -0
- package/dist/question/__tests__/renderer.test.js.map +1 -0
- package/dist/question/__tests__/state.test.d.ts +2 -0
- package/dist/question/__tests__/state.test.d.ts.map +1 -0
- package/dist/question/__tests__/state.test.js +75 -0
- package/dist/question/__tests__/state.test.js.map +1 -0
- package/dist/question/__tests__/types.test.d.ts +2 -0
- package/dist/question/__tests__/types.test.d.ts.map +1 -0
- package/dist/question/__tests__/types.test.js +44 -0
- package/dist/question/__tests__/types.test.js.map +1 -0
- package/dist/question/__tests__/ui.test.d.ts +2 -0
- package/dist/question/__tests__/ui.test.d.ts.map +1 -0
- package/dist/question/__tests__/ui.test.js +169 -0
- package/dist/question/__tests__/ui.test.js.map +1 -0
- package/dist/question/client.d.ts +54 -0
- package/dist/question/client.d.ts.map +1 -0
- package/dist/question/client.js +77 -0
- package/dist/question/client.js.map +1 -0
- package/dist/question/deep-interview.d.ts +30 -0
- package/dist/question/deep-interview.d.ts.map +1 -0
- package/dist/question/deep-interview.js +118 -0
- package/dist/question/deep-interview.js.map +1 -0
- package/dist/question/policy.d.ts +18 -0
- package/dist/question/policy.d.ts.map +1 -0
- package/dist/question/policy.js +77 -0
- package/dist/question/policy.js.map +1 -0
- package/dist/question/renderer.d.ts +20 -0
- package/dist/question/renderer.d.ts.map +1 -0
- package/dist/question/renderer.js +190 -0
- package/dist/question/renderer.js.map +1 -0
- package/dist/question/state.d.ts +19 -0
- package/dist/question/state.d.ts.map +1 -0
- package/dist/question/state.js +108 -0
- package/dist/question/state.js.map +1 -0
- package/dist/question/types.d.ts +66 -0
- package/dist/question/types.d.ts.map +1 -0
- package/dist/question/types.js +82 -0
- package/dist/question/types.js.map +1 -0
- package/dist/question/ui.d.ts +38 -0
- package/dist/question/ui.d.ts.map +1 -0
- package/dist/question/ui.js +321 -0
- package/dist/question/ui.js.map +1 -0
- package/dist/ralph/contract.d.ts +1 -1
- package/dist/ralph/contract.d.ts.map +1 -1
- package/dist/ralph/contract.js +4 -1
- package/dist/ralph/contract.js.map +1 -1
- package/dist/ralplan/runtime.js +1 -1
- package/dist/ralplan/runtime.js.map +1 -1
- package/dist/runtime/__tests__/run-loop.test.d.ts +2 -0
- package/dist/runtime/__tests__/run-loop.test.d.ts.map +1 -0
- package/dist/runtime/__tests__/run-loop.test.js +35 -0
- package/dist/runtime/__tests__/run-loop.test.js.map +1 -0
- package/dist/runtime/__tests__/run-outcome.test.d.ts +2 -0
- package/dist/runtime/__tests__/run-outcome.test.d.ts.map +1 -0
- package/dist/runtime/__tests__/run-outcome.test.js +102 -0
- package/dist/runtime/__tests__/run-outcome.test.js.map +1 -0
- package/dist/runtime/__tests__/run-state.test.d.ts +2 -0
- package/dist/runtime/__tests__/run-state.test.d.ts.map +1 -0
- package/dist/runtime/__tests__/run-state.test.js +37 -0
- package/dist/runtime/__tests__/run-state.test.js.map +1 -0
- package/dist/runtime/run-loop.d.ts +45 -0
- package/dist/runtime/run-loop.d.ts.map +1 -0
- package/dist/runtime/run-loop.js +51 -0
- package/dist/runtime/run-loop.js.map +1 -0
- package/dist/runtime/run-outcome.d.ts +46 -0
- package/dist/runtime/run-outcome.d.ts.map +1 -0
- package/dist/runtime/run-outcome.js +285 -0
- package/dist/runtime/run-outcome.js.map +1 -0
- package/dist/runtime/run-state.d.ts +40 -0
- package/dist/runtime/run-state.d.ts.map +1 -0
- package/dist/runtime/run-state.js +120 -0
- package/dist/runtime/run-state.js.map +1 -0
- package/dist/runtime/terminal-lifecycle.d.ts +11 -0
- package/dist/runtime/terminal-lifecycle.d.ts.map +1 -0
- package/dist/runtime/terminal-lifecycle.js +52 -0
- package/dist/runtime/terminal-lifecycle.js.map +1 -0
- package/dist/scripts/__tests__/codex-native-hook.test.js +1459 -126
- package/dist/scripts/__tests__/codex-native-hook.test.js.map +1 -1
- package/dist/scripts/__tests__/postinstall.test.d.ts +2 -0
- package/dist/scripts/__tests__/postinstall.test.d.ts.map +1 -0
- package/dist/scripts/__tests__/postinstall.test.js +178 -0
- package/dist/scripts/__tests__/postinstall.test.js.map +1 -0
- package/dist/scripts/codex-native-hook.d.ts +3 -0
- package/dist/scripts/codex-native-hook.d.ts.map +1 -1
- package/dist/scripts/codex-native-hook.js +308 -61
- package/dist/scripts/codex-native-hook.js.map +1 -1
- package/dist/scripts/notify-fallback-watcher.js +81 -2
- package/dist/scripts/notify-fallback-watcher.js.map +1 -1
- package/dist/scripts/notify-hook/auto-nudge.d.ts +27 -0
- package/dist/scripts/notify-hook/auto-nudge.d.ts.map +1 -1
- package/dist/scripts/notify-hook/auto-nudge.js +83 -20
- package/dist/scripts/notify-hook/auto-nudge.js.map +1 -1
- package/dist/scripts/notify-hook/managed-tmux.d.ts.map +1 -1
- package/dist/scripts/notify-hook/managed-tmux.js +64 -38
- package/dist/scripts/notify-hook/managed-tmux.js.map +1 -1
- package/dist/scripts/notify-hook/ralph-session-resume.js +1 -1
- package/dist/scripts/notify-hook/ralph-session-resume.js.map +1 -1
- package/dist/scripts/notify-hook.js +15 -5
- package/dist/scripts/notify-hook.js.map +1 -1
- package/dist/scripts/postinstall.d.ts +22 -0
- package/dist/scripts/postinstall.d.ts.map +1 -0
- package/dist/scripts/postinstall.js +105 -0
- package/dist/scripts/postinstall.js.map +1 -0
- package/dist/scripts/sync-prompt-guidance-fragments.js +5 -0
- package/dist/scripts/sync-prompt-guidance-fragments.js.map +1 -1
- package/dist/state/__tests__/operations-ralph-phase.test.js +21 -0
- package/dist/state/__tests__/operations-ralph-phase.test.js.map +1 -1
- package/dist/state/__tests__/operations.test.js +18 -0
- package/dist/state/__tests__/operations.test.js.map +1 -1
- package/dist/state/__tests__/workflow-transition.test.js +11 -0
- package/dist/state/__tests__/workflow-transition.test.js.map +1 -1
- package/dist/state/operations.d.ts.map +1 -1
- package/dist/state/operations.js +15 -0
- package/dist/state/operations.js.map +1 -1
- package/dist/state/workflow-transition-reconcile.d.ts.map +1 -1
- package/dist/state/workflow-transition-reconcile.js +14 -1
- package/dist/state/workflow-transition-reconcile.js.map +1 -1
- package/dist/state/workflow-transition.d.ts.map +1 -1
- package/dist/state/workflow-transition.js +3 -1
- package/dist/state/workflow-transition.js.map +1 -1
- package/dist/team/__tests__/followup-planner.test.js +15 -0
- package/dist/team/__tests__/followup-planner.test.js.map +1 -1
- package/dist/team/__tests__/role-router.test.js +47 -0
- package/dist/team/__tests__/role-router.test.js.map +1 -1
- package/dist/team/__tests__/runtime.test.js +108 -2
- package/dist/team/__tests__/runtime.test.js.map +1 -1
- package/dist/team/followup-planner.d.ts.map +1 -1
- package/dist/team/followup-planner.js +31 -9
- package/dist/team/followup-planner.js.map +1 -1
- package/dist/team/role-router.d.ts.map +1 -1
- package/dist/team/role-router.js +73 -0
- package/dist/team/role-router.js.map +1 -1
- package/dist/team/runtime.d.ts.map +1 -1
- package/dist/team/runtime.js +18 -4
- package/dist/team/runtime.js.map +1 -1
- package/dist/utils/__tests__/dep-versions.test.js +25 -8
- package/dist/utils/__tests__/dep-versions.test.js.map +1 -1
- package/dist/utils/__tests__/paths.test.js +45 -0
- package/dist/utils/__tests__/paths.test.js.map +1 -1
- package/dist/utils/paths.d.ts +2 -0
- package/dist/utils/paths.d.ts.map +1 -1
- package/dist/utils/paths.js +22 -7
- package/dist/utils/paths.js.map +1 -1
- package/dist/verification/__tests__/ci-rust-gates.test.js +1 -1
- package/dist/verification/__tests__/ci-rust-gates.test.js.map +1 -1
- package/package.json +4 -2
- package/prompts/architect.md +4 -0
- package/prompts/code-reviewer.md +3 -0
- package/prompts/dependency-expert.md +3 -0
- package/prompts/executor.md +5 -0
- package/prompts/explore.md +2 -0
- package/prompts/planner.md +5 -0
- package/prompts/product-analyst.md +8 -8
- package/prompts/researcher.md +78 -30
- package/prompts/verifier.md +4 -0
- package/skills/autoresearch/SKILL.md +68 -0
- package/skills/code-review/SKILL.md +94 -28
- package/skills/deep-interview/SKILL.md +100 -9
- package/skills/help/SKILL.md +3 -1
- package/skills/ralplan/SKILL.md +1 -0
- package/skills/team/SKILL.md +1 -0
- package/skills/ultrawork/SKILL.md +1 -0
- package/src/scripts/__tests__/codex-native-hook.test.ts +2373 -692
- package/src/scripts/__tests__/postinstall.test.ts +210 -0
- package/src/scripts/codex-native-hook.ts +365 -66
- package/src/scripts/notify-fallback-watcher.ts +92 -2
- package/src/scripts/notify-hook/auto-nudge.ts +89 -20
- package/src/scripts/notify-hook/managed-tmux.ts +70 -31
- package/src/scripts/notify-hook/ralph-session-resume.ts +1 -1
- package/src/scripts/notify-hook.ts +23 -5
- package/src/scripts/postinstall-bootstrap.js +23 -0
- package/src/scripts/postinstall.ts +161 -0
- package/src/scripts/sync-prompt-guidance-fragments.ts +4 -0
- package/templates/AGENTS.md +48 -37
- package/templates/catalog-manifest.json +7 -0
- package/templates/model-instructions/explore-lightweight-AGENTS.md +11 -0
- package/templates/model-instructions/sparkshell-lightweight-AGENTS.md +10 -0
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import assert from 'node:assert/strict';
|
|
2
|
+
import { EventEmitter } from 'node:events';
|
|
3
|
+
import { describe, it } from 'node:test';
|
|
4
|
+
import { mkdtemp, rm } from 'node:fs/promises';
|
|
5
|
+
import { tmpdir } from 'node:os';
|
|
6
|
+
import { join } from 'node:path';
|
|
7
|
+
import { createQuestionRecord, markQuestionPrompting, readQuestionRecord } from '../state.js';
|
|
8
|
+
import { formatQuestionAnswerForInjection } from '../renderer.js';
|
|
9
|
+
import { applyInteractiveSelectionKey, createInitialInteractiveSelectionState, promptForSelectionsWithArrows, renderInteractiveQuestionFrame, runQuestionUi, } from '../ui.js';
|
|
10
|
+
class FakeTtyInput extends EventEmitter {
|
|
11
|
+
isTTY = true;
|
|
12
|
+
rawMode = false;
|
|
13
|
+
setRawMode(mode) {
|
|
14
|
+
this.rawMode = mode;
|
|
15
|
+
}
|
|
16
|
+
resume() { }
|
|
17
|
+
pause() { }
|
|
18
|
+
}
|
|
19
|
+
class FakeTtyOutput {
|
|
20
|
+
isTTY = true;
|
|
21
|
+
chunks = [];
|
|
22
|
+
write(chunk) {
|
|
23
|
+
this.chunks.push(chunk);
|
|
24
|
+
return true;
|
|
25
|
+
}
|
|
26
|
+
toString() {
|
|
27
|
+
return this.chunks.join('');
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
function makeRecord(overrides = {}) {
|
|
31
|
+
return {
|
|
32
|
+
kind: 'omx.question/v1',
|
|
33
|
+
question_id: 'question-1',
|
|
34
|
+
created_at: '2026-04-19T00:00:00.000Z',
|
|
35
|
+
updated_at: '2026-04-19T00:00:00.000Z',
|
|
36
|
+
status: 'prompting',
|
|
37
|
+
question: 'Pick one',
|
|
38
|
+
options: [
|
|
39
|
+
{ label: 'Alpha', value: 'alpha' },
|
|
40
|
+
{ label: 'Beta', value: 'beta' },
|
|
41
|
+
],
|
|
42
|
+
allow_other: true,
|
|
43
|
+
other_label: 'Other',
|
|
44
|
+
multi_select: false,
|
|
45
|
+
type: 'single-answerable',
|
|
46
|
+
...overrides,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
describe('question ui injection metadata', () => {
|
|
50
|
+
it('persists return-target metadata for answered questions', async () => {
|
|
51
|
+
const cwd = await mkdtemp(join(tmpdir(), 'omx-question-ui-'));
|
|
52
|
+
try {
|
|
53
|
+
const { recordPath } = await createQuestionRecord(cwd, {
|
|
54
|
+
question: 'Pick one',
|
|
55
|
+
options: [{ label: 'A', value: 'a' }],
|
|
56
|
+
allow_other: true,
|
|
57
|
+
other_label: 'Other',
|
|
58
|
+
multi_select: false,
|
|
59
|
+
type: 'single-answerable',
|
|
60
|
+
}, 'sess-ui');
|
|
61
|
+
await markQuestionPrompting(recordPath, {
|
|
62
|
+
renderer: 'tmux-pane',
|
|
63
|
+
target: '%42',
|
|
64
|
+
launched_at: '2026-04-19T00:00:00.000Z',
|
|
65
|
+
return_target: '%11',
|
|
66
|
+
return_transport: 'tmux-send-keys',
|
|
67
|
+
});
|
|
68
|
+
const loaded = await readQuestionRecord(recordPath);
|
|
69
|
+
assert.equal(loaded?.renderer?.return_target, '%11');
|
|
70
|
+
assert.equal(loaded?.renderer?.return_transport, 'tmux-send-keys');
|
|
71
|
+
assert.equal(formatQuestionAnswerForInjection({
|
|
72
|
+
kind: 'other',
|
|
73
|
+
value: 'hello can you hear me',
|
|
74
|
+
selected_labels: ['Other'],
|
|
75
|
+
selected_values: ['hello can you hear me'],
|
|
76
|
+
other_text: 'hello can you hear me',
|
|
77
|
+
}), '[omx question answered] hello can you hear me');
|
|
78
|
+
}
|
|
79
|
+
finally {
|
|
80
|
+
await rm(cwd, { recursive: true, force: true });
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
describe('question ui arrow navigation', () => {
|
|
85
|
+
it('moves single-select cursor with up/down arrows and submits current selection on Enter', () => {
|
|
86
|
+
const record = makeRecord();
|
|
87
|
+
let state = createInitialInteractiveSelectionState();
|
|
88
|
+
state = applyInteractiveSelectionKey(record, state, { name: 'down' }).state;
|
|
89
|
+
assert.equal(state.cursorIndex, 1);
|
|
90
|
+
state = applyInteractiveSelectionKey(record, state, { name: 'down' }).state;
|
|
91
|
+
assert.equal(state.cursorIndex, 2);
|
|
92
|
+
state = applyInteractiveSelectionKey(record, state, { name: 'up' }).state;
|
|
93
|
+
assert.equal(state.cursorIndex, 1);
|
|
94
|
+
const submit = applyInteractiveSelectionKey(record, state, { name: 'enter' });
|
|
95
|
+
assert.equal(submit.submit, true);
|
|
96
|
+
assert.equal(submit.state.cursorIndex, 1);
|
|
97
|
+
});
|
|
98
|
+
it('toggles multi-select choices with Space and requires a choice before Enter', () => {
|
|
99
|
+
const record = makeRecord({ multi_select: true, type: 'multi-answerable', allow_other: false });
|
|
100
|
+
let state = createInitialInteractiveSelectionState();
|
|
101
|
+
let update = applyInteractiveSelectionKey(record, state, { name: 'enter' });
|
|
102
|
+
assert.equal(update.submit, false);
|
|
103
|
+
assert.match(update.state.error ?? '', /Select one or more options/);
|
|
104
|
+
state = update.state;
|
|
105
|
+
state = applyInteractiveSelectionKey(record, state, { name: 'space' }).state;
|
|
106
|
+
assert.deepEqual(state.selectedIndices, [0]);
|
|
107
|
+
state = applyInteractiveSelectionKey(record, state, { name: 'down' }).state;
|
|
108
|
+
state = applyInteractiveSelectionKey(record, state, { name: 'space' }).state;
|
|
109
|
+
assert.deepEqual(state.selectedIndices, [0, 1]);
|
|
110
|
+
update = applyInteractiveSelectionKey(record, state, { name: 'enter' });
|
|
111
|
+
assert.equal(update.submit, true);
|
|
112
|
+
assert.deepEqual(update.state.selectedIndices, [0, 1]);
|
|
113
|
+
});
|
|
114
|
+
it('renders navigation instructions with checkbox markers', () => {
|
|
115
|
+
const frame = renderInteractiveQuestionFrame(makeRecord({ multi_select: true, type: 'multi-answerable' }), {
|
|
116
|
+
cursorIndex: 1,
|
|
117
|
+
selectedIndices: [0],
|
|
118
|
+
});
|
|
119
|
+
assert.match(frame, /Use ↑\/↓ to move, Space to toggle, Enter to submit\./);
|
|
120
|
+
assert.match(frame, /\[x\] 1\. Alpha/);
|
|
121
|
+
assert.match(frame, /› \[ \] 2\. Beta/);
|
|
122
|
+
});
|
|
123
|
+
it('collects arrow-based selection in interactive mode', async () => {
|
|
124
|
+
const input = new FakeTtyInput();
|
|
125
|
+
const output = new FakeTtyOutput();
|
|
126
|
+
const promise = promptForSelectionsWithArrows(makeRecord(), { input, output });
|
|
127
|
+
queueMicrotask(() => {
|
|
128
|
+
input.emit('keypress', '', { name: 'down' });
|
|
129
|
+
input.emit('keypress', '', { name: 'enter' });
|
|
130
|
+
});
|
|
131
|
+
const selections = await promise;
|
|
132
|
+
assert.deepEqual(selections, [2]);
|
|
133
|
+
assert.equal(input.rawMode, false);
|
|
134
|
+
assert.match(output.toString(), /Use ↑\/↓ to move, Enter to select\./);
|
|
135
|
+
});
|
|
136
|
+
it('writes answered state from arrow-key interaction', async () => {
|
|
137
|
+
const cwd = await mkdtemp(join(tmpdir(), 'omx-question-ui-run-'));
|
|
138
|
+
try {
|
|
139
|
+
const { recordPath } = await createQuestionRecord(cwd, {
|
|
140
|
+
question: 'Pick one',
|
|
141
|
+
options: [
|
|
142
|
+
{ label: 'A', value: 'a' },
|
|
143
|
+
{ label: 'B', value: 'b' },
|
|
144
|
+
],
|
|
145
|
+
allow_other: false,
|
|
146
|
+
other_label: 'Other',
|
|
147
|
+
multi_select: false,
|
|
148
|
+
type: 'single-answerable',
|
|
149
|
+
}, 'sess-ui-run');
|
|
150
|
+
const input = new FakeTtyInput();
|
|
151
|
+
const output = new FakeTtyOutput();
|
|
152
|
+
const runPromise = runQuestionUi(recordPath, { input, output });
|
|
153
|
+
setTimeout(() => {
|
|
154
|
+
input.emit('keypress', '', { name: 'down' });
|
|
155
|
+
input.emit('keypress', '', { name: 'enter' });
|
|
156
|
+
}, 25);
|
|
157
|
+
await runPromise;
|
|
158
|
+
const loaded = await readQuestionRecord(recordPath);
|
|
159
|
+
assert.equal(loaded?.status, 'answered');
|
|
160
|
+
assert.equal(loaded?.answer?.kind, 'option');
|
|
161
|
+
assert.equal(loaded?.answer?.value, 'b');
|
|
162
|
+
assert.equal(loaded?.type, 'single-answerable');
|
|
163
|
+
}
|
|
164
|
+
finally {
|
|
165
|
+
await rm(cwd, { recursive: true, force: true });
|
|
166
|
+
}
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
//# sourceMappingURL=ui.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ui.test.js","sourceRoot":"","sources":["../../../src/question/__tests__/ui.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import type { QuestionAnswer, QuestionInput } from './types.js';
|
|
2
|
+
export interface OmxQuestionSuccessPayload {
|
|
3
|
+
ok: true;
|
|
4
|
+
question_id: string;
|
|
5
|
+
session_id?: string;
|
|
6
|
+
prompt: QuestionInput;
|
|
7
|
+
answer: QuestionAnswer;
|
|
8
|
+
}
|
|
9
|
+
export interface OmxQuestionErrorPayload {
|
|
10
|
+
ok: false;
|
|
11
|
+
question_id?: string;
|
|
12
|
+
session_id?: string;
|
|
13
|
+
error: {
|
|
14
|
+
code: string;
|
|
15
|
+
message: string;
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export type OmxQuestionPayload = OmxQuestionSuccessPayload | OmxQuestionErrorPayload;
|
|
19
|
+
export interface OmxQuestionClientOptions {
|
|
20
|
+
cwd?: string;
|
|
21
|
+
env?: NodeJS.ProcessEnv;
|
|
22
|
+
argv1?: string | null;
|
|
23
|
+
runner?: OmxQuestionProcessRunner;
|
|
24
|
+
}
|
|
25
|
+
export interface OmxQuestionProcessResult {
|
|
26
|
+
code: number | null;
|
|
27
|
+
stdout: string;
|
|
28
|
+
stderr: string;
|
|
29
|
+
}
|
|
30
|
+
export type OmxQuestionProcessRunner = (command: string, args: string[], options: {
|
|
31
|
+
cwd: string;
|
|
32
|
+
env: NodeJS.ProcessEnv;
|
|
33
|
+
}) => Promise<OmxQuestionProcessResult>;
|
|
34
|
+
export declare class OmxQuestionError extends Error {
|
|
35
|
+
readonly code: string;
|
|
36
|
+
readonly payload?: OmxQuestionErrorPayload;
|
|
37
|
+
readonly stdout: string;
|
|
38
|
+
readonly stderr: string;
|
|
39
|
+
readonly exitCode: number | null;
|
|
40
|
+
constructor(code: string, message: string, options?: {
|
|
41
|
+
payload?: OmxQuestionErrorPayload;
|
|
42
|
+
stdout?: string;
|
|
43
|
+
stderr?: string;
|
|
44
|
+
exitCode?: number | null;
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
export declare function defaultOmxQuestionProcessRunner(command: string, args: string[], options: {
|
|
48
|
+
cwd: string;
|
|
49
|
+
env: NodeJS.ProcessEnv;
|
|
50
|
+
}): Promise<OmxQuestionProcessResult>;
|
|
51
|
+
export declare function runOmxQuestion(input: Partial<QuestionInput> & {
|
|
52
|
+
question: string;
|
|
53
|
+
}, options?: OmxQuestionClientOptions): Promise<OmxQuestionSuccessPayload>;
|
|
54
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/question/client.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEhE,MAAM,WAAW,yBAAyB;IACxC,EAAE,EAAE,IAAI,CAAC;IACT,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,aAAa,CAAC;IACtB,MAAM,EAAE,cAAc,CAAC;CACxB;AAED,MAAM,WAAW,uBAAuB;IACtC,EAAE,EAAE,KAAK,CAAC;IACV,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE;QACL,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;CACH;AAED,MAAM,MAAM,kBAAkB,GAAG,yBAAyB,GAAG,uBAAuB,CAAC;AAErF,MAAM,WAAW,wBAAwB;IACvC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,MAAM,CAAC,EAAE,wBAAwB,CAAC;CACnC;AAED,MAAM,WAAW,wBAAwB;IACvC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,MAAM,wBAAwB,GAAG,CACrC,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,EAAE,EACd,OAAO,EAAE;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,MAAM,CAAC,UAAU,CAAA;CAAE,KAC7C,OAAO,CAAC,wBAAwB,CAAC,CAAC;AAEvC,qBAAa,gBAAiB,SAAQ,KAAK;IACzC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,OAAO,CAAC,EAAE,uBAAuB,CAAC;IAC3C,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;gBAG/B,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,EACf,OAAO,GAAE;QACP,OAAO,CAAC,EAAE,uBAAuB,CAAC;QAClC,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;KACrB;CAUT;AAED,wBAAsB,+BAA+B,CACnD,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,EAAE,EACd,OAAO,EAAE;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,MAAM,CAAC,UAAU,CAAA;CAAE,GAC/C,OAAO,CAAC,wBAAwB,CAAC,CAmBnC;AAuBD,wBAAsB,cAAc,CAClC,KAAK,EAAE,OAAO,CAAC,aAAa,CAAC,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,EACpD,OAAO,GAAE,wBAA6B,GACrC,OAAO,CAAC,yBAAyB,CAAC,CAkCpC"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { spawn } from 'node:child_process';
|
|
2
|
+
import { resolveOmxCliEntryPath } from '../utils/paths.js';
|
|
3
|
+
export class OmxQuestionError extends Error {
|
|
4
|
+
code;
|
|
5
|
+
payload;
|
|
6
|
+
stdout;
|
|
7
|
+
stderr;
|
|
8
|
+
exitCode;
|
|
9
|
+
constructor(code, message, options = {}) {
|
|
10
|
+
super(`${code}: ${message}`);
|
|
11
|
+
this.name = 'OmxQuestionError';
|
|
12
|
+
this.code = code;
|
|
13
|
+
this.payload = options.payload;
|
|
14
|
+
this.stdout = options.stdout ?? '';
|
|
15
|
+
this.stderr = options.stderr ?? '';
|
|
16
|
+
this.exitCode = options.exitCode ?? null;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
export async function defaultOmxQuestionProcessRunner(command, args, options) {
|
|
20
|
+
return new Promise((resolve, reject) => {
|
|
21
|
+
const child = spawn(command, args, {
|
|
22
|
+
cwd: options.cwd,
|
|
23
|
+
env: options.env,
|
|
24
|
+
stdio: ['ignore', 'pipe', 'pipe'],
|
|
25
|
+
});
|
|
26
|
+
let stdout = '';
|
|
27
|
+
let stderr = '';
|
|
28
|
+
child.stdout.on('data', (chunk) => {
|
|
29
|
+
stdout += String(chunk);
|
|
30
|
+
});
|
|
31
|
+
child.stderr.on('data', (chunk) => {
|
|
32
|
+
stderr += String(chunk);
|
|
33
|
+
});
|
|
34
|
+
child.on('error', reject);
|
|
35
|
+
child.on('close', (code) => resolve({ code, stdout, stderr }));
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
function parseQuestionStdout(stdout, stderr, exitCode) {
|
|
39
|
+
const trimmed = stdout.trim();
|
|
40
|
+
if (!trimmed) {
|
|
41
|
+
throw new OmxQuestionError('question_no_stdout', 'omx question did not emit a JSON response on stdout.', {
|
|
42
|
+
stdout,
|
|
43
|
+
stderr,
|
|
44
|
+
exitCode,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
try {
|
|
48
|
+
return JSON.parse(trimmed);
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
throw new OmxQuestionError('question_invalid_stdout', `omx question emitted invalid JSON on stdout: ${error.message}`, { stdout, stderr, exitCode });
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
export async function runOmxQuestion(input, options = {}) {
|
|
55
|
+
const cwd = options.cwd ?? process.cwd();
|
|
56
|
+
const env = options.env ?? process.env;
|
|
57
|
+
const omxBin = resolveOmxCliEntryPath({ argv1: options.argv1, cwd, env });
|
|
58
|
+
if (!omxBin) {
|
|
59
|
+
throw new OmxQuestionError('question_cli_not_found', 'Could not resolve the omx CLI entrypoint for blocking question execution.');
|
|
60
|
+
}
|
|
61
|
+
const runner = options.runner ?? defaultOmxQuestionProcessRunner;
|
|
62
|
+
const result = await runner(process.execPath, [omxBin, 'question', '--json', '--input', JSON.stringify(input)], { cwd, env });
|
|
63
|
+
const payload = parseQuestionStdout(result.stdout, result.stderr, result.code);
|
|
64
|
+
if (!payload.ok) {
|
|
65
|
+
throw new OmxQuestionError(payload.error.code, payload.error.message, {
|
|
66
|
+
payload,
|
|
67
|
+
stdout: result.stdout,
|
|
68
|
+
stderr: result.stderr,
|
|
69
|
+
exitCode: result.code,
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
if (result.code !== 0) {
|
|
73
|
+
throw new OmxQuestionError('question_nonzero_exit', `omx question returned an answer but exited with code ${result.code}.`, { stdout: result.stdout, stderr: result.stderr, exitCode: result.code });
|
|
74
|
+
}
|
|
75
|
+
return payload;
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/question/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AA0C3D,MAAM,OAAO,gBAAiB,SAAQ,KAAK;IAChC,IAAI,CAAS;IACb,OAAO,CAA2B;IAClC,MAAM,CAAS;IACf,MAAM,CAAS;IACf,QAAQ,CAAgB;IAEjC,YACE,IAAY,EACZ,OAAe,EACf,UAKI,EAAE;QAEN,KAAK,CAAC,GAAG,IAAI,KAAK,OAAO,EAAE,CAAC,CAAC;QAC7B,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;QAC/B,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC;QACnC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC;QACnC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC;IAC3C,CAAC;CACF;AAED,MAAM,CAAC,KAAK,UAAU,+BAA+B,CACnD,OAAe,EACf,IAAc,EACd,OAAgD;IAEhD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE;YACjC,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,KAAK,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC;SAClC,CAAC,CAAC;QAEH,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;YAChC,MAAM,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;YAChC,MAAM,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAC1B,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,mBAAmB,CAAC,MAAc,EAAE,MAAc,EAAE,QAAuB;IAClF,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC;IAC9B,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,gBAAgB,CAAC,oBAAoB,EAAE,sDAAsD,EAAE;YACvG,MAAM;YACN,MAAM;YACN,QAAQ;SACT,CAAC,CAAC;IACL,CAAC;IAED,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAuB,CAAC;IACnD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,gBAAgB,CACxB,yBAAyB,EACzB,gDAAiD,KAAe,CAAC,OAAO,EAAE,EAC1E,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,CAC7B,CAAC;IACJ,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAoD,EACpD,UAAoC,EAAE;IAEtC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;IACzC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC;IACvC,MAAM,MAAM,GAAG,sBAAsB,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;IAC1E,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,MAAM,IAAI,gBAAgB,CAAC,wBAAwB,EAAE,2EAA2E,CAAC,CAAC;IACpI,CAAC;IAED,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,+BAA+B,CAAC;IACjE,MAAM,MAAM,GAAG,MAAM,MAAM,CACzB,OAAO,CAAC,QAAQ,EAChB,CAAC,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAChE,EAAE,GAAG,EAAE,GAAG,EAAE,CACb,CAAC;IACF,MAAM,OAAO,GAAG,mBAAmB,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IAE/E,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC;QAChB,MAAM,IAAI,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE;YACpE,OAAO;YACP,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,QAAQ,EAAE,MAAM,CAAC,IAAI;SACtB,CAAC,CAAC;IACL,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;QACtB,MAAM,IAAI,gBAAgB,CACxB,uBAAuB,EACvB,wDAAwD,MAAM,CAAC,IAAI,GAAG,EACtE,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,IAAI,EAAE,CACxE,CAAC;IACJ,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { type OmxQuestionClientOptions, type OmxQuestionSuccessPayload } from './client.js';
|
|
2
|
+
import type { TerminalLifecycleOutcome } from '../runtime/terminal-lifecycle.js';
|
|
3
|
+
import type { QuestionInput } from './types.js';
|
|
4
|
+
export interface DeepInterviewQuestionEnforcementState {
|
|
5
|
+
obligation_id: string;
|
|
6
|
+
source: 'omx-question';
|
|
7
|
+
status: 'pending' | 'satisfied' | 'cleared';
|
|
8
|
+
lifecycle_outcome: 'askuserQuestion';
|
|
9
|
+
requested_at: string;
|
|
10
|
+
question_id?: string;
|
|
11
|
+
satisfied_at?: string;
|
|
12
|
+
cleared_at?: string;
|
|
13
|
+
clear_reason?: 'handoff' | 'abort' | 'error';
|
|
14
|
+
}
|
|
15
|
+
interface DeepInterviewStateRecord {
|
|
16
|
+
updated_at?: string;
|
|
17
|
+
lifecycle_outcome?: TerminalLifecycleOutcome;
|
|
18
|
+
question_enforcement?: DeepInterviewQuestionEnforcementState;
|
|
19
|
+
[key: string]: unknown;
|
|
20
|
+
}
|
|
21
|
+
export declare function createDeepInterviewQuestionObligation(now?: Date): DeepInterviewQuestionEnforcementState;
|
|
22
|
+
export declare function isPendingDeepInterviewQuestionEnforcement(enforcement: Partial<DeepInterviewQuestionEnforcementState> | null | undefined): enforcement is DeepInterviewQuestionEnforcementState;
|
|
23
|
+
export declare function satisfyDeepInterviewQuestionObligation(enforcement: DeepInterviewQuestionEnforcementState, questionId: string, now?: Date): DeepInterviewQuestionEnforcementState;
|
|
24
|
+
export declare function clearDeepInterviewQuestionObligation(enforcement: DeepInterviewQuestionEnforcementState | undefined, reason: 'handoff' | 'abort' | 'error', now?: Date): DeepInterviewQuestionEnforcementState | undefined;
|
|
25
|
+
export declare function updateDeepInterviewQuestionEnforcement(cwd: string, sessionId: string | undefined, updater: (current: DeepInterviewQuestionEnforcementState | undefined) => DeepInterviewQuestionEnforcementState | undefined): Promise<DeepInterviewStateRecord | null>;
|
|
26
|
+
export declare function runDeepInterviewQuestion(input: Partial<QuestionInput> & {
|
|
27
|
+
question: string;
|
|
28
|
+
}, options?: OmxQuestionClientOptions): Promise<OmxQuestionSuccessPayload>;
|
|
29
|
+
export {};
|
|
30
|
+
//# sourceMappingURL=deep-interview.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deep-interview.d.ts","sourceRoot":"","sources":["../../src/question/deep-interview.ts"],"names":[],"mappings":"AAGA,OAAO,EAEL,KAAK,wBAAwB,EAC7B,KAAK,yBAAyB,EAC/B,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAIhD,MAAM,WAAW,qCAAqC;IACpD,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,cAAc,CAAC;IACvB,MAAM,EAAE,SAAS,GAAG,WAAW,GAAG,SAAS,CAAC;IAC5C,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,SAAS,GAAG,OAAO,GAAG,OAAO,CAAC;CAC9C;AAED,UAAU,wBAAwB;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,iBAAiB,CAAC,EAAE,wBAAwB,CAAC;IAC7C,oBAAoB,CAAC,EAAE,qCAAqC,CAAC;IAC7D,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAgCD,wBAAgB,qCAAqC,CACnD,GAAG,OAAa,GACf,qCAAqC,CAQvC;AAED,wBAAgB,yCAAyC,CACvD,WAAW,EAAE,OAAO,CAAC,qCAAqC,CAAC,GAAG,IAAI,GAAG,SAAS,GAC7E,WAAW,IAAI,qCAAqC,CAGtD;AAED,wBAAgB,sCAAsC,CACpD,WAAW,EAAE,qCAAqC,EAClD,UAAU,EAAE,MAAM,EAClB,GAAG,OAAa,GACf,qCAAqC,CASvC;AAED,wBAAgB,oCAAoC,CAClD,WAAW,EAAE,qCAAqC,GAAG,SAAS,EAC9D,MAAM,EAAE,SAAS,GAAG,OAAO,GAAG,OAAO,EACrC,GAAG,OAAa,GACf,qCAAqC,GAAG,SAAS,CASnD;AAED,wBAAsB,sCAAsC,CAC1D,GAAG,EAAE,MAAM,EACX,SAAS,EAAE,MAAM,GAAG,SAAS,EAC7B,OAAO,EAAE,CACP,OAAO,EAAE,qCAAqC,GAAG,SAAS,KACvD,qCAAqC,GAAG,SAAS,GACrD,OAAO,CAAC,wBAAwB,GAAG,IAAI,CAAC,CAiC1C;AAED,wBAAsB,wBAAwB,CAC5C,KAAK,EAAE,OAAO,CAAC,aAAa,CAAC,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,EACpD,OAAO,GAAE,wBAA6B,GACrC,OAAO,CAAC,yBAAyB,CAAC,CA4CpC"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { mkdir, readFile, writeFile } from 'node:fs/promises';
|
|
2
|
+
import { dirname } from 'node:path';
|
|
3
|
+
import { getStateFilePath, readCurrentSessionId } from '../mcp/state-paths.js';
|
|
4
|
+
import { runOmxQuestion, } from './client.js';
|
|
5
|
+
const DEEP_INTERVIEW_STATE_FILE = 'deep-interview-state.json';
|
|
6
|
+
function safeString(value) {
|
|
7
|
+
return typeof value === 'string' ? value : '';
|
|
8
|
+
}
|
|
9
|
+
function buildObligationId(now = new Date()) {
|
|
10
|
+
return `deep-interview-question-${now.toISOString().replace(/[:.]/g, '-')}-${Math.random().toString(16).slice(2, 10)}`;
|
|
11
|
+
}
|
|
12
|
+
async function readDeepInterviewStateIfExists(cwd, sessionId) {
|
|
13
|
+
const statePath = getStateFilePath(DEEP_INTERVIEW_STATE_FILE, cwd, sessionId);
|
|
14
|
+
try {
|
|
15
|
+
return JSON.parse(await readFile(statePath, 'utf-8'));
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
async function writeDeepInterviewState(cwd, state, sessionId) {
|
|
22
|
+
const statePath = getStateFilePath(DEEP_INTERVIEW_STATE_FILE, cwd, sessionId);
|
|
23
|
+
await mkdir(dirname(statePath), { recursive: true });
|
|
24
|
+
await writeFile(statePath, `${JSON.stringify(state, null, 2)}\n`);
|
|
25
|
+
}
|
|
26
|
+
export function createDeepInterviewQuestionObligation(now = new Date()) {
|
|
27
|
+
return {
|
|
28
|
+
obligation_id: buildObligationId(now),
|
|
29
|
+
source: 'omx-question',
|
|
30
|
+
status: 'pending',
|
|
31
|
+
lifecycle_outcome: 'askuserQuestion',
|
|
32
|
+
requested_at: now.toISOString(),
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
export function isPendingDeepInterviewQuestionEnforcement(enforcement) {
|
|
36
|
+
return safeString(enforcement?.obligation_id).trim() !== ''
|
|
37
|
+
&& safeString(enforcement?.status).trim().toLowerCase() === 'pending';
|
|
38
|
+
}
|
|
39
|
+
export function satisfyDeepInterviewQuestionObligation(enforcement, questionId, now = new Date()) {
|
|
40
|
+
return {
|
|
41
|
+
...enforcement,
|
|
42
|
+
status: 'satisfied',
|
|
43
|
+
question_id: questionId,
|
|
44
|
+
satisfied_at: now.toISOString(),
|
|
45
|
+
cleared_at: undefined,
|
|
46
|
+
clear_reason: undefined,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
export function clearDeepInterviewQuestionObligation(enforcement, reason, now = new Date()) {
|
|
50
|
+
if (!enforcement)
|
|
51
|
+
return undefined;
|
|
52
|
+
if (enforcement.status !== 'pending')
|
|
53
|
+
return enforcement;
|
|
54
|
+
return {
|
|
55
|
+
...enforcement,
|
|
56
|
+
status: 'cleared',
|
|
57
|
+
cleared_at: now.toISOString(),
|
|
58
|
+
clear_reason: reason,
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
export async function updateDeepInterviewQuestionEnforcement(cwd, sessionId, updater) {
|
|
62
|
+
if (!safeString(sessionId).trim())
|
|
63
|
+
return null;
|
|
64
|
+
const state = await readDeepInterviewStateIfExists(cwd, sessionId);
|
|
65
|
+
if (!state)
|
|
66
|
+
return null;
|
|
67
|
+
const nextEnforcement = updater(state.question_enforcement);
|
|
68
|
+
const nextState = {
|
|
69
|
+
...state,
|
|
70
|
+
updated_at: new Date().toISOString(),
|
|
71
|
+
...(nextEnforcement
|
|
72
|
+
? {
|
|
73
|
+
question_enforcement: nextEnforcement,
|
|
74
|
+
...(nextEnforcement.status === 'pending'
|
|
75
|
+
? {
|
|
76
|
+
lifecycle_outcome: 'askuserQuestion',
|
|
77
|
+
run_outcome: 'blocked_on_user',
|
|
78
|
+
active: false,
|
|
79
|
+
completed_at: safeString(state.completed_at) || new Date().toISOString(),
|
|
80
|
+
}
|
|
81
|
+
: {}),
|
|
82
|
+
}
|
|
83
|
+
: {}),
|
|
84
|
+
};
|
|
85
|
+
if (!nextEnforcement) {
|
|
86
|
+
delete nextState.question_enforcement;
|
|
87
|
+
}
|
|
88
|
+
if (nextEnforcement?.status !== 'pending') {
|
|
89
|
+
delete nextState.lifecycle_outcome;
|
|
90
|
+
delete nextState.run_outcome;
|
|
91
|
+
}
|
|
92
|
+
await writeDeepInterviewState(cwd, nextState, sessionId);
|
|
93
|
+
return nextState;
|
|
94
|
+
}
|
|
95
|
+
export async function runDeepInterviewQuestion(input, options = {}) {
|
|
96
|
+
const cwd = options.cwd ?? process.cwd();
|
|
97
|
+
const sessionId = safeString(input.session_id).trim() || await readCurrentSessionId(cwd);
|
|
98
|
+
const obligation = createDeepInterviewQuestionObligation();
|
|
99
|
+
await updateDeepInterviewQuestionEnforcement(cwd, sessionId, () => obligation);
|
|
100
|
+
try {
|
|
101
|
+
const result = await runOmxQuestion({
|
|
102
|
+
...input,
|
|
103
|
+
source: input.source ?? 'deep-interview',
|
|
104
|
+
...(sessionId ? { session_id: sessionId } : {}),
|
|
105
|
+
}, options);
|
|
106
|
+
await updateDeepInterviewQuestionEnforcement(cwd, sessionId, (current) => (current?.obligation_id === obligation.obligation_id
|
|
107
|
+
? satisfyDeepInterviewQuestionObligation(current, result.question_id)
|
|
108
|
+
: current));
|
|
109
|
+
return result;
|
|
110
|
+
}
|
|
111
|
+
catch (error) {
|
|
112
|
+
await updateDeepInterviewQuestionEnforcement(cwd, sessionId, (current) => (current?.obligation_id === obligation.obligation_id
|
|
113
|
+
? clearDeepInterviewQuestionObligation(current, 'error')
|
|
114
|
+
: current));
|
|
115
|
+
throw error;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=deep-interview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deep-interview.js","sourceRoot":"","sources":["../../src/question/deep-interview.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { type NotifyCanonicalActiveTeam } from '../scripts/notify-hook/active-team.js';
|
|
2
|
+
export interface QuestionPolicyDecision {
|
|
3
|
+
allowed: boolean;
|
|
4
|
+
sessionId?: string;
|
|
5
|
+
code?: 'worker_blocked' | 'team_blocked' | 'active_execution_mode_blocked';
|
|
6
|
+
message?: string;
|
|
7
|
+
fallbackAllowed?: boolean;
|
|
8
|
+
activeModes: string[];
|
|
9
|
+
activeSkills: string[];
|
|
10
|
+
activeTeams: NotifyCanonicalActiveTeam[];
|
|
11
|
+
}
|
|
12
|
+
export interface EvaluateQuestionPolicyOptions {
|
|
13
|
+
cwd: string;
|
|
14
|
+
explicitSessionId?: string;
|
|
15
|
+
env?: NodeJS.ProcessEnv;
|
|
16
|
+
}
|
|
17
|
+
export declare function evaluateQuestionPolicy(options: EvaluateQuestionPolicyOptions): Promise<QuestionPolicyDecision>;
|
|
18
|
+
//# sourceMappingURL=policy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../src/question/policy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkC,KAAK,yBAAyB,EAAE,MAAM,uCAAuC,CAAC;AAcvH,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,gBAAgB,GAAG,cAAc,GAAG,+BAA+B,CAAC;IAC3E,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,WAAW,EAAE,yBAAyB,EAAE,CAAC;CAC1C;AAED,MAAM,WAAW,6BAA6B;IAC5C,GAAG,EAAE,MAAM,CAAC;IACZ,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,GAAG,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC;CACzB;AAUD,wBAAsB,sBAAsB,CAC1C,OAAO,EAAE,6BAA6B,GACrC,OAAO,CAAC,sBAAsB,CAAC,CAgEjC"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { listNotifyCanonicalActiveTeams } from '../scripts/notify-hook/active-team.js';
|
|
2
|
+
import { readCurrentSessionId } from '../mcp/state-paths.js';
|
|
3
|
+
import { listActiveSkills, readVisibleSkillActiveState } from '../state/skill-active.js';
|
|
4
|
+
import { readActiveWorkflowModes } from '../state/workflow-transition.js';
|
|
5
|
+
const BLOCKED_EXECUTION_SKILLS = new Set([
|
|
6
|
+
'autopilot',
|
|
7
|
+
'autoresearch',
|
|
8
|
+
'team',
|
|
9
|
+
'ralph',
|
|
10
|
+
'ultrawork',
|
|
11
|
+
'ultraqa',
|
|
12
|
+
]);
|
|
13
|
+
function safeString(value) {
|
|
14
|
+
return typeof value === 'string' ? value : '';
|
|
15
|
+
}
|
|
16
|
+
function hasWorkerContext(env) {
|
|
17
|
+
return safeString(env.OMX_TEAM_WORKER).trim() !== '';
|
|
18
|
+
}
|
|
19
|
+
export async function evaluateQuestionPolicy(options) {
|
|
20
|
+
const env = options.env ?? process.env;
|
|
21
|
+
const sessionId = options.explicitSessionId || await readCurrentSessionId(options.cwd);
|
|
22
|
+
if (hasWorkerContext(env)) {
|
|
23
|
+
return {
|
|
24
|
+
allowed: false,
|
|
25
|
+
sessionId,
|
|
26
|
+
code: 'worker_blocked',
|
|
27
|
+
message: 'omx question is unavailable for OMX team workers; only non-team leader sessions may ask user questions.',
|
|
28
|
+
fallbackAllowed: false,
|
|
29
|
+
activeModes: [],
|
|
30
|
+
activeSkills: [],
|
|
31
|
+
activeTeams: [],
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
const [activeModes, skillState, activeTeams] = await Promise.all([
|
|
35
|
+
readActiveWorkflowModes(options.cwd, sessionId),
|
|
36
|
+
readVisibleSkillActiveState(options.cwd, sessionId),
|
|
37
|
+
sessionId ? listNotifyCanonicalActiveTeams(options.cwd, sessionId) : Promise.resolve([]),
|
|
38
|
+
]);
|
|
39
|
+
const activeSkills = listActiveSkills(skillState ?? {}).map((entry) => entry.skill);
|
|
40
|
+
if (activeTeams.length > 0) {
|
|
41
|
+
const summary = activeTeams.map((team) => `${team.teamName} (${team.phase})`).join(', ');
|
|
42
|
+
return {
|
|
43
|
+
allowed: false,
|
|
44
|
+
sessionId,
|
|
45
|
+
code: 'team_blocked',
|
|
46
|
+
message: `omx question is unavailable while this session owns active team mode: ${summary}.`,
|
|
47
|
+
fallbackAllowed: false,
|
|
48
|
+
activeModes,
|
|
49
|
+
activeSkills,
|
|
50
|
+
activeTeams,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
const blockedModes = activeModes.filter((mode) => BLOCKED_EXECUTION_SKILLS.has(mode));
|
|
54
|
+
const blockedSkills = activeSkills.filter((skill) => BLOCKED_EXECUTION_SKILLS.has(skill));
|
|
55
|
+
const blocked = [...new Set([...blockedModes, ...blockedSkills])];
|
|
56
|
+
if (blocked.length > 0) {
|
|
57
|
+
return {
|
|
58
|
+
allowed: false,
|
|
59
|
+
sessionId,
|
|
60
|
+
code: 'active_execution_mode_blocked',
|
|
61
|
+
message: `omx question is unavailable while auto-executing workflows are active: ${blocked.join(', ')}.`,
|
|
62
|
+
fallbackAllowed: false,
|
|
63
|
+
activeModes,
|
|
64
|
+
activeSkills,
|
|
65
|
+
activeTeams,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
return {
|
|
69
|
+
allowed: true,
|
|
70
|
+
fallbackAllowed: true,
|
|
71
|
+
sessionId,
|
|
72
|
+
activeModes,
|
|
73
|
+
activeSkills,
|
|
74
|
+
activeTeams,
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy.js","sourceRoot":"","sources":["../../src/question/policy.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { QuestionAnswer, QuestionRendererState } from './types.js';
|
|
2
|
+
export type QuestionRendererStrategy = 'inside-tmux' | 'detached-tmux' | 'test-noop' | 'unsupported';
|
|
3
|
+
export interface LaunchQuestionRendererOptions {
|
|
4
|
+
cwd: string;
|
|
5
|
+
recordPath: string;
|
|
6
|
+
sessionId?: string;
|
|
7
|
+
env?: NodeJS.ProcessEnv;
|
|
8
|
+
nowIso?: string;
|
|
9
|
+
}
|
|
10
|
+
export type ExecTmuxSync = (args: string[]) => string;
|
|
11
|
+
export type SleepSync = (ms: number) => void;
|
|
12
|
+
export declare function resolveQuestionRendererStrategy(env?: NodeJS.ProcessEnv, tmuxBinary?: string | null): QuestionRendererStrategy;
|
|
13
|
+
export declare function formatQuestionAnswerForInjection(answer: QuestionAnswer): string;
|
|
14
|
+
export declare function injectQuestionAnswerToPane(paneId: string, answer: QuestionAnswer, execTmux?: ExecTmuxSync, sleepImpl?: SleepSync): boolean;
|
|
15
|
+
export declare function launchQuestionRenderer(options: LaunchQuestionRendererOptions, deps?: {
|
|
16
|
+
strategy?: QuestionRendererStrategy;
|
|
17
|
+
execTmux?: ExecTmuxSync;
|
|
18
|
+
sleepSync?: SleepSync;
|
|
19
|
+
}): QuestionRendererState;
|
|
20
|
+
//# sourceMappingURL=renderer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderer.d.ts","sourceRoot":"","sources":["../../src/question/renderer.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAExE,MAAM,MAAM,wBAAwB,GAAG,aAAa,GAAG,eAAe,GAAG,WAAW,GAAG,aAAa,CAAC;AAErG,MAAM,WAAW,6BAA6B;IAC5C,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,MAAM,YAAY,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,MAAM,CAAC;AACtD,MAAM,MAAM,SAAS,GAAG,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;AAe7C,wBAAgB,+BAA+B,CAC7C,GAAG,GAAE,MAAM,CAAC,UAAwB,EACpC,UAAU,gBAAiC,GAC1C,wBAAwB,CAK1B;AA4ED,wBAAgB,gCAAgC,CAAC,MAAM,EAAE,cAAc,GAAG,MAAM,CAU/E;AAED,wBAAgB,0BAA0B,CACxC,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,cAAc,EACtB,QAAQ,GAAE,YAA8B,EACxC,SAAS,GAAE,SAAqB,GAC/B,OAAO,CAaT;AAED,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,6BAA6B,EACtC,IAAI,GAAE;IACJ,QAAQ,CAAC,EAAE,wBAAwB,CAAC;IACpC,QAAQ,CAAC,EAAE,YAAY,CAAC;IACxB,SAAS,CAAC,EAAE,SAAS,CAAC;CAClB,GACL,qBAAqB,CA2EvB"}
|