agentera 3.0.0-dev.5 → 3.0.0-dev.7

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 (510) hide show
  1. package/README.md +4 -3
  2. package/bundle/extract-corpus-parity.json +23 -0
  3. package/bundle/references/adapters/cursor.md +10 -9
  4. package/bundle/references/adapters/opencode.md +26 -26
  5. package/bundle/references/adapters/package-registry.yaml +0 -1
  6. package/bundle/references/adapters/package-surface-characterization.md +1 -2
  7. package/bundle/references/adapters/runtime-adapter-characterization.md +1 -1
  8. package/bundle/references/adapters/runtime-adapter-registry.yaml +16 -10
  9. package/bundle/references/adapters/runtime-feature-parity.md +2 -2
  10. package/bundle/references/analysis/benchmark.md +1 -1
  11. package/bundle/references/analysis/startup-measurement-contract.yaml +18 -18
  12. package/bundle/references/artifacts/artifact-registry-interface-model.yaml +4 -3
  13. package/bundle/references/cli/agent-ready-state-contract.yaml +6 -6
  14. package/bundle/references/cli/app-lifecycle-vocabulary.yaml +4 -4
  15. package/bundle/references/cli/audience-namespace-cli-migration.yaml +40 -26
  16. package/bundle/references/cli/bundle-skill-vocabulary.yaml +1 -29
  17. package/bundle/references/cli/capability-tool-classification.yaml +12 -12
  18. package/bundle/references/cli/coexistence-probe.yaml +13 -0
  19. package/bundle/references/cli/parity-expected-actual-template.md +30 -0
  20. package/bundle/references/cli/routing-execution-vocabulary.yaml +6 -6
  21. package/bundle/references/cli/routing-model.md +96 -0
  22. package/bundle/references/cli/single-name-protocol.yaml +42 -0
  23. package/bundle/references/cli/trigger-schema-enrichment.md +136 -0
  24. package/bundle/references/cli/update-channels.yaml +16 -0
  25. package/bundle/references/cli/upgrade-repair-wording.md +45 -0
  26. package/bundle/references/cli/v3-handoff-manifest.schema.yaml +98 -0
  27. package/bundle/references/cli/vocabulary-index.yaml +17 -12
  28. package/bundle/references/cli/vocabulary.md +316 -309
  29. package/bundle/references/meta/documentation-inventory.md +9 -3
  30. package/bundle/registry.json +13 -13
  31. package/bundle/skills/agentera/.claude-plugin/plugin.json +13 -13
  32. package/bundle/skills/agentera/SKILL.md +99 -415
  33. package/bundle/skills/agentera/agents/audit.toml +6 -0
  34. package/bundle/skills/agentera/agents/build.toml +6 -0
  35. package/bundle/skills/agentera/agents/design.toml +6 -0
  36. package/bundle/skills/agentera/agents/{planera.toml → discuss.toml} +3 -3
  37. package/bundle/skills/agentera/agents/{resonera.toml → document.toml} +3 -3
  38. package/bundle/skills/agentera/agents/{optimera.toml → optimize.toml} +2 -2
  39. package/bundle/skills/agentera/agents/orchestrate.toml +6 -0
  40. package/bundle/skills/agentera/agents/plan.toml +6 -0
  41. package/bundle/skills/agentera/agents/profile.toml +6 -0
  42. package/bundle/skills/agentera/agents/research.toml +6 -0
  43. package/bundle/skills/agentera/agents/status.toml +6 -0
  44. package/bundle/skills/agentera/agents/vision.toml +6 -0
  45. package/bundle/skills/agentera/capabilities/{inspektera → audit}/schemas/artifacts.yaml +10 -10
  46. package/bundle/skills/agentera/capabilities/{inspektera → audit}/schemas/triggers.yaml +15 -6
  47. package/bundle/skills/agentera/capabilities/{inspektera → audit}/schemas/validation.yaml +9 -9
  48. package/bundle/skills/agentera/capabilities/{realisera → build}/schemas/artifacts.yaml +11 -11
  49. package/bundle/skills/agentera/capabilities/{realisera → build}/schemas/triggers.yaml +13 -3
  50. package/bundle/skills/agentera/capabilities/{realisera → build}/schemas/validation.yaml +7 -7
  51. package/bundle/skills/agentera/capabilities/{visualisera → design}/schemas/artifacts.yaml +6 -6
  52. package/bundle/skills/agentera/capabilities/{visualisera → design}/schemas/triggers.yaml +15 -3
  53. package/bundle/skills/agentera/capabilities/{visualisera → design}/schemas/validation.yaml +5 -5
  54. package/bundle/skills/agentera/capabilities/{resonera → discuss}/schemas/artifacts.yaml +6 -6
  55. package/bundle/skills/agentera/capabilities/{resonera → discuss}/schemas/triggers.yaml +11 -3
  56. package/bundle/skills/agentera/capabilities/{resonera → discuss}/schemas/validation.yaml +4 -4
  57. package/bundle/skills/agentera/capabilities/{dokumentera → document}/schemas/artifacts.yaml +10 -10
  58. package/bundle/skills/agentera/capabilities/{dokumentera → document}/schemas/triggers.yaml +14 -3
  59. package/bundle/skills/agentera/capabilities/{dokumentera → document}/schemas/validation.yaml +8 -8
  60. package/bundle/skills/agentera/capabilities/{optimera → optimize}/schemas/artifacts.yaml +8 -8
  61. package/bundle/skills/agentera/capabilities/{optimera → optimize}/schemas/triggers.yaml +11 -3
  62. package/bundle/skills/agentera/capabilities/{optimera → optimize}/schemas/validation.yaml +7 -7
  63. package/bundle/skills/agentera/capabilities/{orkestrera → orchestrate}/schemas/artifacts.yaml +10 -10
  64. package/bundle/skills/agentera/capabilities/{orkestrera → orchestrate}/schemas/triggers.yaml +16 -3
  65. package/bundle/skills/agentera/capabilities/{orkestrera → orchestrate}/schemas/validation.yaml +27 -27
  66. package/bundle/skills/agentera/capabilities/{planera → plan}/schemas/artifacts.yaml +8 -8
  67. package/bundle/skills/agentera/capabilities/{planera → plan}/schemas/exit.yaml +2 -2
  68. package/bundle/skills/agentera/capabilities/{planera → plan}/schemas/triggers.yaml +15 -3
  69. package/bundle/skills/agentera/capabilities/{planera → plan}/schemas/validation.yaml +3 -3
  70. package/bundle/skills/agentera/capabilities/{profilera → profile}/schemas/artifacts.yaml +2 -2
  71. package/bundle/skills/agentera/capabilities/{profilera → profile}/schemas/exit.yaml +2 -1
  72. package/bundle/skills/agentera/capabilities/{profilera → profile}/schemas/triggers.yaml +7 -3
  73. package/bundle/skills/agentera/capabilities/{profilera → profile}/schemas/validation.yaml +2 -2
  74. package/bundle/skills/agentera/capabilities/{inspirera → research}/schemas/artifacts.yaml +5 -5
  75. package/bundle/skills/agentera/capabilities/{inspirera → research}/schemas/triggers.yaml +9 -3
  76. package/bundle/skills/agentera/capabilities/{inspirera → research}/schemas/validation.yaml +2 -2
  77. package/bundle/skills/agentera/capabilities/{hej → status}/schemas/artifacts.yaml +14 -11
  78. package/bundle/skills/agentera/capabilities/{hej → status}/schemas/triggers.yaml +10 -4
  79. package/bundle/skills/agentera/capabilities/{hej → status}/schemas/validation.yaml +5 -5
  80. package/bundle/skills/agentera/capabilities/{visionera → vision}/schemas/artifacts.yaml +8 -8
  81. package/bundle/skills/agentera/capabilities/{visionera → vision}/schemas/triggers.yaml +17 -3
  82. package/bundle/skills/agentera/capabilities/{visionera → vision}/schemas/validation.yaml +7 -7
  83. package/bundle/skills/agentera/capability_schema_contract.yaml +178 -34
  84. package/bundle/skills/agentera/protocol.yaml +29 -29
  85. package/bundle/skills/agentera/references/contract.md +328 -319
  86. package/bundle/skills/agentera/schemas/artifacts/changelog.yaml +4 -4
  87. package/bundle/skills/agentera/schemas/artifacts/decisions.yaml +9 -9
  88. package/bundle/skills/agentera/schemas/artifacts/design.yaml +4 -4
  89. package/bundle/skills/agentera/schemas/artifacts/docs.yaml +8 -7
  90. package/bundle/skills/agentera/schemas/artifacts/experiments.yaml +5 -5
  91. package/bundle/skills/agentera/schemas/artifacts/health.yaml +5 -5
  92. package/bundle/skills/agentera/schemas/artifacts/objective.yaml +4 -4
  93. package/bundle/skills/agentera/schemas/artifacts/plan.yaml +5 -5
  94. package/bundle/skills/agentera/schemas/artifacts/progress.yaml +5 -5
  95. package/bundle/skills/agentera/schemas/artifacts/todo.yaml +40 -35
  96. package/bundle/skills/agentera/schemas/artifacts/vision.yaml +3 -3
  97. package/dist/analytics/extractCorpus/cli.js +149 -0
  98. package/dist/analytics/extractCorpus/cli.js.map +1 -0
  99. package/dist/analytics/extractCorpus/copilotSessions.js +273 -0
  100. package/dist/analytics/extractCorpus/copilotSessions.js.map +1 -0
  101. package/dist/analytics/extractCorpus/core.js +364 -0
  102. package/dist/analytics/extractCorpus/core.js.map +1 -0
  103. package/dist/analytics/extractCorpus/corpus.js +145 -0
  104. package/dist/analytics/extractCorpus/corpus.js.map +1 -0
  105. package/dist/analytics/extractCorpus/coverageAudit.js +261 -0
  106. package/dist/analytics/extractCorpus/coverageAudit.js.map +1 -0
  107. package/dist/analytics/extractCorpus/cursorSessions.js +423 -0
  108. package/dist/analytics/extractCorpus/cursorSessions.js.map +1 -0
  109. package/dist/analytics/extractCorpus/extractCorpusParity.js +105 -0
  110. package/dist/analytics/extractCorpus/extractCorpusParity.js.map +1 -0
  111. package/dist/analytics/extractCorpus/filesystemSources.js +122 -0
  112. package/dist/analytics/extractCorpus/filesystemSources.js.map +1 -0
  113. package/dist/analytics/extractCorpus/index.js +12 -0
  114. package/dist/analytics/extractCorpus/index.js.map +1 -0
  115. package/dist/analytics/extractCorpus/jsonlSessions.js +185 -0
  116. package/dist/analytics/extractCorpus/jsonlSessions.js.map +1 -0
  117. package/dist/analytics/extractCorpus/sqliteCaps.js +44 -0
  118. package/dist/analytics/extractCorpus/sqliteCaps.js.map +1 -0
  119. package/dist/analytics/extractCorpus/sqliteSessions.js +368 -0
  120. package/dist/analytics/extractCorpus/sqliteSessions.js.map +1 -0
  121. package/dist/analytics/extractCorpus.js +2 -1790
  122. package/dist/analytics/extractCorpus.js.map +1 -1
  123. package/dist/analytics/usageStats.js +20 -20
  124. package/dist/analytics/usageStats.js.map +1 -1
  125. package/dist/capabilities/audit/instructions.js +6 -0
  126. package/dist/capabilities/audit/instructions.js.map +1 -0
  127. package/dist/capabilities/build/instructions.js +6 -0
  128. package/dist/capabilities/build/instructions.js.map +1 -0
  129. package/dist/capabilities/design/instructions.js +5 -0
  130. package/dist/capabilities/design/instructions.js.map +1 -0
  131. package/dist/capabilities/discuss/instructions.js +6 -0
  132. package/dist/capabilities/discuss/instructions.js.map +1 -0
  133. package/dist/capabilities/document/instructions.js +6 -0
  134. package/dist/capabilities/document/instructions.js.map +1 -0
  135. package/dist/capabilities/index.js +24 -24
  136. package/dist/capabilities/index.js.map +1 -1
  137. package/dist/capabilities/inspirera/instructions.js +1 -1
  138. package/dist/capabilities/inspirera/instructions.js.map +1 -1
  139. package/dist/capabilities/optimize/instructions.js +6 -0
  140. package/dist/capabilities/optimize/instructions.js.map +1 -0
  141. package/dist/capabilities/orchestrate/instructions.js +6 -0
  142. package/dist/capabilities/orchestrate/instructions.js.map +1 -0
  143. package/dist/capabilities/plan/instructions.js +6 -0
  144. package/dist/capabilities/plan/instructions.js.map +1 -0
  145. package/dist/capabilities/planera/instructions.js +1 -1
  146. package/dist/capabilities/planera/instructions.js.map +1 -1
  147. package/dist/capabilities/profile/instructions.js +6 -0
  148. package/dist/capabilities/profile/instructions.js.map +1 -0
  149. package/dist/capabilities/profilera/instructions.js +1 -1
  150. package/dist/capabilities/profilera/instructions.js.map +1 -1
  151. package/dist/capabilities/realisera/instructions.js +1 -1
  152. package/dist/capabilities/realisera/instructions.js.map +1 -1
  153. package/dist/capabilities/research/instructions.js +6 -0
  154. package/dist/capabilities/research/instructions.js.map +1 -0
  155. package/dist/capabilities/resonera/instructions.js +1 -1
  156. package/dist/capabilities/resonera/instructions.js.map +1 -1
  157. package/dist/capabilities/status/instructions.js +6 -0
  158. package/dist/capabilities/status/instructions.js.map +1 -0
  159. package/dist/capabilities/vision/instructions.js +6 -0
  160. package/dist/capabilities/vision/instructions.js.map +1 -0
  161. package/dist/capabilities/visionera/instructions.js +1 -1
  162. package/dist/capabilities/visionera/instructions.js.map +1 -1
  163. package/dist/capabilities/visualisera/instructions.js +3 -4
  164. package/dist/capabilities/visualisera/instructions.js.map +1 -1
  165. package/dist/cli/appContext.js +16 -17
  166. package/dist/cli/appContext.js.map +1 -1
  167. package/dist/cli/capabilityContext/benchmark.js +564 -0
  168. package/dist/cli/capabilityContext/benchmark.js.map +1 -0
  169. package/dist/cli/capabilityContext/bespoke.js +36 -0
  170. package/dist/cli/capabilityContext/bespoke.js.map +1 -0
  171. package/dist/cli/capabilityContext/build.js +177 -0
  172. package/dist/cli/capabilityContext/build.js.map +1 -0
  173. package/dist/cli/capabilityContext/closeout.js +230 -0
  174. package/dist/cli/capabilityContext/closeout.js.map +1 -0
  175. package/dist/cli/capabilityContext/contract.js +188 -0
  176. package/dist/cli/capabilityContext/contract.js.map +1 -0
  177. package/dist/cli/capabilityContext/evidence.js +456 -0
  178. package/dist/cli/capabilityContext/evidence.js.map +1 -0
  179. package/dist/cli/capabilityContext/index.js +4 -0
  180. package/dist/cli/capabilityContext/index.js.map +1 -0
  181. package/dist/cli/capabilityContext/orchestration.js +107 -0
  182. package/dist/cli/capabilityContext/orchestration.js.map +1 -0
  183. package/dist/cli/capabilityContext/planState.js +271 -0
  184. package/dist/cli/capabilityContext/planState.js.map +1 -0
  185. package/dist/cli/capabilityContext/progress.js +103 -0
  186. package/dist/cli/capabilityContext/progress.js.map +1 -0
  187. package/dist/cli/capabilityContext/realisera.js +174 -0
  188. package/dist/cli/capabilityContext/realisera.js.map +1 -0
  189. package/dist/cli/capabilityContext/shared.js +94 -0
  190. package/dist/cli/capabilityContext/shared.js.map +1 -0
  191. package/dist/cli/capabilityContext/slim.js +108 -0
  192. package/dist/cli/capabilityContext/slim.js.map +1 -0
  193. package/dist/cli/capabilityContext/startup.js +213 -0
  194. package/dist/cli/capabilityContext/startup.js.map +1 -0
  195. package/dist/cli/capabilityContext/types.js +40 -0
  196. package/dist/cli/capabilityContext/types.js.map +1 -0
  197. package/dist/cli/capabilityContext.js +1 -2486
  198. package/dist/cli/capabilityContext.js.map +1 -1
  199. package/dist/cli/commands/appHome.js +23 -0
  200. package/dist/cli/commands/appHome.js.map +1 -0
  201. package/dist/cli/commands/backfill.js +84 -0
  202. package/dist/cli/commands/backfill.js.map +1 -0
  203. package/dist/cli/commands/capability.js +2 -2
  204. package/dist/cli/commands/capability.js.map +1 -1
  205. package/dist/cli/commands/compact.js +1 -1
  206. package/dist/cli/commands/compact.js.map +1 -1
  207. package/dist/cli/commands/doctor.js +17 -98
  208. package/dist/cli/commands/doctor.js.map +1 -1
  209. package/dist/cli/commands/lint.js +4 -36
  210. package/dist/cli/commands/lint.js.map +1 -1
  211. package/dist/cli/commands/prime/bundleStatus.js +140 -0
  212. package/dist/cli/commands/prime/bundleStatus.js.map +1 -0
  213. package/dist/cli/commands/prime/collectOrientationState.js +156 -0
  214. package/dist/cli/commands/prime/collectOrientationState.js.map +1 -0
  215. package/dist/cli/commands/prime/orientationOutput.js +210 -0
  216. package/dist/cli/commands/prime/orientationOutput.js.map +1 -0
  217. package/dist/cli/commands/prime/routeOutput.js +50 -0
  218. package/dist/cli/commands/prime/routeOutput.js.map +1 -0
  219. package/dist/cli/commands/prime/types.js +2 -0
  220. package/dist/cli/commands/prime/types.js.map +1 -0
  221. package/dist/cli/commands/prime/v1Migration.js +39 -0
  222. package/dist/cli/commands/prime/v1Migration.js.map +1 -0
  223. package/dist/cli/commands/prime.js +11 -554
  224. package/dist/cli/commands/prime.js.map +1 -1
  225. package/dist/cli/commands/query.js +5 -2
  226. package/dist/cli/commands/query.js.map +1 -1
  227. package/dist/cli/commands/report.js +27 -10
  228. package/dist/cli/commands/report.js.map +1 -1
  229. package/dist/cli/commands/schema.js +24 -20
  230. package/dist/cli/commands/schema.js.map +1 -1
  231. package/dist/cli/commands/state/decisions.js +403 -0
  232. package/dist/cli/commands/state/decisions.js.map +1 -0
  233. package/dist/cli/commands/state/docs.js +97 -0
  234. package/dist/cli/commands/state/docs.js.map +1 -0
  235. package/dist/cli/commands/state/experiments.js +68 -0
  236. package/dist/cli/commands/state/experiments.js.map +1 -0
  237. package/dist/cli/commands/state/health.js +116 -0
  238. package/dist/cli/commands/state/health.js.map +1 -0
  239. package/dist/cli/commands/state/index.js +51 -0
  240. package/dist/cli/commands/state/index.js.map +1 -0
  241. package/dist/cli/commands/state/objective.js +69 -0
  242. package/dist/cli/commands/state/objective.js.map +1 -0
  243. package/dist/cli/commands/state/plan.js +173 -0
  244. package/dist/cli/commands/state/plan.js.map +1 -0
  245. package/dist/cli/commands/state/progress.js +47 -0
  246. package/dist/cli/commands/state/progress.js.map +1 -0
  247. package/dist/cli/commands/state/shared.js +15 -0
  248. package/dist/cli/commands/state/shared.js.map +1 -0
  249. package/dist/cli/commands/state/todo.js +121 -0
  250. package/dist/cli/commands/state/todo.js.map +1 -0
  251. package/dist/cli/commands/state.js +7 -7
  252. package/dist/cli/commands/state.js.map +1 -1
  253. package/dist/cli/commands/validate.js +50 -100
  254. package/dist/cli/commands/validate.js.map +1 -1
  255. package/dist/cli/commands/verify.js +1 -1
  256. package/dist/cli/commands/verify.js.map +1 -1
  257. package/dist/cli/contracts/bundleStatus.js +2 -0
  258. package/dist/cli/contracts/bundleStatus.js.map +1 -0
  259. package/dist/cli/contracts/orientationState.js +2 -0
  260. package/dist/cli/contracts/orientationState.js.map +1 -0
  261. package/dist/cli/dispatch/argvParser.js +33 -0
  262. package/dist/cli/dispatch/argvParser.js.map +1 -0
  263. package/dist/cli/dispatch/check.js +328 -0
  264. package/dist/cli/dispatch/check.js.map +1 -0
  265. package/dist/cli/dispatch/commands.js +27 -0
  266. package/dist/cli/dispatch/commands.js.map +1 -0
  267. package/dist/cli/dispatch/index.js +182 -0
  268. package/dist/cli/dispatch/index.js.map +1 -0
  269. package/dist/cli/dispatch/lifecycle.js +597 -0
  270. package/dist/cli/dispatch/lifecycle.js.map +1 -0
  271. package/dist/cli/dispatch/prime.js +104 -0
  272. package/dist/cli/dispatch/prime.js.map +1 -0
  273. package/dist/cli/dispatch/shared.js +64 -0
  274. package/dist/cli/dispatch/shared.js.map +1 -0
  275. package/dist/cli/dispatch/state.js +144 -0
  276. package/dist/cli/dispatch/state.js.map +1 -0
  277. package/dist/cli/dispatch.js +1 -1293
  278. package/dist/cli/dispatch.js.map +1 -1
  279. package/dist/cli/help.js +41 -8
  280. package/dist/cli/help.js.map +1 -1
  281. package/dist/cli/orientation/attention.js +61 -0
  282. package/dist/cli/orientation/attention.js.map +1 -0
  283. package/dist/cli/orientation/corpusCoverage.js +71 -0
  284. package/dist/cli/orientation/corpusCoverage.js.map +1 -0
  285. package/dist/cli/orientation.js +129 -78
  286. package/dist/cli/orientation.js.map +1 -1
  287. package/dist/cli/prime-blob.js +1 -1
  288. package/dist/cli/startupCompletenessContract.js +56 -0
  289. package/dist/cli/startupCompletenessContract.js.map +1 -0
  290. package/dist/cli/stateQuery.js +9 -2
  291. package/dist/cli/stateQuery.js.map +1 -1
  292. package/dist/cli/todoSeverity.js +19 -0
  293. package/dist/cli/todoSeverity.js.map +1 -0
  294. package/dist/core/envPaths.js +21 -0
  295. package/dist/core/envPaths.js.map +1 -0
  296. package/dist/core/git.js +43 -0
  297. package/dist/core/git.js.map +1 -0
  298. package/dist/core/jsonValue.js +6 -0
  299. package/dist/core/jsonValue.js.map +1 -0
  300. package/dist/core/pyjson.js +67 -2
  301. package/dist/core/pyjson.js.map +1 -1
  302. package/dist/eval/evalSkills.js +17 -12
  303. package/dist/eval/evalSkills.js.map +1 -1
  304. package/dist/eval/semanticEval.js +43 -19
  305. package/dist/eval/semanticEval.js.map +1 -1
  306. package/dist/eval/semanticFixtures.js +16 -4
  307. package/dist/eval/semanticFixtures.js.map +1 -1
  308. package/dist/hooks/common.js +8 -23
  309. package/dist/hooks/common.js.map +1 -1
  310. package/dist/hooks/compaction/apply.js +269 -0
  311. package/dist/hooks/compaction/apply.js.map +1 -0
  312. package/dist/hooks/compaction/dryRun.js +183 -0
  313. package/dist/hooks/compaction/dryRun.js.map +1 -0
  314. package/dist/hooks/compaction/index.js +23 -0
  315. package/dist/hooks/compaction/index.js.map +1 -0
  316. package/dist/hooks/compaction/parse.js +258 -0
  317. package/dist/hooks/compaction/parse.js.map +1 -0
  318. package/dist/hooks/compaction/retention.js +199 -0
  319. package/dist/hooks/compaction/retention.js.map +1 -0
  320. package/dist/hooks/compaction/status.js +241 -0
  321. package/dist/hooks/compaction/status.js.map +1 -0
  322. package/dist/hooks/compaction/todoResolved.js +137 -0
  323. package/dist/hooks/compaction/todoResolved.js.map +1 -0
  324. package/dist/hooks/compaction/types.js +6 -0
  325. package/dist/hooks/compaction/types.js.map +1 -0
  326. package/dist/hooks/compaction.js +20 -20
  327. package/dist/hooks/compaction.js.map +1 -1
  328. package/dist/hooks/cursorPreToolUse.js +1 -1
  329. package/dist/hooks/cursorPreToolUse.js.map +1 -1
  330. package/dist/hooks/cursorSessionStart.js +10 -2
  331. package/dist/hooks/cursorSessionStart.js.map +1 -1
  332. package/dist/hooks/sessionStart.js +18 -11
  333. package/dist/hooks/sessionStart.js.map +1 -1
  334. package/dist/hooks/sessionStop.js +6 -12
  335. package/dist/hooks/sessionStop.js.map +1 -1
  336. package/dist/hooks/todoLayout.js +177 -0
  337. package/dist/hooks/todoLayout.js.map +1 -0
  338. package/dist/hooks/validateArtifact/agentFacing.js +10 -0
  339. package/dist/hooks/validateArtifact/agentFacing.js.map +1 -0
  340. package/dist/hooks/validateArtifact/index.js +151 -0
  341. package/dist/hooks/validateArtifact/index.js.map +1 -0
  342. package/dist/hooks/validateArtifact/markdown.js +146 -0
  343. package/dist/hooks/validateArtifact/markdown.js.map +1 -0
  344. package/dist/hooks/validateArtifact/runtime.js +86 -0
  345. package/dist/hooks/validateArtifact/runtime.js.map +1 -0
  346. package/dist/hooks/validateArtifact/schema.js +459 -0
  347. package/dist/hooks/validateArtifact/schema.js.map +1 -0
  348. package/dist/hooks/validateArtifact/traversal.js +106 -0
  349. package/dist/hooks/validateArtifact/traversal.js.map +1 -0
  350. package/dist/hooks/validateArtifact/violations.js +105 -0
  351. package/dist/hooks/validateArtifact/violations.js.map +1 -0
  352. package/dist/hooks/validateArtifact.js +29 -40
  353. package/dist/hooks/validateArtifact.js.map +1 -1
  354. package/dist/migrate/v2HandoffManifest.js +447 -0
  355. package/dist/migrate/v2HandoffManifest.js.map +1 -0
  356. package/dist/registries/artifactProtocolIds.js +77 -0
  357. package/dist/registries/artifactProtocolIds.js.map +1 -0
  358. package/dist/registries/artifactRegistry.js +23 -9
  359. package/dist/registries/artifactRegistry.js.map +1 -1
  360. package/dist/registries/capabilityContract.js +144 -1
  361. package/dist/registries/capabilityContract.js.map +1 -1
  362. package/dist/registries/evaluatorHandoffContract.js +2 -2
  363. package/dist/registries/evaluatorHandoffContract.js.map +1 -1
  364. package/dist/registries/packageRegistry.js +4 -3
  365. package/dist/registries/packageRegistry.js.map +1 -1
  366. package/dist/registries/runtimeAdapterRegistry.js +5 -4
  367. package/dist/registries/runtimeAdapterRegistry.js.map +1 -1
  368. package/dist/registries/triggerLoader.js +211 -0
  369. package/dist/registries/triggerLoader.js.map +1 -0
  370. package/dist/release/releaseMetadata.js +235 -0
  371. package/dist/release/releaseMetadata.js.map +1 -0
  372. package/dist/routing/index.js +2 -0
  373. package/dist/routing/index.js.map +1 -0
  374. package/dist/routing/routeEngine.js +189 -0
  375. package/dist/routing/routeEngine.js.map +1 -0
  376. package/dist/setup/codex/agents.js +96 -0
  377. package/dist/setup/codex/agents.js.map +1 -0
  378. package/dist/setup/codex/cli.js +161 -0
  379. package/dist/setup/codex/cli.js.map +1 -0
  380. package/dist/setup/codex/configToml.js +639 -0
  381. package/dist/setup/codex/configToml.js.map +1 -0
  382. package/dist/setup/codex/constants.js +29 -0
  383. package/dist/setup/codex/constants.js.map +1 -0
  384. package/dist/setup/codex/installRoot.js +64 -0
  385. package/dist/setup/codex/installRoot.js.map +1 -0
  386. package/dist/setup/codex/state.js +270 -0
  387. package/dist/setup/codex/state.js.map +1 -0
  388. package/dist/setup/codex.js +11 -1196
  389. package/dist/setup/codex.js.map +1 -1
  390. package/dist/setup/cursor.js +6 -4
  391. package/dist/setup/cursor.js.map +1 -1
  392. package/dist/setup/cursorSurfaces.js +67 -0
  393. package/dist/setup/cursorSurfaces.js.map +1 -0
  394. package/dist/setup/doctor/core.js +300 -0
  395. package/dist/setup/doctor/core.js.map +1 -0
  396. package/dist/setup/doctor/diagnostics.js +240 -0
  397. package/dist/setup/doctor/diagnostics.js.map +1 -0
  398. package/dist/setup/doctor/opencode.js +313 -0
  399. package/dist/setup/doctor/opencode.js.map +1 -0
  400. package/dist/setup/doctor/report.js +425 -0
  401. package/dist/setup/doctor/report.js.map +1 -0
  402. package/dist/setup/doctor.js +9 -1296
  403. package/dist/setup/doctor.js.map +1 -1
  404. package/dist/setup/opencode.js +13 -0
  405. package/dist/setup/opencode.js.map +1 -0
  406. package/dist/setup/smokeChecks.js +11 -11
  407. package/dist/setup/smokeChecks.js.map +1 -1
  408. package/dist/state/installRoot.js +49 -18
  409. package/dist/state/installRoot.js.map +1 -1
  410. package/dist/state/progressCommit.js +289 -0
  411. package/dist/state/progressCommit.js.map +1 -0
  412. package/dist/state/startupAnalysis/benchmark.js +371 -0
  413. package/dist/state/startupAnalysis/benchmark.js.map +1 -0
  414. package/dist/state/startupAnalysis/contract.js +126 -0
  415. package/dist/state/startupAnalysis/contract.js.map +1 -0
  416. package/dist/state/startupAnalysis/helpers.js +287 -0
  417. package/dist/state/startupAnalysis/helpers.js.map +1 -0
  418. package/dist/state/startupAnalysis/index.js +7 -0
  419. package/dist/state/startupAnalysis/index.js.map +1 -0
  420. package/dist/state/startupAnalysis/metrics.js +341 -0
  421. package/dist/state/startupAnalysis/metrics.js.map +1 -0
  422. package/dist/state/startupAnalysis/records.js +199 -0
  423. package/dist/state/startupAnalysis/records.js.map +1 -0
  424. package/dist/state/startupAnalysis/report.js +112 -0
  425. package/dist/state/startupAnalysis/report.js.map +1 -0
  426. package/dist/state/startupAnalysis/threshold.js +500 -0
  427. package/dist/state/startupAnalysis/threshold.js.map +1 -0
  428. package/dist/state/startupAnalysis.js +2 -1952
  429. package/dist/state/startupAnalysis.js.map +1 -1
  430. package/dist/upgrade/appContentRefresh.js +342 -0
  431. package/dist/upgrade/appContentRefresh.js.map +1 -0
  432. package/dist/upgrade/appModel.js +8 -6
  433. package/dist/upgrade/appModel.js.map +1 -1
  434. package/dist/upgrade/bundleEvidence.js +34 -0
  435. package/dist/upgrade/bundleEvidence.js.map +1 -0
  436. package/dist/upgrade/channels.js +11 -4
  437. package/dist/upgrade/channels.js.map +1 -1
  438. package/dist/upgrade/cliProbe.js +22 -0
  439. package/dist/upgrade/cliProbe.js.map +1 -0
  440. package/dist/upgrade/coexistenceProbe.js +107 -0
  441. package/dist/upgrade/coexistenceProbe.js.map +1 -0
  442. package/dist/upgrade/compatibility.js +13 -4
  443. package/dist/upgrade/compatibility.js.map +1 -1
  444. package/dist/upgrade/doctor.js +165 -183
  445. package/dist/upgrade/doctor.js.map +1 -1
  446. package/dist/upgrade/doctorClassifier.js +177 -0
  447. package/dist/upgrade/doctorClassifier.js.map +1 -0
  448. package/dist/upgrade/installedHooksRetirement.js +190 -0
  449. package/dist/upgrade/installedHooksRetirement.js.map +1 -0
  450. package/dist/upgrade/legacyAgentCleanup.js +116 -0
  451. package/dist/upgrade/legacyAgentCleanup.js.map +1 -0
  452. package/dist/upgrade/migrateArtifactsV2ToV3.js +57 -109
  453. package/dist/upgrade/migrateArtifactsV2ToV3.js.map +1 -1
  454. package/dist/upgrade/nextMajorDoctor.js +42 -7
  455. package/dist/upgrade/nextMajorDoctor.js.map +1 -1
  456. package/dist/upgrade/npxPlatformStatus.js +23 -0
  457. package/dist/upgrade/npxPlatformStatus.js.map +1 -0
  458. package/dist/upgrade/projectIntegration.js +69 -73
  459. package/dist/upgrade/projectIntegration.js.map +1 -1
  460. package/dist/upgrade/projectIntegrationDecision.js +93 -0
  461. package/dist/upgrade/projectIntegrationDecision.js.map +1 -0
  462. package/dist/upgrade/runtimeMigration.js +169 -68
  463. package/dist/upgrade/runtimeMigration.js.map +1 -1
  464. package/dist/upgrade/v3CapabilitySurface.js +15 -0
  465. package/dist/upgrade/v3CapabilitySurface.js.map +1 -0
  466. package/dist/upgrade/versionResolution.js +8 -0
  467. package/dist/upgrade/versionResolution.js.map +1 -1
  468. package/dist/validate/appHomeContract.js +4 -4
  469. package/dist/validate/appHomeContract.js.map +1 -1
  470. package/dist/validate/capability.js +124 -11
  471. package/dist/validate/capability.js.map +1 -1
  472. package/dist/validate/crossCapability.js +1 -1
  473. package/dist/validate/crossCapability.js.map +1 -1
  474. package/dist/validate/lifecycleAdapters/legacyPythonParity.js +93 -0
  475. package/dist/validate/lifecycleAdapters/legacyPythonParity.js.map +1 -0
  476. package/dist/validate/lifecycleAdapters/nodeFormChecks.js +488 -0
  477. package/dist/validate/lifecycleAdapters/nodeFormChecks.js.map +1 -0
  478. package/dist/validate/lifecycleAdapters/shared.js +198 -0
  479. package/dist/validate/lifecycleAdapters/shared.js.map +1 -0
  480. package/dist/validate/lifecycleAdapters.js +13 -723
  481. package/dist/validate/lifecycleAdapters.js.map +1 -1
  482. package/dist/validate/selfAudit.js +62 -20
  483. package/dist/validate/selfAudit.js.map +1 -1
  484. package/dist/validate/vocabularyAuthority.js +303 -0
  485. package/dist/validate/vocabularyAuthority.js.map +1 -0
  486. package/package.json +27 -24
  487. package/bundle/references/v1-section-mapping.md +0 -47
  488. package/bundle/skills/agentera/agents/dokumentera.toml +0 -6
  489. package/bundle/skills/agentera/agents/hej.toml +0 -6
  490. package/bundle/skills/agentera/agents/inspektera.toml +0 -6
  491. package/bundle/skills/agentera/agents/inspirera.toml +0 -6
  492. package/bundle/skills/agentera/agents/orkestrera.toml +0 -6
  493. package/bundle/skills/agentera/agents/profilera.toml +0 -6
  494. package/bundle/skills/agentera/agents/realisera.toml +0 -6
  495. package/bundle/skills/agentera/agents/visionera.toml +0 -6
  496. package/bundle/skills/agentera/agents/visualisera.toml +0 -6
  497. package/bundle/skills/hej/.claude-plugin/plugin.json +0 -6
  498. package/bundle/skills/hej/SKILL.md +0 -69
  499. package/bundle/skills/hej/agents/hej.toml +0 -11
  500. package/bundle/skills/hej/agents/openai.yaml +0 -8
  501. /package/bundle/skills/agentera/capabilities/{inspektera → audit}/schemas/exit.yaml +0 -0
  502. /package/bundle/skills/agentera/capabilities/{realisera → build}/schemas/exit.yaml +0 -0
  503. /package/bundle/skills/agentera/capabilities/{visualisera → design}/schemas/exit.yaml +0 -0
  504. /package/bundle/skills/agentera/capabilities/{resonera → discuss}/schemas/exit.yaml +0 -0
  505. /package/bundle/skills/agentera/capabilities/{dokumentera → document}/schemas/exit.yaml +0 -0
  506. /package/bundle/skills/agentera/capabilities/{optimera → optimize}/schemas/exit.yaml +0 -0
  507. /package/bundle/skills/agentera/capabilities/{orkestrera → orchestrate}/schemas/exit.yaml +0 -0
  508. /package/bundle/skills/agentera/capabilities/{inspirera → research}/schemas/exit.yaml +0 -0
  509. /package/bundle/skills/agentera/capabilities/{hej → status}/schemas/exit.yaml +0 -0
  510. /package/bundle/skills/agentera/capabilities/{visionera → vision}/schemas/exit.yaml +0 -0
