@mindrian_os/cli 1.13.0-beta.10 → 1.13.0-beta.44

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 (590) hide show
  1. package/CHANGELOG.md +348 -13
  2. package/README.md +76 -579
  3. package/bin/cli.js +166 -40
  4. package/lib/core/active-plugin-root.cjs +207 -0
  5. package/package.json +7 -13
  6. package/.claude-plugin/plugin.json +0 -21
  7. package/.mcp.json +0 -9
  8. package/agents/brain-query.md +0 -80
  9. package/agents/framework-runner.md +0 -237
  10. package/agents/grading.md +0 -188
  11. package/agents/investor.md +0 -128
  12. package/agents/larry-extended.md +0 -135
  13. package/agents/opportunity-scanner.md +0 -91
  14. package/agents/persona-analyst.md +0 -132
  15. package/agents/research.md +0 -89
  16. package/agents/reverse-salient-agent.md +0 -27
  17. package/bin/mindrian-mcp-server.cjs +0 -182
  18. package/bin/mindrian-tools.cjs +0 -765
  19. package/commands/act.md +0 -433
  20. package/commands/admin.md +0 -404
  21. package/commands/analyze-needs.md +0 -36
  22. package/commands/analyze-systems.md +0 -33
  23. package/commands/analyze-timing.md +0 -36
  24. package/commands/auto-explore.md +0 -64
  25. package/commands/beautiful-question.md +0 -34
  26. package/commands/brain-derive.md +0 -78
  27. package/commands/build-knowledge.md +0 -36
  28. package/commands/build-thesis.md +0 -40
  29. package/commands/causal.md +0 -228
  30. package/commands/challenge-assumptions.md +0 -33
  31. package/commands/compare-ventures.md +0 -77
  32. package/commands/dashboard.md +0 -110
  33. package/commands/deep-grade.md +0 -76
  34. package/commands/diagnose.md +0 -52
  35. package/commands/diagnostics.md +0 -145
  36. package/commands/doctor.md +0 -151
  37. package/commands/dominant-designs.md +0 -34
  38. package/commands/explain-decision.md +0 -87
  39. package/commands/explore-domains.md +0 -36
  40. package/commands/explore-futures.md +0 -34
  41. package/commands/explore-trends.md +0 -36
  42. package/commands/export.md +0 -103
  43. package/commands/file-meeting.md +0 -724
  44. package/commands/find-analogies.md +0 -182
  45. package/commands/find-bottlenecks.md +0 -56
  46. package/commands/find-connections.md +0 -70
  47. package/commands/funding.md +0 -81
  48. package/commands/grade.md +0 -197
  49. package/commands/graph.md +0 -128
  50. package/commands/hat-briefing.md +0 -119
  51. package/commands/heal.md +0 -196
  52. package/commands/help.md +0 -399
  53. package/commands/hmi-status.md +0 -172
  54. package/commands/jtbd.md +0 -241
  55. package/commands/leadership.md +0 -73
  56. package/commands/lean-canvas.md +0 -34
  57. package/commands/macro-trends.md +0 -34
  58. package/commands/map-unknowns.md +0 -34
  59. package/commands/memory.md +0 -173
  60. package/commands/models.md +0 -175
  61. package/commands/mos-reason.md +0 -279
  62. package/commands/mullins.md +0 -114
  63. package/commands/new-project.md +0 -481
  64. package/commands/onboard.md +0 -434
  65. package/commands/operator.md +0 -149
  66. package/commands/opportunities.md +0 -144
  67. package/commands/organize.md +0 -497
  68. package/commands/persona.md +0 -192
  69. package/commands/pipeline.md +0 -106
  70. package/commands/present.md +0 -91
  71. package/commands/publish.md +0 -201
  72. package/commands/query.md +0 -124
  73. package/commands/radar.md +0 -72
  74. package/commands/reanalyze.md +0 -91
  75. package/commands/research.md +0 -190
  76. package/commands/room.md +0 -352
  77. package/commands/rooms.md +0 -598
  78. package/commands/root-cause.md +0 -34
  79. package/commands/rs-experts.md +0 -79
  80. package/commands/rs-explain.md +0 -94
  81. package/commands/rs-fetch.md +0 -88
  82. package/commands/rs-thesis.md +0 -79
  83. package/commands/scenario-plan.md +0 -34
  84. package/commands/scheduled-tasks.md +0 -285
  85. package/commands/score-innovation.md +0 -37
  86. package/commands/scout.md +0 -239
  87. package/commands/setup.md +0 -618
  88. package/commands/snapshot.md +0 -147
  89. package/commands/speakers.md +0 -84
  90. package/commands/splash.md +0 -28
  91. package/commands/status.md +0 -75
  92. package/commands/structure-argument.md +0 -36
  93. package/commands/suggest-next.md +0 -74
  94. package/commands/systems-thinking.md +0 -34
  95. package/commands/think-hats.md +0 -36
  96. package/commands/update.md +0 -181
  97. package/commands/user-needs.md +0 -34
  98. package/commands/validate.md +0 -34
  99. package/commands/value-proposition.md +0 -55
  100. package/commands/vault.md +0 -180
  101. package/commands/visualize.md +0 -52
  102. package/commands/whitespace.md +0 -501
  103. package/commands/wiki.md +0 -69
  104. package/hooks/hooks.json +0 -381
  105. package/hooks/run-hook.cmd +0 -64
  106. package/lib/__init__.py +0 -0
  107. package/lib/__pycache__/__init__.cpython-312.pyc +0 -0
  108. package/lib/agents/auto-explore-agent.cjs +0 -1043
  109. package/lib/agents/reverse-salient-agent.cjs +0 -679
  110. package/lib/agents/tension-hook-agent.cjs +0 -544
  111. package/lib/chat/chat-context.js +0 -185
  112. package/lib/chat/chat-panel.js +0 -721
  113. package/lib/chat/fabric-chat.cjs +0 -288
  114. package/lib/chat/generative-tools.js +0 -219
  115. package/lib/conversation/ROOM.md +0 -39
  116. package/lib/conversation/classifier-rules.json +0 -38
  117. package/lib/conversation/classifier.cjs +0 -264
  118. package/lib/conversation/operator.cjs +0 -287
  119. package/lib/copy/115-spec-strings.cjs +0 -55
  120. package/lib/core/__init__.py +0 -0
  121. package/lib/core/__nav-stub.cjs +0 -14
  122. package/lib/core/__pycache__/__init__.cpython-312.pyc +0 -0
  123. package/lib/core/__pycache__/rs-math.cpython-312.pyc +0 -0
  124. package/lib/core/__pycache__/rs_cache.cpython-312.pyc +0 -0
  125. package/lib/core/__pycache__/rs_corpus.cpython-312.pyc +0 -0
  126. package/lib/core/__pycache__/rs_hybrid.cpython-312.pyc +0 -0
  127. package/lib/core/__pycache__/rs_math.cpython-312.pyc +0 -0
  128. package/lib/core/__pycache__/rs_rooms.cpython-312.pyc +0 -0
  129. package/lib/core/artifact-id.cjs +0 -148
  130. package/lib/core/asset-ops.cjs +0 -151
  131. package/lib/core/auto-commit-throttle.cjs +0 -129
  132. package/lib/core/bearer-token.cjs +0 -199
  133. package/lib/core/brain-client.cjs +0 -865
  134. package/lib/core/brain-derivation-prompts.cjs +0 -326
  135. package/lib/core/brain-derivation-queue.cjs +0 -431
  136. package/lib/core/brain-derivation.cjs +0 -580
  137. package/lib/core/brain-md-schema.cjs +0 -528
  138. package/lib/core/brain-md-staleness.cjs +0 -357
  139. package/lib/core/brain-response-sanitize.cjs +0 -188
  140. package/lib/core/bridge-writer.cjs +0 -477
  141. package/lib/core/chat-context-builder.cjs +0 -253
  142. package/lib/core/cross-room-aggregator.cjs +0 -762
  143. package/lib/core/daily-briefing.cjs +0 -438
  144. package/lib/core/decision-capture.cjs +0 -618
  145. package/lib/core/deep-links.cjs +0 -82
  146. package/lib/core/dispatch-optimizer.cjs +0 -354
  147. package/lib/core/dual-path-detector.cjs +0 -84
  148. package/lib/core/dual-path-detector.test.cjs +0 -334
  149. package/lib/core/exports-log.cjs +0 -79
  150. package/lib/core/feynman-minto-invariants.cjs +0 -605
  151. package/lib/core/folder-memory-async.cjs +0 -338
  152. package/lib/core/folder-memory-shared.cjs +0 -890
  153. package/lib/core/folder-memory.cjs +0 -416
  154. package/lib/core/framework-chain-composer.cjs +0 -411
  155. package/lib/core/frontmatter-schemas.cjs +0 -330
  156. package/lib/core/git-ops.cjs +0 -141
  157. package/lib/core/graph-ops.cjs +0 -258
  158. package/lib/core/hat-persistence.cjs +0 -362
  159. package/lib/core/index.cjs +0 -60
  160. package/lib/core/integration-registry.cjs +0 -232
  161. package/lib/core/intelligence-cascade.cjs +0 -661
  162. package/lib/core/lazygraph-ops.cjs +0 -1057
  163. package/lib/core/lru-cache.cjs +0 -139
  164. package/lib/core/mcp-profiles.cjs +0 -182
  165. package/lib/core/meeting-ops.cjs +0 -54
  166. package/lib/core/memory-ops.cjs +0 -600
  167. package/lib/core/migrations/ROOM.md +0 -33
  168. package/lib/core/migrations/phase-109-nodes-provenance.cjs +0 -339
  169. package/lib/core/migrations/phase-109-session-focus.cjs +0 -99
  170. package/lib/core/model-profiles.cjs +0 -246
  171. package/lib/core/mullins-scaffold.cjs +0 -160
  172. package/lib/core/nav-dial.cjs +0 -316
  173. package/lib/core/navigation/ROOM.md +0 -15
  174. package/lib/core/navigation/explanation.cjs +0 -43
  175. package/lib/core/navigation/focus.cjs +0 -135
  176. package/lib/core/navigation/ingestion.cjs +0 -82
  177. package/lib/core/navigation/insights.cjs +0 -350
  178. package/lib/core/navigation/memory-events.cjs +0 -118
  179. package/lib/core/navigation/neighborhood.cjs +0 -78
  180. package/lib/core/navigation/packet.cjs +0 -182
  181. package/lib/core/navigation/room-home.cjs +0 -127
  182. package/lib/core/navigation/transitions.cjs +0 -82
  183. package/lib/core/navigation-engine-shared.cjs +0 -242
  184. package/lib/core/navigation-engine.cjs +0 -664
  185. package/lib/core/navigation.cjs +0 -60
  186. package/lib/core/nl-graph-queries.cjs +0 -164
  187. package/lib/core/offer-presenter.cjs +0 -406
  188. package/lib/core/opportunity-extractor.cjs +0 -183
  189. package/lib/core/opportunity-ops.cjs +0 -1371
  190. package/lib/core/persona-ops.cjs +0 -537
  191. package/lib/core/persona-taxonomy.cjs +0 -190
  192. package/lib/core/platform-gates.cjs +0 -120
  193. package/lib/core/platform.cjs +0 -257
  194. package/lib/core/proactive-intelligence.cjs +0 -528
  195. package/lib/core/problem-type-router.cjs +0 -315
  196. package/lib/core/reasoning-ops.cjs +0 -639
  197. package/lib/core/reverse-salient-persona-suffix.cjs +0 -115
  198. package/lib/core/room-classifier-strict-mode.cjs +0 -229
  199. package/lib/core/room-db.cjs +0 -127
  200. package/lib/core/room-ops-async.cjs +0 -92
  201. package/lib/core/room-ops-shared.cjs +0 -64
  202. package/lib/core/room-ops-sync.cjs +0 -70
  203. package/lib/core/room-ops.cjs +0 -32
  204. package/lib/core/room-type-detector.cjs +0 -386
  205. package/lib/core/rs-brain-substrate-prompts.cjs +0 -129
  206. package/lib/core/rs-brain-substrate.cjs +0 -570
  207. package/lib/core/rs-breakthrough-scorer.cjs +0 -255
  208. package/lib/core/rs-canon-violations.cjs +0 -82
  209. package/lib/core/rs-chain-feeder.cjs +0 -343
  210. package/lib/core/rs-commercial-assessor.cjs +0 -280
  211. package/lib/core/rs-differential-scorer.cjs +0 -376
  212. package/lib/core/rs-domain-analyzer.cjs +0 -385
  213. package/lib/core/rs-egress-prompts.cjs +0 -113
  214. package/lib/core/rs-egress-telemetry.cjs +0 -225
  215. package/lib/core/rs-egress-violations.cjs +0 -53
  216. package/lib/core/rs-expert-mapper.cjs +0 -467
  217. package/lib/core/rs-fetcher-academic.cjs +0 -697
  218. package/lib/core/rs-fetcher-experts.cjs +0 -314
  219. package/lib/core/rs-fetcher-industry.cjs +0 -731
  220. package/lib/core/rs-fetcher-patents.cjs +0 -564
  221. package/lib/core/rs-innovation-classifier.cjs +0 -194
  222. package/lib/core/rs-mind-map.cjs +0 -656
  223. package/lib/core/rs-neo4j-writer.cjs +0 -388
  224. package/lib/core/rs-nl-to-query.cjs +0 -425
  225. package/lib/core/rs-pinecone-bridge.cjs +0 -303
  226. package/lib/core/rs-preprocessor.cjs +0 -350
  227. package/lib/core/rs-query-matrix.cjs +0 -316
  228. package/lib/core/rs-query-to-text.cjs +0 -438
  229. package/lib/core/rs-sqlite-mirror.cjs +0 -443
  230. package/lib/core/rs-thesis-generator.cjs +0 -188
  231. package/lib/core/rs_cache.py +0 -479
  232. package/lib/core/rs_corpus.py +0 -468
  233. package/lib/core/rs_hybrid.py +0 -586
  234. package/lib/core/rs_math.py +0 -287
  235. package/lib/core/rs_rooms.py +0 -193
  236. package/lib/core/scheduled-scanner.cjs +0 -463
  237. package/lib/core/scratchpad-ops.cjs +0 -201
  238. package/lib/core/section-8-trace-schema.cjs +0 -138
  239. package/lib/core/section-registry.cjs +0 -111
  240. package/lib/core/session-state.cjs +0 -144
  241. package/lib/core/shallow-doc-parser.cjs +0 -174
  242. package/lib/core/shallow-doc-parser.test.cjs +0 -226
  243. package/lib/core/skill-activation-router.cjs +0 -284
  244. package/lib/core/state-ops.cjs +0 -46
  245. package/lib/core/statusline-cache.cjs +0 -266
  246. package/lib/core/token-estimator.cjs +0 -348
  247. package/lib/core/user-archetype.cjs +0 -239
  248. package/lib/core/user-md-ops.cjs +0 -524
  249. package/lib/core/visual-ops.cjs +0 -624
  250. package/lib/core/write-lock.cjs +0 -149
  251. package/lib/graph/canvas-graph.js +0 -467
  252. package/lib/graph/constellation-config.cjs +0 -299
  253. package/lib/graph/graph-detail-panel.js +0 -165
  254. package/lib/hmi/ROOM.md +0 -47
  255. package/lib/hmi/across-session-memory.cjs +0 -604
  256. package/lib/hmi/cross-room-memory.cjs +0 -575
  257. package/lib/hmi/decoy-tier.cjs +0 -395
  258. package/lib/hmi/jtbd-classifier.cjs +0 -219
  259. package/lib/hmi/jtbd-state.cjs +0 -199
  260. package/lib/hmi/jtbd-taxonomy.json +0 -392
  261. package/lib/hmi/selector-dispatcher.cjs +0 -546
  262. package/lib/hmi/selector-telemetry.cjs +0 -263
  263. package/lib/hmi/shape-f0-renderer.cjs +0 -139
  264. package/lib/hmi/shape-f1-fallback.cjs +0 -80
  265. package/lib/hmi/shape-f1-renderer.cjs +0 -138
  266. package/lib/hmi/shape-f2-renderer.cjs +0 -132
  267. package/lib/hmi/shape-f3-renderer.cjs +0 -66
  268. package/lib/hmi/shape-f4-renderer.cjs +0 -72
  269. package/lib/hmi/shape-f5-renderer.cjs +0 -155
  270. package/lib/hmi/shape-f6-plan-review-renderer.cjs +0 -312
  271. package/lib/hmi/shape-f6-renderer.cjs +0 -144
  272. package/lib/hmi/shape-g-renderer.cjs +0 -219
  273. package/lib/hmi/shape-h-renderer.cjs +0 -222
  274. package/lib/hmi/tier-check.cjs +0 -63
  275. package/lib/import/PRECONDITIONS.md +0 -41
  276. package/lib/import/branding.cjs +0 -210
  277. package/lib/import/branding.test.cjs +0 -235
  278. package/lib/import/classifications-sync.cjs +0 -104
  279. package/lib/import/classifications-sync.test.cjs +0 -129
  280. package/lib/import/enricher.cjs +0 -296
  281. package/lib/import/enricher.test.cjs +0 -273
  282. package/lib/import/integration.test.cjs +0 -376
  283. package/lib/import/manifest.cjs +0 -129
  284. package/lib/import/manifest.schema.json +0 -185
  285. package/lib/import/manifest.test.cjs +0 -123
  286. package/lib/import/meeting-detector.cjs +0 -92
  287. package/lib/import/meeting-detector.test.cjs +0 -100
  288. package/lib/import/person-detector.cjs +0 -229
  289. package/lib/import/person-detector.test.cjs +0 -149
  290. package/lib/import/report.cjs +0 -186
  291. package/lib/import/report.test.cjs +0 -186
  292. package/lib/import/room-md-scaffolder.cjs +0 -49
  293. package/lib/import/router.cjs +0 -224
  294. package/lib/import/router.test.cjs +0 -356
  295. package/lib/import/run-all-tests.cjs +0 -36
  296. package/lib/import/smoke-test.cjs +0 -213
  297. package/lib/import/smoke-test.test.cjs +0 -148
  298. package/lib/import/test-fixtures/collision-vault/preexisting-room/STATE.md +0 -8
  299. package/lib/import/test-fixtures/collision-vault/preexisting-room/problem-definition/onboarding/onboarding.md +0 -7
  300. package/lib/import/test-fixtures/collision-vault/source/onboarding.md +0 -5
  301. package/lib/import/test-fixtures/obsidian-vault/.obsidian/workspace.json +0 -1
  302. package/lib/import/test-fixtures/obsidian-vault/notes/with-wikilinks.md +0 -4
  303. package/lib/import/test-fixtures/tiny-vault/notes/2026-01-15-team-sync.md +0 -9
  304. package/lib/import/test-fixtures/tiny-vault/notes/empty.md +0 -3
  305. package/lib/import/test-fixtures/tiny-vault/notes/onboarding.md +0 -5
  306. package/lib/import/test-fixtures/tiny-vault/notes/pricing.md +0 -5
  307. package/lib/import/test-fixtures/tiny-vault/notes/random.md +0 -4
  308. package/lib/import/undo.test.cjs +0 -199
  309. package/lib/import/vault-scanner.cjs +0 -105
  310. package/lib/import/vault-scanner.test.cjs +0 -67
  311. package/lib/mcp/app-html/dashboard.html +0 -316
  312. package/lib/mcp/app-html/graph.html +0 -428
  313. package/lib/mcp/app-html/mindrian-platform.html +0 -1841
  314. package/lib/mcp/app-html/wiki.html +0 -383
  315. package/lib/mcp/app-views.cjs +0 -322
  316. package/lib/mcp/brain-router.cjs +0 -418
  317. package/lib/mcp/capability-registry.cjs +0 -62
  318. package/lib/mcp/larry-context.cjs +0 -46
  319. package/lib/mcp/larry-server-instructions.md +0 -114
  320. package/lib/mcp/pipeline-state.cjs +0 -275
  321. package/lib/mcp/prompts.cjs +0 -302
  322. package/lib/mcp/resources.cjs +0 -227
  323. package/lib/mcp/session-catchup.cjs +0 -327
  324. package/lib/mcp/surface-detect.cjs +0 -75
  325. package/lib/mcp/tool-router.cjs +0 -1034
  326. package/lib/memory/aaak-compress.cjs +0 -403
  327. package/lib/memory/aaak-compress.test.cjs +0 -288
  328. package/lib/memory/async-artifact-auto-commit.test.cjs +0 -223
  329. package/lib/memory/bearer-token.test.cjs +0 -315
  330. package/lib/memory/brain-cache-lru.test.cjs +0 -259
  331. package/lib/memory/brain-client-query-shape.test.cjs +0 -160
  332. package/lib/memory/brain-derivation-graceful-degradation.test.cjs +0 -1019
  333. package/lib/memory/brain-derivation-queue.test.cjs +0 -539
  334. package/lib/memory/brain-derivation.test.cjs +0 -634
  335. package/lib/memory/brain-derive-command.test.cjs +0 -534
  336. package/lib/memory/brain-md-invariants-validator.test.cjs +0 -704
  337. package/lib/memory/brain-md-schema.test.cjs +0 -467
  338. package/lib/memory/brain-md-staleness.test.cjs +0 -525
  339. package/lib/memory/brain-server-resolution.test.cjs +0 -314
  340. package/lib/memory/chat-context.test.cjs +0 -128
  341. package/lib/memory/cross-room-aggregator.test.cjs +0 -909
  342. package/lib/memory/dashboard-server.test.cjs +0 -256
  343. package/lib/memory/debouncer-drain-at-prompt.test.cjs +0 -389
  344. package/lib/memory/decision-capture.test.cjs +0 -632
  345. package/lib/memory/decision-capture.worker.cjs +0 -70
  346. package/lib/memory/explain-decision-command.test.cjs +0 -521
  347. package/lib/memory/explain-decision-footer.test.cjs +0 -316
  348. package/lib/memory/explored-materials-store.cjs +0 -392
  349. package/lib/memory/feynman-minto-guardian.test.cjs +0 -736
  350. package/lib/memory/feynman-minto-invariants.test.cjs +0 -511
  351. package/lib/memory/feynman-prompts-drift.test.cjs +0 -144
  352. package/lib/memory/feynman-prompts.cjs +0 -151
  353. package/lib/memory/feynman-prompts.test.cjs +0 -96
  354. package/lib/memory/folder-memory-quadruple.test.cjs +0 -548
  355. package/lib/memory/folder-memory.test.cjs +0 -503
  356. package/lib/memory/framework-chain-composer.test.cjs +0 -515
  357. package/lib/memory/frontmatter-schema-validator.test.cjs +0 -290
  358. package/lib/memory/heal-command.test.cjs +0 -604
  359. package/lib/memory/index-artifact-transaction.test.cjs +0 -333
  360. package/lib/memory/lazygraph-rs-discoveries-view.test.cjs +0 -122
  361. package/lib/memory/mcp-input-validation.test.cjs +0 -240
  362. package/lib/memory/mcp-server-brain-deps.test.cjs +0 -270
  363. package/lib/memory/mcp-stack-fallback.test.cjs +0 -433
  364. package/lib/memory/minto-debouncer.test.cjs +0 -407
  365. package/lib/memory/minto-debouncer.worker.cjs +0 -46
  366. package/lib/memory/minto-migration-v88.test.cjs +0 -265
  367. package/lib/memory/minto-schema-v88.test.cjs +0 -390
  368. package/lib/memory/mos-status-renderer.test.cjs +0 -631
  369. package/lib/memory/narrative-schema.cjs +0 -376
  370. package/lib/memory/narrative-schema.test.cjs +0 -209
  371. package/lib/memory/nav-dial.test.cjs +0 -414
  372. package/lib/memory/navigation-engine-core.test.cjs +0 -722
  373. package/lib/memory/navigation-invariants.test.cjs +0 -483
  374. package/lib/memory/offer-presenter.test.cjs +0 -554
  375. package/lib/memory/on-stop-snapshot.test.cjs +0 -404
  376. package/lib/memory/pending-tension-store.cjs +0 -373
  377. package/lib/memory/post-compact-reinjection.test.cjs +0 -854
  378. package/lib/memory/post-write-triple.test.cjs +0 -317
  379. package/lib/memory/pre-compact-snapshot.test.cjs +0 -495
  380. package/lib/memory/problem-type-router.test.cjs +0 -656
  381. package/lib/memory/query-efficiency-telemetry.test.cjs +0 -370
  382. package/lib/memory/recompile-room-references.test.cjs +0 -392
  383. package/lib/memory/recompile-room-references.worker.cjs +0 -42
  384. package/lib/memory/record-decision-dual-write.test.cjs +0 -454
  385. package/lib/memory/room-classifier-strict-mode.test.cjs +0 -417
  386. package/lib/memory/room-minto-hook.test.cjs +0 -398
  387. package/lib/memory/rs-discovery-engine.test.cjs +0 -323
  388. package/lib/memory/run-feynman-tests.cjs +0 -1239
  389. package/lib/memory/security-trifecta.test.cjs +0 -312
  390. package/lib/memory/session-start-brain-staleness.test.cjs +0 -363
  391. package/lib/memory/session-start-triple-injection.test.cjs +0 -514
  392. package/lib/memory/sessionstart-banner-formatter.cjs +0 -318
  393. package/lib/memory/sessionstart-minto-banner.test.cjs +0 -373
  394. package/lib/memory/skill-activation-router.test.cjs +0 -419
  395. package/lib/memory/stamp-artifact-write.test.cjs +0 -304
  396. package/lib/memory/statusline-active-room.test.cjs +0 -315
  397. package/lib/memory/statusline-minto-segment.test.cjs +0 -292
  398. package/lib/memory/sync-async-entry-points.test.cjs +0 -204
  399. package/lib/memory/test-bridge-writer-enhanced.cjs +0 -452
  400. package/lib/memory/test-rs-brain-substrate-shape.cjs +0 -529
  401. package/lib/memory/test-rs-brain-substrate.cjs +0 -636
  402. package/lib/memory/test-rs-breakthrough-scorer.cjs +0 -375
  403. package/lib/memory/test-rs-canon-violations.cjs +0 -218
  404. package/lib/memory/test-rs-chain-feeder-core.cjs +0 -344
  405. package/lib/memory/test-rs-chain-feeder-skill-spawn.cjs +0 -297
  406. package/lib/memory/test-rs-commercial-assessor.cjs +0 -385
  407. package/lib/memory/test-rs-differential-scorer.cjs +0 -480
  408. package/lib/memory/test-rs-discovery-engine.cjs +0 -603
  409. package/lib/memory/test-rs-domain-analyzer.cjs +0 -492
  410. package/lib/memory/test-rs-egress-primitives.cjs +0 -420
  411. package/lib/memory/test-rs-expert-mapper.cjs +0 -547
  412. package/lib/memory/test-rs-explain-command.cjs +0 -443
  413. package/lib/memory/test-rs-fetcher-academic.cjs +0 -848
  414. package/lib/memory/test-rs-fetcher-experts.cjs +0 -496
  415. package/lib/memory/test-rs-fetcher-industry.cjs +0 -702
  416. package/lib/memory/test-rs-fetcher-patents.cjs +0 -674
  417. package/lib/memory/test-rs-innovation-classifier.cjs +0 -301
  418. package/lib/memory/test-rs-mind-map.cjs +0 -646
  419. package/lib/memory/test-rs-neo4j-writer.cjs +0 -518
  420. package/lib/memory/test-rs-nl-to-query.cjs +0 -449
  421. package/lib/memory/test-rs-pinecone-bridge.cjs +0 -277
  422. package/lib/memory/test-rs-preprocessor.cjs +0 -433
  423. package/lib/memory/test-rs-query-matrix.cjs +0 -391
  424. package/lib/memory/test-rs-query-to-text.cjs +0 -551
  425. package/lib/memory/test-rs-sqlite-mirror.cjs +0 -649
  426. package/lib/memory/test-rs-thesis-generator.cjs +0 -360
  427. package/lib/memory/triple-context-formatter.cjs +0 -473
  428. package/lib/memory/triple-context-formatter.test.cjs +0 -442
  429. package/lib/memory/user-md-persona.test.cjs +0 -565
  430. package/lib/memory/userpromptsubmit-integration.test.cjs +0 -690
  431. package/lib/memory/validators/README.md +0 -157
  432. package/lib/memory/validators/brain-md-invariants.cjs +0 -475
  433. package/lib/memory/validators/brain-substrate-invariants.cjs +0 -285
  434. package/lib/memory/validators/external-academic-invariants.cjs +0 -249
  435. package/lib/memory/validators/external-industry-invariants.cjs +0 -271
  436. package/lib/memory/validators/external-patents-invariants.cjs +0 -266
  437. package/lib/memory/validators/minto-invariants.cjs +0 -62
  438. package/lib/memory/validators/navigation-invariants.cjs +0 -340
  439. package/lib/memory/validators/queue-health.cjs +0 -95
  440. package/lib/memory/validators/snapshot-integrity.cjs +0 -129
  441. package/lib/memory/validators/stale-lifecycle.cjs +0 -116
  442. package/lib/memory/vault-section-minto-generator-atomic.test.cjs +0 -556
  443. package/lib/memory/vault-section-minto-generator-atomic.worker.cjs +0 -73
  444. package/lib/memory/write-lock-atomic.test.cjs +0 -137
  445. package/lib/memory/write-lock-atomic.worker.cjs +0 -55
  446. package/lib/parity/check-parity.cjs +0 -83
  447. package/lib/presentation/presentation-server.cjs +0 -101
  448. package/lib/presentation/presentation-watcher.cjs +0 -123
  449. package/lib/quickview/hub-server.cjs +0 -719
  450. package/lib/quickview/server.cjs +0 -533
  451. package/lib/render/JTBD-PALETTES.md +0 -145
  452. package/lib/render/ROOM.md +0 -59
  453. package/lib/render/render-v2.cjs +0 -486
  454. package/lib/render/render-v2.test.cjs +0 -267
  455. package/lib/render/render.cjs +0 -65
  456. package/lib/state/ROOM.md +0 -46
  457. package/lib/state/state-md-parser.cjs +0 -215
  458. package/lib/statusline/ROOM.md +0 -38
  459. package/lib/statusline/banner-suppression.cjs +0 -50
  460. package/lib/statusline/surface-detect.cjs +0 -85
  461. package/lib/update-bootstrap.sh.template +0 -145
  462. package/lib/vault/frontmatter-schema.cjs +0 -297
  463. package/lib/vault/room-scanner.cjs +0 -352
  464. package/lib/vault/wikilink-builder.cjs +0 -231
  465. package/lib/vault/wikilink-builder.test.cjs +0 -182
  466. package/lib/wiki/graph-links.cjs +0 -281
  467. package/lib/wiki/page-renderer.cjs +0 -229
  468. package/lib/wiki/wiki-chat.cjs +0 -81
  469. package/lib/wiki/wiki-layout.cjs +0 -1459
  470. package/lib/wiki/wiki-search.cjs +0 -142
  471. package/lib/wiki/wiki-server.cjs +0 -678
  472. package/lib/wiki/wiki-watcher.cjs +0 -105
  473. package/pipelines/analogy/01-decompose.md +0 -80
  474. package/pipelines/analogy/02-abstract.md +0 -87
  475. package/pipelines/analogy/03-search.md +0 -135
  476. package/pipelines/analogy/04-transfer.md +0 -101
  477. package/pipelines/analogy/05-validate.md +0 -106
  478. package/pipelines/analogy/CHAIN.md +0 -56
  479. package/pipelines/discovery/01-explore-domains.md +0 -44
  480. package/pipelines/discovery/02-think-hats.md +0 -50
  481. package/pipelines/discovery/03-analyze-needs.md +0 -54
  482. package/pipelines/discovery/CHAIN.md +0 -37
  483. package/pipelines/thesis/01-structure-argument.md +0 -45
  484. package/pipelines/thesis/02-challenge-assumptions.md +0 -48
  485. package/pipelines/thesis/03-build-thesis.md +0 -54
  486. package/pipelines/thesis/CHAIN.md +0 -37
  487. package/references/brain/causal-directives.md +0 -91
  488. package/references/brain/causal-enrichment.cypher +0 -165
  489. package/references/brain/command-triggers-schema.md +0 -226
  490. package/references/brain/graph-architecture.md +0 -317
  491. package/references/brain/query-patterns.md +0 -460
  492. package/references/brain/room-hierarchy-schema.md +0 -218
  493. package/references/brain/schema.md +0 -76
  494. package/references/capability-radar/capabilities-index.md +0 -241
  495. package/references/capability-radar/changelog-cache.md +0 -81
  496. package/references/causal/causal-schema.md +0 -103
  497. package/references/design/email-template-standard.md +0 -155
  498. package/references/design/graph-visualization-standard.md +0 -178
  499. package/references/document-generation.md +0 -179
  500. package/references/hsi/HSI-TOOLS-REFERENCE.md +0 -222
  501. package/references/import-config.md +0 -141
  502. package/references/integrations/detection-patterns.md +0 -101
  503. package/references/meeting/artifact-template.md +0 -377
  504. package/references/meeting/cross-meeting-intelligence.md +0 -216
  505. package/references/meeting/cross-relationship-patterns.md +0 -202
  506. package/references/meeting/live-join-interface.md +0 -244
  507. package/references/meeting/section-mapping.md +0 -192
  508. package/references/meeting/segment-classification.md +0 -258
  509. package/references/meeting/speaker-profile-template.md +0 -219
  510. package/references/meeting/summary-template.md +0 -348
  511. package/references/meeting/transcript-patterns.md +0 -226
  512. package/references/methodology/analyze-needs.md +0 -135
  513. package/references/methodology/analyze-systems.md +0 -121
  514. package/references/methodology/analyze-timing.md +0 -149
  515. package/references/methodology/beautiful-question.md +0 -109
  516. package/references/methodology/build-knowledge.md +0 -161
  517. package/references/methodology/build-thesis.md +0 -237
  518. package/references/methodology/challenge-assumptions.md +0 -127
  519. package/references/methodology/diagnose.md +0 -169
  520. package/references/methodology/dominant-designs.md +0 -212
  521. package/references/methodology/explore-domains.md +0 -147
  522. package/references/methodology/explore-futures.md +0 -163
  523. package/references/methodology/explore-trends.md +0 -129
  524. package/references/methodology/find-bottlenecks.md +0 -131
  525. package/references/methodology/grade.md +0 -211
  526. package/references/methodology/index.md +0 -97
  527. package/references/methodology/leadership.md +0 -200
  528. package/references/methodology/lean-canvas.md +0 -116
  529. package/references/methodology/macro-trends.md +0 -192
  530. package/references/methodology/map-unknowns.md +0 -137
  531. package/references/methodology/mullins-7-domains.md +0 -104
  532. package/references/methodology/problem-types.md +0 -65
  533. package/references/methodology/root-cause.md +0 -178
  534. package/references/methodology/sapphire-encoding.md +0 -355
  535. package/references/methodology/scenario-plan.md +0 -178
  536. package/references/methodology/score-innovation.md +0 -154
  537. package/references/methodology/structure-argument.md +0 -158
  538. package/references/methodology/systems-thinking.md +0 -159
  539. package/references/methodology/think-hats.md +0 -147
  540. package/references/methodology/triz-matrix.json +0 -751
  541. package/references/methodology/triz-principles.md +0 -501
  542. package/references/methodology/user-needs.md +0 -199
  543. package/references/methodology/validate.md +0 -163
  544. package/references/methodology/value-proposition.md +0 -244
  545. package/references/opportunities/funding-lifecycle.md +0 -103
  546. package/references/opportunities/grant-api-patterns.md +0 -99
  547. package/references/opportunities/opportunity-template.md +0 -84
  548. package/references/personality/assessment-philosophy.md +0 -72
  549. package/references/personality/lexicon.md +0 -100
  550. package/references/personality/persona-chains.md +0 -56
  551. package/references/personality/pws-lexicon-full.md +0 -499
  552. package/references/personality/voice-dna.md +0 -156
  553. package/references/personas/hat-perspectives.md +0 -76
  554. package/references/personas/persona-template.md +0 -63
  555. package/references/pipeline/act-output-contract.md +0 -88
  556. package/references/pipeline/chains-index.md +0 -39
  557. package/references/pws-profile-generation.md +0 -79
  558. package/references/reasoning/reasoning-schema.md +0 -143
  559. package/references/reasoning/reasoning-template.md +0 -68
  560. package/references/reasoning/run-template.md +0 -38
  561. package/references/research/RESEARCH_14_CLAUDE_CODE_SOURCE_ARCHITECTURE.md +0 -209
  562. package/references/research/RESEARCH_15_V1.8_OPTIMIZATION_JTBD.md +0 -375
  563. package/references/research/RESEARCH_16_NATIVE_FIRST_PLUGIN_ARCHITECTURE.md +0 -575
  564. package/references/research/RESEARCH_17_MCP_UI_FRAMEWORKS.md +0 -272
  565. package/references/taxonomy/TAXONOMY.md +0 -192
  566. package/references/templates/MINTO.md +0 -36
  567. package/references/user-research/2026-04-05-leah-lawrence-session.md +0 -202
  568. package/references/vault-kit/README.md +0 -35
  569. package/references/vault-kit/app.json +0 -12
  570. package/references/vault-kit/appearance.json +0 -12
  571. package/references/vault-kit/graph.json +0 -35
  572. package/references/vault-kit/snippets/mindrian-destijl.css +0 -297
  573. package/references/vault-kit/templates/new-artifact.md +0 -37
  574. package/references/vault-kit/templates/new-meeting-note.md +0 -35
  575. package/references/vault-kit/templates/new-team-profile.md +0 -29
  576. package/references/vault-kit/templates/new-xref.md +0 -35
  577. package/references/visual/symbol-system.md +0 -151
  578. package/skills/MOSDeckEngine/SKILL.md +0 -325
  579. package/skills/brain-connector/SKILL.md +0 -114
  580. package/skills/context-engine/SKILL.md +0 -147
  581. package/skills/conversation-mode/SKILL.md +0 -102
  582. package/skills/larry-personality/SKILL.md +0 -219
  583. package/skills/larry-personality/framework-chains.md +0 -92
  584. package/skills/larry-personality/mode-engine.md +0 -185
  585. package/skills/mullins-scaffold/SKILL.md +0 -61
  586. package/skills/mullins-scaffold/scaffold.json +0 -146
  587. package/skills/pws-methodology/SKILL.md +0 -49
  588. package/skills/room-passive/SKILL.md +0 -165
  589. package/skills/room-proactive/SKILL.md +0 -250
  590. package/skills/ui-system/SKILL.md +0 -277
