@aria_asi/cli 0.2.40 → 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 +1223 -41
- 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 +477 -81
- 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 +477 -81
- 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 +477 -81
- 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 +1225 -41
- 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
|
@@ -1,186 +0,0 @@
|
|
|
1
|
-
// anthropic-oauth.test.ts — unit tests for the Anthropic login flow.
|
|
2
|
-
//
|
|
3
|
-
// Coverage:
|
|
4
|
-
// - _validateKey: 200 = valid, 401 = invalid, network failure = invalid
|
|
5
|
-
// - loginAnthropic: bad key gracefully returns ok: false with descriptive error
|
|
6
|
-
// - loginAnthropic: good key persists to config and returns ok: true
|
|
7
|
-
//
|
|
8
|
-
// Strategy: mock globalThis.fetch (Node 18+ built-in) + mock readline to avoid
|
|
9
|
-
// interactive prompts. No file I/O touches real ~/.aria — we stub fs.writeFileSync.
|
|
10
|
-
|
|
11
|
-
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
12
|
-
|
|
13
|
-
// ── We test the exported internals directly. ─────────────────────────────────
|
|
14
|
-
// anthropic-oauth.ts exports _validateKey for testability; loginAnthropic is
|
|
15
|
-
// also tested end-to-end with readline + fs mocked out.
|
|
16
|
-
|
|
17
|
-
// Hoist mocks before module import so Node's ESM loader sees them.
|
|
18
|
-
vi.mock('node:fs', async (importOriginal) => {
|
|
19
|
-
const actual = await importOriginal<typeof import('node:fs')>();
|
|
20
|
-
return {
|
|
21
|
-
...actual,
|
|
22
|
-
existsSync: vi.fn(() => false),
|
|
23
|
-
mkdirSync: vi.fn(),
|
|
24
|
-
writeFileSync: vi.fn(),
|
|
25
|
-
readFileSync: vi.fn(() => '{}'),
|
|
26
|
-
};
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
vi.mock('node:readline', async (importOriginal) => {
|
|
30
|
-
const actual = await importOriginal<typeof import('node:readline')>();
|
|
31
|
-
return {
|
|
32
|
-
...actual,
|
|
33
|
-
createInterface: vi.fn(() => ({
|
|
34
|
-
question: vi.fn((_prompt: string, cb: (a: string) => void) => cb('sk-ant-fake-key-for-tests')),
|
|
35
|
-
close: vi.fn(),
|
|
36
|
-
})),
|
|
37
|
-
};
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
vi.mock('node:child_process', () => ({
|
|
41
|
-
spawn: vi.fn(() => ({ unref: vi.fn() })),
|
|
42
|
-
}));
|
|
43
|
-
|
|
44
|
-
import { _validateKey, loginAnthropic } from '../anthropic-oauth.js';
|
|
45
|
-
|
|
46
|
-
// ── Helpers ───────────────────────────────────────────────────────────────────
|
|
47
|
-
|
|
48
|
-
function mockFetch(status: number, body: unknown = {}): void {
|
|
49
|
-
vi.stubGlobal(
|
|
50
|
-
'fetch',
|
|
51
|
-
vi.fn().mockResolvedValue({
|
|
52
|
-
status,
|
|
53
|
-
ok: status >= 200 && status < 300,
|
|
54
|
-
json: async () => body,
|
|
55
|
-
}),
|
|
56
|
-
);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
function mockFetchNetworkError(): void {
|
|
60
|
-
vi.stubGlobal('fetch', vi.fn().mockRejectedValue(new Error("I couldn't reach Anthropic")));
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
// ── _validateKey ─────────────────────────────────────────────────────────────
|
|
64
|
-
|
|
65
|
-
describe('_validateKey', () => {
|
|
66
|
-
afterEach(() => {
|
|
67
|
-
vi.unstubAllGlobals();
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
it('returns true when Anthropic /v1/models responds 200', async () => {
|
|
71
|
-
mockFetch(200, { data: [] });
|
|
72
|
-
const result = await _validateKey('sk-ant-valid');
|
|
73
|
-
expect(result).toBe(true);
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
it('returns false when Anthropic /v1/models responds 401 (bad key)', async () => {
|
|
77
|
-
mockFetch(401, { error: { message: 'invalid x-api-key' } });
|
|
78
|
-
const result = await _validateKey('sk-ant-bad');
|
|
79
|
-
expect(result).toBe(false);
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
it('returns false when Anthropic /v1/models responds 403 (revoked key)', async () => {
|
|
83
|
-
mockFetch(403, { error: { message: 'forbidden' } });
|
|
84
|
-
const result = await _validateKey('sk-ant-revoked');
|
|
85
|
-
expect(result).toBe(false);
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
it('returns false on network error — does not throw', async () => {
|
|
89
|
-
mockFetchNetworkError();
|
|
90
|
-
const result = await _validateKey('sk-ant-any');
|
|
91
|
-
expect(result).toBe(false);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('sends x-api-key and anthropic-version headers', async () => {
|
|
95
|
-
const fetchMock = vi.fn().mockResolvedValue({ status: 200, ok: true, json: async () => ({}) });
|
|
96
|
-
vi.stubGlobal('fetch', fetchMock);
|
|
97
|
-
|
|
98
|
-
await _validateKey('sk-ant-check-headers');
|
|
99
|
-
|
|
100
|
-
expect(fetchMock).toHaveBeenCalledWith(
|
|
101
|
-
'https://api.anthropic.com/v1/models',
|
|
102
|
-
expect.objectContaining({
|
|
103
|
-
headers: expect.objectContaining({
|
|
104
|
-
'x-api-key': 'sk-ant-check-headers',
|
|
105
|
-
'anthropic-version': '2023-06-01',
|
|
106
|
-
}),
|
|
107
|
-
}),
|
|
108
|
-
);
|
|
109
|
-
});
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
// ── loginAnthropic ────────────────────────────────────────────────────────────
|
|
113
|
-
|
|
114
|
-
describe('loginAnthropic', () => {
|
|
115
|
-
beforeEach(() => {
|
|
116
|
-
vi.clearAllMocks();
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
afterEach(() => {
|
|
120
|
-
vi.unstubAllGlobals();
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
it('returns ok: false with descriptive Aria-voice error when key fails validation', async () => {
|
|
124
|
-
// readline mock returns 'sk-ant-fake-key-for-tests'; validate returns 401
|
|
125
|
-
mockFetch(401, { error: { message: 'invalid key' } });
|
|
126
|
-
|
|
127
|
-
const result = await loginAnthropic({ noBrowser: true });
|
|
128
|
-
|
|
129
|
-
expect(result.ok).toBe(false);
|
|
130
|
-
expect(result.error).toMatch(/I couldn't verify/);
|
|
131
|
-
// Ensure the error message does NOT contain internal cluster paths or IP addresses
|
|
132
|
-
expect(result.error).not.toMatch(/10\.\d+\.\d+\.\d+/);
|
|
133
|
-
expect(result.error).not.toMatch(/cluster\.local/);
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
it('returns ok: true and apiKey when key passes validation', async () => {
|
|
137
|
-
// readline returns 'sk-ant-fake-key-for-tests'; validate returns 200
|
|
138
|
-
mockFetch(200, { data: [{ id: 'claude-sonnet-4-20250514' }] });
|
|
139
|
-
|
|
140
|
-
const result = await loginAnthropic({ noBrowser: true });
|
|
141
|
-
|
|
142
|
-
expect(result.ok).toBe(true);
|
|
143
|
-
expect(result.apiKey).toBe('sk-ant-fake-key-for-tests');
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
it('returns ok: false when user pastes an empty string', async () => {
|
|
147
|
-
// Override readline mock to return empty string for this test
|
|
148
|
-
const readline = await import('node:readline');
|
|
149
|
-
vi.mocked(readline.createInterface).mockReturnValueOnce({
|
|
150
|
-
question: vi.fn((_: string, cb: (a: string) => void) => cb('')),
|
|
151
|
-
close: vi.fn(),
|
|
152
|
-
} as any);
|
|
153
|
-
|
|
154
|
-
mockFetch(200, {});
|
|
155
|
-
|
|
156
|
-
const result = await loginAnthropic({ noBrowser: true });
|
|
157
|
-
|
|
158
|
-
expect(result.ok).toBe(false);
|
|
159
|
-
// Should not proceed to validation when key is empty
|
|
160
|
-
expect(result.error).toBeTruthy();
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
it('returns ok: false gracefully on network failure during validation', async () => {
|
|
164
|
-
mockFetchNetworkError();
|
|
165
|
-
|
|
166
|
-
const result = await loginAnthropic({ noBrowser: true });
|
|
167
|
-
|
|
168
|
-
expect(result.ok).toBe(false);
|
|
169
|
-
// Should surface a human-readable error, not a raw Error object
|
|
170
|
-
expect(typeof result.error).toBe('string');
|
|
171
|
-
expect(result.error!.length).toBeGreaterThan(10);
|
|
172
|
-
});
|
|
173
|
-
|
|
174
|
-
it('persists apiKey to config when validation succeeds', async () => {
|
|
175
|
-
mockFetch(200, { data: [] });
|
|
176
|
-
const fs = await import('node:fs');
|
|
177
|
-
|
|
178
|
-
await loginAnthropic({ noBrowser: true });
|
|
179
|
-
|
|
180
|
-
expect(vi.mocked(fs.writeFileSync)).toHaveBeenCalledWith(
|
|
181
|
-
expect.stringContaining('config.json'),
|
|
182
|
-
expect.stringContaining('sk-ant-fake-key-for-tests'),
|
|
183
|
-
expect.objectContaining({ mode: 0o600 }),
|
|
184
|
-
);
|
|
185
|
-
});
|
|
186
|
-
});
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
import { login, status, logout, revoke } from '../auth-commands';
|
|
2
|
-
import { loadLicense, saveLicense } from '../auth';
|
|
3
|
-
import { harnessClient } from '../harness-client';
|
|
4
|
-
import * as fs from 'fs';
|
|
5
|
-
import * as path from 'path';
|
|
6
|
-
|
|
7
|
-
jest.mock('../auth');
|
|
8
|
-
jest.mock('../harness-client');
|
|
9
|
-
|
|
10
|
-
const LICENSE_PATH = path.join(require('os').homedir(), '.aria', 'license.json');
|
|
11
|
-
|
|
12
|
-
const mockClaims = {
|
|
13
|
-
jti: 'test-jti-123',
|
|
14
|
-
sub: 'user-test',
|
|
15
|
-
tier: 'pro',
|
|
16
|
-
exp: Math.floor(Date.now() / 1000) + 86400,
|
|
17
|
-
iat: Math.floor(Date.now() / 1000),
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
beforeEach(() => {
|
|
21
|
-
jest.clearAllMocks();
|
|
22
|
-
// Clean up any leftover license file
|
|
23
|
-
try { fs.unlinkSync(LICENSE_PATH); } catch {}
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
describe('login', () => {
|
|
27
|
-
it('should validate token and persist license', async () => {
|
|
28
|
-
(harnessClient.get as jest.Mock).mockResolvedValue({
|
|
29
|
-
ok: true,
|
|
30
|
-
json: () => Promise.resolve({ claims: mockClaims }),
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
const result = await login('valid-token');
|
|
34
|
-
|
|
35
|
-
expect(result.ok).toBe(true);
|
|
36
|
-
expect(result.tier).toBe('pro');
|
|
37
|
-
expect(result.jti).toBe('test-jti-123');
|
|
38
|
-
expect(result.expiresAt).toBeDefined();
|
|
39
|
-
|
|
40
|
-
// Verify file was written with mode 0600
|
|
41
|
-
const written = JSON.parse(fs.readFileSync(LICENSE_PATH, 'utf-8'));
|
|
42
|
-
expect(written.jti).toBe('test-jti-123');
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it('should return error on invalid token', async () => {
|
|
46
|
-
(harnessClient.get as jest.Mock).mockResolvedValue({
|
|
47
|
-
ok: false,
|
|
48
|
-
json: () => Promise.resolve({ error: 'Invalid token' }),
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
const result = await login('bad-token');
|
|
52
|
-
expect(result.ok).toBe(false);
|
|
53
|
-
expect(result.error).toBe('Invalid token');
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
describe('status', () => {
|
|
58
|
-
it('should return logged out when no local license', async () => {
|
|
59
|
-
(loadLicense as jest.Mock).mockReturnValue(null);
|
|
60
|
-
|
|
61
|
-
const result = await status();
|
|
62
|
-
expect(result.loggedIn).toBe(false);
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
it('should return status from server when licensed', async () => {
|
|
66
|
-
(loadLicense as jest.Mock).mockReturnValue(mockClaims);
|
|
67
|
-
(harnessClient.get as jest.Mock).mockResolvedValue({
|
|
68
|
-
ok: true,
|
|
69
|
-
status: 200,
|
|
70
|
-
json: () => Promise.resolve({ claims: mockClaims }),
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
const result = await status();
|
|
74
|
-
expect(result.loggedIn).toBe(true);
|
|
75
|
-
expect(result.tier).toBe('pro');
|
|
76
|
-
expect(result.revoked).toBe(false);
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
it('should detect revoked license from 410', async () => {
|
|
80
|
-
(loadLicense as jest.Mock).mockReturnValue(mockClaims);
|
|
81
|
-
(harnessClient.get as jest.Mock).mockResolvedValue({
|
|
82
|
-
ok: false,
|
|
83
|
-
status: 410,
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
const result = await status();
|
|
87
|
-
expect(result.loggedIn).toBe(true);
|
|
88
|
-
expect(result.revoked).toBe(true);
|
|
89
|
-
});
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
describe('logout', () => {
|
|
93
|
-
it('should delete license file', async () => {
|
|
94
|
-
// Create a fake license file
|
|
95
|
-
fs.writeFileSync(LICENSE_PATH, JSON.stringify(mockClaims), { mode: 0o600 });
|
|
96
|
-
expect(fs.existsSync(LICENSE_PATH)).toBe(true);
|
|
97
|
-
|
|
98
|
-
const result = await logout();
|
|
99
|
-
expect(result.ok).toBe(true);
|
|
100
|
-
expect(fs.existsSync(LICENSE_PATH)).toBe(false);
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
it('should succeed even without license file', async () => {
|
|
104
|
-
const result = await logout();
|
|
105
|
-
expect(result.ok).toBe(true);
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
describe('revoke', () => {
|
|
110
|
-
it('should revoke license server-side and clear local', async () => {
|
|
111
|
-
(loadLicense as jest.Mock).mockReturnValue(mockClaims);
|
|
112
|
-
(harnessClient.post as jest.Mock).mockResolvedValue({
|
|
113
|
-
ok: true,
|
|
114
|
-
json: () => Promise.resolve({}),
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
const result = await revoke('Test revocation');
|
|
118
|
-
expect(result.ok).toBe(true);
|
|
119
|
-
expect(result.jti).toBe('test-jti-123');
|
|
120
|
-
expect(harnessClient.post).toHaveBeenCalledWith('/api/license/revoke', {
|
|
121
|
-
body: { jti: 'test-jti-123', reason: 'Test revocation', revokedBy: 'self' },
|
|
122
|
-
});
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
it('should fail without active license', async () => {
|
|
126
|
-
(loadLicense as jest.Mock).mockReturnValue(null);
|
|
127
|
-
|
|
128
|
-
const result = await revoke();
|
|
129
|
-
expect(result.ok).toBe(false);
|
|
130
|
-
expect(result.error).toBe('No active license to revoke');
|
|
131
|
-
});
|
|
132
|
-
});
|
|
@@ -1,311 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Smoke test — Phase 11 #25 owner-login mode
|
|
3
|
-
*
|
|
4
|
-
* Verifies the end-to-end owner-mode flow with mocked network:
|
|
5
|
-
* 1. loginOwner() writes ~/.aria/owner-token with mode 0600.
|
|
6
|
-
* 2. Subsequent harness requests include x-aria-owner: true.
|
|
7
|
-
* 3. ownerMiddleware logic: valid JWT → isOwner=true; invalid → 401.
|
|
8
|
-
* 4. /api/admin/state returns 501 when authed; 401 when not.
|
|
9
|
-
*
|
|
10
|
-
* No real network calls — fetch is mocked globally.
|
|
11
|
-
* No real FS writes beyond the tmp owner-token path (cleaned up in afterEach).
|
|
12
|
-
*/
|
|
13
|
-
|
|
14
|
-
import * as fs from 'node:fs';
|
|
15
|
-
import * as path from 'node:path';
|
|
16
|
-
import * as os from 'node:os';
|
|
17
|
-
import * as crypto from 'node:crypto';
|
|
18
|
-
|
|
19
|
-
// ── Isolate the owner-token path to a temp dir so we don't pollute ~/.aria ──
|
|
20
|
-
const TEST_ARIA_DIR = path.join(os.tmpdir(), `aria-owner-test-${process.pid}`);
|
|
21
|
-
const TEST_OWNER_TOKEN_PATH = path.join(TEST_ARIA_DIR, 'owner-token');
|
|
22
|
-
|
|
23
|
-
// We need to mock the OWNER_TOKEN_PATH used in the modules under test.
|
|
24
|
-
// Because the path is derived from homedir() at module load time, we intercept
|
|
25
|
-
// via jest.mock on the 'node:os' module to redirect homedir to our temp dir.
|
|
26
|
-
jest.mock('node:os', () => ({
|
|
27
|
-
...jest.requireActual('node:os'),
|
|
28
|
-
homedir: () => TEST_ARIA_DIR,
|
|
29
|
-
}));
|
|
30
|
-
|
|
31
|
-
// Mock fetch globally — no real network calls in unit tests.
|
|
32
|
-
const mockFetch = jest.fn();
|
|
33
|
-
global.fetch = mockFetch as any;
|
|
34
|
-
|
|
35
|
-
// Import under test AFTER mocks are established.
|
|
36
|
-
import { loginOwner, logout, OWNER_TOKEN_PATH } from '../auth-commands';
|
|
37
|
-
|
|
38
|
-
const JWT_SECRET = 'arya-hq-jwt-secret-2026-reinationwide';
|
|
39
|
-
|
|
40
|
-
/** Build a valid owner JWT signed with the default HQ_JWT_SECRET. */
|
|
41
|
-
function buildOwnerJWT(overrides: { sub?: string; tier?: string; exp?: number } = {}): string {
|
|
42
|
-
const header = Buffer.from(JSON.stringify({ alg: 'HS256', typ: 'JWT' })).toString('base64url');
|
|
43
|
-
const now = Math.floor(Date.now() / 1000);
|
|
44
|
-
const payload = Buffer.from(
|
|
45
|
-
JSON.stringify({
|
|
46
|
-
sub: overrides.sub ?? 'hamza',
|
|
47
|
-
tier: overrides.tier ?? 'owner',
|
|
48
|
-
iat: now,
|
|
49
|
-
exp: overrides.exp ?? now + 365 * 24 * 3600,
|
|
50
|
-
}),
|
|
51
|
-
).toString('base64url');
|
|
52
|
-
const sig = crypto
|
|
53
|
-
.createHmac('sha256', JWT_SECRET)
|
|
54
|
-
.update(`${header}.${payload}`)
|
|
55
|
-
.digest('base64url');
|
|
56
|
-
return `${header}.${payload}.${sig}`;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
beforeAll(() => {
|
|
60
|
-
if (!fs.existsSync(TEST_ARIA_DIR)) {
|
|
61
|
-
fs.mkdirSync(TEST_ARIA_DIR, { recursive: true, mode: 0o700 });
|
|
62
|
-
}
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
afterEach(() => {
|
|
66
|
-
jest.clearAllMocks();
|
|
67
|
-
// Clean up owner-token between tests.
|
|
68
|
-
try { fs.unlinkSync(TEST_OWNER_TOKEN_PATH); } catch {}
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
afterAll(() => {
|
|
72
|
-
// Remove temp dir.
|
|
73
|
-
try { fs.rmSync(TEST_ARIA_DIR, { recursive: true, force: true }); } catch {}
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
// ── 1. loginOwner() writes ~/.aria/owner-token with mode 0600 ──────────────
|
|
77
|
-
|
|
78
|
-
describe('loginOwner()', () => {
|
|
79
|
-
it('writes owner-token with mode 0600 on success', async () => {
|
|
80
|
-
const ownerJWT = buildOwnerJWT();
|
|
81
|
-
mockFetch.mockResolvedValueOnce({
|
|
82
|
-
ok: true,
|
|
83
|
-
json: async () => ({ ok: true, token: ownerJWT, tier: 'owner', sub: 'hamza' }),
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
const result = await loginOwner('valid-master-token');
|
|
87
|
-
|
|
88
|
-
expect(result.ok).toBe(true);
|
|
89
|
-
expect(result.owner).toBe(true);
|
|
90
|
-
expect(result.tier).toBe('owner');
|
|
91
|
-
|
|
92
|
-
// File must exist.
|
|
93
|
-
expect(fs.existsSync(OWNER_TOKEN_PATH)).toBe(true);
|
|
94
|
-
|
|
95
|
-
// File content must be the JWT.
|
|
96
|
-
const stored = fs.readFileSync(OWNER_TOKEN_PATH, 'utf-8').trim();
|
|
97
|
-
expect(stored).toBe(ownerJWT);
|
|
98
|
-
|
|
99
|
-
// File permissions must be 0600.
|
|
100
|
-
const stat = fs.statSync(OWNER_TOKEN_PATH);
|
|
101
|
-
// mode & 0o777 masks the file-type bits, leaving only permission bits.
|
|
102
|
-
expect(stat.mode & 0o777).toBe(0o600);
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
it('returns error when server returns 401', async () => {
|
|
106
|
-
mockFetch.mockResolvedValueOnce({
|
|
107
|
-
ok: false,
|
|
108
|
-
status: 401,
|
|
109
|
-
json: async () => ({ ok: false, error: 'Invalid master token' }),
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
const result = await loginOwner('bad-master-token');
|
|
113
|
-
|
|
114
|
-
expect(result.ok).toBe(false);
|
|
115
|
-
expect(result.error).toBe('Invalid master token');
|
|
116
|
-
expect(fs.existsSync(OWNER_TOKEN_PATH)).toBe(false);
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it('returns error on network failure', async () => {
|
|
120
|
-
mockFetch.mockRejectedValueOnce(new Error('ECONNREFUSED'));
|
|
121
|
-
|
|
122
|
-
const result = await loginOwner('some-token');
|
|
123
|
-
|
|
124
|
-
expect(result.ok).toBe(false);
|
|
125
|
-
expect(result.error).toContain('ECONNREFUSED');
|
|
126
|
-
expect(fs.existsSync(OWNER_TOKEN_PATH)).toBe(false);
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
it('posts to /auth/owner with Authorization header (master token never in body)', async () => {
|
|
130
|
-
const ownerJWT = buildOwnerJWT();
|
|
131
|
-
mockFetch.mockResolvedValueOnce({
|
|
132
|
-
ok: true,
|
|
133
|
-
json: async () => ({ ok: true, token: ownerJWT }),
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
await loginOwner('super-secret-master');
|
|
137
|
-
|
|
138
|
-
const [url, init] = mockFetch.mock.calls[0];
|
|
139
|
-
expect(url).toContain('/auth/owner');
|
|
140
|
-
expect(init.headers['Authorization']).toBe('Bearer super-secret-master');
|
|
141
|
-
// Body must be empty (master token not in body).
|
|
142
|
-
expect(init.body).toBeUndefined();
|
|
143
|
-
});
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
// ── 2. logout() deletes owner-token ────────────────────────────────────────
|
|
147
|
-
|
|
148
|
-
describe('logout()', () => {
|
|
149
|
-
it('deletes owner-token on logout', async () => {
|
|
150
|
-
fs.writeFileSync(OWNER_TOKEN_PATH, 'some-jwt', { mode: 0o600 });
|
|
151
|
-
expect(fs.existsSync(OWNER_TOKEN_PATH)).toBe(true);
|
|
152
|
-
|
|
153
|
-
const result = await logout();
|
|
154
|
-
|
|
155
|
-
expect(result.ok).toBe(true);
|
|
156
|
-
expect(fs.existsSync(OWNER_TOKEN_PATH)).toBe(false);
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
it('succeeds even when owner-token does not exist', async () => {
|
|
160
|
-
expect(fs.existsSync(OWNER_TOKEN_PATH)).toBe(false);
|
|
161
|
-
const result = await logout();
|
|
162
|
-
expect(result.ok).toBe(true);
|
|
163
|
-
});
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
// ── 2b. harnessClient shim attaches x-aria-owner when owner-token exists ───
|
|
167
|
-
|
|
168
|
-
describe('harnessClient shim owner header injection', () => {
|
|
169
|
-
it('sends x-aria-owner: true when owner-token exists', async () => {
|
|
170
|
-
const ownerJWT = buildOwnerJWT();
|
|
171
|
-
// Write a real owner-token so the shim's ownerHeaders() picks it up.
|
|
172
|
-
fs.mkdirSync(TEST_ARIA_DIR, { recursive: true });
|
|
173
|
-
fs.writeFileSync(TEST_OWNER_TOKEN_PATH, ownerJWT, { mode: 0o600 });
|
|
174
|
-
|
|
175
|
-
mockFetch.mockResolvedValueOnce({
|
|
176
|
-
ok: true,
|
|
177
|
-
json: async () => ({}),
|
|
178
|
-
});
|
|
179
|
-
|
|
180
|
-
// Import harnessClient after the mock is set up — homedir() is mocked.
|
|
181
|
-
const { harnessClient } = await import('../harness-client');
|
|
182
|
-
await harnessClient.get('/api/test').catch(() => {});
|
|
183
|
-
|
|
184
|
-
const [_url, init] = mockFetch.mock.calls[0];
|
|
185
|
-
expect(init.headers['x-aria-owner']).toBe('true');
|
|
186
|
-
expect(init.headers['Authorization']).toBe(`Bearer ${ownerJWT}`);
|
|
187
|
-
});
|
|
188
|
-
|
|
189
|
-
afterEach(() => {
|
|
190
|
-
// Remove owner-token so other tests start clean.
|
|
191
|
-
try { fs.unlinkSync(TEST_OWNER_TOKEN_PATH); } catch {}
|
|
192
|
-
jest.resetModules(); // Force re-import with fresh module state.
|
|
193
|
-
});
|
|
194
|
-
});
|
|
195
|
-
|
|
196
|
-
// ── 3. ownerMiddleware JWT validation logic (unit-tested inline) ────────────
|
|
197
|
-
// The middleware lives in server.ts (Express runtime). We test the JWT
|
|
198
|
-
// verification logic directly here — same HMAC-HS256 algorithm.
|
|
199
|
-
|
|
200
|
-
describe('owner JWT verification logic', () => {
|
|
201
|
-
function verifyOwnerJWT(
|
|
202
|
-
token: string,
|
|
203
|
-
secret: string = JWT_SECRET,
|
|
204
|
-
): { valid: boolean; claims?: { sub?: string; tier?: string; exp?: number }; reason?: string } {
|
|
205
|
-
try {
|
|
206
|
-
const parts = token.split('.');
|
|
207
|
-
if (parts.length !== 3) return { valid: false, reason: 'wrong part count' };
|
|
208
|
-
const [headerB64, payloadB64, sigB64] = parts;
|
|
209
|
-
const expectedSig = crypto
|
|
210
|
-
.createHmac('sha256', secret)
|
|
211
|
-
.update(`${headerB64}.${payloadB64}`)
|
|
212
|
-
.digest('base64url');
|
|
213
|
-
if (sigB64 !== expectedSig) return { valid: false, reason: 'signature mismatch' };
|
|
214
|
-
const claims = JSON.parse(Buffer.from(payloadB64, 'base64url').toString('utf-8'));
|
|
215
|
-
if (claims.exp && claims.exp < Math.floor(Date.now() / 1000)) {
|
|
216
|
-
return { valid: false, reason: 'expired' };
|
|
217
|
-
}
|
|
218
|
-
return { valid: true, claims };
|
|
219
|
-
} catch (e) {
|
|
220
|
-
return { valid: false, reason: String(e) };
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
it('validates a well-formed owner JWT with tier:owner sub:hamza', () => {
|
|
225
|
-
const jwt = buildOwnerJWT();
|
|
226
|
-
const result = verifyOwnerJWT(jwt);
|
|
227
|
-
expect(result.valid).toBe(true);
|
|
228
|
-
expect(result.claims?.tier).toBe('owner');
|
|
229
|
-
expect(result.claims?.sub).toBe('hamza');
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
it('rejects a JWT with wrong secret', () => {
|
|
233
|
-
const jwt = buildOwnerJWT();
|
|
234
|
-
const result = verifyOwnerJWT(jwt, 'wrong-secret');
|
|
235
|
-
expect(result.valid).toBe(false);
|
|
236
|
-
expect(result.reason).toContain('signature');
|
|
237
|
-
});
|
|
238
|
-
|
|
239
|
-
it('rejects an expired JWT', () => {
|
|
240
|
-
const expiredJWT = buildOwnerJWT({ exp: Math.floor(Date.now() / 1000) - 3600 });
|
|
241
|
-
const result = verifyOwnerJWT(expiredJWT);
|
|
242
|
-
expect(result.valid).toBe(false);
|
|
243
|
-
expect(result.reason).toBe('expired');
|
|
244
|
-
});
|
|
245
|
-
|
|
246
|
-
it('middleware logic: rejects when tier is owner but sub is not hamza (defense-in-depth)', () => {
|
|
247
|
-
const jwt = buildOwnerJWT({ sub: 'eve', tier: 'owner' });
|
|
248
|
-
const result = verifyOwnerJWT(jwt);
|
|
249
|
-
// JWT itself is valid — the middleware must ALSO check sub === 'hamza'.
|
|
250
|
-
expect(result.valid).toBe(true);
|
|
251
|
-
expect(result.claims?.sub).not.toBe('hamza');
|
|
252
|
-
// Simulate middleware check:
|
|
253
|
-
const isOwner = result.valid && result.claims?.tier === 'owner' && result.claims?.sub === 'hamza';
|
|
254
|
-
expect(isOwner).toBe(false);
|
|
255
|
-
});
|
|
256
|
-
});
|
|
257
|
-
|
|
258
|
-
// ── 4. Admin route gate behavior (simulated) ───────────────────────────────
|
|
259
|
-
// The actual Express handler for /api/admin/state lives in api/admin/state.ts.
|
|
260
|
-
// We test its exported function directly to verify 401/501 behavior.
|
|
261
|
-
|
|
262
|
-
describe('admin/state handler gate', () => {
|
|
263
|
-
let handler: (req: any, res: any) => any;
|
|
264
|
-
|
|
265
|
-
beforeAll(async () => {
|
|
266
|
-
// Import the handler directly — no Express middleware chain needed.
|
|
267
|
-
const mod = await import('../../apps/arias-soul/api/admin/state.ts').catch(() => null);
|
|
268
|
-
if (!mod) {
|
|
269
|
-
// If cross-package import fails in this test runner, use a local re-implementation
|
|
270
|
-
// of the gate logic to verify the contract.
|
|
271
|
-
handler = (req, res) => {
|
|
272
|
-
if (!req.isOwner) {
|
|
273
|
-
return res.status(401).json({ ok: false, error: 'owner token required' });
|
|
274
|
-
}
|
|
275
|
-
return res.status(501).json({ ok: false, error: 'Not implemented — Phase 11 #25 follow-up task' });
|
|
276
|
-
};
|
|
277
|
-
} else {
|
|
278
|
-
handler = mod.default;
|
|
279
|
-
}
|
|
280
|
-
});
|
|
281
|
-
|
|
282
|
-
it('returns 401 when isOwner is falsy', () => {
|
|
283
|
-
const req = { isOwner: false } as any;
|
|
284
|
-
const res = {
|
|
285
|
-
_status: 0,
|
|
286
|
-
_body: null as any,
|
|
287
|
-
status(code: number) { this._status = code; return this; },
|
|
288
|
-
json(body: any) { this._body = body; return this; },
|
|
289
|
-
};
|
|
290
|
-
handler(req, res);
|
|
291
|
-
expect(res._status).toBe(401);
|
|
292
|
-
expect(res._body.error).toContain('owner token required');
|
|
293
|
-
});
|
|
294
|
-
|
|
295
|
-
it('returns 501 with TODO body when isOwner is true', () => {
|
|
296
|
-
const req = { isOwner: true } as any;
|
|
297
|
-
const res = {
|
|
298
|
-
_status: 0,
|
|
299
|
-
_body: null as any,
|
|
300
|
-
status(code: number) { this._status = code; return this; },
|
|
301
|
-
json(body: any) { this._body = body; return this; },
|
|
302
|
-
};
|
|
303
|
-
handler(req, res);
|
|
304
|
-
expect(res._status).toBe(501);
|
|
305
|
-
expect(res._body.ok).toBe(false);
|
|
306
|
-
expect(res._body.error).toContain('Not implemented');
|
|
307
|
-
// Must have TODO body, not silently no-op.
|
|
308
|
-
expect(res._body.todo).toBeDefined();
|
|
309
|
-
expect(res._body.todo.description).toBeTruthy();
|
|
310
|
-
});
|
|
311
|
-
});
|