avorelo 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (258) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +56 -0
  3. package/bin/avorelo +9 -0
  4. package/package.json +135 -0
  5. package/scripts/README.md +40 -0
  6. package/scripts/cco-dashboard.js +252 -0
  7. package/scripts/cco-status.js +430 -0
  8. package/scripts/lib/activation/account-state.js +37 -0
  9. package/scripts/lib/activation/activation-runner.js +546 -0
  10. package/scripts/lib/activation/activation-self-healing.js +480 -0
  11. package/scripts/lib/activation/activation-state.js +83 -0
  12. package/scripts/lib/activation/activation-summary.js +191 -0
  13. package/scripts/lib/activation/adapters/claude-code.js +77 -0
  14. package/scripts/lib/activation/adapters/codex-cli.js +52 -0
  15. package/scripts/lib/activation/adapters/cursor.js +37 -0
  16. package/scripts/lib/activation/adapters/github-agent.js +39 -0
  17. package/scripts/lib/activation/adapters/terminal.js +42 -0
  18. package/scripts/lib/activation/adapters/vscode.js +39 -0
  19. package/scripts/lib/activation/adapters/windsurf.js +37 -0
  20. package/scripts/lib/activation/ai-surface-detector.js +151 -0
  21. package/scripts/lib/activation/connect-account.js +145 -0
  22. package/scripts/lib/activation/detect-environment.js +75 -0
  23. package/scripts/lib/activation/detect-hosts.js +62 -0
  24. package/scripts/lib/activation/format-activation-output.js +109 -0
  25. package/scripts/lib/activation/next-action.js +43 -0
  26. package/scripts/lib/activation/repair-engine.js +219 -0
  27. package/scripts/lib/activation-distribution-readiness.js +507 -0
  28. package/scripts/lib/adapter-conformance.js +176 -0
  29. package/scripts/lib/adapter-readiness.js +417 -0
  30. package/scripts/lib/adapter-safety-boundaries.js +335 -0
  31. package/scripts/lib/adapter-technical-readiness-gate.js +205 -0
  32. package/scripts/lib/agent-access-governance.js +455 -0
  33. package/scripts/lib/agent-enforcement.js +765 -0
  34. package/scripts/lib/agent-policy-profile.js +210 -0
  35. package/scripts/lib/agent-security/action-evaluator.js +507 -0
  36. package/scripts/lib/agent-security/adapter-registry.js +98 -0
  37. package/scripts/lib/agent-security/auto-policy.js +139 -0
  38. package/scripts/lib/agent-security/bounded-scan.js +93 -0
  39. package/scripts/lib/agent-security/enforcement-adapter.js +174 -0
  40. package/scripts/lib/agent-security/enforcement-engine.js +1129 -0
  41. package/scripts/lib/agent-security/file-write-adapter.js +183 -0
  42. package/scripts/lib/agent-security/file-write-rules.js +178 -0
  43. package/scripts/lib/agent-security/index.js +3342 -0
  44. package/scripts/lib/agent-security/instruction-risk.js +181 -0
  45. package/scripts/lib/agent-security/mcp-action-adapter.js +185 -0
  46. package/scripts/lib/agent-security/mcp-action-rules.js +184 -0
  47. package/scripts/lib/agent-security/package-action-adapter.js +175 -0
  48. package/scripts/lib/agent-security/package-action-rules.js +233 -0
  49. package/scripts/lib/agent-security/performance.js +148 -0
  50. package/scripts/lib/agent-security/permission-minimizer.js +403 -0
  51. package/scripts/lib/agent-security/scan-cache.js +74 -0
  52. package/scripts/lib/agent-security/source-trust.js +146 -0
  53. package/scripts/lib/ai-install-prompt.js +288 -0
  54. package/scripts/lib/ai-workspace-hygiene.js +1499 -0
  55. package/scripts/lib/alpha-activation.js +520 -0
  56. package/scripts/lib/alpha-feedback.js +263 -0
  57. package/scripts/lib/alpha-readiness-gate.js +332 -0
  58. package/scripts/lib/anti-gaming.js +169 -0
  59. package/scripts/lib/artifact-health.js +431 -0
  60. package/scripts/lib/attribution.js +180 -0
  61. package/scripts/lib/audit.js +289 -0
  62. package/scripts/lib/avorelo-skill-registry.js +810 -0
  63. package/scripts/lib/batch-jobs.js +71 -0
  64. package/scripts/lib/brain-pack.js +578 -0
  65. package/scripts/lib/brand-boundary.js +424 -0
  66. package/scripts/lib/brand.js +74 -0
  67. package/scripts/lib/browser-capability.js +1048 -0
  68. package/scripts/lib/browser-proof-preflight.js +321 -0
  69. package/scripts/lib/cache-readiness.js +187 -0
  70. package/scripts/lib/canonical-reentry.js +162 -0
  71. package/scripts/lib/capability-packs.js +314 -0
  72. package/scripts/lib/capability-recommender.js +512 -0
  73. package/scripts/lib/capability-registry.js +1059 -0
  74. package/scripts/lib/carry-forward-surfacing.js +194 -0
  75. package/scripts/lib/ccusage-adapter.js +188 -0
  76. package/scripts/lib/company-loop.js +1149 -0
  77. package/scripts/lib/config.js +637 -0
  78. package/scripts/lib/context-acquisition-plan.js +287 -0
  79. package/scripts/lib/context-budget-guard.js +170 -0
  80. package/scripts/lib/context-budget-scanner.js +257 -0
  81. package/scripts/lib/context-optimizer.js +715 -0
  82. package/scripts/lib/context-reduction-plan.js +178 -0
  83. package/scripts/lib/context-safety.js +88 -0
  84. package/scripts/lib/context-savings-engine.js +158 -0
  85. package/scripts/lib/cost-evidence.js +254 -0
  86. package/scripts/lib/cross-host-install-plan.js +308 -0
  87. package/scripts/lib/cross-host-install-readiness.js +237 -0
  88. package/scripts/lib/cross-host-value-flow.js +268 -0
  89. package/scripts/lib/dashboard.js +900 -0
  90. package/scripts/lib/design-partner-feedback.js +346 -0
  91. package/scripts/lib/entitlements.js +100 -0
  92. package/scripts/lib/execution-packet.js +559 -0
  93. package/scripts/lib/experimentation-events.js +547 -0
  94. package/scripts/lib/external-capability-compliance.js +107 -0
  95. package/scripts/lib/external-user-simulation.js +166 -0
  96. package/scripts/lib/failure-recovery-readiness.js +81 -0
  97. package/scripts/lib/failure-recovery.js +419 -0
  98. package/scripts/lib/feedback-intelligence.js +537 -0
  99. package/scripts/lib/feedback-signals.js +205 -0
  100. package/scripts/lib/file-integrity.js +68 -0
  101. package/scripts/lib/fsx.js +127 -0
  102. package/scripts/lib/full-readiness-gate.js +451 -0
  103. package/scripts/lib/guidance-builder.js +174 -0
  104. package/scripts/lib/hook-apply.js +1019 -0
  105. package/scripts/lib/hook-baseline.js +310 -0
  106. package/scripts/lib/hook-config-preview.js +275 -0
  107. package/scripts/lib/hook-contracts.js +290 -0
  108. package/scripts/lib/hook-safety-boundary-readiness.js +80 -0
  109. package/scripts/lib/host-capability-matrix.js +351 -0
  110. package/scripts/lib/host-support-context.js +254 -0
  111. package/scripts/lib/http-hook-action.js +538 -0
  112. package/scripts/lib/install-ai-readiness.js +84 -0
  113. package/scripts/lib/install-intake-risk.js +1037 -0
  114. package/scripts/lib/install-journey-intelligence.js +329 -0
  115. package/scripts/lib/intervention-guidance.js +57 -0
  116. package/scripts/lib/known-limitations.js +115 -0
  117. package/scripts/lib/l8-path-truth.js +146 -0
  118. package/scripts/lib/launch-hardening-gate.js +436 -0
  119. package/scripts/lib/launch-readiness.js +628 -0
  120. package/scripts/lib/learning-memory.js +686 -0
  121. package/scripts/lib/lifecycle-hooks.js +802 -0
  122. package/scripts/lib/local-package-smoke.js +423 -0
  123. package/scripts/lib/local-pricing.js +299 -0
  124. package/scripts/lib/mcp-enforcement.js +311 -0
  125. package/scripts/lib/mcp-least-privilege-policy.js +303 -0
  126. package/scripts/lib/mcp-tool-inventory.js +388 -0
  127. package/scripts/lib/mcp-tool-risk.js +0 -0
  128. package/scripts/lib/memory.js +335 -0
  129. package/scripts/lib/metrics.js +699 -0
  130. package/scripts/lib/micro-proof.js +133 -0
  131. package/scripts/lib/next-run-context.js +436 -0
  132. package/scripts/lib/operating-value.js +1648 -0
  133. package/scripts/lib/optimization-v3.js +122 -0
  134. package/scripts/lib/orchestration/adapters/_shared.js +49 -0
  135. package/scripts/lib/orchestration/adapters/aider.js +18 -0
  136. package/scripts/lib/orchestration/adapters/claude-code.js +35 -0
  137. package/scripts/lib/orchestration/adapters/codex.js +35 -0
  138. package/scripts/lib/orchestration/adapters/gemini-cli.js +18 -0
  139. package/scripts/lib/orchestration/adapters/git.js +25 -0
  140. package/scripts/lib/orchestration/adapters/index.js +31 -0
  141. package/scripts/lib/orchestration/adapters/lm-studio.js +18 -0
  142. package/scripts/lib/orchestration/adapters/ollama.js +18 -0
  143. package/scripts/lib/orchestration/adapters/opencode.js +18 -0
  144. package/scripts/lib/orchestration/adapters/openrouter.js +18 -0
  145. package/scripts/lib/orchestration/adapters/test-runner.js +25 -0
  146. package/scripts/lib/orchestration/cli.js +438 -0
  147. package/scripts/lib/orchestration/execution-manager.js +279 -0
  148. package/scripts/lib/orchestration/handoff.js +314 -0
  149. package/scripts/lib/orchestration/index.js +456 -0
  150. package/scripts/lib/orchestration/inventory.js +47 -0
  151. package/scripts/lib/orchestration/model-discovery.js +498 -0
  152. package/scripts/lib/orchestration/model-profiler.js +170 -0
  153. package/scripts/lib/orchestration/model-profiles.js +252 -0
  154. package/scripts/lib/orchestration/model-refresh-policy.js +72 -0
  155. package/scripts/lib/orchestration/proof-writer.js +349 -0
  156. package/scripts/lib/orchestration/provider-discovery/aider.js +49 -0
  157. package/scripts/lib/orchestration/provider-discovery/claude-code.js +56 -0
  158. package/scripts/lib/orchestration/provider-discovery/codex.js +49 -0
  159. package/scripts/lib/orchestration/provider-discovery/common.js +186 -0
  160. package/scripts/lib/orchestration/provider-discovery/gemini.js +106 -0
  161. package/scripts/lib/orchestration/provider-discovery/lm-studio.js +118 -0
  162. package/scripts/lib/orchestration/provider-discovery/models-dev.js +12 -0
  163. package/scripts/lib/orchestration/provider-discovery/ollama.js +100 -0
  164. package/scripts/lib/orchestration/provider-discovery/opencode.js +47 -0
  165. package/scripts/lib/orchestration/provider-discovery/openrouter.js +44 -0
  166. package/scripts/lib/orchestration/risk-classifier.js +130 -0
  167. package/scripts/lib/orchestration/routing-policy.js +486 -0
  168. package/scripts/lib/orchestration/settings.js +112 -0
  169. package/scripts/lib/orchestration/state.js +165 -0
  170. package/scripts/lib/orchestration/verification-manager.js +138 -0
  171. package/scripts/lib/output-profiles.js +146 -0
  172. package/scripts/lib/package-content-audit.js +368 -0
  173. package/scripts/lib/package-runtime.js +278 -0
  174. package/scripts/lib/plan-surface.js +53 -0
  175. package/scripts/lib/plans.js +2318 -0
  176. package/scripts/lib/policy-provider.js +27 -0
  177. package/scripts/lib/prelaunch-activation-readiness.js +409 -0
  178. package/scripts/lib/prelaunch-evidence-store.js +816 -0
  179. package/scripts/lib/prelaunch-intelligence.js +869 -0
  180. package/scripts/lib/pricing-experiment.js +118 -0
  181. package/scripts/lib/pro-moment-events.js +77 -0
  182. package/scripts/lib/pro-moment-state.js +227 -0
  183. package/scripts/lib/pro-moments.js +1216 -0
  184. package/scripts/lib/product-learning-events.js +629 -0
  185. package/scripts/lib/project-profile.js +555 -0
  186. package/scripts/lib/prompt-compiler.js +280 -0
  187. package/scripts/lib/prompt-lint.js +32 -0
  188. package/scripts/lib/prompt-suggestions.js +52 -0
  189. package/scripts/lib/proof-canonical.js +398 -0
  190. package/scripts/lib/proof-drilldown.js +383 -0
  191. package/scripts/lib/proof-events.js +342 -0
  192. package/scripts/lib/proof-history.js +243 -0
  193. package/scripts/lib/proof-metrics.js +296 -0
  194. package/scripts/lib/proof-outcome-evidence.js +134 -0
  195. package/scripts/lib/proof-receipt.js +335 -0
  196. package/scripts/lib/proof-record.js +461 -0
  197. package/scripts/lib/public-activation-distribution-gate.js +258 -0
  198. package/scripts/lib/public-cli.js +3891 -0
  199. package/scripts/lib/public-distribution-truth.js +211 -0
  200. package/scripts/lib/public-install-claim-checker.js +294 -0
  201. package/scripts/lib/publish-provenance-readiness.js +283 -0
  202. package/scripts/lib/readiness-delta.js +218 -0
  203. package/scripts/lib/readiness-evidence-closure.js +196 -0
  204. package/scripts/lib/reentry-memory-capture.js +241 -0
  205. package/scripts/lib/reentry-memory-retrieval.js +302 -0
  206. package/scripts/lib/reentry-memory-status.js +146 -0
  207. package/scripts/lib/reentry-memory-store.js +178 -0
  208. package/scripts/lib/reentry-state.js +66 -0
  209. package/scripts/lib/release-candidate-bundle.js +166 -0
  210. package/scripts/lib/remediation.js +81 -0
  211. package/scripts/lib/repo-map.js +391 -0
  212. package/scripts/lib/run-improvements-lifecycle.js +330 -0
  213. package/scripts/lib/run-improvements.js +789 -0
  214. package/scripts/lib/runtime-decision-policy.js +387 -0
  215. package/scripts/lib/safe-path-engine.js +705 -0
  216. package/scripts/lib/safe-run-controller.js +887 -0
  217. package/scripts/lib/score.js +262 -0
  218. package/scripts/lib/seamless-enforcement.js +329 -0
  219. package/scripts/lib/seamless-outcome.js +689 -0
  220. package/scripts/lib/seamless-reality-gate.js +5043 -0
  221. package/scripts/lib/security-risk-classifier.js +511 -0
  222. package/scripts/lib/security-scan.js +384 -0
  223. package/scripts/lib/session-context-optimizer.js +1211 -0
  224. package/scripts/lib/session-timing.js +315 -0
  225. package/scripts/lib/skill-hygiene.js +805 -0
  226. package/scripts/lib/skill-packs.js +161 -0
  227. package/scripts/lib/skills-operating-layer.js +580 -0
  228. package/scripts/lib/smart-work-routing.js +768 -0
  229. package/scripts/lib/source-catalog.js +700 -0
  230. package/scripts/lib/status-value-summary.js +32 -0
  231. package/scripts/lib/support-bundle.js +578 -0
  232. package/scripts/lib/task-continuation.js +440 -0
  233. package/scripts/lib/test-helpers.js +15 -0
  234. package/scripts/lib/tier.js +38 -0
  235. package/scripts/lib/token-context-quality-gate.js +370 -0
  236. package/scripts/lib/token-cost-capture.js +187 -0
  237. package/scripts/lib/token-cost-intelligence.js +358 -0
  238. package/scripts/lib/token-efficiency-evidence.js +213 -0
  239. package/scripts/lib/token-evidence.js +699 -0
  240. package/scripts/lib/tokenish.js +17 -0
  241. package/scripts/lib/tool-output-sandbox.js +304 -0
  242. package/scripts/lib/trust-audit.js +136 -0
  243. package/scripts/lib/unified-events.js +396 -0
  244. package/scripts/lib/upgrade-interruption-recovery.js +407 -0
  245. package/scripts/lib/usage-ledger.js +201 -0
  246. package/scripts/lib/value-ledger.js +130 -0
  247. package/scripts/lib/value-proof-calibration.js +531 -0
  248. package/scripts/lib/visual-qa.js +231 -0
  249. package/scripts/lib/voice-alpha.js +29 -0
  250. package/scripts/lib/work-aware-orchestration.js +976 -0
  251. package/scripts/lib/work-control-receipts.js +577 -0
  252. package/scripts/lib/work-ledger.js +1123 -0
  253. package/scripts/lib/work-panel-preview.js +352 -0
  254. package/scripts/lib/workflow-discipline.js +280 -0
  255. package/scripts/lib/workflow-signals.js +419 -0
  256. package/scripts/lib/workspace-map.js +281 -0
  257. package/scripts/lib/workspace-registry.js +1367 -0
  258. package/scripts/lib/workspace-resolver.js +480 -0
