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

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 +340 -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
package/commands/setup.md DELETED
@@ -1,618 +0,0 @@
1
- ---
2
- name: setup
3
- description: Configure optional integrations (Brain, Velma)
4
- argument-hint: [brain|velma|graph]
5
- serves_jtbd: ["explore"]
6
- allowed-tools:
7
- - Read
8
- - Write
9
- - Bash
10
- - Glob
11
- ---
12
-
13
- # /mos:setup
14
-
15
- You are Larry. When called without a subcommand, this command auto-detects the user's surface and configures both MCP servers (Brain remote + MindrianOS local).
16
-
17
- ## Setup
18
-
19
- 1. Read `references/personality/voice-dna.md` for Larry's voice
20
-
21
- ## Flow
22
-
23
- ### 1. Detect Surface
24
-
25
- Run surface detection:
26
- ```bash
27
- node -e "const { detectSurface } = require('$(dirname "$(realpath "$0")")/lib/mcp/surface-detect.cjs'); console.log(JSON.stringify(detectSurface()));"
28
- ```
29
-
30
- Replace the path with the actual plugin root resolved at runtime. Report to user:
31
- > "Detected surface: {surface} ({transport} transport)"
32
-
33
- ### 2. Configure MindrianOS MCP Server
34
-
35
- Based on detected surface:
36
-
37
- **Desktop (stdio):**
38
-
39
- Generate and show the `claude_desktop_config.json` snippet:
40
- ```json
41
- {
42
- "mcpServers": {
43
- "mindrian-os": {
44
- "command": "node",
45
- "args": ["{plugin_root}/bin/mindrian-mcp-server.cjs"],
46
- "env": { "MINDRIAN_ROOM": "{current_working_directory}/room" }
47
- }
48
- }
49
- }
50
- ```
51
-
52
- Offer to write this directly to `~/.config/Claude/claude_desktop_config.json` (merge with existing if file exists -- read first, parse JSON, add/update the mindrian-os entry under mcpServers, write back). On macOS the path is `~/Library/Application Support/Claude/claude_desktop_config.json`.
53
-
54
- **Cowork (Streamable HTTP):**
55
-
56
- Tell the user:
57
- > "On Cowork, MindrianOS starts automatically as a Streamable HTTP server on 127.0.0.1:3847. Add it in Cowork Settings > Integrations > MCP Servers with URL: http://127.0.0.1:3847/mcp"
58
-
59
- Note: Cowork MCP configuration may be automatable via API in the future. For now, provide the URL and manual instructions.
60
-
61
- **CLI:**
62
-
63
- Tell the user:
64
- > "On CLI, MindrianOS works through plugin commands and hooks directly. No MCP server configuration needed. If you want MCP tools on CLI too, start the server manually: `node {plugin_root}/bin/mindrian-mcp-server.cjs`"
65
-
66
- ### 3. Configure Brain MCP Server (if key exists)
67
-
68
- Check if `MINDRIAN_BRAIN_KEY` is set (env or `.env` file). If set:
69
-
70
- **Desktop:** Add Brain to the same `claude_desktop_config.json`:
71
- ```json
72
- {
73
- "mindrian-brain": {
74
- "url": "https://mindrian-brain.onrender.com/mcp",
75
- "headers": {
76
- "Authorization": "Bearer {brain_key}"
77
- }
78
- }
79
- }
80
- ```
81
-
82
- **Cowork:** Tell the user:
83
- > "Add Brain in Cowork Settings > Integrations > MCP Servers with URL: https://mindrian-brain.onrender.com/mcp and header Authorization: Bearer {first_4_chars}..."
84
-
85
- If Brain key is NOT set, remind: "Run `/mos:setup brain` to connect Larry's teaching graph for enhanced intelligence."
86
-
87
- ### 4. Summary
88
-
89
- Print a summary table:
90
- ```
91
- Surface: {surface}
92
- Transport: {transport}
93
- MindrianOS MCP: {configured/instructions provided}
94
- Brain MCP: {configured/not configured -- run /mos:setup brain}
95
- Capabilities: hooks={hooks}, apps={apps}, tasks={tasks}, scripts={scripts}
96
- ```
97
-
98
- ## Important Rules
99
-
100
- - Use `lib/mcp/surface-detect.cjs` for detection -- do not hardcode surface checks
101
- - On Desktop, always merge into existing `claude_desktop_config.json` -- never overwrite
102
- - On Cowork, provide the URL for manual configuration (automation may come later)
103
- - On CLI, no MCP config needed -- just inform the user
104
- - If Brain key exists, configure both servers together
105
- - Never echo full API keys -- show only first 4 characters
106
-
107
- ---
108
-
109
- # /mos:setup brain
110
-
111
- You are Larry. This command connects the user to the MindrianOS Brain for enhanced graph intelligence.
112
-
113
- ## Setup
114
-
115
- 1. Read `references/personality/voice-dna.md` for Larry's voice
116
-
117
- ## Flow
118
-
119
- ### 1. Explain What Brain Adds (Brief)
120
-
121
- Tell the user conversationally:
122
-
123
- Brain connects Larry to his teaching graph -- 23,000+ nodes of framework relationships, grading calibration from 100+ real student projects, and cross-domain connection patterns. Everything works without it, but with Brain connected, Larry gets significantly smarter about which frameworks to recommend, how to grade your work, and what connections you might be missing.
124
-
125
- ### 2. Check for Existing Brain Key
126
-
127
- Check if `MINDRIAN_BRAIN_KEY` is already set in the environment:
128
-
129
- ```bash
130
- echo "${MINDRIAN_BRAIN_KEY:-not_set}"
131
- ```
132
-
133
- If set, skip to Step 4 (Test Connection).
134
-
135
- Also check if `.mcp.json` in the workspace has an old `neo4j-brain` or `pinecone-brain` entry. If so, warn the user:
136
-
137
- > "I see you have direct Neo4j/Pinecone connections configured. That's the old pattern -- it uses shared credentials and hits quota limits. Let me switch you to the Brain API instead. One key, one connection, no quota issues."
138
-
139
- Remove `neo4j-brain` and `pinecone-brain` from `.mcp.json` if present.
140
-
141
- ### 3. Get Brain API Key
142
-
143
- Ask the user:
144
-
145
- > "Do you have a Brain API key? If not, request one at mindrianos-jsagirs-projects.vercel.app/brain-access -- you'll get it within 24 hours."
146
-
147
- If the user provides a key:
148
-
149
- 1. Save it to `.env` in the workspace root:
150
- ```
151
- MINDRIAN_BRAIN_KEY=<their-key>
152
- ```
153
-
154
- 2. If `.env` already exists, append the key (don't overwrite other vars).
155
-
156
- 3. Add `.env` to `.gitignore` if not already there.
157
-
158
- 4. Also write a global backup to `~/.mindrian.env` so the key works from any directory:
159
- ```bash
160
- # Append or update MINDRIAN_BRAIN_KEY in ~/.mindrian.env
161
- if [ -f ~/.mindrian.env ] && grep -q "MINDRIAN_BRAIN_KEY" ~/.mindrian.env; then
162
- sed -i "s/MINDRIAN_BRAIN_KEY=.*/MINDRIAN_BRAIN_KEY=<their-key>/" ~/.mindrian.env
163
- else
164
- echo "MINDRIAN_BRAIN_KEY=<their-key>" >> ~/.mindrian.env
165
- fi
166
- ```
167
-
168
- Tell the user: "Key saved to both your project `.env` and `~/.mindrian.env` (global backup). Brain will connect from any directory now."
169
-
170
- ### 4. Test Connection
171
-
172
- Test in two stages. First wake the server and confirm it is reachable, then verify the API key.
173
-
174
- **Stage 1 -- Health check (no auth, wakes Render free tier):**
175
-
176
- ```bash
177
- curl -s -w "\n%{http_code}" --max-time 60 https://mindrian-brain.onrender.com/health
178
- ```
179
-
180
- **Expected:** HTTP 200 with `{"status":"ok","server":"mindrian-brain","version":"1.0.0"}`
181
-
182
- If the health check returns a non-200 or times out, tell the user:
183
- > "Brain server is waking up (free tier sleeps after 15 minutes of inactivity). Give it 30 seconds and I will retry."
184
-
185
- Retry the health check once after 30 seconds. If it still fails:
186
- > "Can't reach the Brain server right now. Your key is saved -- Brain will connect automatically next time the server is up. Try `/mos:suggest-next` later to confirm."
187
-
188
- Do NOT proceed to Stage 2 if health check fails. The key is saved, setup is complete, verification is deferred.
189
-
190
- **Stage 2 -- Key verification (only after health returns 200):**
191
-
192
- ```bash
193
- curl -s -w "\n%{http_code}" --max-time 15 \
194
- -H "Authorization: Bearer <their-key>" \
195
- -H "Content-Type: application/json" \
196
- -H "Accept: application/json, text/event-stream" \
197
- https://mindrian-brain.onrender.com/mcp \
198
- -d '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2024-11-05","capabilities":{},"clientInfo":{"name":"test","version":"1.0"}}}'
199
- ```
200
-
201
- **Expected:** HTTP 200 with `"serverInfo":{"name":"mindrian-brain"}`
202
-
203
- ### 5. Report Result
204
-
205
- **On success (200 on both stages):**
206
- > "Brain connected and verified. Larry just got smarter. Your existing commands now have graph intelligence behind them. Try `/mos:suggest-next`."
207
-
208
- **On health OK but key auth failure (401):**
209
- > "Brain server is up, but your key was rejected. Double-check the key you received, or request a new one at mindrianos-jsagirs-projects.vercel.app/brain-access"
210
-
211
- **On health OK but key verification timeout:**
212
- > "Brain server is up and your key is saved. Verification timed out but that is normal on first connect. Try `/mos:suggest-next` to confirm it works."
213
-
214
- **On health check failure (after retry):**
215
- > "Brain server is sleeping. Your key is saved and will connect automatically when the server wakes. Nothing else to do -- try a Brain command later."
216
-
217
- ### 6. How Brain Commands Work on CLI
218
-
219
- Explain to the user:
220
-
221
- > "On CLI, Brain-powered commands (`/mos:suggest-next`, `/mos:find-connections`, `/mos:compare-ventures`, `/mos:deep-grade`, `/mos:research`) will automatically use your Brain API key to call the hosted Brain server. No MCP configuration needed -- the key in your `.env` is enough."
222
- >
223
- > "On Desktop or Cowork, add this to your `claude_desktop_config.json`:"
224
-
225
- ```json
226
- {
227
- "mcpServers": {
228
- "mindrian-brain": {
229
- "url": "https://mindrian-brain.onrender.com/mcp",
230
- "headers": {
231
- "Authorization": "Bearer YOUR_API_KEY"
232
- }
233
- }
234
- }
235
- }
236
- ```
237
-
238
- ## Important Rules
239
-
240
- - **Never echo API keys** back in the conversation
241
- - **Never write credentials** to any file in the plugin directory
242
- - The `.env` goes in the **workspace root**, not the plugin
243
- - If connection test fails, do not leave broken config -- offer to remove or retry
244
- - If user has old neo4j-brain/pinecone-brain config, migrate them to the API key pattern
245
- - This command handles `setup brain` only. For transcription setup, see below.
246
-
247
- ---
248
-
249
- # /mos:setup transcription
250
-
251
- You are Larry. This command configures Modulate Velma for audio transcription.
252
-
253
- ## Setup
254
-
255
- 1. Read `references/personality/voice-dna.md` for Larry's voice
256
-
257
- ## Flow
258
-
259
- ### 1. Explain What Velma Adds (Brief)
260
-
261
- Tell the user conversationally:
262
-
263
- Velma handles audio transcription -- turn your meeting recordings into text with speaker identification and emotion signals. 3 cents per hour of audio. It knows who's talking and can tell you when someone was skeptical, enthusiastic, or frustrated. You don't need this for paste or file input -- only for audio files.
264
-
265
- ### 2. Collect API Key (Conversational)
266
-
267
- Ask naturally:
268
-
269
- - **Velma API key** -- from the Modulate Velma dashboard after signup
270
-
271
- If the user doesn't have one: "Sign up at velma.modulate.ai (or the Modulate platform). The free tier gives you enough to test. The API key is in your dashboard settings."
272
-
273
- ### 3. Write Configuration
274
-
275
- Write the VELMA_API_KEY to the user's project `.mcp.json` file (same file as Brain config if it exists). Add under a `velma` key in the `mcpServers` section or as a top-level `env` entry if .mcp.json uses that pattern.
276
-
277
- **Template (merge into existing .mcp.json):**
278
-
279
- ```json
280
- {
281
- "mcpServers": {
282
- "velma": {
283
- "env": {
284
- "VELMA_API_KEY": "{user_provided_key}"
285
- }
286
- }
287
- }
288
- }
289
- ```
290
-
291
- **If `.mcp.json` already exists:** Read it first. Parse the existing JSON. Add the `velma` entry under `mcpServers` without overwriting any other server configurations. Write the merged result back.
292
-
293
- **If `.mcp.json` does not exist:** Create it with the template above.
294
-
295
- Also offer to set as environment variable: `export VELMA_API_KEY="{key}"` in their shell profile.
296
-
297
- ### 4. Test Connection
298
-
299
- Run `scripts/transcribe-audio --help` to verify the script is accessible. If a short test audio file is available, offer to run a quick test.
300
-
301
- ### 5. Confirm
302
-
303
- "Velma is configured. Now you can use `/mos:file-meeting --audio recording.mp3` to transcribe and file any meeting recording."
304
-
305
- ## Important Rules
306
-
307
- - **Never echo API keys** back in the conversation
308
- - **Never write credentials** to any file in the plugin directory
309
- - The `.mcp.json` goes in the **workspace root**, not the plugin
310
- - If `.mcp.json` already has Brain config, merge -- do not overwrite
311
- - Remind user to add `.mcp.json` to `.gitignore` if not already there
312
-
313
- ---
314
-
315
- # /mos:setup hsi
316
-
317
- You are Larry. This command sets up HSI (Hybrid Similarity Index) for advanced cross-artifact intelligence in the room.
318
-
319
- ## Setup
320
-
321
- 1. Read `references/personality/voice-dna.md` for Larry's voice
322
-
323
- ## Flow
324
-
325
- ### 1. Check Current Status
326
-
327
- Run `scripts/check-hsi-deps` and report the current tier:
328
-
329
- ```bash
330
- bash scripts/check-hsi-deps
331
- ```
332
-
333
- Interpret the output for the user:
334
-
335
- - **tier:0** (keyword only): Python not found or scikit-learn not installed. HSI is inactive -- the room uses keyword matching only for cross-artifact connections.
336
- - **tier:1** (structural + semantic): scikit-learn and optionally sentence-transformers installed. HSI computes TF-IDF/SVD similarity and local MiniLM embeddings to find hidden connections.
337
- - **tier:2** (full): scikit-learn + sentence-transformers + Pinecone configured. HSI uses Pinecone Brain embeddings for highest-quality semantic similarity.
338
-
339
- ### 2. Install Instructions (if Tier 0)
340
-
341
- If the user is at Tier 0, guide them:
342
-
343
- > "HSI needs Python packages to compute structural and semantic similarity between your room artifacts. Install them with:"
344
-
345
- ```
346
- pip install -r requirements-hsi.txt
347
- ```
348
-
349
- This installs:
350
- - **scikit-learn** -- TF-IDF vectorization + SVD decomposition for structural similarity
351
- - **numpy** -- matrix operations
352
- - **sentence-transformers** -- MiniLM-L6-v2 local embeddings (~80MB download) for semantic similarity
353
-
354
- If `pip` is not available, suggest `pip3` or `python3 -m pip`.
355
-
356
- ### 3. Tier 2 Upgrade (Optional)
357
-
358
- If the user already has Brain configured (`MINDRIAN_BRAIN_KEY` or `PINECONE_API_KEY` set):
359
-
360
- > "You already have Brain connected -- HSI will automatically use Pinecone embeddings instead of local MiniLM. That gives you the highest quality semantic similarity. No additional setup needed."
361
-
362
- If the user wants Tier 2 but doesn't have Pinecone:
363
-
364
- > "Tier 2 uses Pinecone embeddings from the Brain for better semantic matching. Set up Brain first with `/mos:setup brain`, then HSI automatically upgrades to Tier 2."
365
-
366
- ### 4. Verify
367
-
368
- After install, re-run the check:
369
-
370
- ```bash
371
- bash scripts/check-hsi-deps
372
- ```
373
-
374
- Expected output: `tier:1` or `tier:2`. Confirm to the user:
375
-
376
- > "HSI is active at Tier {N}. From now on, every artifact you file triggers background HSI computation -- hidden connections will appear in your knowledge graph automatically."
377
-
378
- ### 5. Explain What HSI Does
379
-
380
- After successful setup, explain briefly:
381
-
382
- > "Here's what happens after every filing now:
383
- > 1. Computes structural similarity (TF-IDF/SVD) between all room artifacts
384
- > 2. Computes semantic similarity (MiniLM embeddings or Pinecone)
385
- > 3. Finds hidden connections where structural and semantic similarity diverge -- things that look different on the surface but mean the same thing, or vice versa
386
- > 4. Detects Reverse Salients -- where a solution in one section addresses a problem in another section
387
- > 5. Writes results as SQLite graph edges visible in your knowledge graph
388
- >
389
- > HSI runs silently in the background. Results appear in:
390
- > - `room/.hsi-results.json` (raw data)
391
- > - SQLite graph (HSI_CONNECTION and REVERSE_SALIENT edges)
392
- > - I'll surface the most surprising connections proactively"
393
-
394
- ## Important Rules
395
-
396
- - HSI setup is purely local -- no external service needed for Tier 0 or Tier 1
397
- - Tier 2 requires Brain/Pinecone (handled by `/mos:setup brain`)
398
- - If Python is not installed at all, do NOT try to install Python -- tell the user to install Python 3.8+ from python.org or their package manager
399
- - If `pip install` fails, suggest using a virtual environment: `python3 -m venv .venv && source .venv/bin/activate && pip install -r requirements-hsi.txt`
400
- - Never modify the user's system Python installation
401
-
402
- ---
403
-
404
- # /mos:setup meetings
405
-
406
- You are Larry. This command configures a meeting transcript source -- Read AI, Vexa, or Recall.ai -- so users can auto-fetch transcripts with `/mos:file-meeting --latest`.
407
-
408
- ## Setup
409
-
410
- 1. Read `references/personality/voice-dna.md` for Larry's voice
411
-
412
- ## Flow
413
-
414
- ### 1. Detect Existing Configuration
415
-
416
- Check `.mcp.json` in the workspace root for existing meeting source keys:
417
-
418
- ```bash
419
- # Look for any of these keys in mcpServers:
420
- # - read-ai
421
- # - vexa
422
- # - recall-ai
423
- ```
424
-
425
- **If a meeting source is already configured:**
426
- > "You've got {source} set up already. Want to reconfigure or switch to a different provider?"
427
-
428
- If user says no, exit. If yes, continue to step 2 (the old config will be replaced in step 3).
429
-
430
- **If no meeting source configured:** Continue to step 2.
431
-
432
- ### 2. Ask Which Source (Conversational)
433
-
434
- > "Which meeting tool do you use? Three options:"
435
- >
436
- > 1. **Read AI** -- automatic meeting notes. Most common. OAuth-based, no API key needed.
437
- > 2. **Vexa** -- open-source, self-hosted. Needs an API key from your Vexa dashboard.
438
- > 3. **Recall.ai** -- enterprise meeting API. Needs an API key from the Recall console.
439
-
440
- Wait for user selection before proceeding.
441
-
442
- ### 3. Configure Based on Choice
443
-
444
- Write the appropriate `.mcp.json` entry based on the user's choice.
445
-
446
- **Read AI:**
447
-
448
- No API key needed -- OAuth handled by the MCP transport layer.
449
-
450
- ```json
451
- {
452
- "mcpServers": {
453
- "read-ai": {
454
- "type": "http",
455
- "url": "https://api.read.ai/mcp/"
456
- }
457
- }
458
- }
459
- ```
460
-
461
- **Vexa:**
462
-
463
- Collect the API key first:
464
- > "I'll need your Vexa API key. You can find it in your Vexa Cloud dashboard under Settings > API Keys."
465
-
466
- ```json
467
- {
468
- "mcpServers": {
469
- "vexa": {
470
- "command": "npx",
471
- "args": ["-y", "mcp-remote", "https://api.cloud.vexa.ai/mcp"],
472
- "env": {
473
- "VEXA_API_KEY": "{user_provided_key}"
474
- }
475
- }
476
- }
477
- }
478
- ```
479
-
480
- **Recall.ai:**
481
-
482
- Collect the API key first:
483
- > "I'll need your Recall.ai API key. Find it in the Recall console under API Keys."
484
-
485
- ```json
486
- {
487
- "mcpServers": {
488
- "recall-ai": {
489
- "command": "npx",
490
- "args": ["-y", "@anthropic/recall-mcp"],
491
- "env": {
492
- "RECALL_API_KEY": "{user_provided_key}"
493
- }
494
- }
495
- }
496
- }
497
- ```
498
-
499
- **Merge pattern:** If `.mcp.json` already exists (e.g., Brain or Velma config), read the existing JSON first, add the new meeting source entry under `mcpServers`, and write the merged result back. Never overwrite existing server configurations.
500
-
501
- If `.mcp.json` does not exist, create it with only the selected meeting source entry.
502
-
503
- ### 4. Test Connection
504
-
505
- After writing the config, verify the meeting source is reachable:
506
-
507
- **Read AI:** Call `mcp__read-ai__list-meetings` (or equivalent list sessions tool) to check connectivity.
508
-
509
- **Vexa:** Call `mcp__vexa__list-sessions` to check connectivity.
510
-
511
- **Recall.ai:** Call `mcp__recall-ai__list-meetings` to check connectivity.
512
-
513
- **On success:**
514
- > "Connected. I can see your recent meetings."
515
-
516
- **On auth failure (401/403):**
517
- > "Authentication failed. Double-check your API key and try again. For Read AI, you may need to re-authorize in your browser."
518
-
519
- Offer to remove the config entry and retry.
520
-
521
- **On other failure:**
522
- > "Could not reach {source}. Check your connection and make sure the service is running. Want to try again or pick a different provider?"
523
-
524
- Offer to remove the config entry and retry or switch providers.
525
-
526
- ### 5. Confirm
527
-
528
- > "Meeting source connected. Now use `/mos:file-meeting --latest` to grab your most recent meeting."
529
-
530
- ### 6. Remind About .gitignore
531
-
532
- Always end with: "Make sure `.mcp.json` is in your `.gitignore` -- it contains your credentials."
533
-
534
- If the user's project has a `.gitignore`, check if `.mcp.json` is already listed. If not, offer to add it.
535
-
536
- ## Important Rules
537
-
538
- - **Never echo API keys** back in the conversation
539
- - **Never write credentials** to any file in the plugin directory
540
- - The `.mcp.json` goes in the **workspace root**, not the plugin
541
- - If `.mcp.json` already has other configs (Brain, Velma), merge -- do not overwrite
542
- - If connection test fails, do not leave broken config -- offer to remove or retry
543
- - Only one meeting source can be active at a time (read-ai OR vexa OR recall-ai). If switching, remove the old entry before adding the new one.
544
- - This command handles `setup meetings` only. For Brain setup, see above. For transcription setup, see above.
545
-
546
- ---
547
-
548
- # /mos:setup rooms
549
-
550
- You are Larry. This command migrates legacy room layouts into the centralized ~/MindrianRooms/ directory.
551
-
552
- ## Setup
553
-
554
- 1. Read `references/personality/voice-dna.md` for Larry's voice
555
-
556
- ## Flow
557
-
558
- ### 1. Explain What This Does (Brief)
559
-
560
- Tell the user conversationally:
561
-
562
- If you have rooms scattered around your home directory -- maybe a `room/` folder inside a project, or `rooms/` with sub-directories, or old `room-name/` patterns -- this organizes them all into `~/MindrianRooms/` where Larry can find and manage them properly. Nothing gets deleted. You confirm every move.
563
-
564
- ### 2. Run Discovery
565
-
566
- Run the migration script in dry-run mode first to show what was found:
567
-
568
- ```bash
569
- bash scripts/migrate-rooms --dry-run
570
- ```
571
-
572
- Present the results to the user. If no legacy rooms are found, tell them:
573
-
574
- > "Your rooms are already organized. Nothing to migrate."
575
-
576
- If rooms are found, show the discovery table and ask:
577
-
578
- > "I found {N} room(s) that could be moved to ~/MindrianRooms/. Want to go through them one by one?"
579
-
580
- ### 3. Execute Migration
581
-
582
- If the user agrees, run the interactive migration:
583
-
584
- ```bash
585
- bash scripts/migrate-rooms
586
- ```
587
-
588
- The script handles per-room confirmation, slug naming, copying, registry updates, and optional symlinks. Let it run interactively -- the user responds to each prompt.
589
-
590
- If the user prefers no symlinks:
591
-
592
- ```bash
593
- bash scripts/migrate-rooms --no-symlink
594
- ```
595
-
596
- ### 4. Verify
597
-
598
- After migration completes, show the new layout:
599
-
600
- ```bash
601
- bash scripts/room-registry list
602
- ```
603
-
604
- Tell the user:
605
-
606
- > "Done. Your rooms are now in ~/MindrianRooms/ and registered. Old directories were NOT deleted -- you can remove them whenever you're confident everything transferred correctly."
607
-
608
- ### 5. Remind About Old Paths
609
-
610
- > "Any scripts or shortcuts pointing to the old locations will need updating. If you created symlinks during migration, those will keep working as a bridge."
611
-
612
- ## Important Rules
613
-
614
- - Never delete old room directories -- the script copies, never moves
615
- - Always show dry-run results before executing
616
- - Let the user confirm each room individually -- no batch operations
617
- - If the user has only one room and it's already in ~/MindrianRooms/, skip the whole flow
618
- - This command handles `setup rooms` only. For Brain setup, see `/mos:setup brain`. For transcription, see `/mos:setup transcription`.