oh-my-codex 0.16.3 → 0.17.0
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 +3 -3
- package/dist/catalog/__tests__/generator.test.js +2 -0
- package/dist/catalog/__tests__/generator.test.js.map +1 -1
- package/dist/catalog/__tests__/plugin-bundle-ssot.test.js +9 -0
- package/dist/catalog/__tests__/plugin-bundle-ssot.test.js.map +1 -1
- package/dist/cli/__tests__/cleanup.test.js +27 -0
- package/dist/cli/__tests__/cleanup.test.js.map +1 -1
- package/dist/cli/__tests__/codex-plugin-layout.test.js +7 -5
- package/dist/cli/__tests__/codex-plugin-layout.test.js.map +1 -1
- package/dist/cli/__tests__/doctor-warning-copy.test.js +175 -7
- package/dist/cli/__tests__/doctor-warning-copy.test.js.map +1 -1
- package/dist/cli/__tests__/index.test.js +147 -12
- package/dist/cli/__tests__/index.test.js.map +1 -1
- package/dist/cli/__tests__/mcp-serve.test.js +4 -0
- package/dist/cli/__tests__/mcp-serve.test.js.map +1 -1
- package/dist/cli/__tests__/ralph-goal-mode-contract.test.js +2 -0
- package/dist/cli/__tests__/ralph-goal-mode-contract.test.js.map +1 -1
- package/dist/cli/__tests__/ralph.test.js +47 -0
- package/dist/cli/__tests__/ralph.test.js.map +1 -1
- package/dist/cli/__tests__/setup-hooks-shared-ownership.test.js +10 -5
- package/dist/cli/__tests__/setup-hooks-shared-ownership.test.js.map +1 -1
- package/dist/cli/__tests__/setup-install-mode.test.js +299 -27
- package/dist/cli/__tests__/setup-install-mode.test.js.map +1 -1
- package/dist/cli/__tests__/setup-refresh.test.js +85 -3
- package/dist/cli/__tests__/setup-refresh.test.js.map +1 -1
- package/dist/cli/__tests__/setup-scope.test.js +1 -1
- package/dist/cli/__tests__/setup-scope.test.js.map +1 -1
- package/dist/cli/__tests__/setup-skills-overwrite.test.js +2 -1
- package/dist/cli/__tests__/setup-skills-overwrite.test.js.map +1 -1
- package/dist/cli/__tests__/team.test.js +108 -0
- package/dist/cli/__tests__/team.test.js.map +1 -1
- package/dist/cli/__tests__/ultragoal.test.js +91 -0
- package/dist/cli/__tests__/ultragoal.test.js.map +1 -1
- package/dist/cli/__tests__/uninstall.test.js +54 -8
- package/dist/cli/__tests__/uninstall.test.js.map +1 -1
- package/dist/cli/cleanup.d.ts.map +1 -1
- package/dist/cli/cleanup.js +8 -4
- package/dist/cli/cleanup.js.map +1 -1
- package/dist/cli/codex-feature-probe.d.ts +9 -0
- package/dist/cli/codex-feature-probe.d.ts.map +1 -0
- package/dist/cli/codex-feature-probe.js +28 -0
- package/dist/cli/codex-feature-probe.js.map +1 -0
- package/dist/cli/doctor.d.ts +1 -0
- package/dist/cli/doctor.d.ts.map +1 -1
- package/dist/cli/doctor.js +214 -23
- package/dist/cli/doctor.js.map +1 -1
- package/dist/cli/index.d.ts +17 -4
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +152 -24
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/mcp-parity.js +8 -8
- package/dist/cli/mcp-parity.js.map +1 -1
- package/dist/cli/mcp-serve.d.ts.map +1 -1
- package/dist/cli/mcp-serve.js +4 -0
- package/dist/cli/mcp-serve.js.map +1 -1
- package/dist/cli/plugin-marketplace.d.ts +23 -0
- package/dist/cli/plugin-marketplace.d.ts.map +1 -1
- package/dist/cli/plugin-marketplace.js +203 -1
- package/dist/cli/plugin-marketplace.js.map +1 -1
- package/dist/cli/ralph.d.ts.map +1 -1
- package/dist/cli/ralph.js +21 -0
- package/dist/cli/ralph.js.map +1 -1
- package/dist/cli/setup-preferences.d.ts +4 -0
- package/dist/cli/setup-preferences.d.ts.map +1 -1
- package/dist/cli/setup-preferences.js +7 -0
- package/dist/cli/setup-preferences.js.map +1 -1
- package/dist/cli/setup.d.ts +5 -3
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +140 -51
- package/dist/cli/setup.js.map +1 -1
- package/dist/cli/ultragoal.d.ts +1 -1
- package/dist/cli/ultragoal.d.ts.map +1 -1
- package/dist/cli/ultragoal.js +70 -5
- package/dist/cli/ultragoal.js.map +1 -1
- package/dist/cli/uninstall.d.ts +2 -0
- package/dist/cli/uninstall.d.ts.map +1 -1
- package/dist/cli/uninstall.js +12 -3
- package/dist/cli/uninstall.js.map +1 -1
- package/dist/config/__tests__/codex-feature-flags.test.d.ts +2 -0
- package/dist/config/__tests__/codex-feature-flags.test.d.ts.map +1 -0
- package/dist/config/__tests__/codex-feature-flags.test.js +35 -0
- package/dist/config/__tests__/codex-feature-flags.test.js.map +1 -0
- package/dist/config/__tests__/codex-hooks.test.js +143 -9
- package/dist/config/__tests__/codex-hooks.test.js.map +1 -1
- package/dist/config/__tests__/generator-idempotent.test.js +85 -9
- package/dist/config/__tests__/generator-idempotent.test.js.map +1 -1
- package/dist/config/__tests__/generator-notify.test.js +116 -11
- package/dist/config/__tests__/generator-notify.test.js.map +1 -1
- package/dist/config/__tests__/wiki-config-contract.test.js +6 -3
- package/dist/config/__tests__/wiki-config-contract.test.js.map +1 -1
- package/dist/config/codex-feature-flags.d.ts +21 -0
- package/dist/config/codex-feature-flags.d.ts.map +1 -0
- package/dist/config/codex-feature-flags.js +56 -0
- package/dist/config/codex-feature-flags.js.map +1 -0
- package/dist/config/codex-hooks.d.ts +14 -13
- package/dist/config/codex-hooks.d.ts.map +1 -1
- package/dist/config/codex-hooks.js +108 -8
- package/dist/config/codex-hooks.js.map +1 -1
- package/dist/config/generator.d.ts +15 -3
- package/dist/config/generator.d.ts.map +1 -1
- package/dist/config/generator.js +233 -129
- package/dist/config/generator.js.map +1 -1
- package/dist/config/omx-first-party-mcp.d.ts +3 -1
- package/dist/config/omx-first-party-mcp.d.ts.map +1 -1
- package/dist/config/omx-first-party-mcp.js +9 -2
- package/dist/config/omx-first-party-mcp.js.map +1 -1
- package/dist/hooks/__tests__/design-skill.test.d.ts +2 -0
- package/dist/hooks/__tests__/design-skill.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/design-skill.test.js +55 -0
- package/dist/hooks/__tests__/design-skill.test.js.map +1 -0
- package/dist/hooks/__tests__/keyword-detector.test.js +92 -2
- package/dist/hooks/__tests__/keyword-detector.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-non-omx-guard.test.js +125 -1
- package/dist/hooks/__tests__/notify-hook-non-omx-guard.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js +265 -0
- package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js.map +1 -1
- package/dist/hooks/__tests__/skill-catalog-hygiene.test.d.ts +2 -0
- package/dist/hooks/__tests__/skill-catalog-hygiene.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/skill-catalog-hygiene.test.js +84 -0
- package/dist/hooks/__tests__/skill-catalog-hygiene.test.js.map +1 -0
- package/dist/hooks/__tests__/skill-guidance-contract.test.js +41 -0
- package/dist/hooks/__tests__/skill-guidance-contract.test.js.map +1 -1
- package/dist/hooks/agents-overlay.js +2 -2
- package/dist/hooks/agents-overlay.js.map +1 -1
- package/dist/hooks/keyword-detector.d.ts +1 -0
- package/dist/hooks/keyword-detector.d.ts.map +1 -1
- package/dist/hooks/keyword-detector.js +12 -6
- 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 +2 -0
- 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 +47 -2
- package/dist/hooks/prompt-guidance-contract.js.map +1 -1
- package/dist/hud/__tests__/state.test.js +164 -0
- package/dist/hud/__tests__/state.test.js.map +1 -1
- package/dist/hud/state.d.ts.map +1 -1
- package/dist/hud/state.js +4 -5
- package/dist/hud/state.js.map +1 -1
- package/dist/mcp/__tests__/bootstrap.test.js +3 -0
- package/dist/mcp/__tests__/bootstrap.test.js.map +1 -1
- package/dist/mcp/__tests__/hermes-bridge.test.d.ts +2 -0
- package/dist/mcp/__tests__/hermes-bridge.test.d.ts.map +1 -0
- package/dist/mcp/__tests__/hermes-bridge.test.js +374 -0
- package/dist/mcp/__tests__/hermes-bridge.test.js.map +1 -0
- package/dist/mcp/__tests__/state-paths.test.js +155 -11
- package/dist/mcp/__tests__/state-paths.test.js.map +1 -1
- package/dist/mcp/__tests__/state-server.test.js +166 -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 +2 -0
- package/dist/mcp/bootstrap.js.map +1 -1
- package/dist/mcp/hermes-bridge.d.ts +81 -0
- package/dist/mcp/hermes-bridge.d.ts.map +1 -0
- package/dist/mcp/hermes-bridge.js +400 -0
- package/dist/mcp/hermes-bridge.js.map +1 -0
- package/dist/mcp/hermes-server.d.ts +269 -0
- package/dist/mcp/hermes-server.d.ts.map +1 -0
- package/dist/mcp/hermes-server.js +121 -0
- package/dist/mcp/hermes-server.js.map +1 -0
- package/dist/mcp/state-paths.d.ts.map +1 -1
- package/dist/mcp/state-paths.js +64 -11
- package/dist/mcp/state-paths.js.map +1 -1
- package/dist/modes/__tests__/base-session-scope.test.js +22 -0
- package/dist/modes/__tests__/base-session-scope.test.js.map +1 -1
- package/dist/modes/__tests__/base-tmux-pane.test.js +88 -27
- package/dist/modes/__tests__/base-tmux-pane.test.js.map +1 -1
- package/dist/modes/base.d.ts.map +1 -1
- package/dist/modes/base.js +5 -0
- package/dist/modes/base.js.map +1 -1
- package/dist/planning/__tests__/approved-execution-lifecycle-matrix.test.d.ts +2 -0
- package/dist/planning/__tests__/approved-execution-lifecycle-matrix.test.d.ts.map +1 -0
- package/dist/planning/__tests__/approved-execution-lifecycle-matrix.test.js +316 -0
- package/dist/planning/__tests__/approved-execution-lifecycle-matrix.test.js.map +1 -0
- package/dist/planning/__tests__/approved-launch-hint-lineage-matrix.test.d.ts +2 -0
- package/dist/planning/__tests__/approved-launch-hint-lineage-matrix.test.d.ts.map +1 -0
- package/dist/planning/__tests__/approved-launch-hint-lineage-matrix.test.js +481 -0
- package/dist/planning/__tests__/approved-launch-hint-lineage-matrix.test.js.map +1 -0
- package/dist/planning/__tests__/artifacts.test.js +533 -4
- package/dist/planning/__tests__/artifacts.test.js.map +1 -1
- package/dist/planning/__tests__/context-pack-status.test.js +524 -0
- package/dist/planning/__tests__/context-pack-status.test.js.map +1 -1
- package/dist/planning/__tests__/markdown-structure.test.d.ts +2 -0
- package/dist/planning/__tests__/markdown-structure.test.d.ts.map +1 -0
- package/dist/planning/__tests__/markdown-structure.test.js +459 -0
- package/dist/planning/__tests__/markdown-structure.test.js.map +1 -0
- package/dist/planning/__tests__/ready-context-pack-role-refs.test.js +523 -1
- package/dist/planning/__tests__/ready-context-pack-role-refs.test.js.map +1 -1
- package/dist/planning/artifacts.d.ts +1 -1
- package/dist/planning/artifacts.d.ts.map +1 -1
- package/dist/planning/artifacts.js +227 -28
- package/dist/planning/artifacts.js.map +1 -1
- package/dist/planning/context-pack-status.d.ts +25 -0
- package/dist/planning/context-pack-status.d.ts.map +1 -1
- package/dist/planning/context-pack-status.js +272 -31
- package/dist/planning/context-pack-status.js.map +1 -1
- package/dist/planning/markdown-structure.d.ts +20 -0
- package/dist/planning/markdown-structure.d.ts.map +1 -0
- package/dist/planning/markdown-structure.js +137 -0
- package/dist/planning/markdown-structure.js.map +1 -0
- package/dist/ralph/__tests__/completion-audit.test.d.ts +2 -0
- package/dist/ralph/__tests__/completion-audit.test.d.ts.map +1 -0
- package/dist/ralph/__tests__/completion-audit.test.js +121 -0
- package/dist/ralph/__tests__/completion-audit.test.js.map +1 -0
- package/dist/ralph/completion-audit.d.ts +8 -0
- package/dist/ralph/completion-audit.d.ts.map +1 -0
- package/dist/ralph/completion-audit.js +99 -0
- package/dist/ralph/completion-audit.js.map +1 -0
- package/dist/scripts/__tests__/codex-native-hook.test.js +407 -15
- package/dist/scripts/__tests__/codex-native-hook.test.js.map +1 -1
- package/dist/scripts/__tests__/notify-dispatcher.test.d.ts +2 -0
- package/dist/scripts/__tests__/notify-dispatcher.test.d.ts.map +1 -0
- package/dist/scripts/__tests__/notify-dispatcher.test.js +126 -0
- package/dist/scripts/__tests__/notify-dispatcher.test.js.map +1 -0
- package/dist/scripts/codex-native-hook.d.ts +1 -0
- package/dist/scripts/codex-native-hook.d.ts.map +1 -1
- package/dist/scripts/codex-native-hook.js +177 -71
- package/dist/scripts/codex-native-hook.js.map +1 -1
- package/dist/scripts/codex-native-pre-post.d.ts.map +1 -1
- package/dist/scripts/codex-native-pre-post.js +4 -2
- package/dist/scripts/codex-native-pre-post.js.map +1 -1
- package/dist/scripts/notify-dispatcher.js +30 -1
- package/dist/scripts/notify-dispatcher.js.map +1 -1
- package/dist/scripts/notify-hook/tmux-injection.d.ts.map +1 -1
- package/dist/scripts/notify-hook/tmux-injection.js +91 -2
- package/dist/scripts/notify-hook/tmux-injection.js.map +1 -1
- package/dist/scripts/notify-hook.js +3 -1
- package/dist/scripts/notify-hook.js.map +1 -1
- package/dist/state/__tests__/workflow-transition.test.js +102 -27
- package/dist/state/__tests__/workflow-transition.test.js.map +1 -1
- package/dist/state/mode-state-context.d.ts +2 -0
- package/dist/state/mode-state-context.d.ts.map +1 -1
- package/dist/state/mode-state-context.js +21 -0
- package/dist/state/mode-state-context.js.map +1 -1
- package/dist/state/operations.d.ts.map +1 -1
- package/dist/state/operations.js +9 -3
- package/dist/state/operations.js.map +1 -1
- package/dist/state/skill-active.d.ts +7 -0
- package/dist/state/skill-active.d.ts.map +1 -1
- package/dist/state/skill-active.js +25 -8
- package/dist/state/skill-active.js.map +1 -1
- package/dist/state/workflow-transition-reconcile.d.ts +1 -0
- package/dist/state/workflow-transition-reconcile.d.ts.map +1 -1
- package/dist/state/workflow-transition-reconcile.js +22 -15
- package/dist/state/workflow-transition-reconcile.js.map +1 -1
- package/dist/state/workflow-transition.js +3 -3
- package/dist/state/workflow-transition.js.map +1 -1
- package/dist/team/__tests__/approved-execution.test.js +39 -0
- package/dist/team/__tests__/approved-execution.test.js.map +1 -1
- package/dist/team/__tests__/runtime.test.js +5 -0
- package/dist/team/__tests__/runtime.test.js.map +1 -1
- package/dist/team/__tests__/scaling.test.js +497 -2
- package/dist/team/__tests__/scaling.test.js.map +1 -1
- package/dist/team/__tests__/state-root.test.js +1 -1
- package/dist/team/__tests__/state-root.test.js.map +1 -1
- package/dist/team/__tests__/worker-bootstrap.test.js +8 -0
- package/dist/team/__tests__/worker-bootstrap.test.js.map +1 -1
- package/dist/team/approved-execution.d.ts.map +1 -1
- package/dist/team/approved-execution.js +3 -0
- package/dist/team/approved-execution.js.map +1 -1
- package/dist/team/scaling.d.ts.map +1 -1
- package/dist/team/scaling.js +43 -0
- package/dist/team/scaling.js.map +1 -1
- package/dist/team/state-root.d.ts.map +1 -1
- package/dist/team/state-root.js +4 -0
- package/dist/team/state-root.js.map +1 -1
- package/dist/team/state.d.ts.map +1 -1
- package/dist/team/state.js +2 -6
- package/dist/team/state.js.map +1 -1
- package/dist/ultragoal/__tests__/artifacts.test.js +245 -1
- package/dist/ultragoal/__tests__/artifacts.test.js.map +1 -1
- package/dist/ultragoal/__tests__/docs-contract.test.js +21 -0
- package/dist/ultragoal/__tests__/docs-contract.test.js.map +1 -1
- package/dist/ultragoal/artifacts.d.ts +52 -2
- package/dist/ultragoal/artifacts.d.ts.map +1 -1
- package/dist/ultragoal/artifacts.js +301 -15
- package/dist/ultragoal/artifacts.js.map +1 -1
- package/dist/utils/__tests__/paths.test.js +31 -1
- package/dist/utils/__tests__/paths.test.js.map +1 -1
- package/dist/utils/paths.d.ts +6 -0
- package/dist/utils/paths.d.ts.map +1 -1
- package/dist/utils/paths.js +18 -0
- package/dist/utils/paths.js.map +1 -1
- package/dist/wiki/lifecycle.js +4 -4
- package/dist/wiki/lifecycle.js.map +1 -1
- package/package.json +1 -1
- package/plugins/oh-my-codex/.codex-plugin/plugin.json +1 -1
- package/plugins/oh-my-codex/.mcp.json +13 -5
- package/plugins/oh-my-codex/skills/analyze/SKILL.md +0 -2
- package/plugins/oh-my-codex/skills/autopilot/SKILL.md +2 -2
- package/plugins/oh-my-codex/skills/code-review/SKILL.md +1 -3
- package/plugins/oh-my-codex/skills/deep-interview/SKILL.md +5 -7
- package/plugins/oh-my-codex/skills/design/SKILL.md +180 -0
- package/plugins/oh-my-codex/skills/doctor/SKILL.md +2 -2
- package/plugins/oh-my-codex/skills/omx-setup/SKILL.md +3 -3
- package/plugins/oh-my-codex/skills/pipeline/SKILL.md +3 -3
- package/plugins/oh-my-codex/skills/plan/SKILL.md +3 -6
- package/plugins/oh-my-codex/skills/ralph/SKILL.md +9 -10
- package/plugins/oh-my-codex/skills/skill/SKILL.md +2 -1
- package/plugins/oh-my-codex/skills/ultragoal/SKILL.md +36 -3
- package/plugins/oh-my-codex/skills/ultraqa/SKILL.md +175 -64
- package/plugins/oh-my-codex/skills/ultrawork/SKILL.md +8 -8
- package/plugins/oh-my-codex/skills/visual-ralph/SKILL.md +2 -2
- package/plugins/oh-my-codex/skills/wiki/SKILL.md +13 -13
- package/skills/analyze/SKILL.md +0 -2
- package/skills/ask-claude/SKILL.md +5 -3
- package/skills/ask-gemini/SKILL.md +5 -3
- package/skills/autopilot/SKILL.md +2 -2
- package/skills/code-review/SKILL.md +1 -3
- package/skills/deep-interview/SKILL.md +5 -7
- package/skills/design/SKILL.md +180 -0
- package/skills/doctor/SKILL.md +2 -2
- package/skills/ecomode/SKILL.md +105 -1
- package/skills/frontend-ui-ux/SKILL.md +6 -24
- package/skills/git-master/SKILL.md +2 -4
- package/skills/omx-setup/SKILL.md +3 -3
- package/skills/pipeline/SKILL.md +3 -3
- package/skills/plan/SKILL.md +3 -6
- package/skills/ralph/SKILL.md +9 -10
- package/skills/skill/SKILL.md +2 -1
- package/skills/swarm/SKILL.md +5 -3
- package/skills/tdd/SKILL.md +95 -1
- package/skills/ultragoal/SKILL.md +36 -3
- package/skills/ultraqa/SKILL.md +175 -64
- package/skills/ultrawork/SKILL.md +8 -8
- package/skills/visual-ralph/SKILL.md +2 -2
- package/skills/web-clone/SKILL.md +348 -1
- package/skills/wiki/SKILL.md +13 -13
- package/src/scripts/__tests__/codex-native-hook.test.ts +437 -14
- package/src/scripts/__tests__/notify-dispatcher.test.ts +153 -0
- package/src/scripts/codex-native-hook.ts +205 -61
- package/src/scripts/codex-native-pre-post.ts +4 -1
- package/src/scripts/notify-dispatcher.ts +40 -1
- package/src/scripts/notify-hook/tmux-injection.ts +110 -3
- package/src/scripts/notify-hook.ts +3 -1
- package/templates/catalog-manifest.json +9 -2
|
@@ -13,6 +13,7 @@ interface NotifyDispatcherMetadata {
|
|
|
13
13
|
version?: number;
|
|
14
14
|
previousNotify?: string[] | null;
|
|
15
15
|
omxNotify?: string[];
|
|
16
|
+
dispatcherNotify?: string[];
|
|
16
17
|
}
|
|
17
18
|
|
|
18
19
|
function parseArgs(): { metadataPath: string; payloadArg: string } {
|
|
@@ -36,6 +37,42 @@ function isCommand(value: unknown): value is string[] {
|
|
|
36
37
|
);
|
|
37
38
|
}
|
|
38
39
|
|
|
40
|
+
function sameCommand(
|
|
41
|
+
left: readonly string[] | null | undefined,
|
|
42
|
+
right: readonly string[] | null | undefined,
|
|
43
|
+
): boolean {
|
|
44
|
+
if (!left || !right || left.length !== right.length) return false;
|
|
45
|
+
return left.every((part, index) => part === right[index]);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function resolveNotifyEntrypoint(command: readonly string[]): string | undefined {
|
|
49
|
+
if (!/(?:^|[\\/])node(?:\.exe)?$/i.test(command[0] ?? "")) {
|
|
50
|
+
return command[0];
|
|
51
|
+
}
|
|
52
|
+
return command.slice(1).find((arg) => !arg.startsWith("-"));
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function isOmxManagedNotifyCommand(command: readonly string[] | null | undefined): boolean {
|
|
56
|
+
if (!command) return false;
|
|
57
|
+
const entrypoint = resolveNotifyEntrypoint(command);
|
|
58
|
+
if (!entrypoint) return false;
|
|
59
|
+
if (!/(?:^|[\\/])notify-(?:hook|dispatcher)\.js$/.test(entrypoint)) {
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
return /(?:^|[\\/])oh-my-codex(?:[\\/]|$)/.test(entrypoint);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
function isManagedPreviousNotify(
|
|
66
|
+
previousNotify: readonly string[] | null | undefined,
|
|
67
|
+
metadata: NotifyDispatcherMetadata | null,
|
|
68
|
+
): boolean {
|
|
69
|
+
return (
|
|
70
|
+
isOmxManagedNotifyCommand(previousNotify) ||
|
|
71
|
+
sameCommand(previousNotify, metadata?.omxNotify) ||
|
|
72
|
+
sameCommand(previousNotify, metadata?.dispatcherNotify)
|
|
73
|
+
);
|
|
74
|
+
}
|
|
75
|
+
|
|
39
76
|
async function readMetadata(
|
|
40
77
|
path: string,
|
|
41
78
|
): Promise<NotifyDispatcherMetadata | null> {
|
|
@@ -67,7 +104,9 @@ async function main(): Promise<void> {
|
|
|
67
104
|
const { metadataPath, payloadArg } = parseArgs();
|
|
68
105
|
if (!payloadArg || payloadArg.startsWith("-")) return;
|
|
69
106
|
const metadata = await readMetadata(metadataPath);
|
|
70
|
-
|
|
107
|
+
if (!isManagedPreviousNotify(metadata?.previousNotify, metadata)) {
|
|
108
|
+
runNotify(metadata?.previousNotify, payloadArg);
|
|
109
|
+
}
|
|
71
110
|
runNotify(metadata?.omxNotify, payloadArg);
|
|
72
111
|
}
|
|
73
112
|
|
|
@@ -99,7 +99,7 @@ async function resolveCanonicalPaneFromPaneTarget(paneTarget: any, expectedCwd:
|
|
|
99
99
|
return finalizeResolvedPane(healedPaneId, 'healed_hud_pane_target', expectedCwd);
|
|
100
100
|
}
|
|
101
101
|
|
|
102
|
-
async function resolvePreferredModePane(stateDir: string, allowedModes: string[]): Promise<{ mode: string; state: any; pane: string } | null> {
|
|
102
|
+
async function resolvePreferredModePane(stateDir: string, allowedModes: string[]): Promise<{ mode: string; state: any; pane: string; stateDir: string } | null> {
|
|
103
103
|
const scopedDirs = await getScopedStateDirsForCurrentSession(stateDir).catch(() => [stateDir]);
|
|
104
104
|
const dirs = [...scopedDirs];
|
|
105
105
|
if (!dirs.map((dir) => resolvePath(dir)).includes(resolvePath(stateDir))) {
|
|
@@ -111,13 +111,84 @@ async function resolvePreferredModePane(stateDir: string, allowedModes: string[]
|
|
|
111
111
|
const parsed = await readJsonIfExists(path, null);
|
|
112
112
|
const pane = safeString(parsed?.tmux_pane_id || '').trim();
|
|
113
113
|
if (parsed?.active && pane) {
|
|
114
|
-
return { mode, state: parsed, pane };
|
|
114
|
+
return { mode, state: parsed, pane, stateDir: dir };
|
|
115
115
|
}
|
|
116
116
|
}
|
|
117
117
|
}
|
|
118
118
|
return null;
|
|
119
119
|
}
|
|
120
120
|
|
|
121
|
+
function modeStateMatchesInvocationOwner(modeState: any, payload: any, managedContext: any): { ok: true } | { ok: false; reason: string } {
|
|
122
|
+
const invocationSessionId = resolveInvocationSessionId(payload);
|
|
123
|
+
const canonicalSessionId = safeString(managedContext?.canonicalSessionId || managedContext?.sessionState?.session_id).trim();
|
|
124
|
+
const nativeSessionId = safeString(managedContext?.nativeSessionId || managedContext?.sessionState?.native_session_id || managedContext?.sessionState?.codex_session_id).trim();
|
|
125
|
+
const allowedSessionIds = new Set([
|
|
126
|
+
invocationSessionId,
|
|
127
|
+
canonicalSessionId,
|
|
128
|
+
nativeSessionId,
|
|
129
|
+
].filter(Boolean));
|
|
130
|
+
|
|
131
|
+
const ownerOmxSessionId = safeString(modeState?.owner_omx_session_id).trim();
|
|
132
|
+
if (ownerOmxSessionId && !allowedSessionIds.has(ownerOmxSessionId)) {
|
|
133
|
+
return { ok: false, reason: 'mode_owner_session_mismatch' };
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
const stateSessionId = safeString(modeState?.session_id).trim();
|
|
137
|
+
if (!ownerOmxSessionId && stateSessionId && !allowedSessionIds.has(stateSessionId)) {
|
|
138
|
+
return { ok: false, reason: 'mode_session_mismatch' };
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
const ownerCodexSessionId = safeString(modeState?.owner_codex_session_id || modeState?.codex_session_id).trim();
|
|
142
|
+
if (ownerCodexSessionId && !allowedSessionIds.has(ownerCodexSessionId)) {
|
|
143
|
+
return { ok: false, reason: 'mode_codex_session_mismatch' };
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
return { ok: true };
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
async function validateResolvedInjectionOwnership({
|
|
150
|
+
paneTarget,
|
|
151
|
+
cwd,
|
|
152
|
+
payload,
|
|
153
|
+
modeState,
|
|
154
|
+
modePane,
|
|
155
|
+
managedCurrentPane,
|
|
156
|
+
}: any): Promise<{ ok: true } | { ok: false; reason: string; managedContext?: any }> {
|
|
157
|
+
const ownership = await verifyManagedPaneTarget(paneTarget, cwd, payload, { allowTeamWorker: false });
|
|
158
|
+
if (!ownership.ok) {
|
|
159
|
+
return { ok: false, reason: ownership.reason || 'pane_not_managed_session', managedContext: ownership.managedContext };
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
const modeOwner = modeStateMatchesInvocationOwner(modeState, payload, ownership.managedContext);
|
|
163
|
+
if (!modeOwner.ok) return { ...modeOwner, managedContext: ownership.managedContext };
|
|
164
|
+
|
|
165
|
+
const statePane = safeString(modePane || modeState?.tmux_pane_id).trim();
|
|
166
|
+
const currentPane = safeString(managedCurrentPane).trim();
|
|
167
|
+
if (statePane && currentPane && statePane !== currentPane) {
|
|
168
|
+
return { ok: false, reason: 'mode_pane_current_pane_mismatch', managedContext: ownership.managedContext };
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
const expectedWindowId = safeString(modeState?.tmux_window_id || modeState?.tmuxWindowId).trim();
|
|
172
|
+
if (!expectedWindowId) {
|
|
173
|
+
return { ok: true };
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
try {
|
|
177
|
+
const windowResult = await runProcess('tmux', ['display-message', '-p', '-t', paneTarget, '#{window_id}'], 2000);
|
|
178
|
+
const paneWindowId = safeString(windowResult.stdout).trim();
|
|
179
|
+
if (!paneWindowId) {
|
|
180
|
+
return { ok: false, reason: 'pane_window_unverified', managedContext: ownership.managedContext };
|
|
181
|
+
}
|
|
182
|
+
if (paneWindowId !== expectedWindowId) {
|
|
183
|
+
return { ok: false, reason: 'pane_window_mismatch', managedContext: ownership.managedContext };
|
|
184
|
+
}
|
|
185
|
+
} catch {
|
|
186
|
+
return { ok: false, reason: 'pane_window_unverified', managedContext: ownership.managedContext };
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
return { ok: true };
|
|
190
|
+
}
|
|
191
|
+
|
|
121
192
|
async function readVisibleAllowedModes(
|
|
122
193
|
cwd: string,
|
|
123
194
|
stateDir: string,
|
|
@@ -460,7 +531,22 @@ export async function handleTmuxInjection({
|
|
|
460
531
|
turnId,
|
|
461
532
|
timestamp: nowIso,
|
|
462
533
|
}), sourceText);
|
|
463
|
-
const
|
|
534
|
+
const managedCurrentPane = await resolveManagedCurrentPane(cwd, payload, { allowTeamWorker: false });
|
|
535
|
+
if (modePane && managedCurrentPane && modePane !== managedCurrentPane) {
|
|
536
|
+
state.last_reason = 'mode_pane_current_pane_mismatch';
|
|
537
|
+
state.last_event_at = nowIso;
|
|
538
|
+
await writeFile(hookStatePath, JSON.stringify(state, null, 2)).catch(() => {});
|
|
539
|
+
await logTmuxHookEvent(logsDir, {
|
|
540
|
+
...baseLog,
|
|
541
|
+
event: 'injection_skipped',
|
|
542
|
+
reason: 'mode_pane_current_pane_mismatch',
|
|
543
|
+
mode_pane: modePane,
|
|
544
|
+
current_pane: managedCurrentPane,
|
|
545
|
+
});
|
|
546
|
+
return;
|
|
547
|
+
}
|
|
548
|
+
|
|
549
|
+
const preferredPaneTarget = modePane || managedCurrentPane;
|
|
464
550
|
let resolution = preferredModePane
|
|
465
551
|
? await resolvePaneTarget({ type: 'pane', value: preferredModePane.pane }, cwd, preferredModePane.pane, cwd, payload)
|
|
466
552
|
: preferredPaneTarget
|
|
@@ -484,6 +570,27 @@ export async function handleTmuxInjection({
|
|
|
484
570
|
}
|
|
485
571
|
const paneTarget = resolution.paneTarget;
|
|
486
572
|
|
|
573
|
+
const ownership = await validateResolvedInjectionOwnership({
|
|
574
|
+
paneTarget,
|
|
575
|
+
cwd,
|
|
576
|
+
payload,
|
|
577
|
+
modeState,
|
|
578
|
+
modePane,
|
|
579
|
+
managedCurrentPane,
|
|
580
|
+
});
|
|
581
|
+
if (!ownership.ok) {
|
|
582
|
+
state.last_reason = ownership.reason;
|
|
583
|
+
state.last_event_at = nowIso;
|
|
584
|
+
await writeFile(hookStatePath, JSON.stringify(state, null, 2)).catch(() => {});
|
|
585
|
+
await logTmuxHookEvent(logsDir, {
|
|
586
|
+
...baseLog,
|
|
587
|
+
event: 'injection_skipped',
|
|
588
|
+
reason: ownership.reason,
|
|
589
|
+
pane_target: paneTarget,
|
|
590
|
+
});
|
|
591
|
+
return;
|
|
592
|
+
}
|
|
593
|
+
|
|
487
594
|
// Final guard phase: pane is canonical identity for quota/cooldown.
|
|
488
595
|
const guard = evaluateInjectionGuards({
|
|
489
596
|
config,
|
|
@@ -29,6 +29,7 @@ import {
|
|
|
29
29
|
getQuotaUsage,
|
|
30
30
|
normalizeInputMessages,
|
|
31
31
|
} from './notify-hook/payload-parser.js';
|
|
32
|
+
import { getBaseStateDir } from '../mcp/state-paths.js';
|
|
32
33
|
import {
|
|
33
34
|
getScopedStatePath,
|
|
34
35
|
readCurrentSessionId,
|
|
@@ -303,7 +304,7 @@ async function main() {
|
|
|
303
304
|
? await resolveTeamStateDirForWorker(cwd, parsedTeamWorker)
|
|
304
305
|
: null;
|
|
305
306
|
const workerStateRootResolved = !isTeamWorker || !!resolvedWorkerStateDir;
|
|
306
|
-
const stateDir = resolvedWorkerStateDir ||
|
|
307
|
+
const stateDir = resolvedWorkerStateDir || getBaseStateDir(cwd);
|
|
307
308
|
const logsDir = join(cwd, '.omx', 'logs');
|
|
308
309
|
const omxDir = join(cwd, '.omx');
|
|
309
310
|
let currentOmxSessionId = '';
|
|
@@ -621,6 +622,7 @@ async function main() {
|
|
|
621
622
|
if (latestUserInput) {
|
|
622
623
|
await recordSkillActivation({
|
|
623
624
|
stateDir,
|
|
625
|
+
sourceCwd: cwd,
|
|
624
626
|
text: latestUserInput,
|
|
625
627
|
sessionId: getEffectiveSessionId(),
|
|
626
628
|
threadId: payloadThreadId,
|
|
@@ -181,13 +181,20 @@
|
|
|
181
181
|
"internalRequired": false
|
|
182
182
|
},
|
|
183
183
|
{
|
|
184
|
-
"name": "
|
|
184
|
+
"name": "design",
|
|
185
185
|
"category": "shortcut",
|
|
186
|
-
"status": "
|
|
186
|
+
"status": "active",
|
|
187
187
|
"canonical": "designer",
|
|
188
188
|
"core": false,
|
|
189
189
|
"internalRequired": false
|
|
190
190
|
},
|
|
191
|
+
{
|
|
192
|
+
"name": "frontend-ui-ux",
|
|
193
|
+
"category": "shortcut",
|
|
194
|
+
"status": "deprecated",
|
|
195
|
+
"core": false,
|
|
196
|
+
"internalRequired": false
|
|
197
|
+
},
|
|
191
198
|
{
|
|
192
199
|
"name": "git-master",
|
|
193
200
|
"category": "shortcut",
|