@@ -0,0 +1,520 @@
1
+ "use strict";
2
+
3
+ // ── Alpha Activation ─────────────────────────────────────────────────────────
4
+ //
5
+ // Contract: avorelo.alphaActivation.v1
6
+ //
7
+ // Builds the first-run activation surface for a new user.
8
+ // Reads existing surfaces (hooks, run, proof, ledger, feedback, support) and
9
+ // aggregates them into a compact first-value view.
10
+ //
11
+ // Rules:
12
+ // - No network calls, no cloud telemetry, no secrets
13
+ // - No automatic hook apply (explicit user approval required)
14
+ // - No deploy/destructive execution
15
+ // - Default output is compact; debug exposes internals
16
+
17
+ const fs = require("fs");
18
+ const path = require("path");
19
+ const { ensureCcoDirs, nowIso } = require("./fsx");
20
+ const { appendProductLearningEvent } = require("./product-learning-events");
21
+
22
+ const CONTRACT = "avorelo.alphaActivation.v1";
23
+ const SCHEMA_VERSION = 1;
24
+
25
+ const RECEIPT_REL = ".claude/cco/orchestration/activation/latest-activation.json";
26
+ const RECEIPT_DIR_REL = ".claude/cco/orchestration/activation";
27
+
28
+ // ── Helpers ───────────────────────────────────────────────────────────────────
29
+
30
+ // The avorelo installation root (where scripts/lib lives)
31
+ const AVORELO_ROOT = path.resolve(__dirname, "../../");
32
+
33
+ function safeReadJson(absPath) {
34
+ try {
35
+ if (!fs.existsSync(absPath)) return null;
36
+ return JSON.parse(fs.readFileSync(absPath, "utf8").replace(/^/, ""));
37
+ } catch {
38
+ return null;
39
+ }
40
+ }
41
+
42
+ function safeReadJsonRel(cwd, rel) {
43
+ return safeReadJson(path.join(cwd, rel));
44
+ }
45
+
46
+ // Check if an avorelo module exists (installed in AVORELO_ROOT, not target project)
47
+ function avorModuleExists(rel) {
48
+ return fs.existsSync(path.join(AVORELO_ROOT, rel));
49
+ }
50
+
51
+ // ── Check: project profile ────────────────────────────────────────────────────
52
+
53
+ function checkProjectProfile(cwd) {
54
+ const profile = safeReadJsonRel(cwd, ".claude/cco/orchestration/project-profile/latest-profile.json");
55
+ if (!profile) {
56
+ return { id: "project_profile", status: "warn", message: "No project profile found. Run `avorelo project-profile --json` to create one." };
57
+ }
58
+ return { id: "project_profile", status: "pass", message: `Project profile detected (${profile.projectType || "unknown"} / ${profile.riskLevel || "unknown"} risk).` };
59
+ }
60
+
61
+ // ── Check: safe run ───────────────────────────────────────────────────────────
62
+
63
+ function checkSafeRun(cwd) {
64
+ const hasBin = avorModuleExists("bin/avorelo") || avorModuleExists("bin/avorelo.js");
65
+ if (!hasBin) {
66
+ return { id: "safe_run", status: "fail", message: "Avorelo binary not found. Run `npm install` or check bin/avorelo." };
67
+ }
68
+ const hasModule = avorModuleExists("scripts/lib/safe-run-controller.js");
69
+ if (!hasModule) {
70
+ return { id: "safe_run", status: "fail", message: "safe-run-controller.js not found." };
71
+ }
72
+ return { id: "safe_run", status: "pass", message: "Safe run available." };
73
+ }
74
+
75
+ // ── Check: smart route ────────────────────────────────────────────────────────
76
+
77
+ function checkSmartRoute(cwd) {
78
+ if (!avorModuleExists("scripts/lib/smart-work-routing.js")) {
79
+ return { id: "smart_route", status: "fail", message: "smart-work-routing.js not found." };
80
+ }
81
+ return { id: "smart_route", status: "pass", message: "Smart route available." };
82
+ }
83
+
84
+ // ── Check: hooks ─────────────────────────────────────────────────────────────
85
+
86
+ function checkHooks(cwd) {
87
+ const baselinePath = path.join(cwd, ".claude/cco/orchestration/hook-baseline/latest-baseline.json");
88
+ const applyPath = path.join(cwd, ".claude/cco/orchestration/hook-apply/latest-apply.json");
89
+ const doctorPath = path.join(cwd, ".claude/cco/orchestration/hook-apply/latest-doctor.json");
90
+
91
+ const baseline = safeReadJson(baselinePath);
92
+ const apply = safeReadJson(applyPath);
93
+ const doctor = safeReadJson(doctorPath);
94
+
95
+ const hookModExists = avorModuleExists("scripts/lib/hook-apply.js");
96
+
97
+ if (!hookModExists) {
98
+ return {
99
+ id: "hook_status",
100
+ status: "fail",
101
+ message: "hook-apply.js not found.",
102
+ applied: false,
103
+ doctorPass: false,
104
+ nextAction: "Check hook-apply.js exists."
105
+ };
106
+ }
107
+
108
+ const applied = apply && apply.hooksApplied === true;
109
+ const doctorPass = doctor && (doctor.summary && doctor.summary.fail === 0);
110
+
111
+ if (!baseline) {
112
+ return {
113
+ id: "hook_status",
114
+ status: "warn",
115
+ message: "Hook baseline not generated. Run `avorelo hooks --json` to generate baseline.",
116
+ applied: false,
117
+ doctorPass: false,
118
+ nextAction: "Run: avorelo hooks --json"
119
+ };
120
+ }
121
+
122
+ if (!applied) {
123
+ return {
124
+ id: "hook_status",
125
+ status: "warn",
126
+ message: "Hooks not yet applied. Run `avorelo hooks apply --dry-run` to preview, then `--yes` to apply with approval.",
127
+ applied: false,
128
+ doctorPass: doctorPass || false,
129
+ nextAction: "Run: avorelo hooks apply --dry-run"
130
+ };
131
+ }
132
+
133
+ return {
134
+ id: "hook_status",
135
+ status: "pass",
136
+ message: `Hooks applied. Doctor: ${doctorPass ? "pass" : "warn"}.`,
137
+ applied: true,
138
+ doctorPass: doctorPass || false,
139
+ nextAction: null
140
+ };
141
+ }
142
+
143
+ // ── Check: proof ─────────────────────────────────────────────────────────────
144
+
145
+ function checkProof(cwd) {
146
+ const hasProofMod = avorModuleExists("scripts/lib/seamless-reality-gate.js");
147
+
148
+ const existingPaths = [
149
+ ".claude/cco/orchestration/seamless-outcome/latest-reality-gate.json",
150
+ ".claude/cco/orchestration/seamless-outcome/latest-value-summary.json",
151
+ ];
152
+ const anyExists = existingPaths.some((rel) => fs.existsSync(path.join(cwd, rel)));
153
+
154
+ if (!hasProofMod) {
155
+ return { id: "proof_status", status: "fail", message: "seamless-reality-gate.js not found." };
156
+ }
157
+ if (!anyExists) {
158
+ return { id: "proof_status", status: "warn", message: "No proof artifacts yet. Run `avorelo proof` to generate.", nextAction: "Run: avorelo proof" };
159
+ }
160
+ return { id: "proof_status", status: "pass", message: "Proof artifacts available." };
161
+ }
162
+
163
+ // ── Check: feedback ───────────────────────────────────────────────────────────
164
+
165
+ function checkFeedback(cwd) {
166
+ const feedbackDir = path.join(cwd, ".claude/cco/feedback");
167
+ const hasModule = avorModuleExists("scripts/lib/alpha-feedback.js");
168
+ const hasDir = fs.existsSync(feedbackDir);
169
+
170
+ if (!hasModule) {
171
+ return { id: "feedback_status", status: "warn", message: "Feedback capture not available.", nextAction: "Add alpha-feedback.js" };
172
+ }
173
+
174
+ let count = 0;
175
+ if (hasDir) {
176
+ try {
177
+ count = fs.readdirSync(feedbackDir).filter((f) => f.endsWith(".json")).length;
178
+ } catch {}
179
+ }
180
+ return {
181
+ id: "feedback_status",
182
+ status: "pass",
183
+ message: `Feedback capture available. ${count} feedback item(s).`,
184
+ feedbackCount: count,
185
+ nextAction: count === 0 ? "Run: avorelo feedback add --source dogfood --summary \"...\"" : null
186
+ };
187
+ }
188
+
189
+ // ── Check: token efficiency ───────────────────────────────────────────────────
190
+
191
+ function checkTokenEfficiency(cwd) {
192
+ const evidencePath = path.join(cwd, ".claude/cco/orchestration/token-efficiency/latest-evidence.json");
193
+ const qualityGatePath = path.join(cwd, ".claude/cco/orchestration/token-efficiency/latest-quality-gate.json");
194
+ const hasEvidence = fs.existsSync(evidencePath);
195
+ const hasGate = fs.existsSync(qualityGatePath);
196
+ const hasModule = avorModuleExists("scripts/lib/token-efficiency-evidence.js");
197
+
198
+ if (!hasModule) {
199
+ return { id: "token_efficiency_status", status: "warn", message: "Token efficiency hardening not available.", nextAction: "Token efficiency is part of PR #143." };
200
+ }
201
+ if (!hasEvidence && !hasGate) {
202
+ return {
203
+ id: "token_efficiency_status",
204
+ status: "warn",
205
+ message: "Token efficiency evidence not yet generated. Run a task to generate.",
206
+ nextAction: "Run: avorelo run \"<task>\" --prepare-only --json"
207
+ };
208
+ }
209
+ let verdict = null;
210
+ if (hasGate) {
211
+ try {
212
+ const gate = JSON.parse(fs.readFileSync(qualityGatePath, "utf8"));
213
+ verdict = gate.verdict;
214
+ if (gate.status === "fail") {
215
+ return { id: "token_efficiency_status", status: "warn", message: `Token context quality gate: ${gate.verdict}. Review: ${gate.nextAction}`, verdict };
216
+ }
217
+ } catch {}
218
+ }
219
+ return {
220
+ id: "token_efficiency_status",
221
+ status: "pass",
222
+ message: `Token efficiency hardening active.${verdict ? ` Quality gate: ${verdict}.` : ""}`,
223
+ verdict: verdict || null,
224
+ nextAction: null
225
+ };
226
+ }
227
+
228
+ // ── Check: support bundle ─────────────────────────────────────────────────────
229
+
230
+ function checkSupportBundle(cwd) {
231
+ const bundlePath = path.join(cwd, ".claude/cco/support/latest-support-bundle.json");
232
+ const hasModule = avorModuleExists("scripts/lib/support-bundle.js");
233
+ const hasBundle = fs.existsSync(bundlePath);
234
+
235
+ if (!hasModule) {
236
+ return { id: "support_status", status: "warn", message: "Support bundle not available.", nextAction: "Add support-bundle.js" };
237
+ }
238
+ return {
239
+ id: "support_status",
240
+ status: hasBundle ? "pass" : "warn",
241
+ message: hasBundle ? "Support bundle available (redacted)." : "Support bundle module available. Run `avorelo support-bundle` to generate.",
242
+ nextAction: hasBundle ? null : "Run: avorelo support-bundle --json"
243
+ };
244
+ }
245
+
246
+ // ── First-value path selection ─────────────────────────────────────────────────
247
+
248
+ function buildFirstValuePath(cwd, checks) {
249
+ const hookCheck = checks.find((c) => c.id === "hook_status") || {};
250
+ const profileCheck = checks.find((c) => c.id === "project_profile") || {};
251
+ const proofCheck = checks.find((c) => c.id === "proof_status") || {};
252
+ const safeRunCheck = checks.find((c) => c.id === "safe_run") || {};
253
+
254
+ // Priority: hooks not applied → guide hook apply (low risk, high value)
255
+ if (hookCheck.status === "warn" && !hookCheck.applied) {
256
+ return {
257
+ type: "hook_readiness",
258
+ label: "Preview and apply lifecycle hooks",
259
+ command: "avorelo hooks apply --dry-run",
260
+ why: "Hook lifecycle automation reduces manual oversight. Dry-run first, apply with --yes after review.",
261
+ riskLevel: "low",
262
+ manualStepsAvoided: 1,
263
+ proofPrepared: false,
264
+ proofRun: false,
265
+ riskBlocked: false,
266
+ caveats: ["Requires explicit --yes to apply. No auto-apply."]
267
+ };
268
+ }
269
+
270
+ // Profile missing → safe project inspection
271
+ if (profileCheck.status !== "pass") {
272
+ return {
273
+ type: "project_inspection",
274
+ label: "Generate project profile",
275
+ command: "avorelo project-profile --json",
276
+ why: "Understanding project type, risk level, and safe boundaries before first run.",
277
+ riskLevel: "low",
278
+ manualStepsAvoided: 1,
279
+ proofPrepared: false,
280
+ proofRun: false,
281
+ riskBlocked: false,
282
+ caveats: []
283
+ };
284
+ }
285
+
286
+ // Proof missing → run proof
287
+ if (proofCheck.status === "warn") {
288
+ return {
289
+ type: "proof_generation",
290
+ label: "Generate safety and outcome proof",
291
+ command: "avorelo proof",
292
+ why: "Proof shows current safety posture and outcome state. Low risk, high clarity.",
293
+ riskLevel: "low",
294
+ manualStepsAvoided: 1,
295
+ proofPrepared: true,
296
+ proofRun: false,
297
+ riskBlocked: false,
298
+ caveats: []
299
+ };
300
+ }
301
+
302
+ // Safe run prepare-only
303
+ if (safeRunCheck.status === "pass") {
304
+ return {
305
+ type: "safe_run_prepare",
306
+ label: "Prepare a safe run for a task",
307
+ command: "avorelo run \"<your task description>\" --prepare-only",
308
+ why: "Builds smart route, execution packet, and worker handoff without executing. Shows what Avorelo would do.",
309
+ riskLevel: "low",
310
+ manualStepsAvoided: 2,
311
+ proofPrepared: true,
312
+ proofRun: false,
313
+ riskBlocked: false,
314
+ caveats: ["Use --prepare-only to inspect before running"]
315
+ };
316
+ }
317
+
318
+ // Fallback: status check
319
+ return {
320
+ type: "status_check",
321
+ label: "Check current Avorelo status",
322
+ command: "avorelo status --json",
323
+ why: "Understand current project state before taking any action.",
324
+ riskLevel: "low",
325
+ manualStepsAvoided: 0,
326
+ proofPrepared: false,
327
+ proofRun: false,
328
+ riskBlocked: false,
329
+ caveats: []
330
+ };
331
+ }
332
+
333
+ // ── Activation stage ──────────────────────────────────────────────────────────
334
+
335
+ function computeActivationStage(checks, firstValuePath) {
336
+ const allPass = checks.every((c) => c.status === "pass");
337
+ const anyFail = checks.some((c) => c.status === "fail");
338
+ const hasFeedback = checks.find((c) => c.id === "feedback_status" && c.feedbackCount > 0);
339
+
340
+ if (anyFail) return "not_started";
341
+ if (!allPass) return "checked";
342
+ if (hasFeedback) return "feedback_ready";
343
+ if (firstValuePath.type !== "status_check") return "first_value_ready";
344
+ return "checked";
345
+ }
346
+
347
+ // ── Status rollup ─────────────────────────────────────────────────────────────
348
+
349
+ function computeStatus(checks) {
350
+ if (checks.some((c) => c.status === "fail")) return "blocked";
351
+ if (checks.some((c) => c.status === "warn")) return "partial";
352
+ return "ready";
353
+ }
354
+
355
+ // ── Next action ───────────────────────────────────────────────────────────────
356
+
357
+ function computeNextAction(status, checks, firstValuePath, hookCheck) {
358
+ if (status === "blocked") {
359
+ const failCheck = checks.find((c) => c.status === "fail");
360
+ return `Fix: ${failCheck ? failCheck.message : "see checks above"}`;
361
+ }
362
+ if (firstValuePath) {
363
+ return `Run: ${firstValuePath.command}`;
364
+ }
365
+ return "Run: avorelo status --json";
366
+ }
367
+
368
+ // ── Build activation plan ─────────────────────────────────────────────────────
369
+
370
+ function buildActivationPlan(cwd, options = {}) {
371
+ const checks = [
372
+ checkProjectProfile(cwd),
373
+ checkSafeRun(cwd),
374
+ checkSmartRoute(cwd),
375
+ checkHooks(cwd),
376
+ checkProof(cwd),
377
+ checkFeedback(cwd),
378
+ checkSupportBundle(cwd),
379
+ checkTokenEfficiency(cwd),
380
+ ];
381
+
382
+ const hookCheck = checks.find((c) => c.id === "hook_status") || {};
383
+ const status = computeStatus(checks);
384
+ const firstValuePath = buildFirstValuePath(cwd, checks);
385
+ const activationStage = computeActivationStage(checks, firstValuePath);
386
+ const nextAction = computeNextAction(status, checks, firstValuePath, hookCheck);
387
+
388
+ return {
389
+ contract: CONTRACT,
390
+ schemaVersion: SCHEMA_VERSION,
391
+ status,
392
+ activationStage,
393
+ checks,
394
+ firstValuePath,
395
+ hookStatus: {
396
+ applied: hookCheck.applied || false,
397
+ doctorPass: hookCheck.doctorPass || false,
398
+ nextAction: hookCheck.nextAction || null
399
+ },
400
+ proofStatus: {
401
+ available: checks.find((c) => c.id === "proof_status")?.status === "pass",
402
+ },
403
+ feedbackStatus: {
404
+ available: checks.find((c) => c.id === "feedback_status")?.status === "pass",
405
+ count: checks.find((c) => c.id === "feedback_status")?.feedbackCount || 0,
406
+ },
407
+ supportStatus: {
408
+ available: checks.find((c) => c.id === "support_status")?.status === "pass",
409
+ },
410
+ tokenEfficiencyStatus: {
411
+ available: checks.find((c) => c.id === "token_efficiency_status")?.status === "pass",
412
+ verdict: checks.find((c) => c.id === "token_efficiency_status")?.verdict || null,
413
+ },
414
+ nextAction,
415
+ redacted: true,
416
+ };
417
+ }
418
+
419
+ // ── Run activation check ──────────────────────────────────────────────────────
420
+
421
+ function runActivationCheck(cwd, options = {}) {
422
+ const plan = buildActivationPlan(cwd, options);
423
+ return plan;
424
+ }
425
+
426
+ // ── Write activation receipt ──────────────────────────────────────────────────
427
+
428
+ function writeActivationReceipt(cwd, receipt) {
429
+ try {
430
+ ensureCcoDirs(cwd);
431
+ const dirAbs = path.join(cwd, RECEIPT_DIR_REL);
432
+ if (!fs.existsSync(dirAbs)) fs.mkdirSync(dirAbs, { recursive: true });
433
+ const receiptAbs = path.join(cwd, RECEIPT_REL);
434
+ fs.writeFileSync(receiptAbs, JSON.stringify(receipt, null, 2), "utf8");
435
+ return receiptAbs;
436
+ } catch {
437
+ return null;
438
+ }
439
+ }
440
+
441
+ // ── Build activation surface ──────────────────────────────────────────────────
442
+
443
+ function buildActivationSurface(cwd, options = {}) {
444
+ const receipt = runActivationCheck(cwd, options);
445
+ const written = writeActivationReceipt(cwd, receipt);
446
+
447
+ try {
448
+ appendProductLearningEvent(cwd, {
449
+ eventName: "alpha_activation_checked",
450
+ status: receipt.status,
451
+ activationStage: receipt.activationStage,
452
+ });
453
+ } catch {}
454
+
455
+ return { ...receipt, artifactPath: written ? RECEIPT_REL : null };
456
+ }
457
+
458
+ // ── Format compact text ───────────────────────────────────────────────────────
459
+
460
+ function formatActivationText(receipt, options = {}) {
461
+ const lines = [];
462
+ const status = receipt.status || "unknown";
463
+ const statusLabel = status === "ready" ? "ready" : status === "partial" ? "partial" : "blocked";
464
+
465
+ lines.push(`Avorelo activation: ${statusLabel}`);
466
+ lines.push("");
467
+
468
+ // Checks summary
469
+ const pass = receipt.checks ? receipt.checks.filter((c) => c.status === "pass").length : 0;
470
+ const warn = receipt.checks ? receipt.checks.filter((c) => c.status === "warn").length : 0;
471
+ const fail = receipt.checks ? receipt.checks.filter((c) => c.status === "fail").length : 0;
472
+ lines.push(`Checks: ${pass} pass ${warn} warn ${fail} fail`);
473
+
474
+ // Readiness
475
+ lines.push("");
476
+ lines.push("Ready:");
477
+ if (receipt.checks) {
478
+ receipt.checks.filter((c) => c.status === "pass").forEach((c) => {
479
+ lines.push(` + ${c.message}`);
480
+ });
481
+ receipt.checks.filter((c) => c.status !== "pass").forEach((c) => {
482
+ const icon = c.status === "fail" ? "✗" : "~";
483
+ lines.push(` ${icon} ${c.message}`);
484
+ });
485
+ }
486
+
487
+ // First value
488
+ if (receipt.firstValuePath) {
489
+ const fv = receipt.firstValuePath;
490
+ lines.push("");
491
+ lines.push("First value:");
492
+ lines.push(` Run: ${fv.command}`);
493
+ if (fv.why) lines.push(` Why: ${fv.why}`);
494
+ }
495
+
496
+ // Protected
497
+ lines.push("");
498
+ lines.push("Protected:");
499
+ lines.push(" Deploy/destructive/secrets blocked by PreToolUse guard.");
500
+ if (!receipt.hookStatus?.applied) {
501
+ lines.push(" Hooks not yet applied — no lifecycle automation until you approve.");
502
+ }
503
+
504
+ // Next
505
+ lines.push("");
506
+ lines.push(`Next: ${receipt.nextAction || "Run: avorelo status --json"}`);
507
+
508
+ return lines.join("\n");
509
+ }
510
+
511
+ module.exports = {
512
+ CONTRACT,
513
+ SCHEMA_VERSION,
514
+ RECEIPT_REL,
515
+ buildActivationPlan,
516
+ runActivationCheck,
517
+ writeActivationReceipt,
518
+ buildActivationSurface,
519
+ formatActivationText,
520
+ };