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,288 @@
1
+ "use strict";
2
+
3
+ // ── AI Install Prompt ─────────────────────────────────────────────────────────
4
+ //
5
+ // Contract: avorelo.aiInstallPrompt.v1
6
+ //
7
+ // Generates a safe, copy-pasteable one-prompt AI install experience.
8
+ // Inspired by PostHog install-with-AI pattern, adapted for Avorelo's
9
+ // approval-boundary requirements (hooks/MCP/tool governance require
10
+ // explicit user approval — never auto-applied).
11
+ //
12
+ // Rules:
13
+ // - Prompt never includes raw secrets, repo-specific sensitive data, or PII
14
+ // - Hook apply always requires explicit --yes approval from user
15
+ // - MCP config is never auto-modified
16
+ // - Global config is never modified
17
+ // - AI must stop on blockers and request explicit approval for config changes
18
+ // - Default output is compact; debug exposes internals
19
+
20
+ const fs = require("fs");
21
+ const path = require("path");
22
+ const { ensureCcoDirs, nowIso } = require("./fsx");
23
+ const { appendProductLearningEvent } = require("./product-learning-events");
24
+
25
+ const CONTRACT = "avorelo.aiInstallPrompt.v1";
26
+ const SCHEMA_VERSION = 1;
27
+
28
+ const PROMPT_DIR_REL = ".claude/cco/orchestration/ai-install";
29
+ const LATEST_PROMPT_REL = `${PROMPT_DIR_REL}/latest-prompt.json`;
30
+
31
+ // ── Helpers ───────────────────────────────────────────────────────────────────
32
+
33
+ const AVORELO_ROOT = path.resolve(__dirname, "../../");
34
+
35
+ function safeReadJson(absPath) {
36
+ try {
37
+ if (!fs.existsSync(absPath)) return null;
38
+ return JSON.parse(fs.readFileSync(absPath, "utf8").replace(/^/, ""));
39
+ } catch {
40
+ return null;
41
+ }
42
+ }
43
+
44
+ function safeReadJsonRel(cwd, rel) {
45
+ return safeReadJson(path.join(cwd, rel));
46
+ }
47
+
48
+ // ── Command sequence ──────────────────────────────────────────────────────────
49
+
50
+ function buildCommandSequence() {
51
+ return [
52
+ { step: 1, cmd: "node bin/avorelo activate --json", purpose: "Detect project and run activation checks" },
53
+ { step: 2, cmd: "node bin/avorelo alpha-readiness --json", purpose: "Verify first-value readiness gate" },
54
+ { step: 3, cmd: "node bin/avorelo launch-hardening --json", purpose: "Check launch hardening status" },
55
+ { step: 4, cmd: "node bin/avorelo token-efficiency --json", purpose: "Check token/context efficiency" },
56
+ { step: 5, cmd: "node bin/avorelo mcp doctor --json", purpose: "Check MCP/tool governance" },
57
+ { step: 6, cmd: "node bin/avorelo hooks doctor --json", purpose: "Check hook lifecycle status" },
58
+ { step: 7, cmd: "node bin/avorelo run \"<task>\" --prepare-only --json", purpose: "Run first safe value path (prepare only)" },
59
+ { step: 8, cmd: "node bin/avorelo support-bundle --json", purpose: "Generate support bundle if needed" },
60
+ { step: 9, cmd: "node bin/avorelo prelaunch-readiness --json", purpose: "Run full pre-launch activation readiness gate" },
61
+ { step: 10, cmd: "node bin/avorelo proof", purpose: "Show compact value summary" },
62
+ ];
63
+ }
64
+
65
+ // ── Approval boundaries ───────────────────────────────────────────────────────
66
+
67
+ function buildApprovalBoundaries() {
68
+ return [
69
+ {
70
+ surface: "hooks",
71
+ rule: "NEVER run `avorelo hooks apply --yes` without explicit user approval. Always show dry-run preview first.",
72
+ command: "node bin/avorelo hooks apply --dry-run",
73
+ approvalCommand: "node bin/avorelo hooks apply --yes",
74
+ },
75
+ {
76
+ surface: "mcp_config",
77
+ rule: "NEVER modify MCP config automatically. MCP governance is preview-only in this flow.",
78
+ command: null,
79
+ approvalCommand: null,
80
+ },
81
+ {
82
+ surface: "global_config",
83
+ rule: "NEVER modify global config files (e.g., ~/.claude/settings.json) without explicit user instruction.",
84
+ command: null,
85
+ approvalCommand: null,
86
+ },
87
+ {
88
+ surface: "destructive_commands",
89
+ rule: "NEVER run deploy, publish, rm -rf, database migrations, or production commands.",
90
+ command: null,
91
+ approvalCommand: null,
92
+ },
93
+ ];
94
+ }
95
+
96
+ // ── Safety rules ──────────────────────────────────────────────────────────────
97
+
98
+ function buildSafetyRules() {
99
+ return [
100
+ "Do not write product code before activation readiness checks complete.",
101
+ "Stop immediately if any command returns status: fail — show the safeNextAction and wait.",
102
+ "Do not bypass, skip, or override any approval boundary.",
103
+ "Do not expose, log, or include secrets, API keys, tokens, or PII in any output.",
104
+ "Do not run --yes on hook apply without the user reading the dry-run preview.",
105
+ "Do not modify global config or MCP server config.",
106
+ "Keep all output compact. Use --debug only if the user requests diagnostics.",
107
+ "The value summary must be evidence-backed — no exact cost savings claims.",
108
+ ];
109
+ }
110
+
111
+ // ── Prompt text ───────────────────────────────────────────────────────────────
112
+
113
+ function buildPromptText(commandSequence, approvalBoundaries, safetyRules) {
114
+ const steps = commandSequence.map((s) => ` ${s.step}. ${s.cmd}\n # ${s.purpose}`).join("\n");
115
+ const boundaries = approvalBoundaries.map((b) => ` - ${b.surface}: ${b.rule}`).join("\n");
116
+ const rules = safetyRules.map((r) => ` - ${r}`).join("\n");
117
+
118
+ return `You are helping install and activate Avorelo in this repo.
119
+
120
+ Follow these steps in order. Stop on any failure and show the safeNextAction.
121
+
122
+ Steps:
123
+ ${steps}
124
+
125
+ Approval boundaries (NEVER bypass these):
126
+ ${boundaries}
127
+
128
+ Safety rules:
129
+ ${rules}
130
+
131
+ After all steps complete, return a compact value summary:
132
+ - What Avorelo checked automatically
133
+ - Activation and readiness status
134
+ - Hook and MCP governance status
135
+ - Token/context efficiency status
136
+ - Support bundle status
137
+ - One safe next action
138
+
139
+ Do not claim public launch readiness. Do not claim exact/guaranteed savings.
140
+ Output must be compact by default. Use --debug flags only if the user asks for details.`;
141
+ }
142
+
143
+ // ── Expected outputs ──────────────────────────────────────────────────────────
144
+
145
+ function buildExpectedOutputs() {
146
+ return [
147
+ { step: "activate", shape: "avorelo.alphaActivation.v1", keyField: "status" },
148
+ { step: "alpha-readiness", shape: "avorelo.alphaReadinessGate.v1", keyField: "status" },
149
+ { step: "launch-hardening", shape: "avorelo.launchHardeningGate.v1", keyField: "status" },
150
+ { step: "token-efficiency", shape: "evidence.contract", keyField: "status" },
151
+ { step: "mcp doctor", shape: "mcp governance summary", keyField: "policy.status" },
152
+ { step: "hooks doctor", shape: "avorelo.hookApply.v1", keyField: "status" },
153
+ { step: "prelaunch-readiness", shape: "avorelo.prelaunchActivationReadiness.v1", keyField: "status" },
154
+ { step: "proof", shape: "compact proof output", keyField: "summary" },
155
+ ];
156
+ }
157
+
158
+ // ── Build prompt receipt ──────────────────────────────────────────────────────
159
+
160
+ function buildAiInstallPrompt(cwd, options = {}) {
161
+ const commandSequence = buildCommandSequence();
162
+ const approvalBoundaries = buildApprovalBoundaries();
163
+ const safetyRules = buildSafetyRules();
164
+ const promptText = buildPromptText(commandSequence, approvalBoundaries, safetyRules);
165
+ const expectedOutputs = buildExpectedOutputs();
166
+
167
+ // Check if activation module is available
168
+ let activationAvailable = false;
169
+ try {
170
+ require("./alpha-activation");
171
+ activationAvailable = true;
172
+ } catch {}
173
+
174
+ // Check if prelaunch readiness module is available
175
+ let prelaunchAvailable = false;
176
+ try {
177
+ require("./prelaunch-activation-readiness");
178
+ prelaunchAvailable = true;
179
+ } catch {}
180
+
181
+ const status = activationAvailable ? "ready" : "partial";
182
+
183
+ const receipt = {
184
+ contract: CONTRACT,
185
+ schemaVersion: SCHEMA_VERSION,
186
+ createdAt: nowIso(),
187
+ status,
188
+ promptText,
189
+ commandSequence,
190
+ approvalBoundaries,
191
+ safetyRules,
192
+ expectedOutputs,
193
+ nextAction: "Copy the promptText and paste it into Claude Code, Codex, Cursor, VS Code, or your AI coding agent.",
194
+ activationAvailable,
195
+ prelaunchAvailable,
196
+ redacted: true,
197
+ };
198
+
199
+ try {
200
+ appendProductLearningEvent(cwd, {
201
+ eventName: "ai_install_prompt_generated",
202
+ status: receipt.status,
203
+ activationAvailable,
204
+ prelaunchAvailable,
205
+ });
206
+ } catch {}
207
+
208
+ return receipt;
209
+ }
210
+
211
+ // ── Build install plan (metadata without full prompt text) ────────────────────
212
+
213
+ function buildAiInstallPlan(cwd, options = {}) {
214
+ return {
215
+ contract: CONTRACT,
216
+ schemaVersion: SCHEMA_VERSION,
217
+ createdAt: nowIso(),
218
+ stepCount: buildCommandSequence().length,
219
+ approvalBoundaryCount: buildApprovalBoundaries().length,
220
+ safetyRuleCount: buildSafetyRules().length,
221
+ summary: "One-prompt AI install: activate → readiness → launch-hardening → token/context → mcp → hooks → first-value → support → prelaunch-readiness → proof",
222
+ safeForAutoRun: false,
223
+ requiresExplicitApproval: ["hooks apply", "mcp config changes", "global config changes"],
224
+ redacted: true,
225
+ };
226
+ }
227
+
228
+ // ── Artifact I/O ──────────────────────────────────────────────────────────────
229
+
230
+ function writeAiInstallPromptReceipt(cwd, receipt) {
231
+ const dir = path.join(cwd, PROMPT_DIR_REL);
232
+ fs.mkdirSync(dir, { recursive: true });
233
+ const latest = path.join(cwd, LATEST_PROMPT_REL);
234
+ // Never write raw secrets. Receipt has redacted:true.
235
+ // Strip promptText from the stored artifact (keep it in-memory only) to avoid
236
+ // accidentally committing repo-sensitive context.
237
+ const stored = Object.assign({}, receipt, { promptText: "[see formatAiInstallPromptText]" });
238
+ fs.writeFileSync(latest, JSON.stringify(stored, null, 2), "utf8");
239
+ return latest;
240
+ }
241
+
242
+ // ── Surface / format ──────────────────────────────────────────────────────────
243
+
244
+ function buildAiInstallPromptSurface(cwd, options = {}) {
245
+ const receipt = buildAiInstallPrompt(cwd, options);
246
+ return { receipt };
247
+ }
248
+
249
+ function formatAiInstallPromptText(receipt, options = {}) {
250
+ const lines = [
251
+ `Install Avorelo with AI`,
252
+ ``,
253
+ `Copy this prompt into Claude Code, Codex, Cursor, VS Code, or your AI coding agent:`,
254
+ ``,
255
+ `─────────────────────────────────────────────────────────────`,
256
+ receipt.promptText,
257
+ `─────────────────────────────────────────────────────────────`,
258
+ ``,
259
+ `What it will do:`,
260
+ ` - Check project readiness.`,
261
+ ` - Run safe activation.`,
262
+ ` - Verify hooks and MCP/tool governance.`,
263
+ ` - Request approval before config changes.`,
264
+ ` - Run first-value verification.`,
265
+ ` - Produce a compact value summary.`,
266
+ ``,
267
+ `Next:`,
268
+ ` - Paste the prompt into your AI coding session.`,
269
+ ``,
270
+ `Note: Hook apply requires explicit approval. MCP config is not modified automatically.`,
271
+ ];
272
+ return lines.join("\n");
273
+ }
274
+
275
+ module.exports = {
276
+ buildAiInstallPrompt,
277
+ buildAiInstallPlan,
278
+ writeAiInstallPromptReceipt,
279
+ buildAiInstallPromptSurface,
280
+ formatAiInstallPromptText,
281
+ // exposed for testing
282
+ buildCommandSequence,
283
+ buildApprovalBoundaries,
284
+ buildSafetyRules,
285
+ buildPromptText,
286
+ CONTRACT,
287
+ LATEST_PROMPT_REL,
288
+ };