@@ -0,0 +1,112 @@
1
+ import fs from "node:fs";
2
+ import path from "node:path";
3
+ import { pyJsonIndentSorted } from "../../core/pyjson.js";
4
+ import { Flt, formatFloat, pyFmt, pyJsonDumps } from "./helpers.js";
5
+ export const STARTUP_REPORT_MARKDOWN = "startup-overhead-report.md";
6
+ export const STARTUP_REPORT_JSON = "startup-overhead-report.json";
7
+ function startupJsonScalar(value) {
8
+ if (value instanceof Flt)
9
+ return formatFloat(value.v);
10
+ return undefined;
11
+ }
12
+ function pyJsonIndent(value, level = 0, indent = " ") {
13
+ return pyJsonIndentSorted(value, indent.length || 2, level, startupJsonScalar);
14
+ }
15
+ function markdownTable(headers, rows) {
16
+ const lines = [
17
+ "| " + headers.join(" | ") + " |",
18
+ "| " + headers.map(() => "---").join(" | ") + " |",
19
+ ];
20
+ if (rows.length === 0) {
21
+ return [...lines, "| " + headers.map(() => "none").join(" | ") + " |"];
22
+ }
23
+ return [...lines, ...rows.map((row) => "| " + row.map((v) => pyFmt(v)).join(" | ") + " |")];
24
+ }
25
+ export function renderStartupReport(metrics) {
26
+ const thresholdDerivation = metrics.threshold_derivation && typeof metrics.threshold_derivation === "object" && !Array.isArray(metrics.threshold_derivation)
27
+ ? metrics.threshold_derivation
28
+ : {};
29
+ const threshold = thresholdDerivation.action_thresholds && typeof thresholdDerivation.action_thresholds === "object" && !Array.isArray(thresholdDerivation.action_thresholds)
30
+ ? thresholdDerivation.action_thresholds
31
+ : {};
32
+ const envelopeThreshold = threshold.startup_envelope && typeof threshold.startup_envelope === "object" && !Array.isArray(threshold.startup_envelope) ? threshold.startup_envelope : {};
33
+ const guidanceThreshold = threshold.targeted_guidance && typeof threshold.targeted_guidance === "object" && !Array.isArray(threshold.targeted_guidance) ? threshold.targeted_guidance : {};
34
+ const recommendation = metrics.startup_recommendation && typeof metrics.startup_recommendation === "object" && !Array.isArray(metrics.startup_recommendation)
35
+ ? metrics.startup_recommendation
36
+ : {};
37
+ const measuredDistribution = thresholdDerivation.measured_distribution && typeof thresholdDerivation.measured_distribution === "object" && !Array.isArray(thresholdDerivation.measured_distribution)
38
+ ? thresholdDerivation.measured_distribution
39
+ : {};
40
+ const runtimeCoverage = Array.isArray(metrics.runtime_coverage) ? metrics.runtime_coverage : [];
41
+ const capabilityCounts = metrics.per_capability_state_counts && typeof metrics.per_capability_state_counts === "object" && !Array.isArray(metrics.per_capability_state_counts)
42
+ ? metrics.per_capability_state_counts
43
+ : {};
44
+ const lines = [
45
+ "# Agentera Startup State-Access Analysis",
46
+ "",
47
+ "This report is local-only and privacy-preserving. It measures raw Agentera artifact access after CLI state calls during capability startup/state gathering.",
48
+ "",
49
+ "## Boundary Source",
50
+ "",
51
+ `- Contract version: \`${pyFmt(metrics.contract_version)}\``,
52
+ `- Boundary source: \`${pyFmt(metrics.boundary_source)}\``,
53
+ `- Boundary commit: \`${pyFmt(metrics.boundary_commit)}\``,
54
+ `- Boundary timestamp: \`${pyFmt(metrics.boundary_committed_at)}\``,
55
+ `- Corpus adapter version: \`${pyFmt(metrics.corpus_adapter_version)}\``,
56
+ "",
57
+ "## Benchmark Window",
58
+ "",
59
+ `- Mode: \`${pyFmt(metrics.benchmark_mode)}\``,
60
+ `- Previous watermark: \`${pyFmt(metrics.benchmark_previous_watermark_at)}\``,
61
+ `- Window started after: \`${pyFmt(metrics.benchmark_window_started_after)}\``,
62
+ `- Watermark: \`${pyFmt(metrics.benchmark_watermark_at)}\``,
63
+ "",
64
+ "## Runtime Coverage",
65
+ "",
66
+ ];
67
+ const runtimeRows = [];
68
+ for (const status of runtimeCoverage) {
69
+ if (status && typeof status === "object" && !Array.isArray(status)) {
70
+ runtimeRows.push([
71
+ status.runtime ?? "unknown",
72
+ status.status ?? "unknown",
73
+ status.reason ?? "unknown",
74
+ status.record_count ?? 0,
75
+ status.file_count ?? 0,
76
+ status.error_count ?? 0,
77
+ ]);
78
+ }
79
+ }
80
+ lines.push(...markdownTable(["Runtime", "Status", "Reason", "Records", "Files", "Errors"], runtimeRows));
81
+ lines.push("", "## Metrics", "", `- Total state-gathering sequences: \`${pyFmt(metrics.total_state_sequences)}\``, `- Sequences with raw artifact access after CLI: \`${pyFmt(metrics.state_sequences_with_raw_after_cli)}\``, `- Sequences with redundant raw artifact access: \`${pyFmt(metrics.state_sequences_with_redundant_raw_access)}\``, `- Raw-after-CLI sequence rate: \`${pyFmt(metrics.raw_after_cli_sequence_rate)}\``, `- Redundant raw sequence rate: \`${pyFmt(metrics.redundant_raw_sequence_rate)}\``, `- CLI state command counts: \`${pyJsonDumps(metrics.cli_state_command_counts ?? {})}\``, `- Raw artifact access after CLI counts: \`${pyJsonDumps(metrics.raw_artifact_access_after_cli_counts ?? {})}\``, `- Redundant raw artifact access counts: \`${pyJsonDumps(metrics.redundant_raw_artifact_access_counts ?? {})}\``, "", "## Estimated Token Impact", "", `- Token estimator version: \`${pyFmt(metrics.token_estimator_version)}\``, `- Estimated raw-after-CLI tokens: \`${pyFmt(metrics.estimated_raw_after_cli_tokens)}\``, `- Estimated redundant raw tokens: \`${pyFmt(metrics.estimated_redundant_raw_tokens)}\``, `- Estimated raw-after-CLI tokens by artifact: \`${pyJsonDumps(metrics.estimated_raw_after_cli_tokens_by_artifact ?? {})}\``, `- Estimated redundant raw tokens by artifact: \`${pyJsonDumps(metrics.estimated_redundant_raw_tokens_by_artifact ?? {})}\``, `- Estimated tokens saved vs previous: \`${pyFmt(metrics.estimated_tokens_saved_vs_previous)}\``, `- Estimated tokens saved null reason: \`${pyFmt(metrics.estimated_tokens_saved_vs_previous_null_reason)}\``, "");
82
+ const capabilityRows = [];
83
+ for (const capability of Object.keys(capabilityCounts).sort()) {
84
+ const counts = capabilityCounts[capability];
85
+ if (counts && typeof counts === "object" && !Array.isArray(counts)) {
86
+ capabilityRows.push([
87
+ capability,
88
+ counts.state_sequences ?? 0,
89
+ counts.cli_state_call ?? 0,
90
+ counts.raw_artifact_access_after_cli ?? 0,
91
+ counts.redundant_raw_artifact_access ?? 0,
92
+ counts.capability_prose_read ?? 0,
93
+ ]);
94
+ }
95
+ }
96
+ lines.push(...markdownTable(["Capability", "Sequences", "CLI Calls", "Raw After CLI", "Redundant Raw", "Prose Reads"], capabilityRows));
97
+ lines.push("", "## Threshold Rationale", "", `- Startup envelope threshold credible: \`${pyFmt(envelopeThreshold.credible)}\``, `- Redundant-sequence threshold: \`${pyFmt(envelopeThreshold.redundant_sequence_threshold)}\``, `- Startup envelope selection reason: ${pyFmt(envelopeThreshold.selection_reason)}`, `- Targeted-guidance selection reason: ${pyFmt(guidanceThreshold.selection_reason)}`, `- Measured distribution: \`${pyJsonDumps(measuredDistribution)}\``, "", "## Recommendation", "", `- Action: \`${pyFmt(recommendation.action)}\``, `- Measured trigger: \`${pyFmt(recommendation.measured_trigger)}\``, `- Rationale: ${pyFmt(recommendation.rationale)}`, `- Implementation recommended: \`${pyFmt(metrics.implementation_recommended)}\``, "", "## Privacy Caveats", "", "- Raw transcript text is not emitted.", "- Full local paths and raw store paths are not emitted.", "- Session identifiers are salted or omitted.", "- Raw artifact accesses use canonical artifact_id labels such as `plan`, not filesystem paths.", "- Runtime coverage may be incomplete or degraded; inspect `confidence_caveats` before selecting follow-up work.", "");
98
+ return lines.join("\n");
99
+ }
100
+ export function writeStartupReports(metrics, outputDir) {
101
+ fs.mkdirSync(outputDir, { recursive: true });
102
+ const jsonPath = path.join(outputDir, STARTUP_REPORT_JSON);
103
+ const markdownPath = path.join(outputDir, STARTUP_REPORT_MARKDOWN);
104
+ fs.writeFileSync(jsonPath, pyJsonIndent(metrics) + "\n");
105
+ fs.writeFileSync(markdownPath, renderStartupReport(metrics));
106
+ return { structured: jsonPath, human_readable: markdownPath };
107
+ }
108
+ // ===========================================================================
109
+ // Slice 6: benchmark persistence + intermediate building + corpus-file extraction
110
+ // (extract_*_from_runtime_stores depends on extract_corpus and lands in Phase 10)
111
+ // ===========================================================================
112
+ //# sourceMappingURL=report.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"report.js","sourceRoot":"","sources":["../../../src/state/startupAnalysis/report.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,500 @@
1
+ import { canonicalArtifactLabel, hashLabel, loadContract } from "./contract.js";
2
+ import { inc, counterDict, countMatches, recordLabel, recordThresholdText, detailMetrics, thresholdWarnings, detailLossStatus, argumentsText, CLI_COMMAND_ARTIFACTS, QUERY_ARTIFACTS, toolName, toolArgument, capabilityInvocation, introCapability, BUDGET_PRESSURE_RE, FULL_PLAN_BUDGET_RE, POST_AUDIT_FLAG_RE, } from "./helpers.js";
3
+ export const THRESHOLD_EVIDENCE_ENVELOPE = "threshold_evidence_scan_v1";
4
+ export const THRESHOLD_CLASSIFICATION_ENVELOPE = "threshold_evidence_classification_v1";
5
+ export const STATE_EVENT_CLASSES = new Set([
6
+ "cli_state_call",
7
+ "raw_artifact_access",
8
+ "capability_prose_read",
9
+ "implementation_boundary",
10
+ "non_state_context",
11
+ ]);
12
+ export const BOUNDARY_DEGRADATION_REASONS = new Set([
13
+ "pre_boundary_record",
14
+ "missing_timestamp",
15
+ "malformed_record",
16
+ "missing_conversation_key",
17
+ "no_agentera_state_sequence",
18
+ "privacy_redaction_required",
19
+ ]);
20
+ export const BOUNDED_RUNTIME_STATUSES = new Set([
21
+ "ok",
22
+ "available",
23
+ "missing",
24
+ "sparse",
25
+ "degraded",
26
+ "skipped",
27
+ ]);
28
+ export const BOUNDED_RUNTIME_REASONS = new Set([
29
+ "candidate_files_found",
30
+ "disabled",
31
+ "extractor_unimplemented",
32
+ "no_candidate_files",
33
+ "no_runtime_stores_approved",
34
+ "no_matching_records",
35
+ "records_extracted",
36
+ "schema_divergent",
37
+ "store_absent",
38
+ "store_locked",
39
+ "store_not_directory",
40
+ "store_unreadable",
41
+ ]);
42
+ export function boundedRuntimeStatus(status) {
43
+ const runtime = String(status.runtime ?? "unknown");
44
+ const state = String(status.status ?? "degraded");
45
+ const reason = String(status.reason ?? "schema_divergent");
46
+ const item = {
47
+ runtime,
48
+ status: BOUNDED_RUNTIME_STATUSES.has(state) ? state : "degraded",
49
+ reason: BOUNDED_RUNTIME_REASONS.has(reason) ? reason : "schema_divergent",
50
+ };
51
+ for (const key of ["file_count", "record_count", "error_count"]) {
52
+ const value = status[key];
53
+ if (typeof value === "number" && Number.isInteger(value))
54
+ item[key] = value;
55
+ }
56
+ if (Array.isArray(status.remediation_labels)) {
57
+ item.remediation_labels = status.remediation_labels.map((l) => String(l));
58
+ }
59
+ return item;
60
+ }
61
+ export const STATE_CLI_COMMANDS = new Set([
62
+ "status",
63
+ "prime",
64
+ "plan",
65
+ "progress",
66
+ "health",
67
+ "todo",
68
+ "decisions",
69
+ "docs",
70
+ "objective",
71
+ "experiments",
72
+ "query",
73
+ ]);
74
+ export function startupConversationKey(record) {
75
+ const key = record.conversation_key;
76
+ if (typeof key === "string" && key)
77
+ return key;
78
+ const sid = record.session_id;
79
+ if (typeof sid === "string" && sid)
80
+ return sid;
81
+ const data = record.data;
82
+ if (data && typeof data === "object" && !Array.isArray(data)) {
83
+ const dsid = data.session_id;
84
+ if (typeof dsid === "string" && dsid)
85
+ return dsid;
86
+ }
87
+ const ssid = record.source_id;
88
+ if (typeof ssid === "string" && ssid)
89
+ return ssid;
90
+ return null;
91
+ }
92
+ function stateCliCommand(command) {
93
+ if (!command)
94
+ return null;
95
+ const tokens = command.replace(/"/g, " ").replace(/'/g, " ").split(/\s+/).filter((t) => t);
96
+ for (let i = 0; i < tokens.length - 1; i++) {
97
+ if (tokens[i].endsWith("agentera") && STATE_CLI_COMMANDS.has(tokens[i + 1])) {
98
+ return tokens[i + 1];
99
+ }
100
+ }
101
+ return null;
102
+ }
103
+ function stateCliArtifacts(command, stateCommand) {
104
+ if (stateCommand === "query") {
105
+ const tokens = command.replace(/"/g, " ").replace(/'/g, " ").split(/\s+/).filter((t) => t);
106
+ for (let i = 0; i < tokens.length - 1; i++) {
107
+ if (tokens[i].endsWith("agentera") && tokens[i + 1] === "query") {
108
+ for (const arg of tokens.slice(i + 2)) {
109
+ const label = QUERY_ARTIFACTS[arg.toLowerCase()];
110
+ if (label)
111
+ return new Set([label]);
112
+ }
113
+ return new Set();
114
+ }
115
+ }
116
+ }
117
+ return new Set(CLI_COMMAND_ARTIFACTS[stateCommand] ?? []);
118
+ }
119
+ export function classifyStartupEvent(record) {
120
+ if (!record || typeof record !== "object" || Array.isArray(record) || record.source_kind !== "tool_call") {
121
+ return ["non_state_context", null, null, new Set()];
122
+ }
123
+ const tool = toolName(record).toLowerCase();
124
+ const command = toolArgument(record, "command");
125
+ if (tool === "bash") {
126
+ const stateCommand = stateCliCommand(command);
127
+ if (stateCommand) {
128
+ return ["cli_state_call", null, stateCommand, stateCliArtifacts(command, stateCommand)];
129
+ }
130
+ return ["implementation_boundary", null, null, new Set()];
131
+ }
132
+ const argsText = argumentsText(record).replace(/\\/g, "/");
133
+ if (["read", "grep", "glob"].includes(tool) &&
134
+ (argsText.includes("skills/agentera/capabilities/") ||
135
+ argsText.includes("skills/agentera/SKILL.md") ||
136
+ argsText.includes("skills/agentera/protocol.yaml"))) {
137
+ return ["capability_prose_read", argsText.includes("SKILL.md") ? "SKILL.md" : null, null, new Set()];
138
+ }
139
+ const artifactLabel = ["read", "grep", "glob"].includes(tool) ? canonicalArtifactLabel(argsText) : null;
140
+ if (artifactLabel) {
141
+ return ["raw_artifact_access", artifactLabel, null, new Set()];
142
+ }
143
+ if (["apply_patch", "edit", "write"].includes(tool)) {
144
+ return ["implementation_boundary", null, null, new Set()];
145
+ }
146
+ return ["non_state_context", null, null, new Set()];
147
+ }
148
+ function eventWarningKeys(event) {
149
+ const keys = [];
150
+ for (const warning of Array.isArray(event.warnings) ? event.warnings : []) {
151
+ if (!warning || typeof warning !== "object" || Array.isArray(warning))
152
+ continue;
153
+ const family = warning.family;
154
+ const category = warning.category;
155
+ if (typeof family === "string" && typeof category === "string")
156
+ keys.push(`${family}.${category}`);
157
+ }
158
+ return keys;
159
+ }
160
+ function eventClassification(event, coverageCaveated) {
161
+ const status = event.detail_loss_status;
162
+ if (status === "possible_useful_detail_removed")
163
+ return "likely_false_positive";
164
+ if (status === "retained_artifact_false_positive_signal")
165
+ return "likely_false_positive";
166
+ if (status === "possible_compression_without_anchor_loss" || status === "not_detected")
167
+ return "legitimate_pressure";
168
+ if (coverageCaveated)
169
+ return "unsupported_by_available_coverage";
170
+ return "inconclusive";
171
+ }
172
+ function categoryClassification(counts) {
173
+ if (counts.likely_false_positive)
174
+ return "likely_false_positive";
175
+ if (counts.unsupported_by_available_coverage)
176
+ return "unsupported_by_available_coverage";
177
+ if (counts.inconclusive)
178
+ return "inconclusive";
179
+ return "legitimate_pressure";
180
+ }
181
+ function nowIsoSeconds() {
182
+ return new Date().toISOString().replace(/\.\d{3}Z$/, "+00:00");
183
+ }
184
+ export function scanThresholdEvidence(corpus, opts) {
185
+ const salt = opts.salt;
186
+ const loaded = opts.contract ?? loadContract();
187
+ let records = corpus && typeof corpus === "object" && !Array.isArray(corpus) ? (corpus.records ?? []) : [];
188
+ if (!Array.isArray(records))
189
+ records = [];
190
+ let metadata = corpus && typeof corpus === "object" && !Array.isArray(corpus) ? (corpus.metadata ?? {}) : {};
191
+ if (!metadata || typeof metadata !== "object" || Array.isArray(metadata))
192
+ metadata = {};
193
+ let runtimeStatuses = metadata.runtime_statuses;
194
+ if (!Array.isArray(runtimeStatuses))
195
+ runtimeStatuses = [];
196
+ const runtimeCoverage = runtimeStatuses
197
+ .filter((s) => s !== null && typeof s === "object" && !Array.isArray(s))
198
+ .map((s) => boundedRuntimeStatus(s));
199
+ const coverageCaveats = [];
200
+ if (runtimeCoverage.length === 0) {
201
+ coverageCaveats.push("No runtime coverage metadata was available for threshold evidence scanning.");
202
+ }
203
+ if (runtimeCoverage.some((s) => ["missing", "sparse", "degraded", "skipped"].includes(s.status))) {
204
+ coverageCaveats.push("Runtime coverage is incomplete or degraded; absence of warning evidence is not proof of absence.");
205
+ }
206
+ const groups = new Map();
207
+ const degradations = [];
208
+ for (const record of records) {
209
+ if (!record || typeof record !== "object" || Array.isArray(record)) {
210
+ degradations.push({ reason: "malformed_record" });
211
+ continue;
212
+ }
213
+ const key = startupConversationKey(record);
214
+ if (key === null) {
215
+ degradations.push({ record: recordLabel(record, salt), reason: "missing_conversation_key" });
216
+ continue;
217
+ }
218
+ if (!groups.has(key))
219
+ groups.set(key, []);
220
+ groups.get(key).push(record);
221
+ }
222
+ const warningCounts = {};
223
+ const artifactCounts = {};
224
+ const capabilityCounts = {};
225
+ const sourceCounts = {};
226
+ const detailStatusCounts = {};
227
+ const warningEvents = [];
228
+ for (const [conversationKey, items] of groups) {
229
+ items.sort((a, b) => {
230
+ const ta = String(a.timestamp ?? "");
231
+ const tb = String(b.timestamp ?? "");
232
+ return ta < tb ? -1 : ta > tb ? 1 : 0;
233
+ });
234
+ let capability = "unknown";
235
+ let pending = [];
236
+ for (const record of items) {
237
+ const text = recordThresholdText(record);
238
+ const data = record.data && typeof record.data === "object" && !Array.isArray(record.data) ? record.data : {};
239
+ const actor = data.actor;
240
+ if (actor === "user") {
241
+ capability = capabilityInvocation(text) || "unknown";
242
+ pending = [];
243
+ continue;
244
+ }
245
+ if (actor === "assistant") {
246
+ capability = introCapability(text) || capability;
247
+ }
248
+ const warnings = thresholdWarnings(text);
249
+ if (warnings.length > 0) {
250
+ const artifactLabel = canonicalArtifactLabel(text, loaded) || "unknown";
251
+ const beforeMetrics = detailMetrics(text);
252
+ const event = {
253
+ event_label: recordLabel(record, salt),
254
+ conversation: hashLabel("session", conversationKey, salt),
255
+ capability,
256
+ artifact_label: artifactLabel,
257
+ warnings,
258
+ detail_loss_status: "not_assessed",
259
+ rewrite_followup: null,
260
+ observed_counts: {
261
+ warning_word_count: beforeMetrics.word_count,
262
+ warning_anchor_count: beforeMetrics.anchor_count,
263
+ },
264
+ };
265
+ warningEvents.push(event);
266
+ pending.push({ event, metrics: beforeMetrics });
267
+ inc(artifactCounts, artifactLabel);
268
+ inc(capabilityCounts, capability);
269
+ for (const warning of warnings) {
270
+ inc(warningCounts, `${warning.family}.${warning.category}`);
271
+ inc(sourceCounts, warning.threshold_source);
272
+ }
273
+ }
274
+ if (pending.length > 0 && record.source_kind === "tool_call") {
275
+ const [eventClass] = classifyStartupEvent(record);
276
+ if (eventClass === "implementation_boundary") {
277
+ const afterMetrics = detailMetrics(text);
278
+ for (const pendingItem of pending) {
279
+ const event = pendingItem.event;
280
+ if (event.rewrite_followup !== null)
281
+ continue;
282
+ const status = detailLossStatus(pendingItem.metrics, afterMetrics);
283
+ event.detail_loss_status = status;
284
+ event.rewrite_followup = {
285
+ event_label: recordLabel(record, salt),
286
+ event_class: eventClass,
287
+ word_count_delta: afterMetrics.word_count - pendingItem.metrics.word_count,
288
+ anchor_count_delta: afterMetrics.anchor_count - pendingItem.metrics.anchor_count,
289
+ };
290
+ inc(detailStatusCounts, status);
291
+ }
292
+ pending = [];
293
+ }
294
+ }
295
+ }
296
+ for (const pendingItem of pending) {
297
+ inc(detailStatusCounts, pendingItem.event.detail_loss_status);
298
+ }
299
+ }
300
+ if (degradations.length > 0) {
301
+ coverageCaveats.push("One or more records were skipped because they were malformed or lacked conversation identity.");
302
+ }
303
+ return {
304
+ output_envelope: THRESHOLD_EVIDENCE_ENVELOPE,
305
+ contract_version: loaded.version,
306
+ generated_at: nowIsoSeconds(),
307
+ total_records: records.length,
308
+ runtime_coverage: runtimeCoverage,
309
+ coverage_caveats: [...new Set(coverageCaveats)],
310
+ counts: {
311
+ warning_events: warningEvents.length,
312
+ by_warning: counterDict(warningCounts),
313
+ by_artifact: counterDict(artifactCounts),
314
+ by_capability: counterDict(capabilityCounts),
315
+ by_threshold_source: counterDict(sourceCounts),
316
+ by_detail_loss_status: counterDict(detailStatusCounts),
317
+ },
318
+ warning_events: warningEvents,
319
+ degradations,
320
+ privacy_redaction_summary: {
321
+ raw_transcript_text: "not_emitted",
322
+ raw_tool_arguments: "not_emitted",
323
+ full_local_paths: "not_emitted",
324
+ raw_store_paths: "not_emitted",
325
+ session_ids: "salted_or_not_emitted",
326
+ artifact_labels: "canonical_only",
327
+ },
328
+ };
329
+ }
330
+ export function scanRetainedThresholdEvidence(artifacts, opts) {
331
+ const salt = opts.salt;
332
+ const loaded = opts.contract ?? loadContract();
333
+ const warningCounts = {};
334
+ const artifactCounts = {};
335
+ const sourceCounts = {};
336
+ const detailStatusCounts = {};
337
+ const warningEvents = [];
338
+ for (const sourceLabel of Object.keys(artifacts).sort()) {
339
+ const text = artifacts[sourceLabel];
340
+ if (typeof sourceLabel !== "string" || typeof text !== "string")
341
+ continue;
342
+ const artifactLabel = canonicalArtifactLabel(sourceLabel, loaded) || canonicalArtifactLabel(text, loaded) || "unknown";
343
+ const warnings = thresholdWarnings(text);
344
+ if (warnings.length === 0)
345
+ continue;
346
+ const postAuditMarkers = countMatches(POST_AUDIT_FLAG_RE, text);
347
+ const budgetMentions = countMatches(BUDGET_PRESSURE_RE, text);
348
+ const fullPlanBudgetPressure = artifactLabel === "plan" && budgetMentions > 0 && FULL_PLAN_BUDGET_RE.test(text);
349
+ const detailStatus = postAuditMarkers && fullPlanBudgetPressure ? "retained_artifact_false_positive_signal" : "not_assessed";
350
+ const event = {
351
+ event_label: hashLabel("record", sourceLabel, salt),
352
+ conversation: "retained_artifacts",
353
+ capability: "agentera",
354
+ artifact_label: artifactLabel,
355
+ evidence_source: "retained_artifact",
356
+ warnings,
357
+ detail_loss_status: detailStatus,
358
+ rewrite_followup: null,
359
+ observed_counts: {
360
+ post_audit_flag_markers: postAuditMarkers,
361
+ budget_pressure_mentions: budgetMentions,
362
+ },
363
+ };
364
+ warningEvents.push(event);
365
+ inc(artifactCounts, artifactLabel);
366
+ inc(detailStatusCounts, detailStatus);
367
+ for (const warning of warnings) {
368
+ inc(warningCounts, `${warning.family}.${warning.category}`);
369
+ inc(sourceCounts, warning.threshold_source);
370
+ }
371
+ }
372
+ return {
373
+ output_envelope: THRESHOLD_EVIDENCE_ENVELOPE,
374
+ contract_version: loaded.version,
375
+ generated_at: nowIsoSeconds(),
376
+ total_records: Object.keys(artifacts).length,
377
+ runtime_coverage: [],
378
+ coverage_caveats: [],
379
+ counts: {
380
+ warning_events: warningEvents.length,
381
+ by_warning: counterDict(warningCounts),
382
+ by_artifact: counterDict(artifactCounts),
383
+ by_capability: warningEvents.length > 0 ? { agentera: warningEvents.length } : {},
384
+ by_threshold_source: counterDict(sourceCounts),
385
+ by_detail_loss_status: counterDict(detailStatusCounts),
386
+ },
387
+ warning_events: warningEvents,
388
+ degradations: [],
389
+ privacy_redaction_summary: {
390
+ raw_artifact_text: "not_emitted",
391
+ raw_transcript_text: "not_emitted",
392
+ raw_tool_arguments: "not_emitted",
393
+ full_local_paths: "not_emitted",
394
+ artifact_labels: "canonical_only",
395
+ },
396
+ };
397
+ }
398
+ export function classifyThresholdEvidence(scan) {
399
+ let events = scan.warning_events;
400
+ if (!Array.isArray(events))
401
+ events = [];
402
+ let coverageCaveats = scan.coverage_caveats;
403
+ if (!Array.isArray(coverageCaveats))
404
+ coverageCaveats = [];
405
+ const byCategory = new Map();
406
+ const coverageCaveated = coverageCaveats.length > 0;
407
+ const unsupported = coverageCaveats.length > 0 && events.length === 0;
408
+ for (const event of events) {
409
+ if (!event || typeof event !== "object" || Array.isArray(event))
410
+ continue;
411
+ const classification = eventClassification(event, coverageCaveated);
412
+ const artifact = typeof event.artifact_label === "string" ? event.artifact_label : "unknown";
413
+ const capability = typeof event.capability === "string" ? event.capability : "unknown";
414
+ const detailStatus = typeof event.detail_loss_status === "string" ? event.detail_loss_status : "not_assessed";
415
+ for (const key of eventWarningKeys(event)) {
416
+ let entry = byCategory.get(key);
417
+ if (!entry) {
418
+ entry = {
419
+ warning: key,
420
+ event_count: 0,
421
+ artifacts: new Set(),
422
+ capabilities: new Set(),
423
+ classification_counts: {},
424
+ detail_loss_status_counts: {},
425
+ event_labels: [],
426
+ };
427
+ byCategory.set(key, entry);
428
+ }
429
+ entry.event_count += 1;
430
+ entry.artifacts.add(artifact);
431
+ entry.capabilities.add(capability);
432
+ inc(entry.classification_counts, classification);
433
+ inc(entry.detail_loss_status_counts, detailStatus);
434
+ if (typeof event.event_label === "string")
435
+ entry.event_labels.push(event.event_label);
436
+ }
437
+ }
438
+ const categories = [];
439
+ let repeatedFalsePositive = false;
440
+ const classificationCounts = {};
441
+ for (const key of [...byCategory.keys()].sort()) {
442
+ const entry = byCategory.get(key);
443
+ const classification = categoryClassification(entry.classification_counts);
444
+ inc(classificationCounts, classification);
445
+ if (classification === "likely_false_positive" && entry.event_count >= 2)
446
+ repeatedFalsePositive = true;
447
+ categories.push({
448
+ warning: key,
449
+ classification,
450
+ event_count: entry.event_count,
451
+ artifacts: [...entry.artifacts].sort(),
452
+ capabilities: [...entry.capabilities].sort(),
453
+ event_classification_counts: counterDict(entry.classification_counts),
454
+ detail_loss_status_counts: counterDict(entry.detail_loss_status_counts),
455
+ event_labels: entry.event_labels,
456
+ });
457
+ }
458
+ if (unsupported)
459
+ inc(classificationCounts, "unsupported_by_available_coverage");
460
+ let recommendation;
461
+ if (repeatedFalsePositive) {
462
+ recommendation = {
463
+ action: "consider_minimal_threshold_or_diagnostic_change",
464
+ reason: "At least one warning category has repeated redacted evidence of possible useful detail removal.",
465
+ };
466
+ }
467
+ else if (unsupported) {
468
+ recommendation = {
469
+ action: "defer_without_threshold_change",
470
+ reason: "Available runtime coverage cannot support a false-positive conclusion.",
471
+ };
472
+ }
473
+ else {
474
+ recommendation = {
475
+ action: "no_threshold_change_yet",
476
+ reason: "False-positive evidence is absent, single-instance, legitimate pressure, or inconclusive.",
477
+ };
478
+ }
479
+ return {
480
+ output_envelope: THRESHOLD_CLASSIFICATION_ENVELOPE,
481
+ input_envelope: scan.output_envelope,
482
+ generated_at: nowIsoSeconds(),
483
+ categories,
484
+ counts: {
485
+ by_classification: counterDict(classificationCounts),
486
+ category_count: categories.length,
487
+ repeated_false_positive_categories: categories.filter((c) => c.classification === "likely_false_positive" && Number(c.event_count) >= 2).length,
488
+ },
489
+ recommendation,
490
+ coverage_caveats: coverageCaveats.map((c) => String(c)),
491
+ privacy_redaction_summary: scan.privacy_redaction_summary || {
492
+ raw_transcript_text: "not_emitted",
493
+ raw_tool_arguments: "not_emitted",
494
+ },
495
+ };
496
+ }
497
+ // ===========================================================================
498
+ // Slice 3: startup record classification into state-gathering sequences
499
+ // ===========================================================================
500
+ //# sourceMappingURL=threshold.js.map