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.
- package/LICENSE +21 -0
- package/README.md +56 -0
- package/bin/avorelo +9 -0
- package/package.json +135 -0
- package/scripts/README.md +40 -0
- package/scripts/cco-dashboard.js +252 -0
- package/scripts/cco-status.js +430 -0
- package/scripts/lib/activation/account-state.js +37 -0
- package/scripts/lib/activation/activation-runner.js +546 -0
- package/scripts/lib/activation/activation-self-healing.js +480 -0
- package/scripts/lib/activation/activation-state.js +83 -0
- package/scripts/lib/activation/activation-summary.js +191 -0
- package/scripts/lib/activation/adapters/claude-code.js +77 -0
- package/scripts/lib/activation/adapters/codex-cli.js +52 -0
- package/scripts/lib/activation/adapters/cursor.js +37 -0
- package/scripts/lib/activation/adapters/github-agent.js +39 -0
- package/scripts/lib/activation/adapters/terminal.js +42 -0
- package/scripts/lib/activation/adapters/vscode.js +39 -0
- package/scripts/lib/activation/adapters/windsurf.js +37 -0
- package/scripts/lib/activation/ai-surface-detector.js +151 -0
- package/scripts/lib/activation/connect-account.js +145 -0
- package/scripts/lib/activation/detect-environment.js +75 -0
- package/scripts/lib/activation/detect-hosts.js +62 -0
- package/scripts/lib/activation/format-activation-output.js +109 -0
- package/scripts/lib/activation/next-action.js +43 -0
- package/scripts/lib/activation/repair-engine.js +219 -0
- package/scripts/lib/activation-distribution-readiness.js +507 -0
- package/scripts/lib/adapter-conformance.js +176 -0
- package/scripts/lib/adapter-readiness.js +417 -0
- package/scripts/lib/adapter-safety-boundaries.js +335 -0
- package/scripts/lib/adapter-technical-readiness-gate.js +205 -0
- package/scripts/lib/agent-access-governance.js +455 -0
- package/scripts/lib/agent-enforcement.js +765 -0
- package/scripts/lib/agent-policy-profile.js +210 -0
- package/scripts/lib/agent-security/action-evaluator.js +507 -0
- package/scripts/lib/agent-security/adapter-registry.js +98 -0
- package/scripts/lib/agent-security/auto-policy.js +139 -0
- package/scripts/lib/agent-security/bounded-scan.js +93 -0
- package/scripts/lib/agent-security/enforcement-adapter.js +174 -0
- package/scripts/lib/agent-security/enforcement-engine.js +1129 -0
- package/scripts/lib/agent-security/file-write-adapter.js +183 -0
- package/scripts/lib/agent-security/file-write-rules.js +178 -0
- package/scripts/lib/agent-security/index.js +3342 -0
- package/scripts/lib/agent-security/instruction-risk.js +181 -0
- package/scripts/lib/agent-security/mcp-action-adapter.js +185 -0
- package/scripts/lib/agent-security/mcp-action-rules.js +184 -0
- package/scripts/lib/agent-security/package-action-adapter.js +175 -0
- package/scripts/lib/agent-security/package-action-rules.js +233 -0
- package/scripts/lib/agent-security/performance.js +148 -0
- package/scripts/lib/agent-security/permission-minimizer.js +403 -0
- package/scripts/lib/agent-security/scan-cache.js +74 -0
- package/scripts/lib/agent-security/source-trust.js +146 -0
- package/scripts/lib/ai-install-prompt.js +288 -0
- package/scripts/lib/ai-workspace-hygiene.js +1499 -0
- package/scripts/lib/alpha-activation.js +520 -0
- package/scripts/lib/alpha-feedback.js +263 -0
- package/scripts/lib/alpha-readiness-gate.js +332 -0
- package/scripts/lib/anti-gaming.js +169 -0
- package/scripts/lib/artifact-health.js +431 -0
- package/scripts/lib/attribution.js +180 -0
- package/scripts/lib/audit.js +289 -0
- package/scripts/lib/avorelo-skill-registry.js +810 -0
- package/scripts/lib/batch-jobs.js +71 -0
- package/scripts/lib/brain-pack.js +578 -0
- package/scripts/lib/brand-boundary.js +424 -0
- package/scripts/lib/brand.js +74 -0
- package/scripts/lib/browser-capability.js +1048 -0
- package/scripts/lib/browser-proof-preflight.js +321 -0
- package/scripts/lib/cache-readiness.js +187 -0
- package/scripts/lib/canonical-reentry.js +162 -0
- package/scripts/lib/capability-packs.js +314 -0
- package/scripts/lib/capability-recommender.js +512 -0
- package/scripts/lib/capability-registry.js +1059 -0
- package/scripts/lib/carry-forward-surfacing.js +194 -0
- package/scripts/lib/ccusage-adapter.js +188 -0
- package/scripts/lib/company-loop.js +1149 -0
- package/scripts/lib/config.js +637 -0
- package/scripts/lib/context-acquisition-plan.js +287 -0
- package/scripts/lib/context-budget-guard.js +170 -0
- package/scripts/lib/context-budget-scanner.js +257 -0
- package/scripts/lib/context-optimizer.js +715 -0
- package/scripts/lib/context-reduction-plan.js +178 -0
- package/scripts/lib/context-safety.js +88 -0
- package/scripts/lib/context-savings-engine.js +158 -0
- package/scripts/lib/cost-evidence.js +254 -0
- package/scripts/lib/cross-host-install-plan.js +308 -0
- package/scripts/lib/cross-host-install-readiness.js +237 -0
- package/scripts/lib/cross-host-value-flow.js +268 -0
- package/scripts/lib/dashboard.js +900 -0
- package/scripts/lib/design-partner-feedback.js +346 -0
- package/scripts/lib/entitlements.js +100 -0
- package/scripts/lib/execution-packet.js +559 -0
- package/scripts/lib/experimentation-events.js +547 -0
- package/scripts/lib/external-capability-compliance.js +107 -0
- package/scripts/lib/external-user-simulation.js +166 -0
- package/scripts/lib/failure-recovery-readiness.js +81 -0
- package/scripts/lib/failure-recovery.js +419 -0
- package/scripts/lib/feedback-intelligence.js +537 -0
- package/scripts/lib/feedback-signals.js +205 -0
- package/scripts/lib/file-integrity.js +68 -0
- package/scripts/lib/fsx.js +127 -0
- package/scripts/lib/full-readiness-gate.js +451 -0
- package/scripts/lib/guidance-builder.js +174 -0
- package/scripts/lib/hook-apply.js +1019 -0
- package/scripts/lib/hook-baseline.js +310 -0
- package/scripts/lib/hook-config-preview.js +275 -0
- package/scripts/lib/hook-contracts.js +290 -0
- package/scripts/lib/hook-safety-boundary-readiness.js +80 -0
- package/scripts/lib/host-capability-matrix.js +351 -0
- package/scripts/lib/host-support-context.js +254 -0
- package/scripts/lib/http-hook-action.js +538 -0
- package/scripts/lib/install-ai-readiness.js +84 -0
- package/scripts/lib/install-intake-risk.js +1037 -0
- package/scripts/lib/install-journey-intelligence.js +329 -0
- package/scripts/lib/intervention-guidance.js +57 -0
- package/scripts/lib/known-limitations.js +115 -0
- package/scripts/lib/l8-path-truth.js +146 -0
- package/scripts/lib/launch-hardening-gate.js +436 -0
- package/scripts/lib/launch-readiness.js +628 -0
- package/scripts/lib/learning-memory.js +686 -0
- package/scripts/lib/lifecycle-hooks.js +802 -0
- package/scripts/lib/local-package-smoke.js +423 -0
- package/scripts/lib/local-pricing.js +299 -0
- package/scripts/lib/mcp-enforcement.js +311 -0
- package/scripts/lib/mcp-least-privilege-policy.js +303 -0
- package/scripts/lib/mcp-tool-inventory.js +388 -0
- package/scripts/lib/mcp-tool-risk.js +0 -0
- package/scripts/lib/memory.js +335 -0
- package/scripts/lib/metrics.js +699 -0
- package/scripts/lib/micro-proof.js +133 -0
- package/scripts/lib/next-run-context.js +436 -0
- package/scripts/lib/operating-value.js +1648 -0
- package/scripts/lib/optimization-v3.js +122 -0
- package/scripts/lib/orchestration/adapters/_shared.js +49 -0
- package/scripts/lib/orchestration/adapters/aider.js +18 -0
- package/scripts/lib/orchestration/adapters/claude-code.js +35 -0
- package/scripts/lib/orchestration/adapters/codex.js +35 -0
- package/scripts/lib/orchestration/adapters/gemini-cli.js +18 -0
- package/scripts/lib/orchestration/adapters/git.js +25 -0
- package/scripts/lib/orchestration/adapters/index.js +31 -0
- package/scripts/lib/orchestration/adapters/lm-studio.js +18 -0
- package/scripts/lib/orchestration/adapters/ollama.js +18 -0
- package/scripts/lib/orchestration/adapters/opencode.js +18 -0
- package/scripts/lib/orchestration/adapters/openrouter.js +18 -0
- package/scripts/lib/orchestration/adapters/test-runner.js +25 -0
- package/scripts/lib/orchestration/cli.js +438 -0
- package/scripts/lib/orchestration/execution-manager.js +279 -0
- package/scripts/lib/orchestration/handoff.js +314 -0
- package/scripts/lib/orchestration/index.js +456 -0
- package/scripts/lib/orchestration/inventory.js +47 -0
- package/scripts/lib/orchestration/model-discovery.js +498 -0
- package/scripts/lib/orchestration/model-profiler.js +170 -0
- package/scripts/lib/orchestration/model-profiles.js +252 -0
- package/scripts/lib/orchestration/model-refresh-policy.js +72 -0
- package/scripts/lib/orchestration/proof-writer.js +349 -0
- package/scripts/lib/orchestration/provider-discovery/aider.js +49 -0
- package/scripts/lib/orchestration/provider-discovery/claude-code.js +56 -0
- package/scripts/lib/orchestration/provider-discovery/codex.js +49 -0
- package/scripts/lib/orchestration/provider-discovery/common.js +186 -0
- package/scripts/lib/orchestration/provider-discovery/gemini.js +106 -0
- package/scripts/lib/orchestration/provider-discovery/lm-studio.js +118 -0
- package/scripts/lib/orchestration/provider-discovery/models-dev.js +12 -0
- package/scripts/lib/orchestration/provider-discovery/ollama.js +100 -0
- package/scripts/lib/orchestration/provider-discovery/opencode.js +47 -0
- package/scripts/lib/orchestration/provider-discovery/openrouter.js +44 -0
- package/scripts/lib/orchestration/risk-classifier.js +130 -0
- package/scripts/lib/orchestration/routing-policy.js +486 -0
- package/scripts/lib/orchestration/settings.js +112 -0
- package/scripts/lib/orchestration/state.js +165 -0
- package/scripts/lib/orchestration/verification-manager.js +138 -0
- package/scripts/lib/output-profiles.js +146 -0
- package/scripts/lib/package-content-audit.js +368 -0
- package/scripts/lib/package-runtime.js +278 -0
- package/scripts/lib/plan-surface.js +53 -0
- package/scripts/lib/plans.js +2318 -0
- package/scripts/lib/policy-provider.js +27 -0
- package/scripts/lib/prelaunch-activation-readiness.js +409 -0
- package/scripts/lib/prelaunch-evidence-store.js +816 -0
- package/scripts/lib/prelaunch-intelligence.js +869 -0
- package/scripts/lib/pricing-experiment.js +118 -0
- package/scripts/lib/pro-moment-events.js +77 -0
- package/scripts/lib/pro-moment-state.js +227 -0
- package/scripts/lib/pro-moments.js +1216 -0
- package/scripts/lib/product-learning-events.js +629 -0
- package/scripts/lib/project-profile.js +555 -0
- package/scripts/lib/prompt-compiler.js +280 -0
- package/scripts/lib/prompt-lint.js +32 -0
- package/scripts/lib/prompt-suggestions.js +52 -0
- package/scripts/lib/proof-canonical.js +398 -0
- package/scripts/lib/proof-drilldown.js +383 -0
- package/scripts/lib/proof-events.js +342 -0
- package/scripts/lib/proof-history.js +243 -0
- package/scripts/lib/proof-metrics.js +296 -0
- package/scripts/lib/proof-outcome-evidence.js +134 -0
- package/scripts/lib/proof-receipt.js +335 -0
- package/scripts/lib/proof-record.js +461 -0
- package/scripts/lib/public-activation-distribution-gate.js +258 -0
- package/scripts/lib/public-cli.js +3891 -0
- package/scripts/lib/public-distribution-truth.js +211 -0
- package/scripts/lib/public-install-claim-checker.js +294 -0
- package/scripts/lib/publish-provenance-readiness.js +283 -0
- package/scripts/lib/readiness-delta.js +218 -0
- package/scripts/lib/readiness-evidence-closure.js +196 -0
- package/scripts/lib/reentry-memory-capture.js +241 -0
- package/scripts/lib/reentry-memory-retrieval.js +302 -0
- package/scripts/lib/reentry-memory-status.js +146 -0
- package/scripts/lib/reentry-memory-store.js +178 -0
- package/scripts/lib/reentry-state.js +66 -0
- package/scripts/lib/release-candidate-bundle.js +166 -0
- package/scripts/lib/remediation.js +81 -0
- package/scripts/lib/repo-map.js +391 -0
- package/scripts/lib/run-improvements-lifecycle.js +330 -0
- package/scripts/lib/run-improvements.js +789 -0
- package/scripts/lib/runtime-decision-policy.js +387 -0
- package/scripts/lib/safe-path-engine.js +705 -0
- package/scripts/lib/safe-run-controller.js +887 -0
- package/scripts/lib/score.js +262 -0
- package/scripts/lib/seamless-enforcement.js +329 -0
- package/scripts/lib/seamless-outcome.js +689 -0
- package/scripts/lib/seamless-reality-gate.js +5043 -0
- package/scripts/lib/security-risk-classifier.js +511 -0
- package/scripts/lib/security-scan.js +384 -0
- package/scripts/lib/session-context-optimizer.js +1211 -0
- package/scripts/lib/session-timing.js +315 -0
- package/scripts/lib/skill-hygiene.js +805 -0
- package/scripts/lib/skill-packs.js +161 -0
- package/scripts/lib/skills-operating-layer.js +580 -0
- package/scripts/lib/smart-work-routing.js +768 -0
- package/scripts/lib/source-catalog.js +700 -0
- package/scripts/lib/status-value-summary.js +32 -0
- package/scripts/lib/support-bundle.js +578 -0
- package/scripts/lib/task-continuation.js +440 -0
- package/scripts/lib/test-helpers.js +15 -0
- package/scripts/lib/tier.js +38 -0
- package/scripts/lib/token-context-quality-gate.js +370 -0
- package/scripts/lib/token-cost-capture.js +187 -0
- package/scripts/lib/token-cost-intelligence.js +358 -0
- package/scripts/lib/token-efficiency-evidence.js +213 -0
- package/scripts/lib/token-evidence.js +699 -0
- package/scripts/lib/tokenish.js +17 -0
- package/scripts/lib/tool-output-sandbox.js +304 -0
- package/scripts/lib/trust-audit.js +136 -0
- package/scripts/lib/unified-events.js +396 -0
- package/scripts/lib/upgrade-interruption-recovery.js +407 -0
- package/scripts/lib/usage-ledger.js +201 -0
- package/scripts/lib/value-ledger.js +130 -0
- package/scripts/lib/value-proof-calibration.js +531 -0
- package/scripts/lib/visual-qa.js +231 -0
- package/scripts/lib/voice-alpha.js +29 -0
- package/scripts/lib/work-aware-orchestration.js +976 -0
- package/scripts/lib/work-control-receipts.js +577 -0
- package/scripts/lib/work-ledger.js +1123 -0
- package/scripts/lib/work-panel-preview.js +352 -0
- package/scripts/lib/workflow-discipline.js +280 -0
- package/scripts/lib/workflow-signals.js +419 -0
- package/scripts/lib/workspace-map.js +281 -0
- package/scripts/lib/workspace-registry.js +1367 -0
- 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
|
+
};
|