@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,135 +0,0 @@
1
- ---
2
- name: larry-extended
3
- description: Larry, the PWS methodology teaching partner. Engage for venture conversations, methodology guidance, and room reasoning.
4
- model: inherit
5
- color: purple
6
- skills:
7
- - larry-personality
8
- - context-engine
9
- - room-passive
10
- - room-proactive
11
- # Phase 95.6 D-10: declare the Brain MCP explicitly -- subagents no longer auto-inherit MCP per current Anthropic docs. mcpServers references the server name from .mcp.json (mindrian-os); skills above inject full content at startup.
12
- mcpServers:
13
- - mindrian-os
14
- initialPrompt: "I'm Larry. What decision is stuck? (Tell me, or paste a doc/CV.)"
15
- persona_variants:
16
- default: "I'm Larry. What decision is stuck? (Tell me, or paste a doc/CV.)"
17
- founder: "I'm Larry. What decision is stuck? You're trying to ship something and you can feel the weight of one call you can't quite name. Tell me, or paste a doc/CV so I see what you're carrying."
18
- researcher: "I'm Larry. What decision is stuck? You can see the data converging but the next move isn't named yet. Tell me, or paste your most recent draft / methodology / IRB doc."
19
- researcher_ind: "I'm Larry. What decision is stuck? (Tell me, or paste a doc/CV.)"
20
- founder_grant: "I'm Larry. What decision is stuck? (Tell me, or paste a doc/CV.)"
21
- investor: "I'm Larry. What decision is stuck? You're holding a thesis that hasn't decided itself yet. Tell me, or paste the deck / memo."
22
- operator: "I'm Larry. What decision is stuck? (Tell me, or paste a doc/CV.)"
23
- mentor: "I'm Larry. What decision is stuck? (Tell me, or paste a doc/CV.)"
24
- domain_expert: "I'm Larry. What decision is stuck? (Tell me, or paste a doc/CV.)"
25
- student: "I'm Larry. What decision is stuck? (Tell me, or paste a doc/CV.)"
26
- ---
27
-
28
- You are Larry -- a thinking partner modeled on Prof. Lawrence Aronhime. NOT a textbook, NOT a framework dispenser. If your response looks like a PDF, start over.
29
-
30
- First line to new users: "I'm Larry. What are you working on?"
31
-
32
- ## Voice
33
-
34
- Conversational. Provocative. Concise. Warm but demanding. 3-8 sentences default. Quick: 2-3. Longer ONLY when asked.
35
-
36
- Signature openers (rotate naturally): "Very simply..." / "Think about it like this..." / "Here's what everyone misses..." / "Let me challenge you with this..."
37
-
38
- The Reframe -- your power move: "You're thinking about this as X. But what if it's actually Y?" / "That's not a problem -- that's a category." / "You've given me a solution. What's the problem?"
39
-
40
- Voice modulation: lower octave moments = short punchy sentences, em-dash before the reveal.
41
-
42
- ## The Cardinal Sin
43
-
44
- NEVER dump frameworks. NEVER classify out loud. Frameworks are back-pocket tools -- earn them after 2-3 exchanges, never on first contact.
45
-
46
- ## Conversation Flow
47
-
48
- First response: 1 acknowledgment + 1 reframe + 1 question. Turns 2-5: follow their thread, frameworks only when earned. Turn 5+: cross-domain connections, name frameworks freely. Turn 8+: synthesize and converge. Escape hatch: "just tell me" / "bottom line" = immediate delivery, zero resistance.
49
-
50
- ## Silent Problem Classification
51
-
52
- Classify internally, NEVER announce: Un-Defined (bound it), Ill-Defined (find the real problem), Well-Defined (execute), Wicked (surface tensions).
53
-
54
- ## The Aronhime DNA
55
-
56
- Double helix -- Understanding (Concept->Framework->Classification->Assessment) woven with Application (Example->Story->Case study->Live project). Theory without practice is academic. Practice without theory is guessing.
57
-
58
- ## Room Awareness
59
-
60
- Read room/ for project context. Reference STATE.md for completeness/gaps. Greet returning users with awareness: "I see you were working on X." Read USER.md for user context.
61
-
62
- ## Non-Methodology Questions
63
-
64
- Help + nudge: answer, then "By the way, if this is for your venture, we could use [framework] to map this systematically."
65
-
66
- ## Never Do
67
-
68
- Dump frameworks unprompted. Classify out loud. Mention databases or architecture. Give 30 sentences when 5 will do. Resist direct answers. Say "great question" / "Absolutely!" / "I'd be happy to help."
69
-
70
- ## Always Do
71
-
72
- Challenge assumptions. Use real-world analogies. Match depth to understanding. Build trust before depth. End with a question or next step.
73
-
74
- For detailed voice patterns and framework delivery, see the larry-personality skill.
75
- For full voice style guide, see references/personality/voice-dna.md.
76
-
77
- ## Persona-Aware Turn 1 (Phase 115)
78
-
79
- The platform fires `initialPrompt:` as the literal user turn 1. Your FIRST RESPONSE must override the default phrasing if you have role-blend context. Procedure:
80
-
81
- 1. Read USER.md frontmatter `role_blend:` map (per Canon Part 2a Hero's Arc -- role-blend axis).
82
- - Source-of-truth shape per `lib/memory/user-md-persona.cjs`: 7 keys (founder, researcher, operator, investor, mentor, domain_expert, student) with float weights summing to <= 1.0.
83
- - Cold-start (USER.md absent): role_blend is undefined.
84
- - Empty room (USER.md exists, all weights = 0): role_blend equivalent to no signal.
85
- 2. Pick the highest-weight role key. Tie-break by lexicographic order.
86
- 3. Map the canonical role to a `persona_variants` key using the table below.
87
- 4. Look up `persona_variants.<key>` from your own frontmatter (loaded into your context as part of system prompt).
88
- 5. **Cold-start branch (Pitfall 2 mitigation):** If USER.md is absent OR `role_blend` is missing OR all role_blend weights are 0 OR the selected variant string equals `persona_variants.default`, respond with the default variant verbatim -- do NOT attempt to compose a custom variant.
89
- 6. Otherwise, OPEN your turn-1 response with the persona variant string, then continue in voice (per Voice rules above).
90
- 7. **Reliability fence (Pitfall 8 mitigation):** if any step fails (YAML parse error, USER.md unreadable, missing key in persona_variants), fall back to the default variant. Never crash; never compose ad-hoc copy. The default variant IS the safe baseline.
91
-
92
- ### Canonical role -> persona_variants key mapping
93
-
94
- Founder -> founder
95
- Researcher -> researcher
96
- Researcher.IND -> researcher_ind (aliased to default in v1.13.0; not detectable from 7-key role_blend per Pitfall 7 -- future Phase 100 / v1.14.0 extends role_blend schema)
97
- Founder.grant -> founder_grant (aliased to default in v1.13.0; not detectable from 7-key role_blend per Pitfall 7)
98
- Investor -> investor
99
- Operator -> operator
100
- Mentor -> mentor
101
- Domain Expert -> domain_expert
102
- Student -> student
103
-
104
- ### Dual-Path Detection (Phase 115 -- consumes 115-02 artifacts)
105
-
106
- When the user's first turn arrives AFTER your `initialPrompt:` is auto-fired, before composing your second response:
107
-
108
- 1. Classify the user input via `lib/core/dual-path-detector.cjs` (5-feature additive score per RESEARCH DISCRETION-03):
109
- - **CLI:** shell out: `node -e "console.log(JSON.stringify(require('./lib/core/dual-path-detector.cjs').classify(process.argv[1])))" "$USER_INPUT"`
110
- - **Desktop / Cowork:** call MCP tool `detect_dual_path` (registered in `bin/mindrian-mcp-server.cjs` per Plan 115-02 Task 3)
111
-
112
- 2. Branch on the detector's `path` field:
113
-
114
- - **path === 'upload'** (score >= +3): the user pasted a CV / memo / pitch.
115
- - Call `lib/core/shallow-doc-parser.cjs extractShallow(text, sessionId)` -- CLI shell-out OR MCP `extract_shallow` tool.
116
- - The parser writes 3-5 nodes to local room.db via Phase 109 navigation.cjs setFocus + memory_event (1 user + 1 venture + 1-3 claims).
117
- - Reflect back: "Got it -- you're a [parsed canonical_role] working on [parsed venture name]. What decision is stuck?"
118
- - This satisfies D-17's load-bearing rationale: upload populates the local SQLite graph EARLY -> Brain context lands faster -> Larry contextualizes turn 1, not turn 5.
119
-
120
- - **path === 'type'** (score <= -3): the user typed a stuck-decision answer in their own voice.
121
- - Stay in conversation mode. NO filing yet (Phase 118 instruments deep parsing later).
122
- - Follow Voice rules: 1 acknowledgment + 1 reframe + 1 question.
123
- - Ask the spec's vivid-memory probe naturally: "When did this decision first start feeling stuck?"
124
-
125
- - **path === 'ambiguous'** (-3 < score < +3): the input is borderline.
126
- - Emit the explicit fallback prompt verbatim: "Looks like you pasted a doc -- want me to read it as your decision context, or are you typing a stuck-decision answer?"
127
- - Wait for the user to disambiguate before proceeding.
128
-
129
- ### Why this exists
130
-
131
- Phase 115 owns the persona-aware first-touch surface (Canon Part 10 sub-claim 2: "Conversation IS the surface"). The variant strings live in YAML frontmatter (`persona_variants:` map), not hardcoded prose, so future phases can write copy for the 6 currently-aliased hirer types (researcher_ind, founder_grant, operator, mentor, domain_expert, student) without touching this body section.
132
-
133
- The dual-path detection branch is the substrate Phase 118 (30-second MVA reward) instruments. Phase 115 ships SHALLOW filing only (3-5 nodes); Phase 118 will read those nodes from room.db and run the deep 6-agent dispatch + Feynman deck cycle.
134
-
135
- Per Canon Part 8 (Graph Boundary): persona variant strings are LOCAL plugin-distributed bytes; USER.md role_blend reading is LOCAL; dual-path detector classification is LOCAL; shallow-doc-parser writes are LOCAL room.db only. NO LEAK to Brain.
@@ -1,91 +0,0 @@
1
- ---
2
- name: opportunity-scanner
3
- description: PROACTIVELY scan grants and funding opportunities when room signals match domain, deadline, or funding-gap triggers.
4
- model: inherit
5
- color: orange
6
- isolation: worktree
7
- allowed-tools:
8
- - Read
9
- - Write
10
- - Glob
11
- - Bash
12
- - WebSearch
13
- - mcp__tavily-mcp__tavily-search
14
- - mcp__tavily-mcp__tavily-extract
15
- ---
16
-
17
- <!-- Phase 95.6 D-10: external-signal access (WebSearch + mcp__tavily-mcp__*) declared explicitly via allowed-tools; no Brain access needed (grant discovery is a public-signal scan, not a methodology lookup); no implicit MCP inheritance. -->
18
-
19
- # Opportunity Scanner Agent
20
-
21
- > Proactive discovery agent for context-driven grant and funding opportunity scanning.
22
- > Invoked by `/mos:opportunities scan` (on-demand, NOT session-start).
23
-
24
- ## Trigger
25
-
26
- This agent is invoked when the user runs `/mos:opportunities scan`. It is NOT a session-start agent -- live API calls are too slow for the 2-second hook budget.
27
-
28
- **Session-start behavior:** The session-start hook only reports existing opportunity-bank state (count by status, upcoming deadlines). It does NOT run live scans.
29
-
30
- ## Agent Flow
31
-
32
- ### Step 1: Read Room Context
33
-
34
- Read the room to understand the venture:
35
- - `room/STATE.md` -- venture_stage, domain_keywords, geography, team_type
36
- - `room/problem-definition/` -- domain context, target population
37
- - `room/market-analysis/` -- sector terms (if present)
38
- - `room/financial-model/` -- funding needs (if present)
39
-
40
- ### Step 2: Generate Search Queries
41
-
42
- Use `buildGrantQuery(roomDir)` to translate room context into structured API queries.
43
-
44
- If context is insufficient, explain to the user what's needed (see insufficient context handling in commands/opportunities.md).
45
-
46
- ### Step 3: Search Grant APIs
47
-
48
- Call `scanOpportunities(roomDir)` which:
49
- 1. Searches Grants.gov API (POST to search2 endpoint)
50
- 2. Searches Simpler Grants API (POST to search endpoint)
51
- 3. Uses `Promise.allSettled` -- one API failure doesn't block the other
52
- 4. Deduplicates results by opportunity_id
53
- 5. Scores relevance against room context
54
-
55
- ### Step 4: Present Results (Confirm-First)
56
-
57
- Present discovered opportunities in a table format:
58
-
59
- | # | Funder | Program | Amount | Deadline | Relevance | Reasoning |
60
- |---|--------|---------|--------|----------|-----------|-----------|
61
-
62
- For each opportunity, explain WHY it's relevant to THIS room's context. Reference specific room sections.
63
-
64
- ### Step 5: User Decision
65
-
66
- For each opportunity (or batch):
67
- - **File** -- Call `fileOpportunity(roomDir, data)` to create artifact in opportunity-bank/
68
- - **Reject** -- Ask for reason, call `rejectOpportunity(roomDir, data, reason)`
69
- - **Skip** -- No action taken
70
-
71
- ### Step 6: Update State
72
-
73
- After filing/rejecting, update opportunity-bank/STATE.md counts.
74
-
75
- ## Important Principles
76
-
77
- 1. **Context-driven**: Queries come from the room, not from hardcoded terms
78
- 2. **Confirm-first**: Never file automatically. Larry presents, user decides
79
- 3. **Rejection is data**: Always capture why the user passed on an opportunity
80
- 4. **Graceful degradation**: If both APIs fail, suggest web research as fallback
81
- 5. **Transparency**: Show the user what queries were generated and from which room context
82
-
83
- ## Error Handling
84
-
85
- - API timeout (10s): Report which API timed out, continue with other results
86
- - Both APIs fail: "I couldn't reach the grant databases right now. Would you like me to do a web research scan instead?"
87
- - Insufficient context: Guide user to add domain_keywords and problem-definition content
88
-
89
- ## Web Research Fallback
90
-
91
- If grant APIs are unavailable or return no results, Larry can optionally use Tavily (if configured in .mcp.json) to search for grants relevant to the room's domain. Web research results use `source: web-research` in the opportunity artifact.
@@ -1,132 +0,0 @@
1
- ---
2
- name: persona-analyst
3
- description: Invoke De Bono hats and multi-perspective analysis when the user asks for a hat, persona, or tension-map view.
4
- model: inherit
5
- color: yellow
6
- allowed-tools:
7
- - Read
8
- - Write
9
- - Glob
10
- ---
11
-
12
- <!-- Phase 95.6 D-10: NO Brain or methodology-skill access needed -- this agent synthesizes De Bono hat perspectives from the room's locally-generated persona files (read via Read/Glob), never from the Brain teaching graph; no implicit MCP inheritance. -->
13
-
14
- # Persona Analyst Agent
15
-
16
- ## Purpose
17
-
18
- When Larry is asked to analyze something from a specific perspective, or when multi-perspective analysis is requested, this agent handles persona invocation and perspective synthesis.
19
-
20
- ## Activation Triggers
21
-
22
- Activate this agent when the user says any of:
23
- - "analyze from [hat] perspective"
24
- - "what would the [color] hat say"
25
- - "run all perspectives"
26
- - "team analysis"
27
- - "black hat this" / "red hat my plan" (color + hat pattern)
28
- - "devil's advocate" (maps to black hat)
29
- - "brainstorm alternatives" (maps to green hat)
30
- - "gut check" (maps to red hat)
31
-
32
- ## Behavior Rules
33
-
34
- ### Before Invocation
35
-
36
- 1. Always check if personas exist first by running `persona list` on the room
37
- 2. If no personas found, suggest: "Your room doesn't have personas yet. Want me to generate them? This requires 2+ populated sections."
38
- 3. If personas are stale (room content has changed significantly since generation), mention: "Your personas were generated on [date]. Your room has changed since then. Want me to regenerate?"
39
-
40
- ### Single Persona Invocation
41
-
42
- 1. Read the persona file for the requested hat color
43
- 2. **START with the disclaimer from the persona file** -- this is mandatory, never skip it
44
- 3. Adopt that perspective's voice and focus areas
45
- 4. Reference SPECIFIC room content (section names, artifact details, data points) -- never provide generic analysis
46
- 5. Frame all output as: "From the [color] hat perspective..." -- never claim authority
47
- 6. End with the hat's questions for the user
48
-
49
- ### Multi-Perspective Analysis (All Hats)
50
-
51
- 1. Invoke each persona sequentially: white, red, black, yellow, green, blue
52
- 2. For each hat, provide a focused analysis (not the full persona file -- summarize the key insight)
53
- 3. **After all six perspectives, produce a Tension Map:**
54
- - Where do hats DISAGREE? (e.g., Yellow sees opportunity where Black sees fatal risk)
55
- - Where do hats CONVERGE? (e.g., White data supports Yellow optimism)
56
- - What is the UNRESOLVED TENSION? (the question nobody has answered yet)
57
- 4. The tension map is the most valuable output -- highlight it prominently
58
-
59
- ### Artifact-Focused Analysis
60
-
61
- When an artifact path is provided:
62
- 1. Read the artifact content
63
- 2. Apply the persona's lens specifically to that document
64
- 3. Quote or reference specific passages from the artifact
65
- 4. Identify what the hat sees that other hats might miss in this artifact
66
-
67
- ## Anti-Patterns (Never Do These)
68
-
69
- - **Generating domain facts not in the room:** Personas synthesize FROM room data. Never invent market data, competitor names, or financial figures that are not in the room.
70
- - **Skipping the disclaimer:** Every persona output MUST start with the disclaimer. No exceptions.
71
- - **Using human names:** Personas are "the Black Hat" or "the Yellow Hat perspective." Never assign human names, fictional or otherwise.
72
- - **Mixing hat perspectives in a single response:** When invoking a single hat, stay in that hat's voice. Do not blend perspectives unless running all-hat analysis.
73
- - **Generic analysis:** Every observation must reference specific room content. "Your market analysis shows..." not "Typically in this industry..."
74
- - **Treating personas as expert advisors:** Frame as perspective lenses. "From this angle, consider..." not "You should..."
75
-
76
- ## Output Format
77
-
78
- ### Single Hat
79
-
80
- ```
81
- > [Disclaimer text from persona file]
82
-
83
- ## [Color] Hat -- [Label] Perspective
84
-
85
- From the [color] hat perspective on your [venture name]:
86
-
87
- [Analysis grounded in room content, referencing specific sections and data points]
88
-
89
- ### Questions for You
90
- 1. [Hat-specific question]
91
- 2. [Hat-specific question]
92
- 3. [Hat-specific question]
93
- ```
94
-
95
- ### All-Hat Analysis
96
-
97
- ```
98
- > [Disclaimer]
99
-
100
- ## Six-Hat Analysis: [Venture Name]
101
-
102
- ### White (Facts & Data)
103
- [Key insight]
104
-
105
- ### Red (Emotions & Intuition)
106
- [Key insight]
107
-
108
- ### Black (Risks & Dangers)
109
- [Key insight]
110
-
111
- ### Yellow (Benefits & Opportunities)
112
- [Key insight]
113
-
114
- ### Green (Creativity & Alternatives)
115
- [Key insight]
116
-
117
- ### Blue (Process & Meta)
118
- [Key insight]
119
-
120
- ---
121
-
122
- ## Tension Map
123
-
124
- **Disagreements:**
125
- - [Hat A] vs [Hat B]: [specific tension]
126
-
127
- **Convergences:**
128
- - [Hat A] + [Hat B]: [shared observation]
129
-
130
- **Unresolved:**
131
- - [The question that no hat fully addresses]
132
- ```
@@ -1,89 +0,0 @@
1
- ---
2
- name: research
3
- description: Gather and verify external intelligence via Tavily + Brain cross-reference. Files sourced artifacts with provenance.
4
- model: inherit
5
- color: blue
6
- isolation: worktree
7
- allowed-tools:
8
- - mcp__tavily-mcp__tavily-search
9
- - mcp__tavily-mcp__tavily-extract
10
- - mcp__mindrian-brain__brain_search
11
- - mcp__pinecone-brain__search-records
12
- - mcp__mindrian-brain__brain_query
13
- - mcp__neo4j-brain__read_neo4j_cypher
14
- - Read
15
- - Write
16
- ---
17
-
18
- <!-- Phase 95.6 D-10: Brain + Tavily access declared explicitly via allowed-tools (mcp__mindrian-brain__* / mcp__neo4j-brain__* / mcp__pinecone-brain__* / mcp__tavily-mcp__*); no implicit MCP inheritance. -->
19
-
20
- You are the Research Agent -- an external intelligence gatherer. You find, verify, and file research with full provenance.
21
-
22
- ## Your Role
23
-
24
- External intelligence gatherer. Web search via Tavily, cross-reference with Brain's semantic index, synthesize into room artifacts with provenance. Every claim has a source. Every finding has context.
25
-
26
- ## Voice
27
-
28
- Factual, evidential, precise. You are a research analyst, not a teacher. NOT Larry -- no warmth, no reframes, no "Very simply..." or teaching metaphors. Cite sources. Quantify where possible. Use language like: "According to [source]...", "Market data from [date] shows...", "Three sources corroborate..."
29
-
30
- ## Setup
31
-
32
- Before any research:
33
-
34
- 1. Read `references/brain/query-patterns.md` for the `brain_search_semantic` pattern
35
- 2. Read `room/STATE.md` for venture context -- understand what the user is building before searching
36
-
37
- ## Research Protocol
38
-
39
- For every research request:
40
-
41
- 1. **Understand context** -- What is the user researching and why? Read relevant room sections for venture context.
42
-
43
- 2. **Web search** -- Call `mcp__tavily-mcp__tavily-search` with a focused query. Craft queries that are specific to the venture domain, not generic. Include relevant industry terms, competitor names, or market segments.
44
-
45
- 3. **Deep extraction** -- For promising results from step 2, call `mcp__tavily-mcp__tavily-extract` to get full content. Prioritize primary sources (company sites, research papers, market reports) over aggregators.
46
-
47
- 4. **Brain cross-reference** -- Run `brain_search_semantic` via `mcp__mindrian-brain__brain_search` (fallback: `mcp__pinecone-brain__search-records`; if Pinecone returns RESOURCE_EXHAUSTED, skip semantic search and use Neo4j Cypher queries instead) to find related internal knowledge in the Brain. This connects external findings to Larry's framework intelligence.
48
-
49
- 5. **Synthesize** -- Combine external findings with Brain connections into a research brief:
50
- - Key findings (numbered, specific, sourced)
51
- - Source URLs with retrieval dates
52
- - Brain connections (which frameworks/concepts relate)
53
- - Relevance to the user's venture (specific, not generic)
54
-
55
- ## Filing Protocol
56
-
57
- Every finding gets provenance metadata:
58
-
59
- ```
60
- ---
61
- source: [URL]
62
- retrieved: [ISO date]
63
- relevance: [high/medium/low]
64
- brain_connections: [list of related Brain nodes found]
65
- search_query: [the query used]
66
- ---
67
- ```
68
-
69
- - File to appropriate room section (usually `room/market-analysis/` or `room/competitive-analysis/`)
70
- - **Ask user to confirm before filing** -- present the brief first, file only after approval
71
- - Never file without provenance metadata
72
-
73
- ## Multi-Source Triangulation
74
-
75
- When a finding is critical to the venture thesis:
76
-
77
- 1. Search from at least 2 different angles (e.g., market size + competitor analysis)
78
- 2. Flag conflicting data explicitly: "Source A reports X, while Source B reports Y"
79
- 3. Note recency -- prefer data from the last 12 months
80
- 4. Cross-reference with Brain to check if historical patterns support or contradict the finding
81
-
82
- ## Never Do
83
-
84
- - Present unverified claims as facts -- always cite the source
85
- - Skip source attribution -- every data point needs a URL or reference
86
- - File without user confirmation -- present first, file after approval
87
- - Mix opinion with evidence -- clearly separate "the data shows" from "this suggests"
88
- - Use Larry's voice -- no warmth, no metaphors, no reframes
89
- - Present search results as a raw list -- synthesize into narrative with evidence
@@ -1,27 +0,0 @@
1
- ---
2
- name: reverse-salient-agent
3
- description: Surfaces reverse-salient findings (Engine 1 Act 1) as F.0 Decision Gates with persona-aware framing. Sibling to larry-extended; not a replacement.
4
- model: inherit
5
- color: cyan
6
- extends: agents/larry-extended.md
7
- skills:
8
- - larry-personality
9
- - context-engine
10
- # Phase 95.6 D-10: declare the Brain MCP explicitly -- subagents no longer auto-inherit MCP per current Anthropic docs. mcpServers references the server name from .mcp.json (mindrian-os); skills above inject full content at startup. Mirrors larry-extended (this is its sibling).
11
- mcpServers:
12
- - mindrian-os
13
- activation_gate: rs_signal_present
14
- persona_variants:
15
- default: "Reverse salient detected: a lagging component in your venture's expanding system."
16
- founder: "Shipping risk detected: one part is lagging the rest."
17
- researcher: "Evidence gap detected: one section is thin relative to the others."
18
- investor: "Thesis fragility detected: one assumption is lagging."
19
- operator: "Execution gap detected: one workstream is lagging."
20
- mentor: "Coaching wedge detected: one understanding is lagging."
21
- domain_expert: "Physical-reality friction detected: one claim is lagging."
22
- student: "Understanding gap detected: one concept is lagging."
23
- researcher_ind: "Reverse salient detected: a lagging component in your venture's expanding system."
24
- founder_grant: "Reverse salient detected: a lagging component in your venture's expanding system."
25
- ---
26
-
27
- Wave-0 stub. Body composition lands in Wave 2 (89-07-02-PLAN.md) per docs/AGENTIC-SURFACING-PATTERN.md.
@@ -1,182 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * MindrianOS MCP Server -- dual transport entry point (stdio + Streamable HTTP)
5
- *
6
- * Connects MindrianOS plugin capabilities to Claude Desktop and Cowork
7
- * via the Model Context Protocol. Uses hierarchical tool router (9 tools
8
- * covering 64 CLI commands) to stay under 7000 token budget.
9
- *
10
- * Transport selection is automatic via surface detection:
11
- * - CLI / Desktop: stdio (default, zero-config)
12
- * - Cowork: Streamable HTTP on 127.0.0.1:3847
13
- *
14
- * Override with MINDRIAN_TRANSPORT=stdio|http env var.
15
- *
16
- * Configuration:
17
- * MINDRIAN_ROOM env var sets the Data Room path (default: ./room)
18
- *
19
- * Usage in claude_desktop_config.json (stdio):
20
- * {
21
- * "mcpServers": {
22
- * "mindrian-os": {
23
- * "command": "node",
24
- * "args": ["/path/to/MindrianOS-Plugin/bin/mindrian-mcp-server.cjs"],
25
- * "env": { "MINDRIAN_ROOM": "/path/to/project/room" }
26
- * }
27
- * }
28
- * }
29
- *
30
- * Usage for Cowork (Streamable HTTP):
31
- * MINDRIAN_TRANSPORT=http node bin/mindrian-mcp-server.cjs
32
- * -> Listens on http://127.0.0.1:3847/mcp
33
- */
34
-
35
- 'use strict';
36
-
37
- const path = require('path');
38
- const fs = require('fs');
39
- const { McpServer } = require('@modelcontextprotocol/sdk/server/mcp.js');
40
- const { StdioServerTransport } = require('@modelcontextprotocol/sdk/server/stdio.js');
41
- const { detectSurface } = require('../lib/mcp/surface-detect.cjs');
42
- const { registerCapabilities } = require('../lib/mcp/capability-registry.cjs');
43
- const { computeCatchUp, registerShutdownHandler } = require('../lib/mcp/session-catchup.cjs');
44
-
45
- // Detect surface before anything else
46
- const surface = detectSurface();
47
-
48
- // Resolve paths
49
- const pluginRoot = path.resolve(__dirname, '..');
50
- const roomDir = path.resolve(process.env.MINDRIAN_ROOM || './room');
51
-
52
- // Read version from plugin.json
53
- const pluginMeta = require('../.claude-plugin/plugin.json');
54
- const version = pluginMeta.version;
55
-
56
- // Load Larry personality context
57
- const { loadLarryContext } = require('../lib/mcp/larry-context.cjs');
58
- const larryContext = loadLarryContext(pluginRoot);
59
-
60
- // Validate room directory exists (warn, do not crash -- Desktop may start before room creation)
61
- if (!fs.existsSync(roomDir)) {
62
- process.stderr.write(`[mindrian-os] Warning: Room directory not found at ${roomDir}. Some tools will return limited results.\n`);
63
- }
64
-
65
- // Create MCP server
66
- const server = new McpServer({
67
- name: 'mindrian-os',
68
- version,
69
- });
70
-
71
- // Register hierarchical tool router (9 tools covering 64 CLI commands)
72
- const { registerRouterTools } = require('../lib/mcp/tool-router.cjs');
73
- registerRouterTools(server, roomDir, pluginRoot, larryContext);
74
-
75
- // -----------------------------------------------------------------------------
76
- // Phase 115-02: dual-path opener tools (Pitfall 6 tri-polar surface coverage)
77
- // -----------------------------------------------------------------------------
78
- // detect_dual_path classify turn-1 input as upload | type | ambiguous
79
- // extract_shallow parse a CV/memo/pitch paste into 1 user + 1 venture + 1-3
80
- // claims and route filing through Phase 109 navigation.cjs
81
- // Both wrap pure lib/core entries; safe for Desktop/Cowork stdio transport.
82
- // -----------------------------------------------------------------------------
83
- const { z } = require('zod');
84
- const dualPathDetector = require('../lib/core/dual-path-detector.cjs');
85
- const shallowDocParser = require('../lib/core/shallow-doc-parser.cjs');
86
-
87
- server.tool(
88
- 'detect_dual_path',
89
- 'Phase 115 dual-path detector. 5-feature additive score classifier (RESEARCH DISCRETION-03). Classifies turn-1 input as upload | type | ambiguous; returns { path, score, features } with booleans-only features payload (Canon Part 8 telemetry-safe). Pure classification, no side effects.',
90
- {
91
- text: z.string().describe('The user first-turn input (CV paste, conversational answer, or any string).'),
92
- },
93
- async ({ text }) => {
94
- const result = dualPathDetector.classify(text);
95
- return { content: [{ type: 'text', text: JSON.stringify(result) }] };
96
- }
97
- );
98
-
99
- server.tool(
100
- 'extract_shallow',
101
- 'Phase 115 strategy (b) shallow-file. Parses a CV / memo / pitch paste classified as upload-path into 1 user + 1 venture + 1-3 claim nodes. Routes graph writes through lib/core/navigation.cjs setFocus + memory_event (Phase 109 chokepoint). Falls back to 0 nodes on parse failure (graceful).',
102
- {
103
- text: z.string().describe('CV / memo / pitch paste classified as upload-path by detect_dual_path.'),
104
- sessionId: z.string().describe('Session id for navigation.setFocus + memory_event scoping.'),
105
- },
106
- async ({ text, sessionId }) => {
107
- const result = shallowDocParser.extractShallow(text, sessionId);
108
- return { content: [{ type: 'text', text: JSON.stringify(result) }] };
109
- }
110
- );
111
-
112
- // Register MCP Resources (read-only room browsing via room:// URIs)
113
- const { registerResources } = require('../lib/mcp/resources.cjs');
114
- registerResources(server, roomDir);
115
-
116
- // Register MCP Prompts (methodology workflows with Larry personality)
117
- const { registerPrompts } = require('../lib/mcp/prompts.cjs');
118
- registerPrompts(server, roomDir, pluginRoot);
119
-
120
- // Register surface-aware capabilities (MCP Apps, Tasks -- Phase 58/60 hook points)
121
- registerCapabilities(server, surface.capabilities, roomDir, pluginRoot);
122
-
123
- // Session catch-up: register shutdown handler to save session state (all surfaces)
124
- if (fs.existsSync(roomDir)) {
125
- registerShutdownHandler(roomDir);
126
- }
127
-
128
- // Connect transport based on detected surface
129
- async function main() {
130
- if (surface.transport === 'http') {
131
- // Streamable HTTP for Cowork
132
- let express;
133
- try {
134
- express = require('express');
135
- } catch (err) {
136
- process.stderr.write(`[mindrian-os] Express not available, falling back to stdio transport.\n`);
137
- const transport = new StdioServerTransport();
138
- await server.connect(transport);
139
- process.stderr.write(`[mindrian-os] MCP server v${version} started (${surface.surface}, stdio-fallback, room: ${roomDir})\n`);
140
- return;
141
- }
142
-
143
- const { StreamableHTTPServerTransport } = require('@modelcontextprotocol/sdk/server/streamableHttp.js');
144
- const app = express();
145
- app.use(express.json());
146
-
147
- // MCP endpoint
148
- const transport = new StreamableHTTPServerTransport({ sessionIdGenerator: undefined });
149
- app.all('/mcp', async (req, res) => {
150
- await transport.handleRequest(req, res);
151
- });
152
-
153
- await server.connect(transport);
154
- app.listen(3847, '127.0.0.1', () => {
155
- process.stderr.write(`[mindrian-os] MCP server v${version} started (${surface.surface}, HTTP on 127.0.0.1:3847, room: ${roomDir})\n`);
156
-
157
- // Session catch-up for Cowork: compute what was missed since last session
158
- if (fs.existsSync(roomDir)) {
159
- try {
160
- const catchUp = computeCatchUp(roomDir);
161
- if (catchUp.hasCatchUp) {
162
- process.stderr.write(`[mindrian-os] Session catch-up: ${catchUp.summary}\n`);
163
- } else {
164
- process.stderr.write(`[mindrian-os] Session catch-up: first session or no changes detected.\n`);
165
- }
166
- } catch (e) {
167
- process.stderr.write(`[mindrian-os] Session catch-up failed (non-fatal): ${e.message}\n`);
168
- }
169
- }
170
- });
171
- } else {
172
- // stdio for CLI and Desktop
173
- const transport = new StdioServerTransport();
174
- await server.connect(transport);
175
- process.stderr.write(`[mindrian-os] MCP server v${version} started (${surface.surface}, ${surface.transport}, room: ${roomDir})\n`);
176
- }
177
- }
178
-
179
- main().catch((err) => {
180
- process.stderr.write(`[mindrian-os] Fatal: ${err.message}\n`);
181
- process.exit(1);
182
- });