@aria_asi/cli 0.2.39 → 0.2.41
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/bin/aria.js +236 -34
- package/dist/aria-connector/src/action-ledger-core.d.ts +387 -0
- package/dist/aria-connector/src/action-ledger-core.d.ts.map +1 -0
- package/dist/aria-connector/src/action-ledger-core.js +638 -0
- package/dist/aria-connector/src/action-ledger-core.js.map +1 -0
- package/dist/aria-connector/src/chat.d.ts.map +1 -1
- package/dist/aria-connector/src/chat.js +5 -6
- package/dist/aria-connector/src/chat.js.map +1 -1
- package/dist/aria-connector/src/codebase-scanner.d.ts +1 -1
- package/dist/aria-connector/src/codebase-scanner.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/claude-code.d.ts +1 -0
- package/dist/aria-connector/src/connectors/claude-code.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/claude-code.js +152 -14
- package/dist/aria-connector/src/connectors/claude-code.js.map +1 -1
- package/dist/aria-connector/src/connectors/codebase-awareness.d.ts +10 -0
- package/dist/aria-connector/src/connectors/codebase-awareness.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/codebase-awareness.js +276 -27
- package/dist/aria-connector/src/connectors/codebase-awareness.js.map +1 -1
- package/dist/aria-connector/src/connectors/codex.d.ts +3 -1
- package/dist/aria-connector/src/connectors/codex.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/codex.js +1271 -40
- package/dist/aria-connector/src/connectors/codex.js.map +1 -1
- package/dist/aria-connector/src/connectors/cursor.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/cursor.js +7 -0
- package/dist/aria-connector/src/connectors/cursor.js.map +1 -1
- package/dist/aria-connector/src/connectors/governed-adapter.d.ts +30 -0
- package/dist/aria-connector/src/connectors/governed-adapter.d.ts.map +1 -0
- package/dist/aria-connector/src/connectors/governed-adapter.js +132 -0
- package/dist/aria-connector/src/connectors/governed-adapter.js.map +1 -0
- package/dist/aria-connector/src/connectors/opencode.d.ts +3 -1
- package/dist/aria-connector/src/connectors/opencode.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/opencode.js +18 -2
- package/dist/aria-connector/src/connectors/opencode.js.map +1 -1
- package/dist/aria-connector/src/connectors/repo-guard.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/repo-guard.js +25 -14
- package/dist/aria-connector/src/connectors/repo-guard.js.map +1 -1
- package/dist/aria-connector/src/connectors/runtime.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/runtime.js +92 -2
- package/dist/aria-connector/src/connectors/runtime.js.map +1 -1
- package/dist/aria-connector/src/connectors/shell.d.ts.map +1 -1
- package/dist/aria-connector/src/connectors/shell.js +123 -7
- package/dist/aria-connector/src/connectors/shell.js.map +1 -1
- package/dist/aria-connector/src/cross-cli-hive-binding.d.ts +63 -0
- package/dist/aria-connector/src/cross-cli-hive-binding.d.ts.map +1 -0
- package/dist/aria-connector/src/cross-cli-hive-binding.js +205 -0
- package/dist/aria-connector/src/cross-cli-hive-binding.js.map +1 -0
- package/dist/aria-connector/src/garden-control-plane.d.ts +6 -1
- package/dist/aria-connector/src/garden-control-plane.d.ts.map +1 -1
- package/dist/aria-connector/src/garden-control-plane.js +8 -2
- package/dist/aria-connector/src/garden-control-plane.js.map +1 -1
- package/dist/aria-connector/src/governed-surface-runner.d.ts +189 -0
- package/dist/aria-connector/src/governed-surface-runner.d.ts.map +1 -0
- package/dist/aria-connector/src/governed-surface-runner.js +1022 -0
- package/dist/aria-connector/src/governed-surface-runner.js.map +1 -0
- package/dist/aria-connector/src/index.d.ts +10 -1
- package/dist/aria-connector/src/index.d.ts.map +1 -1
- package/dist/aria-connector/src/index.js +5 -0
- package/dist/aria-connector/src/index.js.map +1 -1
- package/dist/aria-connector/src/task-runner.d.ts +3 -0
- package/dist/aria-connector/src/task-runner.d.ts.map +1 -0
- package/dist/aria-connector/src/task-runner.js +3526 -0
- package/dist/aria-connector/src/task-runner.js.map +1 -0
- package/dist/aria-web/src/lib/codebase-scanner.d.ts +21 -2
- package/dist/aria-web/src/lib/codebase-scanner.d.ts.map +1 -1
- package/dist/aria-web/src/lib/codebase-scanner.js +59 -14
- package/dist/aria-web/src/lib/codebase-scanner.js.map +1 -1
- package/dist/assets/hooks/README.md +58 -0
- package/dist/assets/hooks/aria-agent-handoff.mjs +147 -2
- package/dist/assets/hooks/aria-agent-ledger-merge.mjs +31 -7
- package/dist/assets/hooks/aria-architect-fallback.mjs +10 -2
- package/dist/assets/hooks/aria-claim-evidence-stop-gate.mjs +240 -0
- package/dist/assets/hooks/aria-cognition-substrate-binding.mjs +84 -10
- package/dist/assets/hooks/aria-first-class-coach.mjs +305 -10
- package/dist/assets/hooks/aria-harness-via-sdk.mjs +93 -16
- package/dist/assets/hooks/aria-import-resolution-gate.mjs +106 -20
- package/dist/assets/hooks/aria-outcome-record.mjs +56 -20
- package/dist/assets/hooks/aria-pre-emit-autoload.mjs +1809 -0
- package/dist/assets/hooks/aria-pre-emit-autoload.mjs.before-orchestration-redesign +1400 -0
- package/dist/assets/hooks/aria-pre-emit-dryrun.mjs +22 -3
- package/dist/assets/hooks/aria-pre-text-gate.mjs +11 -2
- package/dist/assets/hooks/aria-pre-tool-gate.mjs +516 -92
- package/dist/assets/hooks/aria-pre-tool-use.mjs +70 -6
- package/dist/assets/hooks/aria-preprompt-consult.mjs +23 -4
- package/dist/assets/hooks/aria-repo-doctrine-gate.mjs +29 -3
- package/dist/assets/hooks/aria-stop-gate.mjs +585 -76
- package/dist/assets/hooks/aria-trigger-autolearn.mjs +17 -3
- package/dist/assets/hooks/aria-universal-turn-packet.mjs +1165 -0
- package/dist/assets/hooks/aria-userprompt-abandon-detect.mjs +9 -1
- package/dist/assets/hooks/canonical-settings-block.json +172 -0
- package/dist/assets/hooks/codex-native/aria-harness-ticker-sidecar.mjs +92 -0
- package/dist/assets/hooks/codex-native/aria-hive-wal-consumer.mjs +86 -0
- package/dist/assets/hooks/codex-native/aria-live-ticker.mjs +38 -0
- package/dist/assets/hooks/codex-native/aria-post-tool-use.mjs +236 -0
- package/dist/assets/hooks/codex-native/aria-pre-tool-use.mjs +362 -0
- package/dist/assets/hooks/codex-native/aria-stop.mjs +691 -0
- package/dist/assets/hooks/codex-native/aria-userprompt-submit.mjs +623 -0
- package/dist/assets/hooks/codex-native/atlas-session-context.mjs +121 -0
- package/dist/assets/hooks/codex-native/lib/evaluate-with-kernel.mjs +257 -0
- package/dist/assets/hooks/codex-native/lib/hive-wal-consumer.mjs +452 -0
- package/dist/assets/hooks/codex-native/lib/kernel/deterministic-cognitive-kernel.mjs +914 -0
- package/dist/assets/hooks/codex-native/lib/project-boundary-cognition.mjs +143 -0
- package/dist/assets/hooks/codex-native/lib/runtime-client.mjs +3567 -0
- package/dist/assets/hooks/codex-native/lib/task-project-ledger.mjs +294 -0
- package/dist/assets/hooks/doctrine_trigger_map.json +236 -25
- package/dist/assets/hooks/doctrine_trigger_map.schema.json +46 -0
- package/dist/assets/hooks/install.sh +84 -0
- package/dist/assets/hooks/lib/action-ledger-core.mjs +269 -0
- package/dist/assets/hooks/lib/aria-gate-ledger.mjs +143 -0
- package/dist/assets/hooks/lib/ast-stub-shape-detector.mjs +107 -0
- package/dist/assets/hooks/lib/atlas-dossier-client.mjs +151 -0
- package/dist/assets/hooks/lib/atlas-orchestrator-postwire.mjs +221 -0
- package/dist/assets/hooks/lib/canonical-lenses.mjs +83 -6
- package/dist/assets/hooks/lib/coach-intent-classifier.mjs +248 -0
- package/dist/assets/hooks/lib/cognitive-block-parser.mjs +111 -0
- package/dist/assets/hooks/lib/doctrine-trigger-map-loader.mjs +137 -0
- package/dist/assets/hooks/lib/domain-output-quality.mjs +132 -3
- package/dist/assets/hooks/lib/empty-catch-scanner.mjs +91 -0
- package/dist/assets/hooks/lib/end-phase-qa-autofire.mjs +426 -0
- package/dist/assets/hooks/lib/evaluate-with-kernel.mjs +133 -0
- package/dist/assets/hooks/lib/first-class-coach.mjs +454 -19
- package/dist/assets/hooks/lib/gate-audit.mjs +12 -2
- package/dist/assets/hooks/lib/gate-loop-state.mjs +11 -2
- package/dist/assets/hooks/lib/goal-contract-quality.mjs +302 -0
- package/dist/assets/hooks/lib/hook-message-window.mjs +101 -9
- package/dist/assets/hooks/lib/invocation-required-verifier.mjs +184 -0
- package/dist/assets/hooks/lib/kernel/deterministic-cognitive-kernel.mjs +906 -0
- package/dist/assets/hooks/lib/obligation-ledger.mjs +147 -0
- package/dist/assets/hooks/lib/orchestration-manifest-extract.mjs +217 -0
- package/dist/assets/hooks/lib/owner-authorizations.mjs +269 -0
- package/dist/assets/hooks/lib/probe-discipline-scanner.mjs +142 -0
- package/dist/assets/hooks/lib/project-boundary-cognition.mjs +143 -0
- package/dist/assets/hooks/lib/recovery-context.mjs +151 -0
- package/dist/assets/hooks/lib/recovery-template-loader.mjs +154 -0
- package/dist/assets/hooks/lib/self-doctrine-check.mjs +321 -0
- package/dist/assets/hooks/lib/sensitive-shape-detector.mjs +64 -0
- package/dist/assets/hooks/lib/skill-autoload-gate-impl.mjs +226 -1
- package/dist/assets/hooks/lib/stop-hook-protocol.mjs +166 -0
- package/dist/assets/hooks/lib/surface-caught.mjs +94 -0
- package/dist/assets/hooks/recovery-templates/force-reauthor.md +67 -0
- package/dist/assets/hooks/recovery-templates/handoff-recovery.md +25 -0
- package/dist/assets/hooks/scripts/check-hard-risk-prefix.mjs +99 -0
- package/dist/assets/hooks/skills/aria-conversational-doctrine-discipline/SKILL.md +101 -0
- package/dist/assets/hooks/test-aria-preturn-memory-gate.mjs +2 -2
- package/dist/assets/hooks/test-tier-lens-labeling.mjs +14 -3
- package/dist/assets/opencode-plugins/harness-context/index.js +39 -6
- package/dist/assets/opencode-plugins/harness-context/task-project-ledger.mjs +5 -1
- package/dist/assets/opencode-plugins/harness-gate/index.js +36 -0
- package/dist/assets/opencode-plugins/harness-gate/lib/atlas-dossier-client.js +1 -0
- package/dist/assets/opencode-plugins/harness-gate/lib/recovery-grants.js +79 -0
- package/dist/assets/opencode-plugins/harness-outcome/index.js +12 -0
- package/dist/assets/opencode-plugins/harness-stop/index.js +97 -2
- package/dist/assets/opencode-plugins/harness-stop/lib/atlas-dossier-client.js +1 -0
- package/dist/assets/opencode-plugins/harness-stop/lib/domain-output-quality.js +15 -2
- package/dist/assets/opencode-plugins/lib/coach.js +148 -0
- package/dist/runtime/coach-kernel.mjs +144 -7
- package/dist/runtime/codex-bridge.mjs +254 -8
- package/dist/runtime/discipline/doctrine_trigger_map.json +236 -25
- package/dist/runtime/discipline/skills/aria-cognition/34-frameworks-unified/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-aristotle-cognitives/SKILL.md +128 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-aristotle-intra-phase/SKILL.md +99 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-aristotle-post-phase/SKILL.md +118 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-aristotle-pre-phase/SKILL.md +117 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-axioms-first-principles/SKILL.md +202 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-axioms-first-principles/agents/openai.yaml +4 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-axioms-first-principles/references/source-map.md +130 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-backend-architect/SKILL.md +124 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-backend-architect/references/backend-cookbook.md +417 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-business-audit/SKILL.md +133 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-business-audit/references/audit-cookbook.md +247 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-business-frame/SKILL.md +138 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-business-frame/references/business-cookbook.md +154 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-chat/SKILL.md +84 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-chat/scripts/aria-chat.sh +57 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-cognition-autofire/SKILL.md +137 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-cognition-batch/SKILL.md +264 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-decision-mizan/SKILL.md +136 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-decision-mizan/references/decision-frameworks.md +287 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-first-class-operating-contract/SKILL.md +104 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-frontend-architect/SKILL.md +123 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-frontend-architect/references/frontend-cookbook.md +358 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-fullstack-orchestrator/SKILL.md +127 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-fullstack-orchestrator/references/fullstack-cookbook.md +383 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-gtm-architect/SKILL.md +126 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-gtm-architect/references/gtm-cookbook.md +235 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-harness-deploy/SKILL.md +145 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-harness-no-stripping/SKILL.md +135 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-harness-onboarding/SKILL.md +130 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-harness-output-discipline/SKILL.md +120 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-harness-substrate-binding/SKILL.md +139 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-http-harness-client/SKILL.md +85 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-http-harness-client/scripts/smoke.mjs +47 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-k8s-deploy/SKILL.md +174 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-k8s-deploy/agents/openai.yaml +3 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-ladduniframe/SKILL.md +60 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-ledger-fleet-execution/SKILL.md +126 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-live-ops/SKILL.md +54 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-mac-ssh-ops/SKILL.md +100 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-memory-index/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-noor-cognitives/SKILL.md +120 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-ops/SKILL.md +60 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-ops/references/live-endpoints.md +59 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-quality-audit/SKILL.md +133 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-readable-output/SKILL.md +239 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-readable-output/references/layout-cookbook.md +366 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-reasoning/SKILL.md +67 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-reasoning/references/core-principles.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-repo-audit/SKILL.md +135 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-repo-audit/references/repo-audit-cookbook.md +375 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-research-orchestrator/SKILL.md +138 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-research-orchestrator/references/research-patterns.md +270 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-retention-engine/SKILL.md +120 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-retention-engine/references/retention-cookbook.md +271 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-revenue-engine/SKILL.md +128 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-revenue-engine/references/revenue-cookbook.md +227 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-senior-code-audit/SKILL.md +233 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-senior-code-audit/references/audit-checklist.md +369 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-senior-code-cookbook/SKILL.md +288 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-senior-code-cookbook/references/engineering-cookbook.md +489 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-soul-principles/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/aria-task-codex-executor/SKILL.md +86 -0
- package/dist/runtime/discipline/skills/aria-cognition/aristotle-engine/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/cross-domain-24/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/deepsoul-emotional/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/fitrah-guard/SKILL.md +78 -0
- package/dist/runtime/discipline/skills/aria-cognition/ghazali-8lens/SKILL.md +227 -29
- package/dist/runtime/discipline/skills/aria-cognition/ghazali-8lens/references/ghazali-8lens-cookbook.md +797 -0
- package/dist/runtime/discipline/skills/aria-cognition/ijtihad-novel/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/ilham-intuition/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/never-guess/SKILL.md +77 -0
- package/dist/runtime/discipline/skills/aria-cognition/noor-recognition/SKILL.md +45 -0
- package/dist/runtime/discipline/skills/aria-cognition/qiyas-analogy/SKILL.md +174 -14
- package/dist/runtime/discipline/skills/aria-cognition/ruh-basis/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/tadabbur/SKILL.md +506 -0
- package/dist/runtime/discipline/skills/aria-cognition/tadabbur/references/tadabbur-cookbook.md +921 -0
- package/dist/runtime/discipline/skills/aria-cognition/tadabbur-ops/SKILL.md +42 -0
- package/dist/runtime/discipline/skills/aria-cognition/tafakkur/SKILL.md +104 -0
- package/dist/runtime/doctrine_trigger_map.json +236 -25
- package/dist/runtime/embedded-public-key.mjs +27 -0
- package/dist/runtime/gated-ledger.mjs +41 -14
- package/dist/runtime/harness-daemon.mjs +85 -10
- package/dist/runtime/hive-wal-publisher.mjs +292 -0
- package/dist/runtime/hooks/README.md +58 -0
- package/dist/runtime/hooks/aria-agent-handoff.mjs +147 -2
- package/dist/runtime/hooks/aria-agent-ledger-merge.mjs +31 -7
- package/dist/runtime/hooks/aria-architect-fallback.mjs +10 -2
- package/dist/runtime/hooks/aria-claim-evidence-stop-gate.mjs +240 -0
- package/dist/runtime/hooks/aria-cognition-substrate-binding.mjs +84 -10
- package/dist/runtime/hooks/aria-first-class-coach.mjs +305 -10
- package/dist/runtime/hooks/aria-harness-via-sdk.mjs +93 -16
- package/dist/runtime/hooks/aria-import-resolution-gate.mjs +106 -20
- package/dist/runtime/hooks/aria-outcome-record.mjs +56 -20
- package/dist/runtime/hooks/aria-pre-emit-autoload.mjs +1809 -0
- package/dist/runtime/hooks/aria-pre-emit-autoload.mjs.before-orchestration-redesign +1400 -0
- package/dist/runtime/hooks/aria-pre-emit-dryrun.mjs +22 -3
- package/dist/runtime/hooks/aria-pre-text-gate.mjs +11 -2
- package/dist/runtime/hooks/aria-pre-tool-gate.mjs +516 -92
- package/dist/runtime/hooks/aria-pre-tool-use.mjs +70 -6
- package/dist/runtime/hooks/aria-preprompt-consult.mjs +23 -4
- package/dist/runtime/hooks/aria-repo-doctrine-gate.mjs +29 -3
- package/dist/runtime/hooks/aria-stop-gate.mjs +585 -76
- package/dist/runtime/hooks/aria-trigger-autolearn.mjs +17 -3
- package/dist/runtime/hooks/aria-universal-turn-packet.mjs +1165 -0
- package/dist/runtime/hooks/aria-userprompt-abandon-detect.mjs +9 -1
- package/dist/runtime/hooks/canonical-settings-block.json +172 -0
- package/dist/runtime/hooks/codex-native/aria-harness-ticker-sidecar.mjs +92 -0
- package/dist/runtime/hooks/codex-native/aria-hive-wal-consumer.mjs +86 -0
- package/dist/runtime/hooks/codex-native/aria-live-ticker.mjs +38 -0
- package/dist/runtime/hooks/codex-native/aria-post-tool-use.mjs +236 -0
- package/dist/runtime/hooks/codex-native/aria-pre-tool-use.mjs +362 -0
- package/dist/runtime/hooks/codex-native/aria-stop.mjs +691 -0
- package/dist/runtime/hooks/codex-native/aria-userprompt-submit.mjs +623 -0
- package/dist/runtime/hooks/codex-native/atlas-session-context.mjs +121 -0
- package/dist/runtime/hooks/codex-native/lib/evaluate-with-kernel.mjs +257 -0
- package/dist/runtime/hooks/codex-native/lib/hive-wal-consumer.mjs +452 -0
- package/dist/runtime/hooks/codex-native/lib/kernel/deterministic-cognitive-kernel.mjs +914 -0
- package/dist/runtime/hooks/codex-native/lib/project-boundary-cognition.mjs +143 -0
- package/dist/runtime/hooks/codex-native/lib/runtime-client.mjs +3567 -0
- package/dist/runtime/hooks/codex-native/lib/task-project-ledger.mjs +294 -0
- package/dist/runtime/hooks/doctrine_trigger_map.json +236 -25
- package/dist/runtime/hooks/doctrine_trigger_map.schema.json +46 -0
- package/dist/runtime/hooks/install.sh +84 -0
- package/dist/runtime/hooks/lib/action-ledger-core.mjs +269 -0
- package/dist/runtime/hooks/lib/aria-gate-ledger.mjs +143 -0
- package/dist/runtime/hooks/lib/ast-stub-shape-detector.mjs +107 -0
- package/dist/runtime/hooks/lib/atlas-dossier-client.mjs +151 -0
- package/dist/runtime/hooks/lib/atlas-orchestrator-postwire.mjs +221 -0
- package/dist/runtime/hooks/lib/canonical-lenses.mjs +83 -6
- package/dist/runtime/hooks/lib/coach-intent-classifier.mjs +248 -0
- package/dist/runtime/hooks/lib/cognitive-block-parser.mjs +111 -0
- package/dist/runtime/hooks/lib/doctrine-trigger-map-loader.mjs +137 -0
- package/dist/runtime/hooks/lib/domain-output-quality.mjs +132 -3
- package/dist/runtime/hooks/lib/empty-catch-scanner.mjs +91 -0
- package/dist/runtime/hooks/lib/end-phase-qa-autofire.mjs +426 -0
- package/dist/runtime/hooks/lib/evaluate-with-kernel.mjs +133 -0
- package/dist/runtime/hooks/lib/first-class-coach.mjs +454 -19
- package/dist/runtime/hooks/lib/gate-audit.mjs +12 -2
- package/dist/runtime/hooks/lib/gate-loop-state.mjs +11 -2
- package/dist/runtime/hooks/lib/goal-contract-quality.mjs +302 -0
- package/dist/runtime/hooks/lib/hook-message-window.mjs +101 -9
- package/dist/runtime/hooks/lib/invocation-required-verifier.mjs +184 -0
- package/dist/runtime/hooks/lib/kernel/deterministic-cognitive-kernel.mjs +906 -0
- package/dist/runtime/hooks/lib/obligation-ledger.mjs +147 -0
- package/dist/runtime/hooks/lib/orchestration-manifest-extract.mjs +217 -0
- package/dist/runtime/hooks/lib/owner-authorizations.mjs +269 -0
- package/dist/runtime/hooks/lib/probe-discipline-scanner.mjs +142 -0
- package/dist/runtime/hooks/lib/project-boundary-cognition.mjs +143 -0
- package/dist/runtime/hooks/lib/recovery-context.mjs +151 -0
- package/dist/runtime/hooks/lib/recovery-template-loader.mjs +154 -0
- package/dist/runtime/hooks/lib/self-doctrine-check.mjs +321 -0
- package/dist/runtime/hooks/lib/sensitive-shape-detector.mjs +64 -0
- package/dist/runtime/hooks/lib/skill-autoload-gate-impl.mjs +226 -1
- package/dist/runtime/hooks/lib/stop-hook-protocol.mjs +166 -0
- package/dist/runtime/hooks/lib/surface-caught.mjs +94 -0
- package/dist/runtime/hooks/recovery-templates/force-reauthor.md +67 -0
- package/dist/runtime/hooks/recovery-templates/handoff-recovery.md +25 -0
- package/dist/runtime/hooks/scripts/check-hard-risk-prefix.mjs +99 -0
- package/dist/runtime/hooks/skills/aria-conversational-doctrine-discipline/SKILL.md +101 -0
- package/dist/runtime/hooks/test-aria-preturn-memory-gate.mjs +2 -2
- package/dist/runtime/hooks/test-tier-lens-labeling.mjs +14 -3
- package/dist/runtime/lib/evaluate-with-kernel.mjs +133 -0
- package/dist/runtime/lib/kernel/deterministic-cognitive-kernel.mjs +906 -0
- package/dist/runtime/local-phase.mjs +10 -5
- package/dist/runtime/manifest.json +8 -8
- package/dist/runtime/packet-verifier.mjs +166 -0
- package/dist/runtime/provider-proxy.mjs +13 -0
- package/dist/runtime/quality-enforcer.mjs +40 -23
- package/dist/runtime/runtime-rails/registry.mjs +252 -0
- package/dist/runtime/sdk/BUNDLED.json +2 -2
- package/dist/runtime/sdk/index.d.ts +119 -4
- package/dist/runtime/sdk/index.js +138 -12
- package/dist/runtime/sdk/index.js.map +1 -1
- package/dist/runtime/service.mjs +8036 -764
- package/dist/runtime/sub-agent-enforcer.mjs +201 -0
- package/dist/runtime/task-project-ledger.mjs +5 -1
- package/dist/sdk/BUNDLED.json +2 -2
- package/dist/sdk/index.d.ts +119 -4
- package/dist/sdk/index.js +138 -12
- package/dist/sdk/index.js.map +1 -1
- package/hooks/README.md +58 -0
- package/hooks/aria-agent-handoff.mjs +147 -2
- package/hooks/aria-agent-ledger-merge.mjs +31 -7
- package/hooks/aria-architect-fallback.mjs +10 -2
- package/hooks/aria-claim-evidence-stop-gate.mjs +240 -0
- package/hooks/aria-cognition-substrate-binding.mjs +84 -10
- package/hooks/aria-first-class-coach.mjs +305 -10
- package/hooks/aria-harness-via-sdk.mjs +93 -16
- package/hooks/aria-import-resolution-gate.mjs +106 -20
- package/hooks/aria-outcome-record.mjs +56 -20
- package/hooks/aria-pre-emit-autoload.mjs +1809 -0
- package/hooks/aria-pre-emit-autoload.mjs.before-orchestration-redesign +1400 -0
- package/hooks/aria-pre-emit-dryrun.mjs +22 -3
- package/hooks/aria-pre-text-gate.mjs +11 -2
- package/hooks/aria-pre-tool-gate.mjs +516 -92
- package/hooks/aria-pre-tool-use.mjs +70 -6
- package/hooks/aria-preprompt-consult.mjs +23 -4
- package/hooks/aria-repo-doctrine-gate.mjs +29 -3
- package/hooks/aria-stop-gate.mjs +585 -76
- package/hooks/aria-trigger-autolearn.mjs +17 -3
- package/hooks/aria-universal-turn-packet.mjs +1165 -0
- package/hooks/aria-userprompt-abandon-detect.mjs +9 -1
- package/hooks/canonical-settings-block.json +172 -0
- package/hooks/codex-native/aria-harness-ticker-sidecar.mjs +92 -0
- package/hooks/codex-native/aria-hive-wal-consumer.mjs +86 -0
- package/hooks/codex-native/aria-live-ticker.mjs +38 -0
- package/hooks/codex-native/aria-post-tool-use.mjs +236 -0
- package/hooks/codex-native/aria-pre-tool-use.mjs +362 -0
- package/hooks/codex-native/aria-stop.mjs +691 -0
- package/hooks/codex-native/aria-userprompt-submit.mjs +623 -0
- package/hooks/codex-native/atlas-session-context.mjs +121 -0
- package/hooks/codex-native/lib/evaluate-with-kernel.mjs +257 -0
- package/hooks/codex-native/lib/hive-wal-consumer.mjs +452 -0
- package/hooks/codex-native/lib/kernel/deterministic-cognitive-kernel.mjs +914 -0
- package/hooks/codex-native/lib/project-boundary-cognition.mjs +143 -0
- package/hooks/codex-native/lib/runtime-client.mjs +3567 -0
- package/hooks/codex-native/lib/task-project-ledger.mjs +294 -0
- package/hooks/doctrine_trigger_map.json +236 -25
- package/hooks/doctrine_trigger_map.schema.json +46 -0
- package/hooks/install.sh +84 -0
- package/hooks/lib/action-ledger-core.mjs +269 -0
- package/hooks/lib/aria-gate-ledger.mjs +143 -0
- package/hooks/lib/ast-stub-shape-detector.mjs +107 -0
- package/hooks/lib/atlas-dossier-client.mjs +151 -0
- package/hooks/lib/atlas-orchestrator-postwire.mjs +221 -0
- package/hooks/lib/canonical-lenses.mjs +83 -6
- package/hooks/lib/coach-intent-classifier.mjs +248 -0
- package/hooks/lib/cognitive-block-parser.mjs +111 -0
- package/hooks/lib/doctrine-trigger-map-loader.mjs +137 -0
- package/hooks/lib/domain-output-quality.mjs +132 -3
- package/hooks/lib/empty-catch-scanner.mjs +91 -0
- package/hooks/lib/end-phase-qa-autofire.mjs +426 -0
- package/hooks/lib/evaluate-with-kernel.mjs +133 -0
- package/hooks/lib/first-class-coach.mjs +454 -19
- package/hooks/lib/gate-audit.mjs +12 -2
- package/hooks/lib/gate-loop-state.mjs +11 -2
- package/hooks/lib/goal-contract-quality.mjs +302 -0
- package/hooks/lib/hook-message-window.mjs +101 -9
- package/hooks/lib/invocation-required-verifier.mjs +184 -0
- package/hooks/lib/kernel/deterministic-cognitive-kernel.mjs +906 -0
- package/hooks/lib/obligation-ledger.mjs +147 -0
- package/hooks/lib/orchestration-manifest-extract.mjs +217 -0
- package/hooks/lib/owner-authorizations.mjs +269 -0
- package/hooks/lib/probe-discipline-scanner.mjs +142 -0
- package/hooks/lib/project-boundary-cognition.mjs +143 -0
- package/hooks/lib/recovery-context.mjs +151 -0
- package/hooks/lib/recovery-template-loader.mjs +154 -0
- package/hooks/lib/self-doctrine-check.mjs +321 -0
- package/hooks/lib/sensitive-shape-detector.mjs +64 -0
- package/hooks/lib/skill-autoload-gate-impl.mjs +226 -1
- package/hooks/lib/stop-hook-protocol.mjs +166 -0
- package/hooks/lib/surface-caught.mjs +94 -0
- package/hooks/recovery-templates/force-reauthor.md +67 -0
- package/hooks/recovery-templates/handoff-recovery.md +25 -0
- package/hooks/scripts/check-hard-risk-prefix.mjs +99 -0
- package/hooks/skills/aria-conversational-doctrine-discipline/SKILL.md +101 -0
- package/hooks/test-aria-preturn-memory-gate.mjs +2 -2
- package/hooks/test-tier-lens-labeling.mjs +14 -3
- package/opencode-plugins/harness-context/index.js +39 -6
- package/opencode-plugins/harness-context/task-project-ledger.mjs +5 -1
- package/opencode-plugins/harness-gate/index.js +36 -0
- package/opencode-plugins/harness-gate/lib/atlas-dossier-client.js +1 -0
- package/opencode-plugins/harness-gate/lib/recovery-grants.js +79 -0
- package/opencode-plugins/harness-outcome/index.js +12 -0
- package/opencode-plugins/harness-stop/index.js +97 -2
- package/opencode-plugins/harness-stop/lib/atlas-dossier-client.js +1 -0
- package/opencode-plugins/harness-stop/lib/domain-output-quality.js +15 -2
- package/opencode-plugins/lib/coach.js +148 -0
- package/package.json +71 -5
- package/runtime-src/coach-kernel.mjs +144 -7
- package/runtime-src/codex-bridge.mjs +254 -8
- package/runtime-src/embedded-public-key.mjs +27 -0
- package/runtime-src/gated-ledger.mjs +41 -14
- package/runtime-src/harness-daemon.mjs +85 -10
- package/runtime-src/hive-wal-publisher.mjs +292 -0
- package/runtime-src/lib/evaluate-with-kernel.mjs +133 -0
- package/runtime-src/lib/kernel/deterministic-cognitive-kernel.mjs +906 -0
- package/runtime-src/local-phase.mjs +10 -5
- package/runtime-src/packet-verifier.mjs +166 -0
- package/runtime-src/provider-proxy.mjs +13 -0
- package/runtime-src/quality-enforcer.mjs +40 -23
- package/runtime-src/runtime-rails/registry.mjs +252 -0
- package/runtime-src/service.mjs +8036 -764
- package/runtime-src/sub-agent-enforcer.mjs +201 -0
- package/scripts/aria-ledger-append.mjs +337 -0
- package/scripts/aria-task-cheap-worker-dispatch.mjs +234 -0
- package/scripts/audit-of-audit-prior-tasks.mjs +194 -0
- package/scripts/audit-of-audit-this-turn.mjs +116 -0
- package/scripts/bundle-sdk.mjs +31 -5
- package/scripts/check-cli-wrapper-provider-contract.mjs +160 -0
- package/scripts/check-client-compatibility.mjs +15 -5
- package/scripts/check-client-smoke.mjs +297 -0
- package/scripts/check-codex-orchestrator-adoption.mjs +150 -0
- package/scripts/check-glm-env-wired.mjs +131 -0
- package/scripts/check-hive-local-storage-contract.mjs +91 -0
- package/scripts/check-hook-mirror.mjs +150 -0
- package/scripts/check-install-sh-drift.mjs +152 -0
- package/scripts/check-kernel-sync.mjs +101 -0
- package/scripts/check-package-artifact.mjs +152 -0
- package/scripts/check-registry-mirror.mjs +71 -0
- package/scripts/drain-owner-airtable-sync-queue.mjs +287 -0
- package/scripts/export-owner-status-sheets.mjs +589 -0
- package/scripts/live-sidecar-receipt-canary.mjs +347 -0
- package/scripts/qiyas-tadabbur-model-matrix.mjs +970 -0
- package/scripts/quality-ab-live-provider.mjs +913 -0
- package/scripts/self-test-action-ledger-core.mjs +190 -0
- package/scripts/self-test-approval-receipt-binding.mjs +122 -0
- package/scripts/self-test-autofire-quality-output.mjs +110 -0
- package/scripts/self-test-claude-code-action-ledger.mjs +132 -0
- package/scripts/self-test-claude-code-mechanical-autofire-hive.mjs +138 -0
- package/scripts/self-test-claude-code-mechanical-autofire.mjs +234 -0
- package/scripts/self-test-codebase-awareness-atlas-delta.mjs +159 -0
- package/scripts/self-test-codebase-awareness-delta-ingest.mjs +179 -0
- package/scripts/self-test-codex-live-hook-parity.mjs +84 -0
- package/scripts/self-test-codex-native-action-ledger.mjs +167 -0
- package/scripts/self-test-codex-native-hook-json-contract.mjs +74 -0
- package/scripts/self-test-codex-orchestrator-continuity.mjs +113 -0
- package/scripts/self-test-codex-readable-recovery.mjs +94 -0
- package/scripts/self-test-codex-self-harness.mjs +538 -0
- package/scripts/self-test-compiled-workunit.mjs +214 -0
- package/scripts/self-test-continuation-output-smoke.mjs +101 -0
- package/scripts/self-test-cross-cli-fleet-ticker.mjs +85 -0
- package/scripts/self-test-cross-cli-hive-adoption.mjs +125 -0
- package/scripts/self-test-cross-cli-hive-learning.mjs +146 -0
- package/scripts/self-test-cross-phase-tool-failure.mjs +110 -0
- package/scripts/self-test-cross-surface-action-ledger.mjs +149 -0
- package/scripts/self-test-end-of-phase-qa-court.mjs +616 -0
- package/scripts/self-test-evaluate-with-kernel.mjs +111 -0
- package/scripts/self-test-first-class-output-delta-proof.mjs +307 -0
- package/scripts/self-test-goal-contract-output-qa.mjs +73 -0
- package/scripts/self-test-goal-contract.mjs +35 -0
- package/scripts/self-test-governed-adapters.mjs +105 -0
- package/scripts/self-test-governed-surface-runner.mjs +198 -0
- package/scripts/self-test-harness-gates.mjs +15 -12
- package/scripts/self-test-harness-ticker-sidecar.mjs +153 -0
- package/scripts/self-test-hive-org-kernel.mjs +233 -0
- package/scripts/self-test-hive-session-coordination.mjs +156 -0
- package/scripts/self-test-hive-wal-consumer.mjs +111 -0
- package/scripts/self-test-kernel-a3-a4-selection.mjs +179 -0
- package/scripts/self-test-ledger-append.mjs +175 -0
- package/scripts/self-test-live-codex-posttool-packet-smoke.mjs +111 -0
- package/scripts/self-test-live-codex-pretool-packet-smoke.mjs +101 -0
- package/scripts/self-test-live-codex-stop-qa-kernel-smoke.mjs +43 -0
- package/scripts/self-test-live-wrapper-substrate-inventory.mjs +149 -0
- package/scripts/self-test-local-main-sync-script.mjs +47 -0
- package/scripts/self-test-mechanical-autofire-resolver.mjs +296 -0
- package/scripts/self-test-no-consult-cognitive-skills-output.mjs +135 -0
- package/scripts/self-test-owner-airtable-sync-queue.mjs +196 -0
- package/scripts/self-test-owner-airtable-sync.mjs +181 -0
- package/scripts/self-test-owner-sheets-action-ledger.mjs +100 -0
- package/scripts/self-test-production-preflight.mjs +78 -0
- package/scripts/self-test-project-boundary-cognition.mjs +79 -0
- package/scripts/self-test-qa-exec-kernel.mjs +34 -0
- package/scripts/self-test-qa-recovery-learning-loop.mjs +113 -0
- package/scripts/self-test-qiyas-label-alignment.mjs +94 -0
- package/scripts/self-test-recovery-context.mjs +110 -0
- package/scripts/self-test-repo-guard.mjs +10 -0
- package/scripts/self-test-runtime-health-self-heal.mjs +161 -0
- package/scripts/self-test-runtime-postcondition.mjs +70 -0
- package/scripts/self-test-soul-precommit-hook.mjs +39 -0
- package/scripts/self-test-stop-gate-kernel-guards.mjs +185 -0
- package/scripts/self-test-stop-gate.mjs +128 -0
- package/scripts/self-test-substrate-kernel-execution-receipt.mjs +130 -0
- package/scripts/self-test-substrate-open-skill-floor.mjs +87 -0
- package/scripts/self-test-substrate-output-quality-eval.mjs +171 -0
- package/scripts/self-test-task-closeout-drift.mjs +97 -0
- package/scripts/self-test-task-project-ledger-readiness.mjs +43 -0
- package/scripts/self-test-task-runner-phase-consumer.mjs +134 -0
- package/scripts/self-test-task-worker-lane.mjs +256 -0
- package/scripts/self-test-turn-substrate-qa-kernel.mjs +188 -0
- package/scripts/self-test-universal-action-capture.mjs +153 -0
- package/scripts/self-test-universal-turn-packet-entrypoints.mjs +252 -0
- package/scripts/self-test-universal-turn-packet.mjs +320 -0
- package/scripts/session-quality-backfill.mjs +253 -0
- package/scripts/smoke-autofire-100-prompts.mjs +481 -0
- package/scripts/sync-local-main-on-task-complete.mjs +278 -0
- package/scripts/sync-owner-status-airtable.mjs +1158 -0
- package/scripts/validate-skill-prompts.mjs +12 -1
- package/scripts/verify-codex-native-mirror.mjs +262 -0
- package/skills/34-frameworks-unified/SKILL.md +42 -0
- package/skills/api-design/SKILL.md +123 -0
- package/skills/architecture-decision/SKILL.md +105 -0
- package/skills/aria-aristotle-cognitives/SKILL.md +128 -0
- package/skills/aria-aristotle-intra-phase/SKILL.md +99 -0
- package/skills/aria-aristotle-post-phase/SKILL.md +116 -0
- package/skills/aria-aristotle-pre-phase/SKILL.md +117 -0
- package/skills/aria-axioms-first-principles/SKILL.md +202 -0
- package/skills/aria-axioms-first-principles/agents/openai.yaml +4 -0
- package/skills/aria-axioms-first-principles/references/source-map.md +130 -0
- package/skills/aria-chat/SKILL.md +84 -0
- package/skills/aria-chat/scripts/aria-chat.sh +57 -0
- package/skills/aria-cognition/34-frameworks-unified/SKILL.md +42 -0
- package/skills/aria-cognition/aria-aristotle-cognitives/SKILL.md +128 -0
- package/skills/aria-cognition/aria-aristotle-intra-phase/SKILL.md +99 -0
- package/skills/aria-cognition/aria-aristotle-post-phase/SKILL.md +118 -0
- package/skills/aria-cognition/aria-aristotle-pre-phase/SKILL.md +117 -0
- package/skills/aria-cognition/aria-axioms-first-principles/SKILL.md +202 -0
- package/skills/aria-cognition/aria-axioms-first-principles/agents/openai.yaml +4 -0
- package/skills/aria-cognition/aria-axioms-first-principles/references/source-map.md +130 -0
- package/skills/aria-cognition/aria-backend-architect/SKILL.md +124 -0
- package/skills/aria-cognition/aria-backend-architect/references/backend-cookbook.md +417 -0
- package/skills/aria-cognition/aria-business-audit/SKILL.md +133 -0
- package/skills/aria-cognition/aria-business-audit/references/audit-cookbook.md +247 -0
- package/skills/aria-cognition/aria-business-frame/SKILL.md +138 -0
- package/skills/aria-cognition/aria-business-frame/references/business-cookbook.md +154 -0
- package/skills/aria-cognition/aria-chat/SKILL.md +84 -0
- package/skills/aria-cognition/aria-chat/scripts/aria-chat.sh +57 -0
- package/skills/aria-cognition/aria-cognition-autofire/SKILL.md +137 -0
- package/skills/aria-cognition/aria-cognition-batch/SKILL.md +264 -0
- package/skills/aria-cognition/aria-decision-mizan/SKILL.md +136 -0
- package/skills/aria-cognition/aria-decision-mizan/references/decision-frameworks.md +287 -0
- package/skills/aria-cognition/aria-first-class-operating-contract/SKILL.md +104 -0
- package/skills/aria-cognition/aria-frontend-architect/SKILL.md +123 -0
- package/skills/aria-cognition/aria-frontend-architect/references/frontend-cookbook.md +358 -0
- package/skills/aria-cognition/aria-fullstack-orchestrator/SKILL.md +127 -0
- package/skills/aria-cognition/aria-fullstack-orchestrator/references/fullstack-cookbook.md +383 -0
- package/skills/aria-cognition/aria-gtm-architect/SKILL.md +126 -0
- package/skills/aria-cognition/aria-gtm-architect/references/gtm-cookbook.md +235 -0
- package/skills/aria-cognition/aria-harness-deploy/SKILL.md +145 -0
- package/skills/aria-cognition/aria-harness-no-stripping/SKILL.md +135 -0
- package/skills/aria-cognition/aria-harness-onboarding/SKILL.md +130 -0
- package/skills/aria-cognition/aria-harness-output-discipline/SKILL.md +120 -0
- package/skills/aria-cognition/aria-harness-substrate-binding/SKILL.md +139 -0
- package/skills/aria-cognition/aria-http-harness-client/SKILL.md +85 -0
- package/skills/aria-cognition/aria-http-harness-client/scripts/smoke.mjs +47 -0
- package/skills/aria-cognition/aria-k8s-deploy/SKILL.md +174 -0
- package/skills/aria-cognition/aria-k8s-deploy/agents/openai.yaml +3 -0
- package/skills/aria-cognition/aria-ladduniframe/SKILL.md +60 -0
- package/skills/aria-cognition/aria-ledger-fleet-execution/SKILL.md +126 -0
- package/skills/aria-cognition/aria-live-ops/SKILL.md +54 -0
- package/skills/aria-cognition/aria-mac-ssh-ops/SKILL.md +100 -0
- package/skills/aria-cognition/aria-memory-index/SKILL.md +42 -0
- package/skills/aria-cognition/aria-noor-cognitives/SKILL.md +120 -0
- package/skills/aria-cognition/aria-ops/SKILL.md +60 -0
- package/skills/aria-cognition/aria-ops/references/live-endpoints.md +59 -0
- package/skills/aria-cognition/aria-quality-audit/SKILL.md +133 -0
- package/skills/aria-cognition/aria-readable-output/SKILL.md +239 -0
- package/skills/aria-cognition/aria-readable-output/references/layout-cookbook.md +366 -0
- package/skills/aria-cognition/aria-reasoning/SKILL.md +67 -0
- package/skills/aria-cognition/aria-reasoning/references/core-principles.md +42 -0
- package/skills/aria-cognition/aria-repo-audit/SKILL.md +135 -0
- package/skills/aria-cognition/aria-repo-audit/references/repo-audit-cookbook.md +375 -0
- package/skills/aria-cognition/aria-research-orchestrator/SKILL.md +138 -0
- package/skills/aria-cognition/aria-research-orchestrator/references/research-patterns.md +270 -0
- package/skills/aria-cognition/aria-retention-engine/SKILL.md +120 -0
- package/skills/aria-cognition/aria-retention-engine/references/retention-cookbook.md +271 -0
- package/skills/aria-cognition/aria-revenue-engine/SKILL.md +128 -0
- package/skills/aria-cognition/aria-revenue-engine/references/revenue-cookbook.md +227 -0
- package/skills/aria-cognition/aria-senior-code-audit/SKILL.md +233 -0
- package/skills/aria-cognition/aria-senior-code-audit/references/audit-checklist.md +369 -0
- package/skills/aria-cognition/aria-senior-code-cookbook/SKILL.md +288 -0
- package/skills/aria-cognition/aria-senior-code-cookbook/references/engineering-cookbook.md +489 -0
- package/skills/aria-cognition/aria-soul-principles/SKILL.md +42 -0
- package/skills/aria-cognition/aria-task-codex-executor/SKILL.md +86 -0
- package/skills/aria-cognition/aristotle-engine/SKILL.md +42 -0
- package/skills/aria-cognition/cross-domain-24/SKILL.md +42 -0
- package/skills/aria-cognition/deepsoul-emotional/SKILL.md +42 -0
- package/skills/aria-cognition/fitrah-guard/SKILL.md +78 -0
- package/skills/aria-cognition/ghazali-8lens/SKILL.md +227 -29
- package/skills/aria-cognition/ghazali-8lens/references/ghazali-8lens-cookbook.md +797 -0
- package/skills/aria-cognition/ijtihad-novel/SKILL.md +42 -0
- package/skills/aria-cognition/ilham-intuition/SKILL.md +42 -0
- package/skills/aria-cognition/never-guess/SKILL.md +77 -0
- package/skills/aria-cognition/noor-recognition/SKILL.md +45 -0
- package/skills/aria-cognition/qiyas-analogy/SKILL.md +174 -14
- package/skills/aria-cognition/ruh-basis/SKILL.md +42 -0
- package/skills/aria-cognition/tadabbur/SKILL.md +506 -0
- package/skills/aria-cognition/tadabbur/references/tadabbur-cookbook.md +921 -0
- package/skills/aria-cognition/tadabbur-ops/SKILL.md +42 -0
- package/skills/aria-cognition/tafakkur/SKILL.md +104 -0
- package/skills/aria-cognition-autofire/SKILL.md +109 -0
- package/skills/aria-cognition-batch/SKILL.md +264 -0
- package/skills/aria-conversational-doctrine-discipline/SKILL.md +125 -0
- package/skills/aria-essence/SKILL.md +81 -0
- package/skills/aria-essence/references/domain-matrix.md +80 -0
- package/skills/aria-essence/references/evolution-loop.md +30 -0
- package/skills/aria-essence/references/readable-cognition.md +27 -0
- package/skills/aria-first-class-operating-contract/SKILL.md +104 -0
- package/skills/aria-forge-guardrails/SKILL.md +53 -0
- package/skills/aria-forge-guardrails/references/checklist.md +31 -0
- package/skills/aria-harness-deploy/SKILL.md +145 -0
- package/skills/aria-harness-no-stripping/SKILL.md +135 -0
- package/skills/aria-harness-onboarding/SKILL.md +130 -0
- package/skills/aria-harness-output-discipline/SKILL.md +120 -0
- package/skills/aria-harness-substrate-binding/SKILL.md +139 -0
- package/skills/aria-http-harness-client/SKILL.md +85 -0
- package/skills/aria-http-harness-client/scripts/smoke.mjs +47 -0
- package/skills/aria-k8s-deploy/SKILL.md +174 -0
- package/skills/aria-k8s-deploy/agents/openai.yaml +3 -0
- package/skills/aria-ladduniframe/SKILL.md +60 -0
- package/skills/aria-ledger-fleet-execution/SKILL.md +126 -0
- package/skills/aria-live-ops/SKILL.md +54 -0
- package/skills/aria-mac-ssh-ops/SKILL.md +100 -0
- package/skills/aria-memory-index/SKILL.md +42 -0
- package/skills/aria-noor-cognitives/SKILL.md +120 -0
- package/skills/aria-ops/SKILL.md +60 -0
- package/skills/aria-ops/references/live-endpoints.md +59 -0
- package/skills/aria-quality-audit/SKILL.md +133 -0
- package/skills/aria-reasoning/SKILL.md +67 -0
- package/skills/aria-reasoning/references/core-principles.md +42 -0
- package/skills/aria-repo-doctrine/SKILL.md +57 -0
- package/skills/aria-soul-principles/SKILL.md +42 -0
- package/skills/aria-task-codex-executor/SKILL.md +86 -0
- package/skills/aristotle-engine/SKILL.md +42 -0
- package/skills/ci-cd-pipeline/SKILL.md +116 -0
- package/skills/code-review/SKILL.md +131 -0
- package/skills/cross-domain-24/SKILL.md +42 -0
- package/skills/database-design/SKILL.md +124 -0
- package/skills/deepsoul-emotional/SKILL.md +42 -0
- package/skills/deno-kv-raft-pubsub/SKILL.md +561 -0
- package/skills/deno-kv-raft-pubsub/reference/maelstrom-integration.md +393 -0
- package/skills/deno-kv-raft-pubsub/reference/pubsub-api.md +376 -0
- package/skills/deno-kv-raft-pubsub/reference/raft-spec.md +402 -0
- package/skills/deno-kv-raft-pubsub/reference/state-machine.md +182 -0
- package/skills/error-handling/SKILL.md +159 -0
- package/skills/firecrawl/SKILL.md +165 -0
- package/skills/firecrawl/rules/install.md +82 -0
- package/skills/firecrawl/rules/security.md +26 -0
- package/skills/firecrawl-agent/SKILL.md +86 -0
- package/skills/firecrawl-build-interact/SKILL.md +96 -0
- package/skills/firecrawl-build-onboarding/SKILL.md +131 -0
- package/skills/firecrawl-build-onboarding/references/auth-flow.md +39 -0
- package/skills/firecrawl-build-onboarding/references/project-setup.md +20 -0
- package/skills/firecrawl-build-onboarding/references/sdk-installation.md +17 -0
- package/skills/firecrawl-build-scrape/SKILL.md +97 -0
- package/skills/firecrawl-build-search/SKILL.md +97 -0
- package/skills/firecrawl-clone/SKILL.md +419 -0
- package/skills/firecrawl-crawl/SKILL.md +87 -0
- package/skills/firecrawl-download/SKILL.md +98 -0
- package/skills/firecrawl-interact/SKILL.md +112 -0
- package/skills/firecrawl-map/SKILL.md +79 -0
- package/skills/firecrawl-scrape/SKILL.md +97 -0
- package/skills/firecrawl-search/SKILL.md +88 -0
- package/skills/fitrah-guard/SKILL.md +78 -0
- package/skills/forge-quality-rules/SKILL.md +61 -0
- package/skills/ghazali-8lens/SKILL.md +56 -0
- package/skills/ijtihad-novel/SKILL.md +42 -0
- package/skills/ilham-intuition/SKILL.md +42 -0
- package/skills/imagegen/LICENSE.txt +201 -0
- package/skills/imagegen/SKILL.md +374 -0
- package/skills/imagegen/agents/openai.yaml +6 -0
- package/skills/imagegen/assets/imagegen-small.svg +5 -0
- package/skills/imagegen/assets/imagegen.png +0 -0
- package/skills/imagegen/references/cli.md +242 -0
- package/skills/imagegen/references/codex-network.md +33 -0
- package/skills/imagegen/references/image-api.md +90 -0
- package/skills/imagegen/references/prompting.md +118 -0
- package/skills/imagegen/references/sample-prompts.md +433 -0
- package/skills/imagegen/scripts/image_gen.py +995 -0
- package/skills/imagegen/scripts/remove_chroma_key.py +440 -0
- package/skills/istiqra-induction/SKILL.md +44 -0
- package/skills/ladunni-22/SKILL.md +53 -0
- package/skills/mizan/SKILL.md +90 -0
- package/skills/nadia/SKILL.md +56 -0
- package/skills/nadia-psi/SKILL.md +56 -0
- package/skills/never-guess/SKILL.md +75 -0
- package/skills/noor-recognition/SKILL.md +45 -0
- package/skills/observability/SKILL.md +133 -0
- package/skills/openai-docs/LICENSE.txt +201 -0
- package/skills/openai-docs/SKILL.md +100 -0
- package/skills/openai-docs/agents/openai.yaml +14 -0
- package/skills/openai-docs/assets/openai-small.svg +3 -0
- package/skills/openai-docs/assets/openai.png +0 -0
- package/skills/openai-docs/references/latest-model.md +37 -0
- package/skills/openai-docs/references/prompting-guide.md +244 -0
- package/skills/openai-docs/references/upgrade-guide.md +181 -0
- package/skills/openai-docs/scripts/resolve-latest-model-info.js +147 -0
- package/skills/pdf/LICENSE.txt +201 -0
- package/skills/pdf/SKILL.md +85 -0
- package/skills/pdf/agents/openai.yaml +5 -0
- package/skills/pdf/assets/pdf.png +0 -0
- package/skills/playwright/LICENSE.txt +201 -0
- package/skills/playwright/NOTICE.txt +14 -0
- package/skills/playwright/SKILL.md +165 -0
- package/skills/playwright/agents/openai.yaml +6 -0
- package/skills/playwright/assets/playwright-small.svg +3 -0
- package/skills/playwright/assets/playwright.png +0 -0
- package/skills/playwright/references/cli.md +116 -0
- package/skills/playwright/references/workflows.md +95 -0
- package/skills/playwright/scripts/playwright_cli.sh +25 -0
- package/skills/plugin-creator/SKILL.md +178 -0
- package/skills/plugin-creator/agents/openai.yaml +6 -0
- package/skills/plugin-creator/assets/plugin-creator-small.svg +3 -0
- package/skills/plugin-creator/assets/plugin-creator.png +0 -0
- package/skills/plugin-creator/references/plugin-json-spec.md +170 -0
- package/skills/plugin-creator/scripts/create_basic_plugin.py +301 -0
- package/skills/predictor/SKILL.md +43 -0
- package/skills/qiyas-analogy/SKILL.md +204 -0
- package/skills/refactoring/SKILL.md +137 -0
- package/skills/ruh-basis/SKILL.md +42 -0
- package/skills/security-review/SKILL.md +129 -0
- package/skills/skill-creator/SKILL.md +434 -0
- package/skills/skill-creator/agents/openai.yaml +5 -0
- package/skills/skill-creator/assets/skill-creator-small.svg +3 -0
- package/skills/skill-creator/assets/skill-creator.png +0 -0
- package/skills/skill-creator/license.txt +202 -0
- package/skills/skill-creator/references/openai_yaml.md +49 -0
- package/skills/skill-creator/scripts/generate_openai_yaml.py +226 -0
- package/skills/skill-creator/scripts/init_skill.py +400 -0
- package/skills/skill-creator/scripts/quick_validate.py +101 -0
- package/skills/skill-installer/LICENSE.txt +202 -0
- package/skills/skill-installer/SKILL.md +76 -0
- package/skills/skill-installer/agents/openai.yaml +5 -0
- package/skills/skill-installer/assets/skill-installer-small.svg +3 -0
- package/skills/skill-installer/assets/skill-installer.png +0 -0
- package/skills/skill-installer/scripts/github_utils.py +21 -0
- package/skills/skill-installer/scripts/install-skill-from-github.py +308 -0
- package/skills/skill-installer/scripts/list-skills.py +107 -0
- package/skills/skills-and-hooks-reference/SKILL.md +196 -0
- package/skills/soul-domains/SKILL.md +43 -0
- package/skills/tadabbur/SKILL.md +232 -0
- package/skills/tadabbur-ops/SKILL.md +42 -0
- package/skills/tafakkur/SKILL.md +104 -0
- package/skills/testing-strategy/SKILL.md +122 -0
- package/src/action-ledger-core.ts +1054 -0
- package/src/chat.ts +5 -6
- package/src/codebase-scanner.ts +2 -0
- package/src/connectors/claude-code.ts +149 -12
- package/src/connectors/codebase-awareness.ts +325 -25
- package/src/connectors/codex.ts +1273 -40
- package/src/connectors/cursor.ts +8 -0
- package/src/connectors/governed-adapter.ts +174 -0
- package/src/connectors/opencode.ts +18 -2
- package/src/connectors/repo-guard.ts +24 -12
- package/src/connectors/runtime.ts +99 -2
- package/src/connectors/shell.ts +125 -7
- package/src/cross-cli-hive-binding.ts +290 -0
- package/src/garden-control-plane.ts +24 -1
- package/src/governed-surface-runner.ts +1227 -0
- package/src/index.ts +104 -1
- package/src/task-runner.ts +3794 -0
- package/dist/aria-connector/src/install-hooks.d.ts +0 -18
- package/dist/aria-connector/src/install-hooks.d.ts.map +0 -1
- package/dist/aria-connector/src/install-hooks.js +0 -224
- package/dist/aria-connector/src/install-hooks.js.map +0 -1
- package/dist/aria-connector/src/onboarding-wizard.d.ts +0 -5
- package/dist/aria-connector/src/onboarding-wizard.d.ts.map +0 -1
- package/dist/aria-connector/src/onboarding-wizard.js +0 -188
- package/dist/aria-connector/src/onboarding-wizard.js.map +0 -1
- package/dist/cli-0.2.38.tgz +0 -0
- package/dist/install.sh +0 -13
- package/src/__tests__/anthropic-oauth.test.ts +0 -186
- package/src/__tests__/auth-commands.test.ts +0 -132
- package/src/__tests__/owner-login.test.ts +0 -311
|
@@ -0,0 +1,296 @@
|
|
|
1
|
+
import assert from 'node:assert/strict';
|
|
2
|
+
import { readFileSync } from 'node:fs';
|
|
3
|
+
import path from 'node:path';
|
|
4
|
+
|
|
5
|
+
import {
|
|
6
|
+
GovernedSurfaceRunner,
|
|
7
|
+
UNIVERSAL_TURN_PACKET_CORRECTION_SKILL_FLOOR,
|
|
8
|
+
UNIVERSAL_TURN_PACKET_HIVE_OBSERVER_FLOOR,
|
|
9
|
+
UNIVERSAL_TURN_PACKET_HIVE_SOURCE_FLOOR,
|
|
10
|
+
UNIVERSAL_TURN_PACKET_MAPPING_FLOOR,
|
|
11
|
+
UNIVERSAL_TURN_PACKET_PRIMITIVE_FLOOR,
|
|
12
|
+
UNIVERSAL_TURN_PACKET_QA_SKILL_FLOOR,
|
|
13
|
+
UNIVERSAL_TURN_PACKET_RUNTIME_FLOOR,
|
|
14
|
+
UNIVERSAL_TURN_PACKET_SKILL_FLOOR,
|
|
15
|
+
UNIVERSAL_TURN_PACKET_SKILLS,
|
|
16
|
+
} from '../dist/aria-connector/src/index.js';
|
|
17
|
+
|
|
18
|
+
const RUNTIME_URL = (process.env.ARIA_RUNTIME_URL || 'http://127.0.0.1:4319').replace(/\/+$/, '');
|
|
19
|
+
const repoRoot = path.resolve(import.meta.dirname, '..', '..', '..');
|
|
20
|
+
const sessionId = `mechanical-autofire-resolver-${process.pid}`;
|
|
21
|
+
const surfaceId = 'claude-code';
|
|
22
|
+
const userText = [
|
|
23
|
+
'Claude Code mechanical autofire resolver test.',
|
|
24
|
+
'Promote runtime and SDK receipts for Claude Code with full Tadabbur, full Qiyas, Mizan, Noor, Hive observer/source topology, QA correction, and owner approval packet safety.',
|
|
25
|
+
'Do not route Claude provider auth through Aria runtime.',
|
|
26
|
+
].join(' ');
|
|
27
|
+
const correctionFindings = [
|
|
28
|
+
'Autofire must not mean prompt-loaded skills.',
|
|
29
|
+
'Runtime route and SDK runner must agree on selected operators.',
|
|
30
|
+
'Provider prompt must stay compact mechanical-receipt mode.',
|
|
31
|
+
];
|
|
32
|
+
const requiredSkills = [
|
|
33
|
+
...UNIVERSAL_TURN_PACKET_SKILLS,
|
|
34
|
+
'aria-quality-audit',
|
|
35
|
+
'tadabbur',
|
|
36
|
+
'qiyas-analogy',
|
|
37
|
+
];
|
|
38
|
+
|
|
39
|
+
function readJson(relativePath) {
|
|
40
|
+
return JSON.parse(readFileSync(path.join(repoRoot, relativePath), 'utf8'));
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const expectedRuntimes = readJson('codex/plans/aria-civilizational-corpus-skills/proposed-runtimes-index.json')
|
|
44
|
+
.runtimes.map((runtime) => runtime.name).sort();
|
|
45
|
+
const expectedPrimitives = readJson('codex/plans/aria-civilizational-corpus-skills/proposed-primitives-index.json')
|
|
46
|
+
.primitives.map((primitive) => primitive.name).sort();
|
|
47
|
+
const expectedMappings = readJson('codex/plans/aria-civilizational-corpus-skills/proposed-cross-domain-mappings.json')
|
|
48
|
+
.mappings.map((mapping) => mapping.primitive).sort();
|
|
49
|
+
|
|
50
|
+
function uniqueSorted(values) {
|
|
51
|
+
return [...new Set(values.filter((item) => typeof item === 'string' && item.trim()).map((item) => item.trim()))].sort();
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
async function postJson(pathname, body) {
|
|
55
|
+
const response = await fetch(`${RUNTIME_URL}${pathname}`, {
|
|
56
|
+
method: 'POST',
|
|
57
|
+
headers: { 'content-type': 'application/json' },
|
|
58
|
+
body: JSON.stringify(body),
|
|
59
|
+
});
|
|
60
|
+
const text = await response.text();
|
|
61
|
+
let data;
|
|
62
|
+
try {
|
|
63
|
+
data = text ? JSON.parse(text) : null;
|
|
64
|
+
} catch {
|
|
65
|
+
data = { raw: text };
|
|
66
|
+
}
|
|
67
|
+
assert.equal(response.ok, true, `${pathname} failed (${response.status}): ${text.slice(0, 500)}`);
|
|
68
|
+
return data;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
function summarizeRuntime(data) {
|
|
72
|
+
return {
|
|
73
|
+
ok: data.ok,
|
|
74
|
+
mode: data.skillExecutionMode,
|
|
75
|
+
loadedSkillCount: Array.isArray(data.loadedSkillIds) ? data.loadedSkillIds.length : 0,
|
|
76
|
+
firedSkillCount: Array.isArray(data.skillExecutionReceipt?.firedSkillIds) ? data.skillExecutionReceipt.firedSkillIds.length : 0,
|
|
77
|
+
activeRuntimeCount: Array.isArray(data.activeRuntimes) ? data.activeRuntimes.length : 0,
|
|
78
|
+
activePrimitiveCount: Array.isArray(data.activePrimitives) ? data.activePrimitives.length : 0,
|
|
79
|
+
activeMappingCount: Array.isArray(data.activeMappings) ? data.activeMappings.length : 0,
|
|
80
|
+
qaSkillCount: Array.isArray(data.qaSkills) ? data.qaSkills.length : 0,
|
|
81
|
+
correctionSkillCount: Array.isArray(data.correctionSkills) ? data.correctionSkills.length : 0,
|
|
82
|
+
taskClass: data.taskClass,
|
|
83
|
+
ownerApprovalRequired: data.ownerApprovalPacket?.required === true,
|
|
84
|
+
ownerApprovalBlocksProduction: data.ownerApprovalPacket?.blocksProductionPromotion === true,
|
|
85
|
+
hiveObserverCount: Array.isArray(data.hiveObserverSourceTopology?.observerSurfaces) ? data.hiveObserverSourceTopology.observerSurfaces.length : 0,
|
|
86
|
+
hiveSourceCount: Array.isArray(data.hiveObserverSourceTopology?.sourceSurfaces) ? data.hiveObserverSourceTopology.sourceSurfaces.length : 0,
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
function assertRuntimeContract(data, options = {}) {
|
|
91
|
+
const expectOwnerApprovalRequired = options.expectOwnerApprovalRequired !== false;
|
|
92
|
+
assert.equal(data.ok, true, JSON.stringify(summarizeRuntime(data), null, 2));
|
|
93
|
+
assert.equal(data.skillExecutionMode, 'mechanical-receipt', 'runtime must build compact mechanical receipts');
|
|
94
|
+
assert.equal(data.skillExecutionReceipt?.schema, 'aria.skill_execution_receipt.v1', 'runtime must emit skill execution receipt schema');
|
|
95
|
+
assert.equal(data.skillExecutionReceipt?.ok, true, JSON.stringify(summarizeRuntime(data), null, 2));
|
|
96
|
+
assert.ok(Array.isArray(data.loadedSkillIds) && data.loadedSkillIds.length >= UNIVERSAL_TURN_PACKET_SKILL_FLOOR, 'loaded skills must meet floor');
|
|
97
|
+
assert.ok(Array.isArray(data.skillExecutionReceipt.firedSkillIds) && data.skillExecutionReceipt.firedSkillIds.length >= UNIVERSAL_TURN_PACKET_SKILL_FLOOR, 'fired skills must meet floor');
|
|
98
|
+
assert.deepEqual(uniqueSorted(data.activeRuntimes), expectedRuntimes, 'runtime route must select every registry runtime');
|
|
99
|
+
assert.deepEqual(uniqueSorted(data.activePrimitives), expectedPrimitives, 'runtime route must select every registry primitive');
|
|
100
|
+
assert.deepEqual(uniqueSorted(data.activeMappings), expectedMappings, 'runtime route must select every registry mapping');
|
|
101
|
+
assert.ok(Array.isArray(data.qaSkills) && data.qaSkills.length >= UNIVERSAL_TURN_PACKET_QA_SKILL_FLOOR, 'QA skills must meet floor');
|
|
102
|
+
assert.ok(Array.isArray(data.correctionSkills) && data.correctionSkills.length >= UNIVERSAL_TURN_PACKET_CORRECTION_SKILL_FLOOR, 'correction skills must meet floor');
|
|
103
|
+
assert.equal(data.cognitiveRuntimeReceipts?.ok, true, 'cognitive runtime bundle must pass');
|
|
104
|
+
assert.equal(data.cognitiveRuntimeReceipts?.tadabbur?.stageCount, 12, 'Tadabbur full depth must run 12 stages');
|
|
105
|
+
assert.equal(data.cognitiveRuntimeReceipts?.qiyas?.perspectiveCount, 15, 'Qiyas full depth must run 15 perspectives');
|
|
106
|
+
assert.equal(data.cognitiveRuntimeReceipts?.mizan?.ok, true, 'Mizan receipt must pass');
|
|
107
|
+
assert.equal(data.cognitiveRuntimeReceipts?.noor?.noorSuiteCount, 14, 'Noor suite count must be 14');
|
|
108
|
+
assert.equal(data.hiveObserverSourceTopology?.ok, true, 'Hive observer/source topology must pass');
|
|
109
|
+
assert.ok(data.hiveObserverSourceTopology.observerSurfaces.length >= UNIVERSAL_TURN_PACKET_HIVE_OBSERVER_FLOOR, 'Hive observer floor must pass');
|
|
110
|
+
assert.ok(data.hiveObserverSourceTopology.sourceSurfaces.length >= UNIVERSAL_TURN_PACKET_HIVE_SOURCE_FLOOR, 'Hive source floor must pass');
|
|
111
|
+
assert.equal(data.ownerApprovalPacket?.schema, 'aria.owner_final_approval_packet.v1', 'owner approval packet must be present');
|
|
112
|
+
assert.equal(data.ownerApprovalPacket?.required, expectOwnerApprovalRequired, 'owner approval requirement must match task sensitivity');
|
|
113
|
+
assert.equal(data.ownerApprovalPacket?.blocksProductionPromotion, expectOwnerApprovalRequired, 'owner approval packet must only block production promotion when approval is required');
|
|
114
|
+
assert.equal(String(data.prompt || '').includes('<skill_content '), false, 'mechanical mode must not inject full skill bodies');
|
|
115
|
+
assert.equal(String(data.prompt || '').includes('ARIA RUNTIME FORCED SKILL LOAD'), false, 'mechanical mode must not use forced full prompt block');
|
|
116
|
+
assert.ok(String(data.prompt || '').length < 75000, `mechanical prompt must stay compact; observed=${String(data.prompt || '').length}`);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
function assertSdkContract(receipt) {
|
|
120
|
+
assert.equal(receipt.ok, true, JSON.stringify({
|
|
121
|
+
surfaceId: receipt.surfaceId,
|
|
122
|
+
qaStatus: receipt.qa?.status,
|
|
123
|
+
findings: receipt.qa?.findings,
|
|
124
|
+
activeRuntimeCount: receipt.activeRuntimes.length,
|
|
125
|
+
activePrimitiveCount: receipt.activePrimitives.length,
|
|
126
|
+
activeMappingCount: receipt.activeMappings.length,
|
|
127
|
+
}, null, 2));
|
|
128
|
+
assert.equal(receipt.surfaceId, surfaceId, 'SDK receipt must preserve Claude Code surface');
|
|
129
|
+
assert.equal(receipt.skillExecutionMode, 'mechanical-receipt', 'SDK must request mechanical receipt mode');
|
|
130
|
+
assert.equal(receipt.skillExecutionReceipt?.schema, 'aria.skill_execution_receipt.v1', 'SDK must expose runtime skill receipt');
|
|
131
|
+
assert.deepEqual(uniqueSorted(receipt.activeRuntimes), expectedRuntimes, 'SDK must expose every registry runtime');
|
|
132
|
+
assert.deepEqual(uniqueSorted(receipt.activePrimitives), expectedPrimitives, 'SDK must expose every registry primitive');
|
|
133
|
+
assert.deepEqual(uniqueSorted(receipt.activeMappings), expectedMappings, 'SDK must expose every registry mapping');
|
|
134
|
+
assert.ok(receipt.qaSkills.length >= UNIVERSAL_TURN_PACKET_QA_SKILL_FLOOR, 'SDK QA skill floor must pass');
|
|
135
|
+
assert.ok(receipt.correctionSkills.length >= UNIVERSAL_TURN_PACKET_CORRECTION_SKILL_FLOOR, 'SDK correction skill floor must pass');
|
|
136
|
+
assert.equal(receipt.cognitiveRuntimeReceipts?.tadabbur?.stageCount, 12, 'SDK Tadabbur full depth must pass');
|
|
137
|
+
assert.equal(receipt.cognitiveRuntimeReceipts?.qiyas?.perspectiveCount, 15, 'SDK Qiyas full depth must pass');
|
|
138
|
+
assert.equal(receipt.ownerApprovalPacket?.blocksProductionPromotion, true, 'SDK default owner approval must block promotion');
|
|
139
|
+
assert.equal(receipt.promptChars < 75000, true, `SDK mechanical prompt must stay compact; observed=${receipt.promptChars}`);
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
async function main() {
|
|
143
|
+
const direct = await postJson('/build-system-prompt', {
|
|
144
|
+
sessionId: `${sessionId}-direct`,
|
|
145
|
+
surface: surfaceId,
|
|
146
|
+
message: userText,
|
|
147
|
+
requiredSkills,
|
|
148
|
+
allowOwnerBypass: true,
|
|
149
|
+
injection: {
|
|
150
|
+
harness: {
|
|
151
|
+
packet: {
|
|
152
|
+
sessionId: `${sessionId}-direct`,
|
|
153
|
+
surfaceId,
|
|
154
|
+
universalTurnPacket: true,
|
|
155
|
+
phaseContract: ['pre_cognition', 'pre_tool', 'intra_tool', 'intra_cognition', 'post_tool', 'post_cognition'],
|
|
156
|
+
correctionFindings,
|
|
157
|
+
},
|
|
158
|
+
},
|
|
159
|
+
task: userText,
|
|
160
|
+
docs: [
|
|
161
|
+
{
|
|
162
|
+
title: 'Mechanical autofire resolver test',
|
|
163
|
+
content: 'Runtime route and SDK runner must select the same mechanical operator floors.',
|
|
164
|
+
},
|
|
165
|
+
],
|
|
166
|
+
files: {},
|
|
167
|
+
loadedAt: new Date().toISOString(),
|
|
168
|
+
},
|
|
169
|
+
metadata: {
|
|
170
|
+
source: 'self-test-mechanical-autofire-resolver',
|
|
171
|
+
universalTurnPacket: true,
|
|
172
|
+
skillExecutionMode: 'mechanical-receipt',
|
|
173
|
+
requiredSkills,
|
|
174
|
+
correctionFindings,
|
|
175
|
+
},
|
|
176
|
+
skillExecutionMode: 'mechanical-receipt',
|
|
177
|
+
});
|
|
178
|
+
assertRuntimeContract(direct);
|
|
179
|
+
|
|
180
|
+
const weakTextDirect = await postJson('/build-system-prompt', {
|
|
181
|
+
sessionId: `${sessionId}-weak-text-direct`,
|
|
182
|
+
surface: surfaceId,
|
|
183
|
+
message: 'so why did u leave ryntime down if its down? thats a failure',
|
|
184
|
+
requiredSkills,
|
|
185
|
+
allowOwnerBypass: true,
|
|
186
|
+
injection: {
|
|
187
|
+
harness: {
|
|
188
|
+
packet: {
|
|
189
|
+
sessionId: `${sessionId}-weak-text-direct`,
|
|
190
|
+
surfaceId,
|
|
191
|
+
universalTurnPacket: true,
|
|
192
|
+
phaseContract: ['pre_cognition', 'pre_tool', 'intra_tool', 'intra_cognition', 'post_tool', 'post_cognition'],
|
|
193
|
+
correctionFindings: [],
|
|
194
|
+
},
|
|
195
|
+
},
|
|
196
|
+
task: 'weak text universal packet regression',
|
|
197
|
+
docs: [
|
|
198
|
+
{
|
|
199
|
+
title: 'Weak text universal packet regression',
|
|
200
|
+
content: 'Universal packet mode must force full cognitive receipts even when owner text has typos or weak classifier keywords.',
|
|
201
|
+
},
|
|
202
|
+
],
|
|
203
|
+
files: {},
|
|
204
|
+
loadedAt: new Date().toISOString(),
|
|
205
|
+
},
|
|
206
|
+
metadata: {
|
|
207
|
+
source: 'self-test-mechanical-autofire-resolver-weak-text',
|
|
208
|
+
universalTurnPacket: true,
|
|
209
|
+
skillExecutionMode: 'mechanical-receipt',
|
|
210
|
+
requiredSkills,
|
|
211
|
+
correctionFindings: [],
|
|
212
|
+
},
|
|
213
|
+
skillExecutionMode: 'mechanical-receipt',
|
|
214
|
+
});
|
|
215
|
+
assertRuntimeContract(weakTextDirect, { expectOwnerApprovalRequired: false });
|
|
216
|
+
assert.equal(weakTextDirect.taskClassReceipt?.requiresFullDepth, true, 'universal packet must force full depth for weak text');
|
|
217
|
+
assert.ok(
|
|
218
|
+
Array.isArray(weakTextDirect.taskClassReceipt?.tags) && weakTextDirect.taskClassReceipt.tags.includes('universal_turn_packet'),
|
|
219
|
+
'universal packet tag must drive full depth independent of lexical classifier matches',
|
|
220
|
+
);
|
|
221
|
+
assert.equal(
|
|
222
|
+
weakTextDirect.weakQaEnhancementLoopReceipt?.schema,
|
|
223
|
+
'aria.weak_qa_enhancement_loop_receipt.v1',
|
|
224
|
+
'weak QA path must emit a first-class enhancement loop receipt',
|
|
225
|
+
);
|
|
226
|
+
assert.equal(weakTextDirect.weakQaEnhancementLoopReceipt?.nextRoundRequired, true, 'weak QA must force another enhancement round');
|
|
227
|
+
assert.equal(weakTextDirect.weakQaEnhancementLoopReceipt?.ownerApprovalRequired, false, 'weak QA enhancement round must not become owner approval');
|
|
228
|
+
assert.equal(weakTextDirect.weakQaEnhancementLoopReceipt?.tadabburQuestionCount, 12, 'weak QA enhancement round must question through Tadabbur-12');
|
|
229
|
+
assert.equal(weakTextDirect.weakQaEnhancementLoopReceipt?.qiyasQuestionCount, 15, 'weak QA enhancement round must question through Qiyas-15');
|
|
230
|
+
assert.ok(
|
|
231
|
+
Array.isArray(weakTextDirect.selectedExtraOperators) && weakTextDirect.selectedExtraOperators.includes('qa-first-class-enhancement-loop-runtime'),
|
|
232
|
+
'weak QA must select the first-class enhancement loop runtime',
|
|
233
|
+
);
|
|
234
|
+
|
|
235
|
+
const correctiveDoctrineText = [
|
|
236
|
+
'Finding: deterministic-one-attempt-then-skip is the broken pattern.',
|
|
237
|
+
'Evidence boundary: observed in the recovery route.',
|
|
238
|
+
'Verification predicate: pass when the runtime retries or heals instead of adopting the pattern.',
|
|
239
|
+
'Next action: repair the matcher.',
|
|
240
|
+
'Learning/reflexion loop: store the lesson and use it in future QA.',
|
|
241
|
+
].join(' ');
|
|
242
|
+
const correctiveDoctrine = await postJson('/full-chain', {
|
|
243
|
+
text: correctiveDoctrineText,
|
|
244
|
+
fetchPacket: true,
|
|
245
|
+
packetRequest: {
|
|
246
|
+
platform: surfaceId,
|
|
247
|
+
message: correctiveDoctrineText,
|
|
248
|
+
},
|
|
249
|
+
metadata: {
|
|
250
|
+
surface: surfaceId,
|
|
251
|
+
source: 'self-test-mechanical-autofire-corrective-doctrine-use',
|
|
252
|
+
},
|
|
253
|
+
});
|
|
254
|
+
assert.equal(correctiveDoctrine.pass, true, 'corrective doctrine mentions must not hard-block QA output');
|
|
255
|
+
assert.equal(correctiveDoctrine.failures?.[0]?.severity, 'warn', 'corrective doctrine mention must remain observable as a warning');
|
|
256
|
+
assert.equal(correctiveDoctrine.doctrine?.hits?.[0]?.correctiveUse, true, 'corrective doctrine mention must be classified as use/mention, not adoption');
|
|
257
|
+
|
|
258
|
+
const runner = new GovernedSurfaceRunner({ sessionId: `${sessionId}-sdk` });
|
|
259
|
+
const sdk = await runner.buildUniversalTurnPacket({
|
|
260
|
+
surfaceId,
|
|
261
|
+
sessionId: `${sessionId}-sdk`,
|
|
262
|
+
userText,
|
|
263
|
+
correctionFindings,
|
|
264
|
+
requiredSkills,
|
|
265
|
+
});
|
|
266
|
+
assertSdkContract(sdk);
|
|
267
|
+
|
|
268
|
+
assert.deepEqual(uniqueSorted(direct.skillExecutionReceipt.firedSkillIds), uniqueSorted(sdk.skillExecutionReceipt.firedSkillIds), 'runtime route and SDK must fire the same skill ids');
|
|
269
|
+
assert.deepEqual(uniqueSorted(direct.selectedExtraOperators), uniqueSorted(sdk.selectedExtraOperators), 'runtime route and SDK must select the same task-class extra operators');
|
|
270
|
+
assert.equal(direct.taskClass, sdk.taskClass, 'runtime route and SDK must agree on task class');
|
|
271
|
+
assert.equal(direct.hiveObserverSourceTopology?.coherenceHash, sdk.hiveObserverSourceTopology?.coherenceHash, 'runtime route and SDK must agree on Hive topology coherence hash');
|
|
272
|
+
|
|
273
|
+
process.stdout.write(`${JSON.stringify({
|
|
274
|
+
ok: true,
|
|
275
|
+
surfaceId,
|
|
276
|
+
runtime: summarizeRuntime(direct),
|
|
277
|
+
sdk: {
|
|
278
|
+
ok: sdk.ok,
|
|
279
|
+
skillExecutionMode: sdk.skillExecutionMode,
|
|
280
|
+
loadedSkillCount: sdk.loadedSkillIds.length,
|
|
281
|
+
firedSkillCount: sdk.skillExecutionReceipt.firedSkillIds.length,
|
|
282
|
+
activeRuntimeCount: sdk.activeRuntimes.length,
|
|
283
|
+
activePrimitiveCount: sdk.activePrimitives.length,
|
|
284
|
+
activeMappingCount: sdk.activeMappings.length,
|
|
285
|
+
qaSkillCount: sdk.qaSkills.length,
|
|
286
|
+
correctionSkillCount: sdk.correctionSkills.length,
|
|
287
|
+
taskClass: sdk.taskClass,
|
|
288
|
+
ownerApprovalBlocksProduction: sdk.ownerApprovalPacket?.blocksProductionPromotion === true,
|
|
289
|
+
},
|
|
290
|
+
}, null, 2)}\n`);
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
main().catch((error) => {
|
|
294
|
+
process.stderr.write(`[self-test-mechanical-autofire-resolver] ${error instanceof Error ? error.stack || error.message : String(error)}\n`);
|
|
295
|
+
process.exitCode = 1;
|
|
296
|
+
});
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
import assert from 'node:assert/strict';
|
|
4
|
+
import { mkdirSync, readFileSync, writeFileSync } from 'node:fs';
|
|
5
|
+
import path from 'node:path';
|
|
6
|
+
|
|
7
|
+
import { analyzeDomainOutputQuality } from '../hooks/lib/domain-output-quality.mjs';
|
|
8
|
+
|
|
9
|
+
const connectorRoot = path.resolve(import.meta.dirname, '..');
|
|
10
|
+
const phase43Prompt =
|
|
11
|
+
'Continue Phase 43. Wire no-consult cognitive-skills QA through the Aria runtime sidecar/control plane without making /consult the quality engine.';
|
|
12
|
+
|
|
13
|
+
const requiredSkills = [
|
|
14
|
+
'aria-cognition-autofire',
|
|
15
|
+
'aria-cognition-batch',
|
|
16
|
+
'aria-quality-audit',
|
|
17
|
+
'aria-ledger-fleet-execution',
|
|
18
|
+
'aria-axioms-first-principles',
|
|
19
|
+
'ghazali-8lens',
|
|
20
|
+
'tadabbur',
|
|
21
|
+
'tadabbur-ops',
|
|
22
|
+
'tafakkur',
|
|
23
|
+
'qiyas-analogy',
|
|
24
|
+
'mizan',
|
|
25
|
+
'never-guess',
|
|
26
|
+
'aria-noor-cognitives',
|
|
27
|
+
'aria-readable-output',
|
|
28
|
+
'aria-harness-output-discipline',
|
|
29
|
+
'aria-harness-substrate-binding',
|
|
30
|
+
'aria-harness-no-stripping',
|
|
31
|
+
'aria-task-codex-executor',
|
|
32
|
+
'aria-repo-doctrine',
|
|
33
|
+
'aria-senior-code-audit',
|
|
34
|
+
'testing-strategy',
|
|
35
|
+
'code-review',
|
|
36
|
+
'observability',
|
|
37
|
+
'security-review',
|
|
38
|
+
'forge-quality-rules',
|
|
39
|
+
];
|
|
40
|
+
|
|
41
|
+
function evaluate(text, userText = phase43Prompt) {
|
|
42
|
+
return analyzeDomainOutputQuality(text, { userText });
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function assertBlock(label, text, expectedBlocker, expectedRepair) {
|
|
46
|
+
const result = evaluate(text);
|
|
47
|
+
assert.ok(
|
|
48
|
+
result.blockers.some((blocker) => blocker.includes(expectedBlocker)),
|
|
49
|
+
`${label} missing blocker ${expectedBlocker}; result=${JSON.stringify(result, null, 2)}`,
|
|
50
|
+
);
|
|
51
|
+
assert.ok(
|
|
52
|
+
result.repairs.some((repair) => repair.includes(expectedRepair)),
|
|
53
|
+
`${label} missing repair ${expectedRepair}; result=${JSON.stringify(result, null, 2)}`,
|
|
54
|
+
);
|
|
55
|
+
return result;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
const consultDependency = assertBlock(
|
|
59
|
+
'consult API dependency',
|
|
60
|
+
[
|
|
61
|
+
'Status: pending because I need to call the consult API.',
|
|
62
|
+
'Evidence: I will consult the API to find the answer.',
|
|
63
|
+
'QA-as-gate: use the consult response as the quality source.',
|
|
64
|
+
'Next highest-impact step: ask the owner to allow the consult route.',
|
|
65
|
+
].join('\n'),
|
|
66
|
+
'consult API dependency detected',
|
|
67
|
+
'local cognitive skills plus deterministic QA',
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
const unsupportedInventory = assertBlock(
|
|
71
|
+
'unsupported numeric inventory continuation claim',
|
|
72
|
+
[
|
|
73
|
+
'Status: All six component bundles mapped; wiring started.',
|
|
74
|
+
'Evidence: 14/22 target surfaces have live extraction feeds; 8 pending connector alignment.',
|
|
75
|
+
'QA-as-gate: Must verify each surface reacts correctly to extracted input before releasing to production.',
|
|
76
|
+
'Next highest-impact step: Prioritize the two CLI surfaces with highest daily invocation volume.',
|
|
77
|
+
].join('\n'),
|
|
78
|
+
'unsupported numeric or inventory claim detected',
|
|
79
|
+
'concrete artifact',
|
|
80
|
+
);
|
|
81
|
+
|
|
82
|
+
const anchoredInventory = evaluate(
|
|
83
|
+
[
|
|
84
|
+
'Status: Phase 43 report is verified.',
|
|
85
|
+
'Evidence: 14/22 target surfaces claim comes from `phase43-report.json` stdout_sha256=abc123 and ledger row Gate 13.',
|
|
86
|
+
'QA-as-gate: expected artifact-bound numeric evidence; observed hash and ledger row are present; correction is not needed.',
|
|
87
|
+
'Next highest-impact step: wire the same deterministic QA into the stop-gate path.',
|
|
88
|
+
].join('\n'),
|
|
89
|
+
);
|
|
90
|
+
assert.deepEqual(anchoredInventory.blockers, [], JSON.stringify(anchoredInventory, null, 2));
|
|
91
|
+
|
|
92
|
+
const acceptedSkillDriven = evaluate(
|
|
93
|
+
[
|
|
94
|
+
'Actual goal: wire extracted books, doctrines, skills, runtimes, CLIs, connectors, and agent surfaces into operating behavior so outputs improve automatically.',
|
|
95
|
+
`Skills fired: ${requiredSkills.join(', ')}.`,
|
|
96
|
+
'Architecture boundary: Codex and Claude are first-class execution surfaces; Aria runtime is the localhost sidecar/control plane.',
|
|
97
|
+
'Status: Phase 43 wires no-consult cognitive-skills QA into the shared output path.',
|
|
98
|
+
'Evidence: the shared domain-output QA rejects external-advisory dependence, unsupported inventory claims, receipt-heavy output, micro-step deferral, and gate-chasing.',
|
|
99
|
+
'QA-as-gate: expected local skills plus deterministic QA; observed accepted output has actual goal, skill bundle, correction, verification, learning, and next step.',
|
|
100
|
+
'Correction: local cognitive skills and runtime sidecar/control-plane checks are the structural path.',
|
|
101
|
+
'Verification: run `npm --prefix packages/aria-connector run check:no-consult-cognitive-skills-output` and require all negative controls rejected.',
|
|
102
|
+
'Learning: optional Codex/Claude execution can supply evidence later, but the quality decision stays local and deterministic.',
|
|
103
|
+
'Next highest-impact step: update readiness and ledger with Phase 43 runtime-path evidence.',
|
|
104
|
+
].join('\n'),
|
|
105
|
+
);
|
|
106
|
+
assert.deepEqual(acceptedSkillDriven.blockers, [], JSON.stringify(acceptedSkillDriven, null, 2));
|
|
107
|
+
|
|
108
|
+
const stopGateSource = readFileSync(path.join(connectorRoot, 'hooks', 'aria-stop-gate.mjs'), 'utf8');
|
|
109
|
+
const domainQaSource = readFileSync(path.join(connectorRoot, 'hooks', 'lib', 'domain-output-quality.mjs'), 'utf8');
|
|
110
|
+
|
|
111
|
+
assert.ok(stopGateSource.includes('analyzeDomainOutputQuality'), 'Stop gate must call shared domain output QA');
|
|
112
|
+
assert.ok(domainQaSource.includes('consult API dependency detected'), 'Domain QA must reject consult API dependency');
|
|
113
|
+
assert.ok(domainQaSource.includes('unsupported numeric or inventory claim detected'), 'Domain QA must reject unsupported continuation inventory claims');
|
|
114
|
+
|
|
115
|
+
const report = {
|
|
116
|
+
ok: true,
|
|
117
|
+
schema: 'aria.connector.phase43_no_consult_cognitive_skills_output.v1',
|
|
118
|
+
consult_api_dependency_blocked: consultDependency.blockers.length > 0,
|
|
119
|
+
consult_api_dependency_repair_present: consultDependency.repairs.length > 0,
|
|
120
|
+
unsupported_inventory_blocked: unsupportedInventory.blockers.length > 0,
|
|
121
|
+
unsupported_inventory_repair_present: unsupportedInventory.repairs.length > 0,
|
|
122
|
+
anchored_inventory_allowed: anchoredInventory.blockers.length === 0,
|
|
123
|
+
skill_driven_owner_readable_output_allowed: acceptedSkillDriven.blockers.length === 0,
|
|
124
|
+
stop_gate_uses_shared_domain_output_qa: true,
|
|
125
|
+
runtime_sidecar_boundary: 'codex_claude_execution_surfaces__aria_runtime_sidecar_control_plane',
|
|
126
|
+
required_skill_count: requiredSkills.length,
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
const outPath = process.env.ARIA_PHASE43_NO_CONSULT_RUNTIME_REPORT_OUT;
|
|
130
|
+
if (outPath) {
|
|
131
|
+
mkdirSync(path.dirname(outPath), { recursive: true });
|
|
132
|
+
writeFileSync(outPath, `${JSON.stringify(report, null, 2)}\n`);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
console.log(JSON.stringify(report, null, 2));
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
import assert from 'node:assert/strict';
|
|
4
|
+
import { existsSync, mkdirSync, mkdtempSync, readFileSync, rmSync, writeFileSync } from 'node:fs';
|
|
5
|
+
import { tmpdir } from 'node:os';
|
|
6
|
+
import { join } from 'node:path';
|
|
7
|
+
|
|
8
|
+
import {
|
|
9
|
+
ownerAirtableSyncQueuePath,
|
|
10
|
+
recordActionEventLocal,
|
|
11
|
+
} from '../dist/aria-connector/src/action-ledger-core.js';
|
|
12
|
+
import { drainOwnerAirtableSyncQueue } from './drain-owner-airtable-sync-queue.mjs';
|
|
13
|
+
|
|
14
|
+
function makeResponse(status, payload) {
|
|
15
|
+
return {
|
|
16
|
+
ok: status >= 200 && status < 300,
|
|
17
|
+
status,
|
|
18
|
+
async text() {
|
|
19
|
+
return JSON.stringify(payload || {});
|
|
20
|
+
},
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const home = mkdtempSync(join(tmpdir(), 'aria-owner-airtable-queue-'));
|
|
25
|
+
const taskDir = join(home, 'tasks');
|
|
26
|
+
const runtimeStateDir = join(home, 'runtime-state');
|
|
27
|
+
const outDir = join(home, 'owner-export');
|
|
28
|
+
const statePath = join(home, 'owner-airtable-state.json');
|
|
29
|
+
const drainStatePath = join(home, 'owner-airtable-drain-state.json');
|
|
30
|
+
const drainHistoryPath = join(home, 'owner-airtable-drain-history.jsonl');
|
|
31
|
+
const projectId = 'owner-airtable-queue-smoke';
|
|
32
|
+
const taskId = 'task-owner-airtable-queue-smoke';
|
|
33
|
+
|
|
34
|
+
try {
|
|
35
|
+
mkdirSync(taskDir, { recursive: true });
|
|
36
|
+
mkdirSync(runtimeStateDir, { recursive: true });
|
|
37
|
+
writeFileSync(join(taskDir, `${taskId}.json`), JSON.stringify({
|
|
38
|
+
taskId,
|
|
39
|
+
status: 'active',
|
|
40
|
+
goal: 'owner Airtable queue smoke',
|
|
41
|
+
updatedAt: '2026-05-17T22:10:00.000Z',
|
|
42
|
+
createdAt: '2026-05-17T22:10:00.000Z',
|
|
43
|
+
phases: [{ phaseId: '01-queue', title: 'Queue', status: 'active', consumerReceipts: [] }],
|
|
44
|
+
checkpoints: [],
|
|
45
|
+
}, null, 2));
|
|
46
|
+
writeFileSync(join(runtimeStateDir, 'end-of-phase-qa-court-latest.json'), JSON.stringify({
|
|
47
|
+
generated_at: '2026-05-17T22:10:00.000Z',
|
|
48
|
+
claim_gate: { verdict: 'pass' },
|
|
49
|
+
}, null, 2));
|
|
50
|
+
|
|
51
|
+
const local = recordActionEventLocal({
|
|
52
|
+
surface: 'codex',
|
|
53
|
+
sessionId: 'codex:owner-airtable-queue-smoke',
|
|
54
|
+
threadId: 'codex:owner-airtable-queue-smoke',
|
|
55
|
+
projectId,
|
|
56
|
+
taskId,
|
|
57
|
+
phaseId: '01-queue',
|
|
58
|
+
lifecyclePhase: 'post_tool',
|
|
59
|
+
status: 'verified',
|
|
60
|
+
intent: 'queue owner Airtable sync after action-ledger event',
|
|
61
|
+
atlas: { status: 'grounded', target: 'packages/aria-connector/src/action-ledger-core.ts' },
|
|
62
|
+
}, { home, projectId });
|
|
63
|
+
|
|
64
|
+
const queuePath = ownerAirtableSyncQueuePath({ home });
|
|
65
|
+
assert.equal(existsSync(queuePath), true, 'owner Airtable queue missing');
|
|
66
|
+
const queuedLines = readFileSync(queuePath, 'utf8').trim().split('\n');
|
|
67
|
+
assert.equal(queuedLines.length, 1);
|
|
68
|
+
const queued = JSON.parse(queuedLines[0]);
|
|
69
|
+
assert.equal(queued.eventId, local.event.eventId);
|
|
70
|
+
assert.equal(local.projection.ownerAirtableSyncQueuePath, queuePath);
|
|
71
|
+
|
|
72
|
+
const calls = [];
|
|
73
|
+
const createdTables = [];
|
|
74
|
+
const apiFetch = async (url, options = {}) => {
|
|
75
|
+
const parsed = new URL(url);
|
|
76
|
+
calls.push({ method: options.method || 'GET', path: parsed.pathname, body: options.body ? JSON.parse(options.body) : null });
|
|
77
|
+
if (parsed.pathname.endsWith('/meta/bases/app_owner_airtable_queue_smoke/tables') && (!options.method || options.method === 'GET')) {
|
|
78
|
+
return makeResponse(200, { tables: createdTables });
|
|
79
|
+
}
|
|
80
|
+
if (parsed.pathname.endsWith('/meta/bases/app_owner_airtable_queue_smoke/tables') && options.method === 'POST') {
|
|
81
|
+
const body = JSON.parse(options.body);
|
|
82
|
+
createdTables.push({ id: `tbl${createdTables.length + 1}`, name: body.name, fields: body.fields });
|
|
83
|
+
return makeResponse(200, createdTables[createdTables.length - 1]);
|
|
84
|
+
}
|
|
85
|
+
if (options.method === 'PATCH' && parsed.pathname.startsWith('/v0/app_owner_airtable_queue_smoke/')) {
|
|
86
|
+
const body = JSON.parse(options.body);
|
|
87
|
+
if (parsed.pathname.endsWith('/Dashboard')) {
|
|
88
|
+
for (const record of body.records) {
|
|
89
|
+
assert.equal(typeof record.fields.metric, 'string', 'Dashboard metric must be sent as Airtable text');
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return makeResponse(200, { records: body.records.map((record, index) => ({ id: `rec${index}`, fields: record.fields })) });
|
|
93
|
+
}
|
|
94
|
+
return makeResponse(404, { error: parsed.pathname });
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
const drained = await drainOwnerAirtableSyncQueue({
|
|
98
|
+
queuePath,
|
|
99
|
+
statePath: drainStatePath,
|
|
100
|
+
historyPath: drainHistoryPath,
|
|
101
|
+
lockDir: join(home, 'sync-drain.lock'),
|
|
102
|
+
syncOptions: {
|
|
103
|
+
token: 'unit_test_token_no_network',
|
|
104
|
+
baseId: 'app_owner_airtable_queue_smoke',
|
|
105
|
+
taskDir,
|
|
106
|
+
runtimeStateDir,
|
|
107
|
+
actionLedgerDir: join(home, '.aria', 'action-ledger'),
|
|
108
|
+
outDir,
|
|
109
|
+
statePath,
|
|
110
|
+
atlasSocket: join(home, 'missing-atlas.sock'),
|
|
111
|
+
apiFetch,
|
|
112
|
+
},
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
assert.equal(drained.ok, true);
|
|
116
|
+
assert.equal(drained.drained, 1);
|
|
117
|
+
assert.equal(drained.syncOk, true);
|
|
118
|
+
assert.equal(readFileSync(queuePath, 'utf8'), '');
|
|
119
|
+
assert.equal(drained.sync.dashboardRows, 9);
|
|
120
|
+
assert.ok(drained.sync.ownerBoardRows >= 8);
|
|
121
|
+
assert.equal(drained.sync.ownerSyncRows, 3);
|
|
122
|
+
assert.equal(drained.sync.deferredRows, 2);
|
|
123
|
+
assert.equal(drained.sync.atlasRows >= 2, true);
|
|
124
|
+
assert.equal(createdTables.length, 12);
|
|
125
|
+
assert.equal(calls.some((call) => call.method === 'PATCH'), true);
|
|
126
|
+
assert.equal(JSON.parse(readFileSync(drainStatePath, 'utf8')).drained, 1);
|
|
127
|
+
assert.equal(existsSync(drainHistoryPath), true);
|
|
128
|
+
assert.equal(readFileSync(drainHistoryPath, 'utf8').trim().split('\n').length, 1);
|
|
129
|
+
|
|
130
|
+
const failureQueuePath = join(home, 'failure-sync-queue.jsonl');
|
|
131
|
+
const failureStatePath = join(home, 'failure-drain-state.json');
|
|
132
|
+
const failureHistoryPath = join(home, 'failure-drain-history.jsonl');
|
|
133
|
+
writeFileSync(failureQueuePath, `${JSON.stringify({
|
|
134
|
+
schema: 'aria.owner_airtable_sync_needed.v1',
|
|
135
|
+
at: '2026-05-17T22:12:00.000Z',
|
|
136
|
+
projectId,
|
|
137
|
+
taskId,
|
|
138
|
+
eventId: 'ev_owner_airtable_failure',
|
|
139
|
+
status: 'blocked',
|
|
140
|
+
})}\n`);
|
|
141
|
+
const failureTables = [];
|
|
142
|
+
const failureFetch = async (url, options = {}) => {
|
|
143
|
+
const parsed = new URL(url);
|
|
144
|
+
if (parsed.pathname.endsWith('/meta/bases/app_owner_airtable_queue_failure/tables') && (!options.method || options.method === 'GET')) {
|
|
145
|
+
return makeResponse(200, { tables: failureTables });
|
|
146
|
+
}
|
|
147
|
+
if (parsed.pathname.endsWith('/meta/bases/app_owner_airtable_queue_failure/tables') && options.method === 'POST') {
|
|
148
|
+
const body = JSON.parse(options.body);
|
|
149
|
+
failureTables.push({ id: `tblFailure${failureTables.length + 1}`, name: body.name, fields: body.fields });
|
|
150
|
+
return makeResponse(200, failureTables[failureTables.length - 1]);
|
|
151
|
+
}
|
|
152
|
+
if (options.method === 'PATCH' && parsed.pathname.startsWith('/v0/app_owner_airtable_queue_failure/')) {
|
|
153
|
+
return makeResponse(422, { error: 'forced sync failure' });
|
|
154
|
+
}
|
|
155
|
+
return makeResponse(404, { error: parsed.pathname });
|
|
156
|
+
};
|
|
157
|
+
const failed = await drainOwnerAirtableSyncQueue({
|
|
158
|
+
queuePath: failureQueuePath,
|
|
159
|
+
statePath: failureStatePath,
|
|
160
|
+
historyPath: failureHistoryPath,
|
|
161
|
+
lockDir: join(home, 'failure-sync-drain.lock'),
|
|
162
|
+
syncOptions: {
|
|
163
|
+
token: 'unit_test_token_no_network',
|
|
164
|
+
baseId: 'app_owner_airtable_queue_failure',
|
|
165
|
+
taskDir,
|
|
166
|
+
runtimeStateDir,
|
|
167
|
+
actionLedgerDir: join(home, '.aria', 'action-ledger'),
|
|
168
|
+
outDir,
|
|
169
|
+
statePath: join(home, 'failure-owner-state.json'),
|
|
170
|
+
ownerAirtableDir: home,
|
|
171
|
+
atlasSocket: join(home, 'missing-atlas.sock'),
|
|
172
|
+
apiFetch: failureFetch,
|
|
173
|
+
},
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
assert.equal(failed.ok, false);
|
|
177
|
+
assert.equal(failed.syncOk, false);
|
|
178
|
+
assert.match(failed.syncError, /Airtable PATCH/);
|
|
179
|
+
assert.equal(readFileSync(failureQueuePath, 'utf8').trim().length > 0, true);
|
|
180
|
+
assert.equal(JSON.parse(readFileSync(failureStatePath, 'utf8')).ok, false);
|
|
181
|
+
assert.equal(readFileSync(failureHistoryPath, 'utf8').trim().split('\n').length, 1);
|
|
182
|
+
|
|
183
|
+
console.log(JSON.stringify({
|
|
184
|
+
ok: true,
|
|
185
|
+
queuePath,
|
|
186
|
+
drained: drained.drained,
|
|
187
|
+
failurePersisted: failed.ok === false && existsSync(failureStatePath),
|
|
188
|
+
createdTableCount: createdTables.length,
|
|
189
|
+
dashboardRows: drained.sync.dashboardRows,
|
|
190
|
+
ownerBoardRows: drained.sync.ownerBoardRows,
|
|
191
|
+
ownerSyncRows: drained.sync.ownerSyncRows,
|
|
192
|
+
atlasRows: drained.sync.atlasRows,
|
|
193
|
+
}, null, 2));
|
|
194
|
+
} finally {
|
|
195
|
+
rmSync(home, { recursive: true, force: true });
|
|
196
|
+
}
|