@mindrian_os/install 1.13.0-beta.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude-plugin/plugin.json +21 -0
- package/.mcp.json +9 -0
- package/CHANGELOG.md +3333 -0
- package/LICENSE +123 -0
- package/README.md +673 -0
- package/agents/brain-query.md +80 -0
- package/agents/framework-runner.md +237 -0
- package/agents/grading.md +188 -0
- package/agents/investor.md +128 -0
- package/agents/larry-extended.md +135 -0
- package/agents/opportunity-scanner.md +91 -0
- package/agents/persona-analyst.md +132 -0
- package/agents/research.md +89 -0
- package/agents/reverse-salient-agent.md +27 -0
- package/bin/cli.js +142 -0
- package/bin/mindrian-mcp-server.cjs +182 -0
- package/bin/mindrian-tools.cjs +765 -0
- package/commands/act.md +439 -0
- package/commands/admin.md +404 -0
- package/commands/analyze-needs.md +42 -0
- package/commands/analyze-systems.md +39 -0
- package/commands/analyze-timing.md +42 -0
- package/commands/auto-explore.md +64 -0
- package/commands/beautiful-question.md +40 -0
- package/commands/brain-derive.md +78 -0
- package/commands/build-knowledge.md +42 -0
- package/commands/build-thesis.md +46 -0
- package/commands/causal.md +234 -0
- package/commands/challenge-assumptions.md +33 -0
- package/commands/compare-ventures.md +83 -0
- package/commands/dashboard.md +110 -0
- package/commands/deep-grade.md +82 -0
- package/commands/diagnose.md +58 -0
- package/commands/diagnostics.md +151 -0
- package/commands/doctor.md +151 -0
- package/commands/dominant-designs.md +40 -0
- package/commands/explain-decision.md +87 -0
- package/commands/explore-domains.md +42 -0
- package/commands/explore-futures.md +40 -0
- package/commands/explore-trends.md +42 -0
- package/commands/export.md +103 -0
- package/commands/file-meeting.md +724 -0
- package/commands/find-analogies.md +188 -0
- package/commands/find-bottlenecks.md +62 -0
- package/commands/find-connections.md +76 -0
- package/commands/funding.md +81 -0
- package/commands/grade.md +203 -0
- package/commands/graph.md +128 -0
- package/commands/hat-briefing.md +125 -0
- package/commands/heal.md +196 -0
- package/commands/help.md +399 -0
- package/commands/hmi-status.md +172 -0
- package/commands/jtbd.md +241 -0
- package/commands/leadership.md +73 -0
- package/commands/lean-canvas.md +40 -0
- package/commands/macro-trends.md +40 -0
- package/commands/map-unknowns.md +40 -0
- package/commands/memory.md +173 -0
- package/commands/models.md +175 -0
- package/commands/mos-reason.md +285 -0
- package/commands/mullins.md +120 -0
- package/commands/new-project.md +481 -0
- package/commands/onboard.md +434 -0
- package/commands/operator.md +149 -0
- package/commands/opportunities.md +144 -0
- package/commands/organize.md +497 -0
- package/commands/persona.md +198 -0
- package/commands/pipeline.md +112 -0
- package/commands/present.md +91 -0
- package/commands/publish.md +201 -0
- package/commands/query.md +124 -0
- package/commands/radar.md +72 -0
- package/commands/reanalyze.md +91 -0
- package/commands/research.md +196 -0
- package/commands/room.md +352 -0
- package/commands/rooms.md +598 -0
- package/commands/root-cause.md +40 -0
- package/commands/rs-experts.md +85 -0
- package/commands/rs-explain.md +100 -0
- package/commands/rs-fetch.md +94 -0
- package/commands/rs-thesis.md +85 -0
- package/commands/scenario-plan.md +40 -0
- package/commands/scheduled-tasks.md +285 -0
- package/commands/score-innovation.md +43 -0
- package/commands/scout.md +239 -0
- package/commands/setup.md +618 -0
- package/commands/snapshot.md +147 -0
- package/commands/speakers.md +84 -0
- package/commands/splash.md +28 -0
- package/commands/status.md +75 -0
- package/commands/structure-argument.md +42 -0
- package/commands/suggest-next.md +80 -0
- package/commands/systems-thinking.md +40 -0
- package/commands/think-hats.md +42 -0
- package/commands/update.md +181 -0
- package/commands/user-needs.md +40 -0
- package/commands/validate.md +40 -0
- package/commands/value-proposition.md +61 -0
- package/commands/vault.md +180 -0
- package/commands/visualize.md +52 -0
- package/commands/whitespace.md +507 -0
- package/commands/wiki.md +69 -0
- package/hooks/hooks.json +381 -0
- package/hooks/run-hook.cmd +64 -0
- package/lib/__init__.py +0 -0
- package/lib/__pycache__/__init__.cpython-312.pyc +0 -0
- package/lib/agents/auto-explore-agent.cjs +1043 -0
- package/lib/agents/reverse-salient-agent.cjs +679 -0
- package/lib/agents/tension-hook-agent.cjs +544 -0
- package/lib/brain/ROOM.md +44 -0
- package/lib/brain/chain-recommender.cjs +301 -0
- package/lib/chat/chat-context.js +185 -0
- package/lib/chat/chat-panel.js +721 -0
- package/lib/chat/fabric-chat.cjs +288 -0
- package/lib/chat/generative-tools.js +219 -0
- package/lib/conversation/ROOM.md +39 -0
- package/lib/conversation/classifier-rules.json +38 -0
- package/lib/conversation/classifier.cjs +264 -0
- package/lib/conversation/operator.cjs +287 -0
- package/lib/copy/115-spec-strings.cjs +55 -0
- package/lib/core/__init__.py +0 -0
- package/lib/core/__nav-stub.cjs +14 -0
- package/lib/core/__pycache__/__init__.cpython-312.pyc +0 -0
- package/lib/core/__pycache__/rs-math.cpython-312.pyc +0 -0
- package/lib/core/__pycache__/rs_cache.cpython-312.pyc +0 -0
- package/lib/core/__pycache__/rs_corpus.cpython-312.pyc +0 -0
- package/lib/core/__pycache__/rs_hybrid.cpython-312.pyc +0 -0
- package/lib/core/__pycache__/rs_math.cpython-312.pyc +0 -0
- package/lib/core/__pycache__/rs_rooms.cpython-312.pyc +0 -0
- package/lib/core/artifact-id.cjs +148 -0
- package/lib/core/asset-ops.cjs +151 -0
- package/lib/core/auto-commit-throttle.cjs +129 -0
- package/lib/core/bearer-token.cjs +199 -0
- package/lib/core/brain-client.cjs +865 -0
- package/lib/core/brain-derivation-prompts.cjs +326 -0
- package/lib/core/brain-derivation-queue.cjs +431 -0
- package/lib/core/brain-derivation.cjs +580 -0
- package/lib/core/brain-md-schema.cjs +528 -0
- package/lib/core/brain-md-staleness.cjs +357 -0
- package/lib/core/brain-response-sanitize.cjs +188 -0
- package/lib/core/bridge-writer.cjs +477 -0
- package/lib/core/chat-context-builder.cjs +253 -0
- package/lib/core/cross-room-aggregator.cjs +762 -0
- package/lib/core/daily-briefing.cjs +438 -0
- package/lib/core/decision-capture.cjs +618 -0
- package/lib/core/deep-links.cjs +82 -0
- package/lib/core/dispatch-optimizer.cjs +354 -0
- package/lib/core/dual-path-detector.cjs +84 -0
- package/lib/core/dual-path-detector.test.cjs +334 -0
- package/lib/core/exports-log.cjs +79 -0
- package/lib/core/feynman-minto-invariants.cjs +605 -0
- package/lib/core/folder-memory-async.cjs +338 -0
- package/lib/core/folder-memory-shared.cjs +890 -0
- package/lib/core/folder-memory.cjs +416 -0
- package/lib/core/framework-chain-composer.cjs +411 -0
- package/lib/core/frontmatter-schemas.cjs +330 -0
- package/lib/core/git-ops.cjs +141 -0
- package/lib/core/graph-ops.cjs +258 -0
- package/lib/core/hat-persistence.cjs +362 -0
- package/lib/core/index.cjs +60 -0
- package/lib/core/integration-registry.cjs +232 -0
- package/lib/core/intelligence-cascade.cjs +661 -0
- package/lib/core/lazygraph-ops.cjs +1057 -0
- package/lib/core/lru-cache.cjs +139 -0
- package/lib/core/mcp-profiles.cjs +182 -0
- package/lib/core/meeting-ops.cjs +54 -0
- package/lib/core/memory-ops.cjs +600 -0
- package/lib/core/migrations/ROOM.md +33 -0
- package/lib/core/migrations/phase-109-nodes-provenance.cjs +339 -0
- package/lib/core/migrations/phase-109-session-focus.cjs +99 -0
- package/lib/core/model-profiles.cjs +246 -0
- package/lib/core/mullins-scaffold.cjs +160 -0
- package/lib/core/nav-dial.cjs +316 -0
- package/lib/core/navigation/ROOM.md +15 -0
- package/lib/core/navigation/explanation.cjs +43 -0
- package/lib/core/navigation/focus.cjs +135 -0
- package/lib/core/navigation/ingestion.cjs +82 -0
- package/lib/core/navigation/insights.cjs +350 -0
- package/lib/core/navigation/memory-events.cjs +118 -0
- package/lib/core/navigation/neighborhood.cjs +78 -0
- package/lib/core/navigation/packet.cjs +182 -0
- package/lib/core/navigation/room-home.cjs +127 -0
- package/lib/core/navigation/transitions.cjs +82 -0
- package/lib/core/navigation-engine-shared.cjs +242 -0
- package/lib/core/navigation-engine.cjs +664 -0
- package/lib/core/navigation.cjs +60 -0
- package/lib/core/nl-graph-queries.cjs +164 -0
- package/lib/core/offer-presenter.cjs +406 -0
- package/lib/core/opportunity-extractor.cjs +183 -0
- package/lib/core/opportunity-ops.cjs +1371 -0
- package/lib/core/persona-ops.cjs +537 -0
- package/lib/core/persona-taxonomy.cjs +190 -0
- package/lib/core/platform-gates.cjs +120 -0
- package/lib/core/platform.cjs +257 -0
- package/lib/core/proactive-intelligence.cjs +528 -0
- package/lib/core/problem-type-router.cjs +315 -0
- package/lib/core/reasoning-ops.cjs +639 -0
- package/lib/core/reverse-salient-persona-suffix.cjs +115 -0
- package/lib/core/room-classifier-strict-mode.cjs +229 -0
- package/lib/core/room-db.cjs +127 -0
- package/lib/core/room-ops-async.cjs +92 -0
- package/lib/core/room-ops-shared.cjs +64 -0
- package/lib/core/room-ops-sync.cjs +70 -0
- package/lib/core/room-ops.cjs +32 -0
- package/lib/core/room-type-detector.cjs +386 -0
- package/lib/core/rs-brain-substrate-prompts.cjs +129 -0
- package/lib/core/rs-brain-substrate.cjs +570 -0
- package/lib/core/rs-breakthrough-scorer.cjs +255 -0
- package/lib/core/rs-canon-violations.cjs +82 -0
- package/lib/core/rs-chain-feeder.cjs +343 -0
- package/lib/core/rs-commercial-assessor.cjs +280 -0
- package/lib/core/rs-differential-scorer.cjs +376 -0
- package/lib/core/rs-domain-analyzer.cjs +385 -0
- package/lib/core/rs-egress-prompts.cjs +113 -0
- package/lib/core/rs-egress-telemetry.cjs +225 -0
- package/lib/core/rs-egress-violations.cjs +53 -0
- package/lib/core/rs-expert-mapper.cjs +467 -0
- package/lib/core/rs-fetcher-academic.cjs +697 -0
- package/lib/core/rs-fetcher-experts.cjs +314 -0
- package/lib/core/rs-fetcher-industry.cjs +731 -0
- package/lib/core/rs-fetcher-patents.cjs +564 -0
- package/lib/core/rs-innovation-classifier.cjs +194 -0
- package/lib/core/rs-mind-map.cjs +656 -0
- package/lib/core/rs-neo4j-writer.cjs +388 -0
- package/lib/core/rs-nl-to-query.cjs +425 -0
- package/lib/core/rs-pinecone-bridge.cjs +303 -0
- package/lib/core/rs-preprocessor.cjs +350 -0
- package/lib/core/rs-query-matrix.cjs +316 -0
- package/lib/core/rs-query-to-text.cjs +438 -0
- package/lib/core/rs-sqlite-mirror.cjs +443 -0
- package/lib/core/rs-thesis-generator.cjs +188 -0
- package/lib/core/rs_cache.py +479 -0
- package/lib/core/rs_corpus.py +468 -0
- package/lib/core/rs_hybrid.py +586 -0
- package/lib/core/rs_math.py +287 -0
- package/lib/core/rs_rooms.py +193 -0
- package/lib/core/scheduled-scanner.cjs +463 -0
- package/lib/core/scratchpad-ops.cjs +201 -0
- package/lib/core/section-8-trace-schema.cjs +138 -0
- package/lib/core/section-registry.cjs +111 -0
- package/lib/core/session-state.cjs +144 -0
- package/lib/core/shallow-doc-parser.cjs +174 -0
- package/lib/core/shallow-doc-parser.test.cjs +226 -0
- package/lib/core/skill-activation-router.cjs +284 -0
- package/lib/core/state-ops.cjs +46 -0
- package/lib/core/statusline-cache.cjs +266 -0
- package/lib/core/token-estimator.cjs +348 -0
- package/lib/core/user-archetype.cjs +239 -0
- package/lib/core/user-md-ops.cjs +524 -0
- package/lib/core/visual-ops.cjs +624 -0
- package/lib/core/write-lock.cjs +149 -0
- package/lib/graph/canvas-graph.js +467 -0
- package/lib/graph/constellation-config.cjs +299 -0
- package/lib/graph/graph-detail-panel.js +165 -0
- package/lib/hmi/ROOM.md +47 -0
- package/lib/hmi/across-session-memory.cjs +604 -0
- package/lib/hmi/cross-room-memory.cjs +575 -0
- package/lib/hmi/decoy-tier.cjs +395 -0
- package/lib/hmi/jtbd-classifier.cjs +219 -0
- package/lib/hmi/jtbd-state.cjs +199 -0
- package/lib/hmi/jtbd-taxonomy.json +392 -0
- package/lib/hmi/selector-dispatcher.cjs +546 -0
- package/lib/hmi/selector-telemetry.cjs +263 -0
- package/lib/hmi/shape-f0-renderer.cjs +139 -0
- package/lib/hmi/shape-f1-fallback.cjs +80 -0
- package/lib/hmi/shape-f1-renderer.cjs +138 -0
- package/lib/hmi/shape-f2-renderer.cjs +132 -0
- package/lib/hmi/shape-f3-renderer.cjs +66 -0
- package/lib/hmi/shape-f4-renderer.cjs +72 -0
- package/lib/hmi/shape-f5-renderer.cjs +155 -0
- package/lib/hmi/shape-f6-plan-review-renderer.cjs +312 -0
- package/lib/hmi/shape-f6-renderer.cjs +144 -0
- package/lib/hmi/shape-g-renderer.cjs +219 -0
- package/lib/hmi/shape-h-renderer.cjs +222 -0
- package/lib/hmi/tier-check.cjs +63 -0
- package/lib/import/PRECONDITIONS.md +41 -0
- package/lib/import/branding.cjs +210 -0
- package/lib/import/branding.test.cjs +235 -0
- package/lib/import/classifications-sync.cjs +104 -0
- package/lib/import/classifications-sync.test.cjs +129 -0
- package/lib/import/enricher.cjs +296 -0
- package/lib/import/enricher.test.cjs +273 -0
- package/lib/import/integration.test.cjs +376 -0
- package/lib/import/manifest.cjs +129 -0
- package/lib/import/manifest.schema.json +185 -0
- package/lib/import/manifest.test.cjs +123 -0
- package/lib/import/meeting-detector.cjs +92 -0
- package/lib/import/meeting-detector.test.cjs +100 -0
- package/lib/import/person-detector.cjs +229 -0
- package/lib/import/person-detector.test.cjs +149 -0
- package/lib/import/report.cjs +186 -0
- package/lib/import/report.test.cjs +186 -0
- package/lib/import/room-md-scaffolder.cjs +49 -0
- package/lib/import/router.cjs +224 -0
- package/lib/import/router.test.cjs +356 -0
- package/lib/import/run-all-tests.cjs +36 -0
- package/lib/import/smoke-test.cjs +213 -0
- package/lib/import/smoke-test.test.cjs +148 -0
- package/lib/import/test-fixtures/collision-vault/preexisting-room/STATE.md +8 -0
- package/lib/import/test-fixtures/collision-vault/preexisting-room/problem-definition/onboarding/onboarding.md +7 -0
- package/lib/import/test-fixtures/collision-vault/source/onboarding.md +5 -0
- package/lib/import/test-fixtures/obsidian-vault/.obsidian/workspace.json +1 -0
- package/lib/import/test-fixtures/obsidian-vault/notes/with-wikilinks.md +4 -0
- package/lib/import/test-fixtures/tiny-vault/notes/2026-01-15-team-sync.md +9 -0
- package/lib/import/test-fixtures/tiny-vault/notes/empty.md +3 -0
- package/lib/import/test-fixtures/tiny-vault/notes/onboarding.md +5 -0
- package/lib/import/test-fixtures/tiny-vault/notes/pricing.md +5 -0
- package/lib/import/test-fixtures/tiny-vault/notes/random.md +4 -0
- package/lib/import/undo.test.cjs +199 -0
- package/lib/import/vault-scanner.cjs +105 -0
- package/lib/import/vault-scanner.test.cjs +67 -0
- package/lib/mcp/app-html/dashboard.html +316 -0
- package/lib/mcp/app-html/graph.html +428 -0
- package/lib/mcp/app-html/mindrian-platform.html +1841 -0
- package/lib/mcp/app-html/wiki.html +383 -0
- package/lib/mcp/app-views.cjs +322 -0
- package/lib/mcp/brain-router.cjs +418 -0
- package/lib/mcp/capability-registry.cjs +62 -0
- package/lib/mcp/larry-context.cjs +46 -0
- package/lib/mcp/larry-server-instructions.md +114 -0
- package/lib/mcp/pipeline-state.cjs +275 -0
- package/lib/mcp/prompts.cjs +302 -0
- package/lib/mcp/resources.cjs +227 -0
- package/lib/mcp/session-catchup.cjs +327 -0
- package/lib/mcp/surface-detect.cjs +75 -0
- package/lib/mcp/tool-router.cjs +1034 -0
- package/lib/memory/aaak-compress.cjs +403 -0
- package/lib/memory/aaak-compress.test.cjs +288 -0
- package/lib/memory/async-artifact-auto-commit.test.cjs +223 -0
- package/lib/memory/bearer-token.test.cjs +315 -0
- package/lib/memory/brain-cache-lru.test.cjs +259 -0
- package/lib/memory/brain-client-query-shape.test.cjs +160 -0
- package/lib/memory/brain-derivation-graceful-degradation.test.cjs +1019 -0
- package/lib/memory/brain-derivation-queue.test.cjs +539 -0
- package/lib/memory/brain-derivation.test.cjs +634 -0
- package/lib/memory/brain-derive-command.test.cjs +534 -0
- package/lib/memory/brain-md-invariants-validator.test.cjs +704 -0
- package/lib/memory/brain-md-schema.test.cjs +467 -0
- package/lib/memory/brain-md-staleness.test.cjs +525 -0
- package/lib/memory/brain-server-resolution.test.cjs +314 -0
- package/lib/memory/chain-recommender.test.cjs +233 -0
- package/lib/memory/chat-context.test.cjs +128 -0
- package/lib/memory/command-registry.test.cjs +220 -0
- package/lib/memory/cross-room-aggregator.test.cjs +909 -0
- package/lib/memory/dashboard-server.test.cjs +256 -0
- package/lib/memory/debouncer-drain-at-prompt.test.cjs +389 -0
- package/lib/memory/decision-capture.test.cjs +632 -0
- package/lib/memory/decision-capture.worker.cjs +70 -0
- package/lib/memory/explain-decision-command.test.cjs +521 -0
- package/lib/memory/explain-decision-footer.test.cjs +316 -0
- package/lib/memory/explored-materials-store.cjs +392 -0
- package/lib/memory/feynman-minto-guardian.test.cjs +736 -0
- package/lib/memory/feynman-minto-invariants.test.cjs +511 -0
- package/lib/memory/feynman-prompts-drift.test.cjs +144 -0
- package/lib/memory/feynman-prompts.cjs +151 -0
- package/lib/memory/feynman-prompts.test.cjs +96 -0
- package/lib/memory/folder-memory-quadruple.test.cjs +548 -0
- package/lib/memory/folder-memory.test.cjs +503 -0
- package/lib/memory/framework-chain-composer.test.cjs +515 -0
- package/lib/memory/frontmatter-schema-validator.test.cjs +290 -0
- package/lib/memory/heal-command.test.cjs +604 -0
- package/lib/memory/index-artifact-transaction.test.cjs +333 -0
- package/lib/memory/lazygraph-rs-discoveries-view.test.cjs +122 -0
- package/lib/memory/mcp-input-validation.test.cjs +240 -0
- package/lib/memory/mcp-server-brain-deps.test.cjs +270 -0
- package/lib/memory/mcp-stack-fallback.test.cjs +433 -0
- package/lib/memory/minto-debouncer.test.cjs +407 -0
- package/lib/memory/minto-debouncer.worker.cjs +46 -0
- package/lib/memory/minto-migration-v88.test.cjs +265 -0
- package/lib/memory/minto-schema-v88.test.cjs +390 -0
- package/lib/memory/mos-status-renderer.test.cjs +631 -0
- package/lib/memory/narrative-schema.cjs +376 -0
- package/lib/memory/narrative-schema.test.cjs +209 -0
- package/lib/memory/nav-dial.test.cjs +414 -0
- package/lib/memory/navigation-engine-core.test.cjs +722 -0
- package/lib/memory/navigation-invariants.test.cjs +483 -0
- package/lib/memory/offer-presenter.test.cjs +554 -0
- package/lib/memory/on-stop-snapshot.test.cjs +404 -0
- package/lib/memory/pending-tension-store.cjs +373 -0
- package/lib/memory/post-compact-reinjection.test.cjs +854 -0
- package/lib/memory/post-write-triple.test.cjs +317 -0
- package/lib/memory/pre-compact-snapshot.test.cjs +495 -0
- package/lib/memory/problem-type-router.test.cjs +656 -0
- package/lib/memory/query-efficiency-telemetry.test.cjs +370 -0
- package/lib/memory/recompile-room-references.test.cjs +392 -0
- package/lib/memory/recompile-room-references.worker.cjs +42 -0
- package/lib/memory/record-decision-dual-write.test.cjs +454 -0
- package/lib/memory/room-classifier-strict-mode.test.cjs +417 -0
- package/lib/memory/room-minto-hook.test.cjs +398 -0
- package/lib/memory/rs-discovery-engine.test.cjs +323 -0
- package/lib/memory/run-feynman-tests.cjs +1247 -0
- package/lib/memory/security-trifecta.test.cjs +312 -0
- package/lib/memory/session-start-brain-staleness.test.cjs +363 -0
- package/lib/memory/session-start-triple-injection.test.cjs +514 -0
- package/lib/memory/sessionstart-banner-formatter.cjs +318 -0
- package/lib/memory/sessionstart-minto-banner.test.cjs +373 -0
- package/lib/memory/skill-activation-router.test.cjs +419 -0
- package/lib/memory/stamp-artifact-write.test.cjs +304 -0
- package/lib/memory/statusline-active-room.test.cjs +315 -0
- package/lib/memory/statusline-minto-segment.test.cjs +292 -0
- package/lib/memory/sync-async-entry-points.test.cjs +204 -0
- package/lib/memory/test-bridge-writer-enhanced.cjs +452 -0
- package/lib/memory/test-rs-brain-substrate-shape.cjs +529 -0
- package/lib/memory/test-rs-brain-substrate.cjs +636 -0
- package/lib/memory/test-rs-breakthrough-scorer.cjs +375 -0
- package/lib/memory/test-rs-canon-violations.cjs +218 -0
- package/lib/memory/test-rs-chain-feeder-core.cjs +344 -0
- package/lib/memory/test-rs-chain-feeder-skill-spawn.cjs +297 -0
- package/lib/memory/test-rs-commercial-assessor.cjs +385 -0
- package/lib/memory/test-rs-differential-scorer.cjs +480 -0
- package/lib/memory/test-rs-discovery-engine.cjs +603 -0
- package/lib/memory/test-rs-domain-analyzer.cjs +492 -0
- package/lib/memory/test-rs-egress-primitives.cjs +420 -0
- package/lib/memory/test-rs-expert-mapper.cjs +547 -0
- package/lib/memory/test-rs-explain-command.cjs +443 -0
- package/lib/memory/test-rs-fetcher-academic.cjs +848 -0
- package/lib/memory/test-rs-fetcher-experts.cjs +496 -0
- package/lib/memory/test-rs-fetcher-industry.cjs +702 -0
- package/lib/memory/test-rs-fetcher-patents.cjs +674 -0
- package/lib/memory/test-rs-innovation-classifier.cjs +301 -0
- package/lib/memory/test-rs-mind-map.cjs +646 -0
- package/lib/memory/test-rs-neo4j-writer.cjs +518 -0
- package/lib/memory/test-rs-nl-to-query.cjs +449 -0
- package/lib/memory/test-rs-pinecone-bridge.cjs +277 -0
- package/lib/memory/test-rs-preprocessor.cjs +433 -0
- package/lib/memory/test-rs-query-matrix.cjs +391 -0
- package/lib/memory/test-rs-query-to-text.cjs +551 -0
- package/lib/memory/test-rs-sqlite-mirror.cjs +649 -0
- package/lib/memory/test-rs-thesis-generator.cjs +360 -0
- package/lib/memory/triple-context-formatter.cjs +473 -0
- package/lib/memory/triple-context-formatter.test.cjs +442 -0
- package/lib/memory/user-md-persona.test.cjs +565 -0
- package/lib/memory/userpromptsubmit-integration.test.cjs +690 -0
- package/lib/memory/validators/README.md +157 -0
- package/lib/memory/validators/brain-md-invariants.cjs +475 -0
- package/lib/memory/validators/brain-substrate-invariants.cjs +285 -0
- package/lib/memory/validators/external-academic-invariants.cjs +249 -0
- package/lib/memory/validators/external-industry-invariants.cjs +271 -0
- package/lib/memory/validators/external-patents-invariants.cjs +266 -0
- package/lib/memory/validators/minto-invariants.cjs +62 -0
- package/lib/memory/validators/navigation-invariants.cjs +340 -0
- package/lib/memory/validators/queue-health.cjs +95 -0
- package/lib/memory/validators/snapshot-integrity.cjs +129 -0
- package/lib/memory/validators/stale-lifecycle.cjs +116 -0
- package/lib/memory/vault-section-minto-generator-atomic.test.cjs +556 -0
- package/lib/memory/vault-section-minto-generator-atomic.worker.cjs +73 -0
- package/lib/memory/write-lock-atomic.test.cjs +137 -0
- package/lib/memory/write-lock-atomic.worker.cjs +55 -0
- package/lib/parity/check-parity.cjs +83 -0
- package/lib/presentation/presentation-server.cjs +101 -0
- package/lib/presentation/presentation-watcher.cjs +123 -0
- package/lib/quickview/hub-server.cjs +719 -0
- package/lib/quickview/server.cjs +533 -0
- package/lib/render/JTBD-PALETTES.md +145 -0
- package/lib/render/ROOM.md +59 -0
- package/lib/render/render-v2.cjs +486 -0
- package/lib/render/render-v2.test.cjs +267 -0
- package/lib/render/render.cjs +65 -0
- package/lib/state/ROOM.md +46 -0
- package/lib/state/state-md-parser.cjs +215 -0
- package/lib/statusline/ROOM.md +38 -0
- package/lib/statusline/banner-suppression.cjs +50 -0
- package/lib/statusline/surface-detect.cjs +85 -0
- package/lib/update-bootstrap.sh.template +145 -0
- package/lib/vault/frontmatter-schema.cjs +297 -0
- package/lib/vault/room-scanner.cjs +352 -0
- package/lib/vault/wikilink-builder.cjs +231 -0
- package/lib/vault/wikilink-builder.test.cjs +182 -0
- package/lib/wiki/graph-links.cjs +281 -0
- package/lib/wiki/page-renderer.cjs +229 -0
- package/lib/wiki/wiki-chat.cjs +81 -0
- package/lib/wiki/wiki-layout.cjs +1459 -0
- package/lib/wiki/wiki-search.cjs +142 -0
- package/lib/wiki/wiki-server.cjs +678 -0
- package/lib/wiki/wiki-watcher.cjs +105 -0
- package/lib/workflow/ROOM.md +47 -0
- package/lib/workflow/command-resolver.cjs +155 -0
- package/lib/workflow/command-resolver.test.cjs +235 -0
- package/package.json +44 -0
- package/pipelines/analogy/01-decompose.md +80 -0
- package/pipelines/analogy/02-abstract.md +87 -0
- package/pipelines/analogy/03-search.md +135 -0
- package/pipelines/analogy/04-transfer.md +101 -0
- package/pipelines/analogy/05-validate.md +106 -0
- package/pipelines/analogy/CHAIN.md +56 -0
- package/pipelines/discovery/01-explore-domains.md +44 -0
- package/pipelines/discovery/02-think-hats.md +50 -0
- package/pipelines/discovery/03-analyze-needs.md +54 -0
- package/pipelines/discovery/CHAIN.md +37 -0
- package/pipelines/thesis/01-structure-argument.md +45 -0
- package/pipelines/thesis/02-challenge-assumptions.md +48 -0
- package/pipelines/thesis/03-build-thesis.md +54 -0
- package/pipelines/thesis/CHAIN.md +37 -0
- package/references/brain/causal-directives.md +91 -0
- package/references/brain/causal-enrichment.cypher +165 -0
- package/references/brain/command-triggers-schema.md +226 -0
- package/references/brain/graph-architecture.md +317 -0
- package/references/brain/query-patterns.md +460 -0
- package/references/brain/room-hierarchy-schema.md +218 -0
- package/references/brain/schema.md +76 -0
- package/references/capability-radar/capabilities-index.md +241 -0
- package/references/capability-radar/changelog-cache.md +81 -0
- package/references/causal/causal-schema.md +103 -0
- package/references/design/email-template-standard.md +155 -0
- package/references/design/graph-visualization-standard.md +178 -0
- package/references/document-generation.md +179 -0
- package/references/hsi/HSI-TOOLS-REFERENCE.md +222 -0
- package/references/import-config.md +141 -0
- package/references/integrations/detection-patterns.md +101 -0
- package/references/meeting/artifact-template.md +377 -0
- package/references/meeting/cross-meeting-intelligence.md +216 -0
- package/references/meeting/cross-relationship-patterns.md +202 -0
- package/references/meeting/live-join-interface.md +244 -0
- package/references/meeting/section-mapping.md +192 -0
- package/references/meeting/segment-classification.md +258 -0
- package/references/meeting/speaker-profile-template.md +219 -0
- package/references/meeting/summary-template.md +348 -0
- package/references/meeting/transcript-patterns.md +226 -0
- package/references/methodology/analyze-needs.md +135 -0
- package/references/methodology/analyze-systems.md +121 -0
- package/references/methodology/analyze-timing.md +149 -0
- package/references/methodology/beautiful-question.md +109 -0
- package/references/methodology/build-knowledge.md +161 -0
- package/references/methodology/build-thesis.md +237 -0
- package/references/methodology/challenge-assumptions.md +127 -0
- package/references/methodology/diagnose.md +169 -0
- package/references/methodology/dominant-designs.md +212 -0
- package/references/methodology/explore-domains.md +147 -0
- package/references/methodology/explore-futures.md +163 -0
- package/references/methodology/explore-trends.md +129 -0
- package/references/methodology/find-bottlenecks.md +131 -0
- package/references/methodology/grade.md +211 -0
- package/references/methodology/index.md +97 -0
- package/references/methodology/leadership.md +200 -0
- package/references/methodology/lean-canvas.md +116 -0
- package/references/methodology/macro-trends.md +192 -0
- package/references/methodology/map-unknowns.md +137 -0
- package/references/methodology/mullins-7-domains.md +104 -0
- package/references/methodology/problem-types.md +65 -0
- package/references/methodology/root-cause.md +178 -0
- package/references/methodology/sapphire-encoding.md +355 -0
- package/references/methodology/scenario-plan.md +178 -0
- package/references/methodology/score-innovation.md +154 -0
- package/references/methodology/structure-argument.md +158 -0
- package/references/methodology/systems-thinking.md +159 -0
- package/references/methodology/think-hats.md +147 -0
- package/references/methodology/triz-matrix.json +751 -0
- package/references/methodology/triz-principles.md +501 -0
- package/references/methodology/user-needs.md +199 -0
- package/references/methodology/validate.md +163 -0
- package/references/methodology/value-proposition.md +244 -0
- package/references/opportunities/funding-lifecycle.md +103 -0
- package/references/opportunities/grant-api-patterns.md +99 -0
- package/references/opportunities/opportunity-template.md +84 -0
- package/references/personality/assessment-philosophy.md +72 -0
- package/references/personality/lexicon.md +100 -0
- package/references/personality/persona-chains.md +56 -0
- package/references/personality/pws-lexicon-full.md +499 -0
- package/references/personality/voice-dna.md +156 -0
- package/references/personas/hat-perspectives.md +76 -0
- package/references/personas/persona-template.md +63 -0
- package/references/pipeline/act-output-contract.md +88 -0
- package/references/pipeline/chains-index.md +39 -0
- package/references/pws-profile-generation.md +79 -0
- package/references/reasoning/reasoning-schema.md +143 -0
- package/references/reasoning/reasoning-template.md +68 -0
- package/references/reasoning/run-template.md +38 -0
- package/references/research/RESEARCH_14_CLAUDE_CODE_SOURCE_ARCHITECTURE.md +209 -0
- package/references/research/RESEARCH_15_V1.8_OPTIMIZATION_JTBD.md +375 -0
- package/references/research/RESEARCH_16_NATIVE_FIRST_PLUGIN_ARCHITECTURE.md +575 -0
- package/references/research/RESEARCH_17_MCP_UI_FRAMEWORKS.md +272 -0
- package/references/taxonomy/TAXONOMY.md +192 -0
- package/references/templates/MINTO.md +36 -0
- package/references/user-research/2026-04-05-leah-lawrence-session.md +202 -0
- package/references/vault-kit/README.md +35 -0
- package/references/vault-kit/app.json +12 -0
- package/references/vault-kit/appearance.json +12 -0
- package/references/vault-kit/graph.json +35 -0
- package/references/vault-kit/snippets/mindrian-destijl.css +297 -0
- package/references/vault-kit/templates/new-artifact.md +37 -0
- package/references/vault-kit/templates/new-meeting-note.md +35 -0
- package/references/vault-kit/templates/new-team-profile.md +29 -0
- package/references/vault-kit/templates/new-xref.md +35 -0
- package/references/visual/symbol-system.md +151 -0
- package/skills/MOSDeckEngine/SKILL.md +325 -0
- package/skills/brain-connector/SKILL.md +114 -0
- package/skills/context-engine/SKILL.md +147 -0
- package/skills/conversation-mode/SKILL.md +102 -0
- package/skills/larry-personality/SKILL.md +219 -0
- package/skills/larry-personality/framework-chains.md +92 -0
- package/skills/larry-personality/mode-engine.md +185 -0
- package/skills/mullins-scaffold/SKILL.md +61 -0
- package/skills/mullins-scaffold/scaffold.json +146 -0
- package/skills/pws-methodology/SKILL.md +49 -0
- package/skills/room-passive/SKILL.md +165 -0
- package/skills/room-proactive/SKILL.md +250 -0
- package/skills/ui-system/SKILL.md +277 -0
|
@@ -0,0 +1,618 @@
|
|
|
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`.
|