@@ -1,724 +0,0 @@
1
- ---
2
- name: file-meeting
3
- description: File a meeting transcript into the Data Room
4
- argument-hint: [--latest|--paste|<file>]
5
- serves_jtbd: ["file-meeting"]
6
- allowed-tools:
7
- - Read
8
- - Write
9
- - Bash
10
- - Glob
11
- ---
12
-
13
- # /mos:file-meeting
14
-
15
- You are Larry. This command turns meeting conversations into Data Room intelligence through a 6-step conversational pipeline.
16
-
17
- ---
18
-
19
- ## Setup
20
-
21
- Load all reference files and context before starting:
22
-
23
- 1. Read `references/personality/voice-dna.md` for Larry's voice
24
- 2. Read `references/meeting/transcript-patterns.md` for speaker ID regex patterns
25
- 3. Read `references/meeting/segment-classification.md` for the 6-type taxonomy
26
- 4. Read `references/meeting/section-mapping.md` for the 12-role x 6-type x 8-section routing matrix
27
- 5. Read `references/meeting/artifact-template.md` for wicked-problem-aware YAML frontmatter
28
- 6. Read `references/meeting/summary-template.md` for narrative + structured dual storage format
29
- 7. Read `references/meeting/speaker-profile-template.md` for ICM nested folder profiles
30
- 8. Read `references/meeting/cross-relationship-patterns.md` (if file exists -- skip gracefully if not)
31
- 9. Read `references/meeting/cross-meeting-intelligence.md` for cross-meeting convergence/contradiction detection and action item triage protocols
32
- 10. Read `room/STATE.md` for venture context (if exists)
33
- 11. Scan `room/team/` for known speaker profiles: glob `room/team/*/*/PROFILE.md`
34
-
35
- Track any newly created speaker profiles in a list called `new_profiles` for the post-pipeline research step.
36
-
37
- ---
38
-
39
- ## Step 0: Action Item Triage (Pre-Filing)
40
-
41
- Before starting the filing pipeline, check for open action items from prior meetings.
42
-
43
- ### Load Open Items
44
-
45
- Read `room/action-items.md` if it exists. If the file does not exist or has zero open items, skip Step 0 entirely and proceed to Step 1.
46
-
47
- ### Present Quick Triage
48
-
49
- Show open items as a pre-flight check (not an interrogation):
50
-
51
- > "3 open items from your last meeting. Quick check -- any done?"
52
- >
53
- > | # | Owner | Task | From Meeting |
54
- > |---|-------|------|--------------|
55
- > | 1 | Lawrence | Review TAM analysis | 2026-03-15-mentoring |
56
- > | 2 | Sarah | Send competitor deck | 2026-03-15-mentoring |
57
- > | 3 | Tyler | Schedule user interviews | 2026-03-10-research |
58
- >
59
- > [mark done: 1,3 / skip / review all]
60
-
61
- ### Handle Responses
62
-
63
- - **mark done (e.g., "1,3")**: Update each item's status from `open` to `done` in the SOURCE meeting's action-items.md file (not the aggregated file). Find the source by the meeting_id in the aggregated table.
64
- - **skip**: Move on to Step 1. No changes.
65
- - **review all**: Show each item individually for yes/no.
66
-
67
- Track items marked done for inclusion in this meeting's summary ("Cleared 2 action items from prior meetings").
68
-
69
- ---
70
-
71
- ## Step 1: Get Transcript Input
72
-
73
- Determine the input mode based on flags:
74
-
75
- ### No flags (default) -- Paste Mode
76
-
77
- Ask the user to paste their transcript text:
78
-
79
- > "Paste your meeting transcript below. I'll handle any format -- Zoom, Teams, Otter, Google Meet, or raw text."
80
-
81
- Accept multi-line paste. After receiving text, detect the transcript format using the regex patterns from `references/meeting/transcript-patterns.md`. Report the detected format:
82
-
83
- > "Got it. Looks like a {format} transcript."
84
-
85
- ### `--file <path>` -- File Mode
86
-
87
- Read the file at the provided path. Support `.txt` and `.md` extensions. Detect format from content using transcript-patterns.md patterns. If the file does not exist, report the error and suggest alternatives:
88
-
89
- > "Can't find that file. Try the full path, or just paste the transcript here."
90
-
91
- ### `--audio <path>` -- Audio Mode
92
-
93
- Check if Velma is configured:
94
- 1. Check `VELMA_API_KEY` environment variable
95
- 2. Check `.mcp.json` for `mcpServers.velma.env.VELMA_API_KEY`
96
-
97
- **If not configured:**
98
- > "Audio needs Velma configured. Set it up now? (30 seconds)"
99
- > - If yes: Walk through the Velma setup flow (same as `/mos:setup transcription`)
100
- > - If no: "No problem. Paste the transcript text instead, or point me to a text file with `--file`."
101
-
102
- **If configured:**
103
- Run `bash scripts/transcribe-audio <path>` and use the output as the transcript. Note the source as `velma` (affects artifact frontmatter).
104
-
105
- Also capture the full JSON response (written to temp file via stderr) for emotion data parsing downstream.
106
-
107
- ### `--latest` -- Auto-Fetch Mode
108
-
109
- Automatically fetch the most recent meeting transcript from a configured meeting source (Read AI, Vexa, or Recall.ai).
110
-
111
- #### 1. Check for Configured Meeting Source
112
-
113
- Read `.mcp.json` in the workspace root and look for meeting source keys under `mcpServers`:
114
-
115
- - `read-ai` -- Read AI MCP
116
- - `vexa` -- Vexa MCP
117
- - `recall-ai` -- Recall.ai MCP
118
-
119
- **If no meeting source configured:**
120
- > "No meeting source configured. Run `/mos:setup meetings` first, or paste your transcript here."
121
-
122
- Then fall back to default paste mode (continue to the paste prompt above).
123
-
124
- #### 2. Fetch Recent Meetings
125
-
126
- If a meeting source is found, detect which provider by the key name in `mcpServers` and call its list tool:
127
-
128
- | Provider | MCP Tool Call | Returns |
129
- |----------|--------------|---------|
130
- | Read AI | `mcp__read-ai__list-meetings` | Recent meetings with titles, dates, durations |
131
- | Vexa | `mcp__vexa__list-sessions` | Recent sessions with metadata |
132
- | Recall.ai | `mcp__recall-ai__list-meetings` | Recent meetings with participant info |
133
-
134
- Present the 5 most recent meetings in a table:
135
-
136
- ```
137
- | # | Date | Title | Duration | Participants |
138
- |---|------------|--------------------------------|----------|--------------|
139
- | 1 | 2026-03-23 | Weekly Team Sync | 45min | 4 |
140
- | 2 | 2026-03-22 | Investor Update Call | 30min | 3 |
141
- | 3 | 2026-03-21 | Product Review | 1h 15min | 6 |
142
- | 4 | 2026-03-20 | Mentor Session with Lawrence | 50min | 2 |
143
- | 5 | 2026-03-19 | Customer Discovery Interview | 35min | 3 |
144
- ```
145
-
146
- > "Grabbing your latest meeting. Or pick a different one: [1-5]"
147
-
148
- Default to #1 (most recent) if user confirms or presses enter. If user selects a number, use that meeting.
149
-
150
- #### 3. Fetch Transcript
151
-
152
- Call the source's transcript retrieval tool with the selected session/meeting ID:
153
-
154
- | Provider | MCP Tool Call |
155
- |----------|--------------|
156
- | Read AI | `mcp__read-ai__get-transcript` with the session ID |
157
- | Vexa | `mcp__vexa__get-transcript` with the session ID |
158
- | Recall.ai | `mcp__recall-ai__get-meeting-transcript` with the meeting ID |
159
-
160
- Use the returned transcript text as input to Step 1 format detection (proceed to "Infer Meeting Metadata" below).
161
-
162
- Set source metadata to the meeting provider name (e.g., `read-ai`, `vexa`, or `recall-ai`) for artifact provenance tracking.
163
-
164
- #### 4. Handle MCP Errors
165
-
166
- **Auth errors (401/403):**
167
- > "Authentication expired. Re-run `/mos:setup meetings` to reconnect."
168
-
169
- Then fall back to paste mode. Never block the pipeline.
170
-
171
- **Network / other errors:**
172
- > "Could not reach {source}. Check your connection. Meanwhile, paste the transcript or use `--file`."
173
-
174
- Then fall back to paste mode. Never block the pipeline.
175
-
176
- **Empty response (no meetings found):**
177
- > "No recent meetings found in {source}. Your meeting tool might not have recorded anything recently. Paste the transcript here instead."
178
-
179
- Then fall back to paste mode.
180
-
181
- ### `--join <url>` -- Future Mode
182
-
183
- Print:
184
- > "Not yet available. Coming in a future update. Use `--latest`, paste, `--file`, or `--audio` for now."
185
-
186
- This flag is designed in `references/meeting/live-join-interface.md` but not implemented until v3.0.
187
-
188
- ### Infer Meeting Metadata
189
-
190
- After getting the transcript content, infer metadata from content and Data Room context:
191
-
192
- - **Meeting date**: Extract from timestamps in transcript, file modification date, or ask user. When `--latest` is used, the meeting date comes directly from the MCP response metadata -- no need to infer from transcript content.
193
- - **Meeting purpose**: Infer from content themes and dominant topics
194
- - **Participant count**: Count unique speaker labels. When `--latest` is used, the participant count comes from the MCP response metadata and can be cross-checked against speaker labels in the transcript.
195
-
196
- Present inferences for confirmation:
197
- > "This looks like a {type} meeting from {date} with {N} participants. Correct?"
198
-
199
- If the user corrects any inference, use their version. Store confirmed metadata for artifact provenance.
200
-
201
- ---
202
-
203
- ## Step 2: Speaker Identification + Profile Creation
204
-
205
- ### Parse Speaker Labels
206
-
207
- Use the regex patterns from `references/meeting/transcript-patterns.md` to extract speaker labels from the transcript.
208
-
209
- **If speaker labels are found:** Extract all unique speakers and proceed to matching.
210
-
211
- **If no speaker labels found:** Ask the user:
212
- > "I don't see speaker labels in this transcript. Who was in this meeting? Give me names and I'll match the voices to the content."
213
-
214
- Use their response combined with content analysis to attribute segments to speakers.
215
-
216
- ### Cross-Reference Against Team Directory
217
-
218
- For each identified speaker, check `room/team/` profiles:
219
-
220
- - **Known match** (exact name match in existing profile): Mark as `AUTO-MATCHED`
221
- - Example: "Lawrence matches team/mentors/lawrence-aronhime/ (mentor)"
222
- - **Partial match** (similar name in existing profile): Present for confirmation
223
- - Example: "This sounds like Lawrence -- mentor from team directory. Confirm?"
224
- - **Unknown** (no match in team directory): Infer role from content
225
- - Example: "Speaker 2 discussed financials and seems senior -- could this be your advisor?"
226
-
227
- ### Present Smart Hybrid Table
228
-
229
- Show all speakers in a single table:
230
-
231
- ```
232
- | Speaker | Match | Role | Status |
233
- |---------|-------|------|--------|
234
- | Lawrence | team/mentors/lawrence-aronhime/ | mentor | AUTO-MATCHED |
235
- | Tyler | (no match) | researcher? | NEEDS CONFIRMATION |
236
- | Sarah | team/founders/sarah-chen/ | founder | AUTO-MATCHED |
237
- ```
238
-
239
- User confirms matches and fills unknowns. Roles must be from the 12-type taxonomy:
240
- mentor, researcher, team-member, investor, advisor, customer, founder, partner, domain-expert, government, competitor, unknown
241
-
242
- ### Create Profiles for New Speakers
243
-
244
- For each CONFIRMED unknown speaker (user has confirmed their identity and role):
245
-
246
- Run `bash scripts/create-speaker-profile <room_dir> <speaker-slug> <speaker-role> <display-name>`
247
-
248
- Add the speaker to the `new_profiles` list for post-pipeline research.
249
-
250
- ### Emotion Signals (Audio Input Only)
251
-
252
- If the input was `--audio` and Velma data includes emotion scores, surface ONLY strong emotions (score > 0.7):
253
-
254
- > "Tyler was notably skeptical when discussing market size."
255
- > "Sarah showed high enthusiasm about the enterprise pivot."
256
-
257
- Do not surface routine or weak emotions. Only notable emotional signals that provide insight.
258
-
259
- ---
260
-
261
- ## Step 3: Segment Classification (Priority-First)
262
-
263
- ### Classify Each Segment
264
-
265
- Process each non-greeting, non-trivial segment from the transcript:
266
-
267
- 1. **Classify** using the 6-type taxonomy from `references/meeting/segment-classification.md`:
268
- - decision, action-item, insight, advice, question, noise
269
-
270
- 2. **Apply role-aware heuristics** from `references/meeting/section-mapping.md`:
271
- - Investor question about financials = HIGH priority
272
- - Mentor advice on problem framing = HIGH priority
273
- - Team-member status update = MEDIUM priority
274
- - Use the routing matrix to determine the target room section
275
-
276
- 3. **Sort by priority**: decisions (HIGHEST) > action-items (HIGH) > insights (MEDIUM) > advice (MEDIUM) > questions (LOW)
277
-
278
- 4. **Flag potential noise** that contains proper nouns, competitor names, or numbers:
279
- > "This looks like small talk but Lawrence mentioned a competitor name. File or skip?"
280
-
281
- ### Show Classification Reasoning
282
-
283
- For EVERY classified segment, show Larry's reasoning:
284
-
285
- > "This is an insight about market size -> market-analysis. Confidence: 0.85"
286
- > "This is a decision about product focus -> solution-design. Confidence: 0.92"
287
- > "This is advice on hiring strategy -> team-execution. Confidence: 0.78"
288
-
289
- Transparency is mandatory -- even when it makes the flow longer. The user needs to trust Larry's classifications.
290
-
291
- ---
292
-
293
- ## Step 4: Section Mapping + Confirm-Then-File
294
-
295
- ### Present Segments Batched by Type (Priority Order)
296
-
297
- Group classified segments by type. Within each type, sort by confidence. Present the highest-priority types first:
298
-
299
- ```
300
- **DECISIONS (2 segments):**
301
- 1. Lawrence (mentor): "Focus on B2B first, consumer can wait."
302
- -> team-execution | decision | HIGH confidence
303
- Reasoning: Direct strategic direction from mentor
304
-
305
- 2. Sarah (founder): "We're pausing the mobile app."
306
- -> solution-design | decision | HIGH confidence
307
- Reasoning: Product roadmap change from founder
308
-
309
- File both decisions? [all / review individually / skip]
310
- ```
311
-
312
- ### Filing Options Per Batch
313
-
314
- - **all**: File every segment in this batch
315
- - **review individually**: Present each one for yes/no/redirect
316
- - **skip**: Skip the entire batch (captures structured rejection)
317
-
318
- ### Handle Rejections
319
-
320
- When the user rejects a filing, offer structured rejection reasons:
321
-
322
- > "Why skip? [not relevant] [already known] [wrong section] [other]"
323
-
324
- Capture the rejection reason. This becomes graph data per the wicked problem architecture (rejection IS data).
325
-
326
- ### Cross-Reference Against Open Action Items
327
-
328
- During filing, if any open action items remain (not cleared in Step 0), compare each segment being filed against them. If a segment appears to address or complete an open action item:
329
-
330
- > "This looks like progress on Lawrence's 'Review TAM analysis'. Mark as done?"
331
-
332
- Use Larry's judgment -- not exact text matching. Only surface when confidence is high. If user confirms, update the source meeting's action-items.md.
333
-
334
- ### Create Filed Artifacts
335
-
336
- For each filed segment, create a markdown file in the target room section using the frontmatter from `references/meeting/artifact-template.md`:
337
-
338
- **File path pattern:** `room/{section}/YYYY-MM-DD-{slug}.md`
339
-
340
- Include ALL provenance fields:
341
- - methodology: file-meeting
342
- - created: {today}
343
- - source: transcript (or velma)
344
- - attribution:
345
- - speaker: {name}
346
- - role: {role}
347
- - profile_path: team/{role-plural}/{speaker-slug}
348
- - meeting_date: {meeting date}
349
- - meeting_id: {YYYY-MM-DD-meeting-slug}
350
- - segment_type: {type}
351
- - confidence: {confidence score}
352
- - meeting_date: {meeting date}
353
- - meeting_name: {meeting identifier}
354
- - room_section: {target section}
355
- - assumptions: {extracted assumptions with status and impacts}
356
- - perspective: {speaker_role}
357
- - cascade_sections: {sections this may affect beyond target}
358
-
359
- When writing the artifact content, auto-insert [[concept-name]] links for key concepts that connect this segment to other parts of the Data Room. Use [[section-name]] for cross-section references (existing pattern) and [[concept-name]] for domain concepts, frameworks, or recurring themes. Examples: [[wicked-problems]], [[assumption-tracking]], [[market-sizing]], [[competitive-moat]]. These wikilinks feed the knowledge graph -- build-graph parses them into concept nodes and REFERENCES edges. Users can also manually add [[wikilinks]] to any room artifact at any time.
360
-
361
- **Native wikilink injection (NATIVE-01/02):** Immediately after writing each filed artifact, run:
362
- ```bash
363
- node scripts/wikilink-file.cjs "$ROOM_DIR" "$ARTIFACT_PATH"
364
- ```
365
- This uses `lib/vault/wikilink-builder.cjs` to inject team-name wikilinks at write time so the artifact arrives pre-linked. Errors are logged but non-fatal -- filing never aborts because of a wikilink pass.
366
-
367
- Speaker contributions are tracked via computed backlinks in PROFILE.md (run by compute-team), not by filing copies to speaker subfolders.
368
-
369
- Track: total segments filed, total rejected, sections touched.
370
-
371
- ---
372
-
373
- ## Step 5: Create Meeting Summary + Archive
374
-
375
- ### Infer Meeting Name + Confirm
376
-
377
- Before creating the archive, confirm the meeting name with the user:
378
-
379
- 1. **Larry proposes** a meeting name from the dominant topic/purpose of classified segments:
380
- > "This looks like a mentoring session focused on market validation. I'd call it 'Market Validation Mentoring'. Sound right?"
381
-
382
- 2. **User confirms or changes** the name. Use their version if they provide one.
383
-
384
- 3. The confirmed meeting name becomes the **meeting_id** used in all attribution blocks and archive paths:
385
- - meeting_id: `YYYY-MM-DD-{confirmed-slug}` (e.g., `2026-03-15-market-validation-mentoring`)
386
- - Slugify: lowercase, hyphens, no special characters, max 50 characters
387
-
388
- ### Meeting Archive Package
389
-
390
- The complete meeting archive directory structure:
391
-
392
- ```
393
- room/meetings/YYYY-MM-DD-{meeting-name}/
394
- transcript.md
395
- summary.md
396
- speakers.md
397
- decisions.md
398
- action-items.md
399
- metadata.yaml
400
- {audio-filename} # only if --audio input
401
- filed-to/
402
- ```
403
-
404
- Each meeting is a self-contained knowledge artifact. The entire folder can be browsed, shared, or referenced as a unit.
405
-
406
- ### Create Meeting Archive Directory
407
-
408
- ```bash
409
- mkdir -p room/meetings/YYYY-MM-DD-{meeting-name}/filed-to/
410
- ```
411
-
412
- ### Store Processed Transcript
413
-
414
- Write the processed transcript (with speaker labels and format metadata) to:
415
- `room/meetings/YYYY-MM-DD-{meeting-name}/transcript.md`
416
-
417
- ### Create Speakers Roster
418
-
419
- Create `room/meetings/YYYY-MM-DD-{meeting-name}/speakers.md`:
420
-
421
- ```markdown
422
- ---
423
- meeting_id: {YYYY-MM-DD-meeting-slug}
424
- meeting_date: {YYYY-MM-DD}
425
- ---
426
- # Speakers: {meeting_name}
427
-
428
- | Speaker | Role | Segments | Profile |
429
- |---------|------|----------|---------|
430
- | {name} | {role} | {count} | [[team/{role-plural}/{slug}/PROFILE.md]] |
431
- ```
432
-
433
- One row per confirmed speaker from Step 2. Profile links use the slug from create-speaker-profile (canonical slug source).
434
-
435
- ### Create Full Summary
436
-
437
- Following `references/meeting/summary-template.md`, create the full meeting summary at:
438
- `room/meetings/YYYY-MM-DD-{meeting-name}/summary.md`
439
-
440
- Structure:
441
-
442
- 1. **Narrative lead paragraph** in Larry's voice:
443
- > "Lawrence pushed hard on market validation today. Three things you can't ignore..."
444
-
445
- 2. **## Key Decisions** -- with who decided and the reasoning
446
-
447
- 3. **## Insights Filed** -- {count} insights filed to {sections list}
448
-
449
- 4. **## Contradictions Detected** -- if any contradictions found between this meeting's content and existing room content. Skip section entirely if none.
450
-
451
- 5. **## Gaps Identified** -- room sections that SHOULD have received input from this meeting but didn't. Based on the speaker roles present and what they discussed.
452
-
453
- 6. **## Action Items** -- with owners assigned from speaker context. Deadlines ONLY when explicitly mentioned in transcript. Never invent deadlines.
454
-
455
- 7. **## Rejections** -- segments rejected with structured reasons. This IS data -- do not hide or minimize rejections.
456
-
457
- 8. **## Speakers** -- {count} speakers with roles and contribution summary
458
-
459
- 9. **## Convergence Signals** -- topics appearing in 3+ meetings across the meeting history. Only include if convergence was detected. Skip section entirely if none.
460
-
461
- 10. **## Cross-Meeting Contradictions** -- contradictions detected against prior meetings (beyond within-meeting contradictions in section 4). Only include if cross-meeting contradictions were found.
462
-
463
- ### Create Decisions Log
464
-
465
- Create `room/meetings/YYYY-MM-DD-{meeting-name}/decisions.md`:
466
-
467
- ```markdown
468
- ---
469
- meeting_id: {YYYY-MM-DD-meeting-slug}
470
- ---
471
- # Decisions: {meeting_name}
472
-
473
- 1. **{Decision summary}** -- {speaker} ({role})
474
- Filed to: [[{section}/{artifact-filename}.md]]
475
- Impact: {cascade_sections from the decision artifact}
476
- ```
477
-
478
- Extract from the segments classified as `decision` in Step 3. If no decisions were made, write: "No explicit decisions were recorded in this meeting."
479
-
480
- ### Create Action Items Log
481
-
482
- Create `room/meetings/YYYY-MM-DD-{meeting-name}/action-items.md`:
483
-
484
- ```markdown
485
- ---
486
- meeting_id: {YYYY-MM-DD-meeting-slug}
487
- ---
488
- # Action Items: {meeting_name}
489
-
490
- | Owner | Task | Deadline | Status |
491
- |-------|------|----------|--------|
492
- | {name} | {task} | {date or "not specified"} | open |
493
- ```
494
-
495
- Extract from segments classified as `action-item` in Step 3. Deadlines ONLY if explicitly stated in transcript -- never invent deadlines. All items start as `status: open`. If no action items, write: "No action items were identified in this meeting."
496
-
497
- ### Create Structured Metadata
498
-
499
- Create `room/meetings/YYYY-MM-DD-{meeting-name}/metadata.yaml` as the LAST file in the archive (after all other data is known):
500
-
501
- ```yaml
502
- meeting_id: {YYYY-MM-DD-meeting-slug}
503
- meeting_name: {human-readable meeting name}
504
- meeting_date: {YYYY-MM-DD}
505
- source: {transcript | velma}
506
- speakers:
507
- - name: {full name}
508
- role: {role}
509
- slug: {speaker-slug matching profile directory}
510
- - name: {full name}
511
- role: {role}
512
- slug: {speaker-slug}
513
- topics:
514
- - {dominant topic 1}
515
- - {dominant topic 2}
516
- decisions_count: {N}
517
- insights_count: {N}
518
- action_items_count: {N}
519
- sections_touched:
520
- - {section-name}
521
- - {section-name}
522
- has_audio: {true | false}
523
- ```
524
-
525
- Topics are inferred from the dominant themes of filed segments. Speaker slugs MUST match the directory names created by create-speaker-profile (canonical slug source).
526
-
527
- ### Copy Audio File (if --audio)
528
-
529
- If input was `--audio <path>`, copy the audio file into the meeting archive:
530
-
531
- ```bash
532
- cp {audio-path} room/meetings/{YYYY-MM-DD-meeting-slug}/{original-filename}
533
- ```
534
-
535
- Set `has_audio: true` in metadata.yaml. If no audio input, set `has_audio: false`.
536
-
537
- Register the audio file in the room's ASSET_MANIFEST.md for dashboard/wiki discovery:
538
-
539
- ```bash
540
- # Register audio in ASSET_MANIFEST.md
541
- bash scripts/file-asset "$room_path" "$audio_path" "meetings" --meeting "$meeting_id"
542
- ```
543
-
544
- This creates a markdown wrapper alongside the audio file in the meeting archive with a link to the transcript:
545
- ```yaml
546
- ---
547
- type: audio
548
- asset_path: meetings/{meeting_id}/{audio_filename}
549
- meeting_id: {meeting_id}
550
- transcript: meetings/{meeting_id}/transcript.md
551
- ---
552
- ```
553
-
554
- The wrapper content includes: `Transcript: [[meetings/{meeting_id}/transcript.md]]`
555
-
556
- ### Create Filed-To Reference Directory
557
-
558
- In `room/meetings/YYYY-MM-DD-{meeting-name}/filed-to/`, create a small markdown file for each filed artifact pointing to its location:
559
-
560
- ```markdown
561
- # {artifact-slug}
562
- Filed to: room/{section}/YYYY-MM-DD-{slug}.md
563
- Speaker: {name} ({role})
564
- Type: {segment_type}
565
- ```
566
-
567
- **Native wikilink injection (NATIVE-01/02):** After writing each filed-to stub AND the meeting summary.md, run the wikilink wrapper to inject team links and filed-to footer lines at write time:
568
- ```bash
569
- # For each filed-to stub
570
- node scripts/wikilink-file.cjs "$ROOM_DIR" "$STUB_PATH" \
571
- --filed-to-target="{section}/YYYY-MM-DD-{slug}.md" \
572
- --meeting-slug="YYYY-MM-DD-{meeting-name}"
573
-
574
- # For the meeting summary
575
- node scripts/wikilink-file.cjs "$ROOM_DIR" "$SUMMARY_PATH" \
576
- --meeting-slug="YYYY-MM-DD-{meeting-name}"
577
- ```
578
- See `lib/vault/wikilink-builder.cjs` for the canonical builders. The wrapper fails soft -- if the room has zero team profiles or scan errors, filing still completes cleanly.
579
-
580
- ### Create Compact Root Reference
581
-
582
- Create a compact one-paragraph reference at the room root:
583
- `room/meeting-YYYY-MM-DD-{meeting-name}.md`
584
-
585
- ```markdown
586
- ---
587
- type: meeting-reference
588
- meeting_date: YYYY-MM-DD
589
- meeting_name: {name}
590
- speakers: {count}
591
- artifacts_filed: {count}
592
- sections_touched: [{sections}]
593
- ---
594
-
595
- {One paragraph summary of the meeting and its impact on the Data Room.}
596
-
597
- Full summary: [[meetings/YYYY-MM-DD-{meeting-name}/summary.md]]
598
- Transcript: [[meetings/YYYY-MM-DD-{meeting-name}/transcript.md]]
599
- Filed {N} artifacts across {M} sections.
600
- ```
601
-
602
- ### Past Meeting Lookup
603
-
604
- When Larry needs to reference past meetings (e.g., "Lawrence mentioned this 3 meetings ago"), grep metadata.yaml files across `room/meetings/`:
605
-
606
- - **By speaker:** `grep -rl '{speaker-slug}' room/meetings/*/metadata.yaml`
607
- - **By topic:** `grep -rl '{topic}' room/meetings/*/metadata.yaml`
608
- - **By date range:** Scan `meeting_date` fields in metadata.yaml files
609
- - **By decision count:** `grep -l 'decisions_count: [1-9]' room/meetings/*/metadata.yaml`
610
-
611
- This provides fast targeted lookups without indexing. metadata.yaml is designed as a grep-friendly structured search surface.
612
-
613
- ---
614
-
615
- ## Step 6: Cross-Relationship Batch Scan
616
-
617
- After ALL filing is complete, scan filed artifacts against existing Data Room content.
618
-
619
- ### Load Detection Heuristics
620
-
621
- Use `references/meeting/cross-relationship-patterns.md` (already loaded in Setup if available) for the 5 edge types:
622
-
623
- - **INFORMS**: new artifact references or provides evidence for another section
624
- - **CONTRADICTS**: new artifact conflicts with existing claim
625
- - **CONVERGES**: theme from this meeting appears in 3+ sections
626
- - **INVALIDATES**: new artifact makes an existing assumption stale
627
- - **ENABLES**: new artifact unblocks something in another section
628
-
629
- ### Scan Protocol
630
-
631
- 1. For each filed artifact, read its content and assumptions
632
- 2. Glob existing room content in related sections (especially cascade_sections)
633
- 3. Apply Tier 0 keyword matching heuristics from cross-relationship-patterns.md
634
- 4. Detect significant cross-relationships only -- not every minor keyword overlap
635
-
636
- **Tier 0 implementation:** Larry's conversational reasoning against room content. No LSA/MiniLM in Phase 6 -- computational similarity comes in Phase 8.
637
-
638
- ### Present Findings
639
-
640
- **If significant cross-relationships found:**
641
-
642
- Present in priority order (INVALIDATES > CONTRADICTS > CONVERGES > ENABLES > INFORMS):
643
-
644
- > "This meeting changed something in your Data Room:"
645
- >
646
- > **CONTRADICTS:** Tyler's market size estimate ($50M) conflicts with the $190M TAM in your financial-model/revenue-projection.md. Which is current?
647
- >
648
- > **CONVERGES:** Enterprise focus was mentioned by 3 speakers and now appears in problem-definition, market-analysis, and solution-design. This is becoming a clear strategic direction.
649
- >
650
- > **INFORMS:** Sarah's competitive analysis point adds evidence to your competitive-analysis section.
651
-
652
- **If no significant cross-relationships found:**
653
-
654
- > "No significant cross-relationships detected from this meeting's content against your existing Data Room. As your room grows, cross-meeting intelligence will get richer."
655
-
656
- ### Cross-Meeting Intelligence Scan
657
-
658
- After the within-meeting cross-relationship scan, perform cross-meeting pattern detection using the protocols from `references/meeting/cross-meeting-intelligence.md`:
659
-
660
- #### Convergence Detection
661
- 1. Extract key topics from the current meeting's metadata (topics inferred from filed segments)
662
- 2. Grep `topics:` across all `room/meetings/*/metadata.yaml` files
663
- 3. Any topic in 3+ meetings (including this one) = convergence signal
664
- 4. Surface each: "Market validation has been raised in 4 of your last 6 meetings. This is becoming a central theme."
665
-
666
- #### Contradiction Detection
667
- 1. Pre-filter prior meetings that share topics/speakers with current meeting (via metadata.yaml grep)
668
- 2. Load summaries from up to 10 matching prior meetings
669
- 3. Use Larry's reasoning to detect position changes or disagreements across meetings
670
- 4. HIGH-impact contradictions (financials, strategy, key decisions): surface immediately with specific references
671
- 5. LOW-impact contradictions (opinions, preferences): note in meeting summary
672
-
673
- #### Record Findings
674
- - Add convergence signals and cross-meeting contradictions to the meeting summary (new sections in Step 5)
675
- - Present the combined cross-relationship + cross-meeting findings to the user in priority order
676
-
677
- ---
678
-
679
- ## Post-Pipeline: Proactive Speaker Research
680
-
681
- After the entire 6-step pipeline is complete, check if any new speaker profiles were created in Step 2.
682
-
683
- **If `new_profiles` is empty:** Skip this section.
684
-
685
- **If `new_profiles` has entries:**
686
-
687
- > "I created profiles for {names}. Let me research them online to fill in context..."
688
-
689
- For each new speaker profile:
690
-
691
- 1. Extract venture context from `room/STATE.md` (venture name, domain, stage) or use confirmed meeting context
692
- 2. Run: `bash scripts/research-speaker <room_dir> <speaker-slug> <display-name> "<project-context>"`
693
- 3. Present the research findings to the user:
694
- > "Here's what I found about {name}. Want me to update their profile?"
695
- 4. **User confirms** before any research content is written to PROFILE.md
696
- 5. If confirmed, run: `bash scripts/research-speaker <room_dir> <speaker-slug> <display-name> "<project-context>" --apply`
697
- 6. If declined: Leave profile with `research_status: pending` -- user can research later
698
-
699
- **Important:** Research runs AFTER the filing pipeline. Never block filing on external API calls. This follows Pitfall 7 from research: proactive research is valuable but must not interrupt the core workflow.
700
-
701
- ---
702
-
703
- ## Closing
704
-
705
- After all steps complete (including optional research):
706
-
707
- > "Meeting filed. {N} artifacts across {M} sections. {P} speakers identified. {R} new profiles created. Anything else from this conversation?"
708
-
709
- If cross-relationships were found, add:
710
- > "I flagged {X} cross-relationships worth reviewing."
711
-
712
- If cross-meeting intelligence was detected, add:
713
- > "{Y} convergence signals and {Z} cross-meeting contradictions detected."
714
-
715
- ---
716
-
717
- ## Voice Rules
718
-
719
- - Larry's conversational voice throughout. Short sentences. Direct.
720
- - Frame gaps as opportunities: "Your competitive-analysis is light -- this meeting could change that."
721
- - Show reasoning for every classification. Transparency builds trust.
722
- - Never file silently. Always confirm-then-file.
723
- - Rejection reasons are valuable -- treat them with respect, not as failures.
724
- - Challenge gently when a user skips something important: "That decision from Lawrence seems significant. Sure you want to skip it?"