claude-brain 0.30.2 → 0.30.3

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 (236) hide show
  1. package/README.md +241 -191
  2. package/VERSION +1 -1
  3. package/assets/CLAUDE-unified.md +11 -11
  4. package/assets/CLAUDE.md +29 -29
  5. package/package.json +7 -3
  6. package/packs/backend/node.json +173 -173
  7. package/packs/core/javascript.json +176 -176
  8. package/packs/core/typescript.json +222 -222
  9. package/packs/frontend/react.json +254 -254
  10. package/packs/meta/testing.json +172 -172
  11. package/scripts/postinstall.mjs +531 -531
  12. package/src/automation/decision-detector.ts +452 -452
  13. package/src/automation/phase12-manager.ts +456 -456
  14. package/src/automation/proactive-recall.ts +373 -373
  15. package/src/automation/project-detector.ts +310 -310
  16. package/src/automation/repo-scanner.ts +210 -205
  17. package/src/cli/auto-setup.ts +75 -75
  18. package/src/cli/auto-start.ts +266 -266
  19. package/src/cli/bin.ts +264 -264
  20. package/src/cli/commands/autostart.ts +90 -90
  21. package/src/cli/commands/chroma.ts +578 -577
  22. package/src/cli/commands/export-training.ts +70 -70
  23. package/src/cli/commands/export.ts +130 -130
  24. package/src/cli/commands/git-hook.ts +183 -183
  25. package/src/cli/commands/hooks.ts +217 -217
  26. package/src/cli/commands/init.ts +123 -123
  27. package/src/cli/commands/install-mcp.ts +122 -111
  28. package/src/cli/commands/models.ts +979 -979
  29. package/src/cli/commands/pack.ts +200 -200
  30. package/src/cli/commands/refresh.ts +344 -339
  31. package/src/cli/commands/reindex.ts +120 -120
  32. package/src/cli/commands/serve.ts +466 -463
  33. package/src/cli/commands/start.ts +44 -44
  34. package/src/cli/commands/status.ts +220 -203
  35. package/src/cli/commands/uninstall-mcp.ts +45 -41
  36. package/src/cli/commands/update.ts +130 -124
  37. package/src/cli/migrate-chroma.ts +106 -106
  38. package/src/cli/ui/animations.ts +80 -80
  39. package/src/cli/ui/components.ts +82 -82
  40. package/src/cli/ui/index.ts +4 -4
  41. package/src/cli/ui/logo.ts +36 -36
  42. package/src/cli/ui/theme.ts +55 -55
  43. package/src/code-intelligence/indexer.ts +352 -352
  44. package/src/code-intelligence/linker.ts +178 -178
  45. package/src/code-intelligence/parser.ts +484 -484
  46. package/src/code-intelligence/query.ts +291 -291
  47. package/src/code-intelligence/schema.ts +83 -83
  48. package/src/code-intelligence/types.ts +95 -95
  49. package/src/config/defaults.ts +52 -52
  50. package/src/config/home.ts +56 -56
  51. package/src/config/index.ts +5 -5
  52. package/src/config/loader.ts +192 -192
  53. package/src/config/schema.ts +446 -415
  54. package/src/config/validator.ts +182 -182
  55. package/src/context/assembler.ts +407 -400
  56. package/src/context/index.ts +79 -79
  57. package/src/context/progress-tracker.ts +174 -174
  58. package/src/context/standards-manager.ts +287 -287
  59. package/src/context/validator.ts +58 -58
  60. package/src/diagnostics/index.ts +122 -121
  61. package/src/health/index.ts +233 -232
  62. package/src/hooks/brain-hook.ts +134 -131
  63. package/src/hooks/capture.ts +168 -168
  64. package/src/hooks/claude-code-mastery.md +112 -112
  65. package/src/hooks/context-hook.ts +260 -245
  66. package/src/hooks/deduplicator.ts +72 -72
  67. package/src/hooks/git-capture.ts +109 -109
  68. package/src/hooks/git-hook-installer.ts +211 -207
  69. package/src/hooks/index.ts +20 -20
  70. package/src/hooks/installer.ts +306 -288
  71. package/src/hooks/interceptor-hook.ts +204 -201
  72. package/src/hooks/passive-classifier.ts +397 -397
  73. package/src/hooks/queue.ts +160 -129
  74. package/src/hooks/session-tracker.ts +312 -312
  75. package/src/hooks/types.ts +52 -52
  76. package/src/index.ts +7 -7
  77. package/src/intelligence/cross-project/generalizer.ts +283 -283
  78. package/src/intelligence/cross-project/index.ts +7 -7
  79. package/src/intelligence/hf-downloader.ts +222 -222
  80. package/src/intelligence/hf-manifest.json +78 -78
  81. package/src/intelligence/index.ts +24 -24
  82. package/src/intelligence/inference-router.ts +762 -762
  83. package/src/intelligence/model-manager.ts +263 -245
  84. package/src/intelligence/optimization/index.ts +10 -10
  85. package/src/intelligence/optimization/precompute.ts +202 -202
  86. package/src/intelligence/optimization/semantic-cache.ts +213 -207
  87. package/src/intelligence/prediction/index.ts +7 -7
  88. package/src/intelligence/prediction/recommender.ts +276 -268
  89. package/src/intelligence/reasoning/chain-retrieval.ts +243 -247
  90. package/src/intelligence/reasoning/index.ts +7 -7
  91. package/src/intelligence/temporal/evolution.ts +193 -197
  92. package/src/intelligence/temporal/index.ts +16 -16
  93. package/src/intelligence/temporal/query-processor.ts +190 -190
  94. package/src/intelligence/temporal/timeline.ts +272 -259
  95. package/src/intelligence/temporal/trends.ts +263 -263
  96. package/src/intelligence/tokenizer.ts +118 -118
  97. package/src/knowledge/entity-extractor.ts +447 -443
  98. package/src/knowledge/graph/builder.ts +185 -185
  99. package/src/knowledge/graph/linker.ts +201 -201
  100. package/src/knowledge/graph/memory-graph.ts +359 -359
  101. package/src/knowledge/graph/schema.ts +99 -99
  102. package/src/knowledge/graph/search.ts +166 -166
  103. package/src/knowledge/relationship-extractor.ts +108 -108
  104. package/src/memory/chroma/client.ts +211 -192
  105. package/src/memory/chroma/collection-manager.ts +92 -92
  106. package/src/memory/chroma/config.ts +57 -57
  107. package/src/memory/chroma/embeddings.ts +177 -175
  108. package/src/memory/chroma/index.ts +82 -82
  109. package/src/memory/chroma/migration.ts +270 -270
  110. package/src/memory/chroma/schemas.ts +69 -69
  111. package/src/memory/chroma/search.ts +319 -315
  112. package/src/memory/chroma/store.ts +755 -747
  113. package/src/memory/compression.ts +121 -121
  114. package/src/memory/consolidation/archiver.ts +162 -165
  115. package/src/memory/consolidation/merger.ts +182 -186
  116. package/src/memory/consolidation/scorer.ts +136 -136
  117. package/src/memory/database.ts +9 -0
  118. package/src/memory/dual-write.ts +145 -0
  119. package/src/memory/embeddings.ts +226 -226
  120. package/src/memory/episodic/detector.ts +108 -108
  121. package/src/memory/episodic/manager.ts +347 -351
  122. package/src/memory/episodic/summarizer.ts +179 -179
  123. package/src/memory/episodic/types.ts +52 -52
  124. package/src/memory/fts5-search.ts +692 -633
  125. package/src/memory/index.ts +943 -1060
  126. package/src/memory/migrations/add-fts5.ts +118 -108
  127. package/src/memory/patterns.ts +438 -438
  128. package/src/memory/pruning.ts +60 -60
  129. package/src/memory/schema.ts +88 -88
  130. package/src/memory/store.ts +911 -787
  131. package/src/orchestrator/handlers/decision-handler.ts +204 -204
  132. package/src/packs/index.ts +9 -9
  133. package/src/packs/loader.ts +134 -134
  134. package/src/packs/manager.ts +204 -204
  135. package/src/packs/ranker.ts +78 -78
  136. package/src/packs/types.ts +81 -81
  137. package/src/phase12/index.ts +5 -5
  138. package/src/retrieval/bm25/index.ts +300 -297
  139. package/src/retrieval/bm25/tokenizer.ts +184 -184
  140. package/src/retrieval/feedback/adaptive.ts +221 -221
  141. package/src/retrieval/feedback/index.ts +16 -16
  142. package/src/retrieval/feedback/metrics.ts +221 -221
  143. package/src/retrieval/feedback/store.ts +283 -283
  144. package/src/retrieval/fusion/index.ts +194 -194
  145. package/src/retrieval/fusion/rrf.ts +165 -165
  146. package/src/retrieval/index.ts +12 -12
  147. package/src/retrieval/pipeline.ts +375 -375
  148. package/src/retrieval/query/expander.ts +203 -203
  149. package/src/retrieval/query/index.ts +27 -27
  150. package/src/retrieval/query/intent-classifier.ts +252 -252
  151. package/src/retrieval/query/temporal-parser.ts +295 -295
  152. package/src/retrieval/reranker/index.ts +189 -188
  153. package/src/retrieval/reranker/model.ts +99 -95
  154. package/src/retrieval/service.ts +125 -125
  155. package/src/retrieval/types.ts +162 -162
  156. package/src/routing/entity-extractor.ts +454 -454
  157. package/src/routing/handlers/exploration-handler.ts +369 -0
  158. package/src/routing/handlers/index.ts +19 -0
  159. package/src/routing/handlers/memory-handler.ts +273 -0
  160. package/src/routing/handlers/mutation-handler.ts +241 -0
  161. package/src/routing/handlers/recall-handler.ts +642 -0
  162. package/src/routing/handlers/shared.ts +515 -0
  163. package/src/routing/handlers/types.ts +48 -0
  164. package/src/routing/intent-classifier.ts +552 -552
  165. package/src/routing/response-filter.ts +399 -391
  166. package/src/routing/router.ts +245 -2193
  167. package/src/routing/search-engine.ts +521 -514
  168. package/src/routing/types.ts +104 -94
  169. package/src/scripts/health-check.ts +118 -118
  170. package/src/scripts/setup.ts +122 -122
  171. package/src/server/auto-updater.ts +283 -276
  172. package/src/server/handlers/call-tool.ts +159 -159
  173. package/src/server/handlers/list-tools.ts +35 -35
  174. package/src/server/handlers/tools/auto-remember.ts +165 -165
  175. package/src/server/handlers/tools/brain.ts +86 -86
  176. package/src/server/handlers/tools/create-project.ts +135 -135
  177. package/src/server/handlers/tools/get-code-standards.ts +123 -123
  178. package/src/server/handlers/tools/get-corrections.ts +152 -152
  179. package/src/server/handlers/tools/get-patterns.ts +156 -156
  180. package/src/server/handlers/tools/get-project-context.ts +75 -75
  181. package/src/server/handlers/tools/index.ts +30 -30
  182. package/src/server/handlers/tools/init-project.ts +756 -756
  183. package/src/server/handlers/tools/list-projects.ts +126 -126
  184. package/src/server/handlers/tools/recall-similar.ts +87 -87
  185. package/src/server/handlers/tools/recognize-pattern.ts +132 -132
  186. package/src/server/handlers/tools/record-correction.ts +131 -131
  187. package/src/server/handlers/tools/remember-decision.ts +168 -168
  188. package/src/server/handlers/tools/schemas.ts +179 -179
  189. package/src/server/handlers/tools/search-code.ts +122 -122
  190. package/src/server/handlers/tools/smart-context.ts +146 -146
  191. package/src/server/handlers/tools/update-progress.ts +131 -131
  192. package/src/server/http-api.ts +215 -1229
  193. package/src/server/mcp-proxy.ts +85 -84
  194. package/src/server/mcp-server.ts +285 -284
  195. package/src/server/middleware/auth.ts +39 -0
  196. package/src/server/middleware/error-handler.ts +37 -0
  197. package/src/server/middleware/rate-limit.ts +53 -0
  198. package/src/server/middleware/validate.ts +42 -0
  199. package/src/server/pid-manager.ts +137 -136
  200. package/src/server/providers/resources.ts +581 -581
  201. package/src/server/routes/code.ts +228 -0
  202. package/src/server/routes/context.ts +26 -0
  203. package/src/server/routes/health.ts +19 -0
  204. package/src/server/routes/helpers.ts +100 -0
  205. package/src/server/routes/hooks.ts +197 -0
  206. package/src/server/routes/mcp.ts +47 -0
  207. package/src/server/routes/memory.ts +397 -0
  208. package/src/server/routes/models.ts +96 -0
  209. package/src/server/routes/projects.ts +89 -0
  210. package/src/server/routes/types.ts +21 -0
  211. package/src/server/schemas/api-schemas.ts +202 -0
  212. package/src/server/services.ts +720 -720
  213. package/src/server/utils/memory-indicator.ts +84 -84
  214. package/src/server/utils/response-formatter.ts +129 -129
  215. package/src/server/web-viewer.ts +1145 -1115
  216. package/src/setup/index.ts +38 -38
  217. package/src/tools/registry.ts +115 -115
  218. package/src/tools/schemas.ts +666 -666
  219. package/src/tools/types.ts +412 -412
  220. package/src/training/data-store.ts +320 -298
  221. package/src/training/retrain-pipeline.ts +399 -394
  222. package/src/utils/error-handler.ts +136 -136
  223. package/src/utils/index.ts +58 -58
  224. package/src/utils/kill-port.ts +55 -53
  225. package/src/utils/phase12-helper.ts +56 -56
  226. package/src/utils/safe-path.ts +43 -0
  227. package/src/utils/timing.ts +47 -47
  228. package/src/utils/transaction.ts +63 -63
  229. package/src/vault/index.ts +4 -3
  230. package/src/vault/paths.ts +106 -106
  231. package/src/vault/query.ts +4 -1
  232. package/src/vault/reader.ts +44 -1
  233. package/src/vault/watcher.ts +24 -1
  234. package/src/vault/writer.ts +487 -413
  235. package/skills/persistent-memory/SKILL.md +0 -148
  236. package/skills/persistent-memory/references/tool-reference.md +0 -90
@@ -1,415 +1,446 @@
1
- import { z } from 'zod'
2
- import pkg from '../../package.json'
3
-
4
- /** Log level options for the application */
5
- export const LogLevelSchema = z.enum(['debug', 'info', 'warn', 'error'])
6
- export type LogLevel = z.infer<typeof LogLevelSchema>
7
-
8
- /** Retrieval configuration for hybrid search */
9
- export const RetrievalConfigSchema = z.object({
10
- /** Enable hybrid retrieval pipeline (opt-in) */
11
- enabled: z.boolean().default(false),
12
-
13
- /** Dense (semantic) search configuration */
14
- dense: z.object({
15
- /** Weight for dense search in fusion (0-1) */
16
- weight: z.number().min(0).max(1).default(0.7),
17
- /** Maximum number of results from dense search */
18
- limit: z.number().int().min(1).max(100).default(20),
19
- /** Minimum similarity threshold (0-1) */
20
- minSimilarity: z.number().min(0).max(1).default(0.3)
21
- }).default({} as any),
22
-
23
- /** Sparse (BM25) search configuration */
24
- sparse: z.object({
25
- /** Enable sparse search */
26
- enabled: z.boolean().default(true),
27
- /** Weight for sparse search in fusion (0-1) */
28
- weight: z.number().min(0).max(1).default(0.3),
29
- /** Maximum number of results from sparse search */
30
- limit: z.number().int().min(1).max(100).default(20)
31
- }).default({} as any),
32
-
33
- /** Fusion configuration for combining results */
34
- fusion: z.object({
35
- /** Fusion method */
36
- method: z.enum(['rrf', 'linear', 'max']).default('rrf'),
37
- /** RRF k parameter (default 60 per original paper) */
38
- rrfK: z.number().int().min(1).default(60)
39
- }).default({} as any),
40
-
41
- /** Cross-encoder reranking configuration */
42
- reranker: z.object({
43
- /** Enable cross-encoder reranking */
44
- enabled: z.boolean().default(false),
45
- /** Model to use for reranking */
46
- model: z.string().default('cross-encoder/ms-marco-MiniLM-L-6-v2'),
47
- /** Number of results to rerank */
48
- topK: z.number().int().min(1).max(100).default(10)
49
- }).default({} as any),
50
-
51
- /** Query understanding configuration */
52
- queryUnderstanding: z.object({
53
- /** Enable query understanding */
54
- enabled: z.boolean().default(true),
55
- /** Enable intent classification */
56
- intentClassification: z.boolean().default(true),
57
- /** Enable query expansion */
58
- queryExpansion: z.boolean().default(true),
59
- /** Enable temporal parsing */
60
- temporalParsing: z.boolean().default(true)
61
- }).default({} as any),
62
-
63
- /** Feedback collection configuration */
64
- feedback: z.object({
65
- /** Enable feedback collection */
66
- enabled: z.boolean().default(true),
67
- /** Enable adaptive threshold learning */
68
- adaptiveThresholds: z.boolean().default(true),
69
- /** Minimum feedback count before adaptation */
70
- minFeedbackForAdaptation: z.number().int().min(1).default(10)
71
- }).default({} as any)
72
- })
73
-
74
- export type RetrievalConfig = z.infer<typeof RetrievalConfigSchema>
75
-
76
- /** Knowledge graph and episodic memory configuration */
77
- export const KnowledgeConfigSchema = z.object({
78
- /** Entity extraction settings */
79
- extraction: z.object({
80
- /** Minimum confidence for extracted entities */
81
- minConfidence: z.number().min(0).max(1).default(0.5),
82
- /** Maximum entities to extract per text */
83
- maxEntities: z.number().int().min(1).max(200).default(50)
84
- }).default({} as any),
85
-
86
- /** Knowledge graph settings */
87
- graph: z.object({
88
- /** Enable knowledge graph auto-population */
89
- enabled: z.boolean().default(true),
90
- /** Path for graph persistence */
91
- persistPath: z.string().default('./data/knowledge-graph.json'),
92
- /** Auto-save interval in seconds */
93
- autoSaveInterval: z.number().int().min(10).default(60),
94
- /** Maximum graph traversal depth */
95
- maxTraversalDepth: z.number().int().min(1).max(10).default(5),
96
- /** Alpha for combined scoring (vector vs graph proximity) */
97
- alpha: z.number().min(0).max(1).default(0.6)
98
- }).default({} as any),
99
-
100
- /** Episodic memory settings */
101
- episodic: z.object({
102
- /** Enable episodic memory */
103
- enabled: z.boolean().default(true),
104
- /** Time gap in minutes to detect new session */
105
- sessionGapMinutes: z.number().int().min(1).default(30),
106
- /** Maximum messages per episode before auto-splitting */
107
- maxMessagesPerEpisode: z.number().int().min(10).default(200),
108
- /** Number of top sentences for brief summary */
109
- briefSummarySize: z.number().int().min(1).max(10).default(2),
110
- /** Number of top sentences for detailed summary */
111
- detailedSummarySize: z.number().int().min(1).max(20).default(8)
112
- }).default({} as any),
113
-
114
- /** Memory consolidation settings */
115
- consolidation: z.object({
116
- /** Enable memory consolidation */
117
- enabled: z.boolean().default(true),
118
- /** Similarity threshold for merge candidates */
119
- mergeThreshold: z.number().min(0).max(1).default(0.85),
120
- /** Importance score threshold for archival */
121
- archiveThreshold: z.number().min(0).max(1).default(0.2),
122
- /** Interval in minutes between automatic archival sweeps (0 = disabled) */
123
- archiveIntervalMinutes: z.number().int().min(0).default(60),
124
- /** Importance scoring weights */
125
- weights: z.object({
126
- recency: z.number().min(0).max(1).default(0.2),
127
- frequency: z.number().min(0).max(1).default(0.2),
128
- references: z.number().min(0).max(1).default(0.2),
129
- feedback: z.number().min(0).max(1).default(0.2),
130
- uniqueness: z.number().min(0).max(1).default(0.2)
131
- }).default({} as any)
132
- }).default({} as any)
133
- })
134
-
135
- export type KnowledgeConfig = z.infer<typeof KnowledgeConfigSchema>
136
-
137
- /** Phase 17+20: Passive Learning via Hooks configuration */
138
- export const HooksConfigSchema = z.object({
139
- /** Master switch for hooks passive learning (Phase 20: enabled by default) */
140
- enabled: z.boolean().default(true),
141
-
142
- /** What to capture from tool calls */
143
- capture: z.object({
144
- /** Capture knowledge from tool use (Edit/Write) */
145
- toolUse: z.boolean().default(true),
146
- /** Capture knowledge from file edits */
147
- fileEdits: z.boolean().default(true),
148
- /** Capture knowledge from bash commands */
149
- bashCommands: z.boolean().default(true),
150
- /** Capture knowledge from user messages */
151
- userMessages: z.boolean().default(true)
152
- }).default({} as any),
153
-
154
- /** Privacy filters */
155
- privacy: z.object({
156
- /** File paths to ignore (glob patterns) — Phase 20: sensible defaults */
157
- ignorePaths: z.array(z.string()).default([
158
- 'node_modules/**',
159
- '.env*',
160
- '*.key',
161
- '*.pem',
162
- '*.p12',
163
- '*.pfx',
164
- '.git/**',
165
- 'dist/**',
166
- 'build/**',
167
- '*.secret',
168
- 'credentials*',
169
- '.aws/**',
170
- '.ssh/**'
171
- ]),
172
- /** Projects to ignore */
173
- ignoreProjects: z.array(z.string()).default([]),
174
- /** Minimum confidence to store captured knowledge */
175
- minConfidence: z.number().min(0).max(1).default(0.7)
176
- }).default({} as any),
177
-
178
- /** Session tracking settings */
179
- sessions: z.object({
180
- /** Enable session tracking */
181
- enabled: z.boolean().default(true),
182
- /** Idle timeout in minutes before summarizing */
183
- idleTimeoutMinutes: z.number().int().min(1).default(30),
184
- /** Minimum events required before generating summary */
185
- minEventsForSummary: z.number().int().min(1).default(3)
186
- }).default({} as any),
187
-
188
- /** Deduplication thresholds */
189
- deduplication: z.object({
190
- /** Similarity above this skips storage (exact duplicate) */
191
- skipThreshold: z.number().min(0).max(1).default(0.95),
192
- /** Similarity above this merges instead of creating new */
193
- mergeThreshold: z.number().min(0).max(1).default(0.85)
194
- }).default({} as any)
195
- })
196
-
197
- export type HooksConfig = z.infer<typeof HooksConfigSchema>
198
-
199
- /** Phase 18: Knowledge Packs configuration */
200
- export const PacksConfigSchema = z.object({
201
- /** Master switch for knowledge packs */
202
- enabled: z.boolean().default(true),
203
-
204
- /** Directory name for pack files (relative to package root) */
205
- packsDir: z.string().default('packs'),
206
-
207
- /** Always load core/ packs regardless of tech stack */
208
- alwaysLoadCore: z.boolean().default(true),
209
-
210
- /** Always load meta/ packs regardless of tech stack */
211
- alwaysLoadMeta: z.boolean().default(true),
212
-
213
- /** Confidence multiplier for community (pack) entries (dampens scores) */
214
- communityConfidenceMultiplier: z.number().min(0).max(1).default(0.8),
215
-
216
- /** Search result boost for personal (user-created) entries */
217
- personalBoost: z.number().min(1).max(2).default(1.2),
218
-
219
- /** Search result boost for project-specific entries */
220
- projectBoost: z.number().min(1).max(2).default(1.15)
221
- })
222
-
223
- export type PacksConfig = z.infer<typeof PacksConfigSchema>
224
-
225
- /** Phase 15: Advanced Intelligence configuration */
226
- export const AdvancedIntelligenceConfigSchema = z.object({
227
- /** Enable advanced intelligence features (Phase 15) */
228
- enabled: z.boolean().default(true),
229
-
230
- /** Temporal intelligence settings */
231
- temporal: z.object({
232
- /** Enable temporal query processing */
233
- enabled: z.boolean().default(true),
234
- /** Default timeline limit */
235
- defaultTimelineLimit: z.number().int().min(1).max(500).default(50),
236
- /** Default trend analysis period in days */
237
- defaultTrendPeriodDays: z.number().int().min(1).max(3650).default(90)
238
- }).default({} as any),
239
-
240
- /** Multi-hop reasoning settings */
241
- reasoning: z.object({
242
- /** Enable multi-hop reasoning */
243
- enabled: z.boolean().default(true),
244
- /** Maximum retrieval hops */
245
- maxHops: z.number().int().min(1).max(10).default(3),
246
- /** Results per hop */
247
- resultsPerHop: z.number().int().min(1).max(50).default(5)
248
- }).default({} as any),
249
-
250
- /** Predictive intelligence settings */
251
- prediction: z.object({
252
- /** Enable predictive features */
253
- enabled: z.boolean().default(true),
254
- /** Default recommendation limit */
255
- defaultRecommendationLimit: z.number().int().min(1).max(50).default(10)
256
- }).default({} as any),
257
-
258
- /** Cross-project intelligence settings */
259
- crossProject: z.object({
260
- /** Enable cross-project analysis */
261
- enabled: z.boolean().default(true),
262
- /** Minimum projects for pattern detection */
263
- minProjects: z.number().int().min(2).max(50).default(2)
264
- }).default({} as any),
265
-
266
- /** Semantic caching settings */
267
- cache: z.object({
268
- /** Enable semantic caching */
269
- enabled: z.boolean().default(true),
270
- /** Maximum cache entries */
271
- maxSize: z.number().int().min(10).max(10000).default(500),
272
- /** Cache TTL in milliseconds */
273
- ttlMs: z.number().int().min(60000).default(30 * 60 * 1000),
274
- /** Semantic similarity threshold for cache hits */
275
- similarityThreshold: z.number().min(0.5).max(1).default(0.85)
276
- }).default({} as any)
277
- })
278
-
279
- export type AdvancedIntelligenceConfig = z.infer<typeof AdvancedIntelligenceConfigSchema>
280
-
281
- /** Main configuration schema for Claude Brain */
282
- export const ConfigSchema = z.object({
283
- /** Absolute path to the Obsidian vault (auto-detected if empty) */
284
- vaultPath: z.string().default(''),
285
-
286
- /** MCP server identifier */
287
- serverName: z.string().default('claude-brain'),
288
-
289
- /** Server version in semver format */
290
- serverVersion: z.string().regex(/^\d+\.\d+\.\d+$/, 'Version must be semver format').default(pkg.version),
291
-
292
- /** Logging level */
293
- logLevel: LogLevelSchema.default('warn'),
294
-
295
- /** Path to log file */
296
- logFilePath: z.string().default('./logs/claude-brain.log'),
297
-
298
- /** Path to vector database */
299
- dbPath: z.string().default('./data/memory.db'),
300
-
301
- /** Port for future HTTP interface */
302
- port: z.number().int().min(1).max(65535).default(3000),
303
-
304
- /** Enable file watching for vault changes */
305
- enableFileWatch: z.boolean().default(true),
306
-
307
- /** Cache size in MB for context cache */
308
- cacheSize: z.number().int().min(1).default(100),
309
-
310
- /** Node environment */
311
- nodeEnv: z.enum(['development', 'production', 'test']).default('development'),
312
-
313
- /** Hybrid retrieval configuration */
314
- retrieval: RetrievalConfigSchema.default({} as any),
315
-
316
- /** Knowledge graph and episodic memory configuration */
317
- knowledge: KnowledgeConfigSchema.default({} as any),
318
-
319
- /** Advanced intelligence configuration (Phase 15) */
320
- advancedIntelligence: AdvancedIntelligenceConfigSchema.default({} as any),
321
-
322
- /** Phase 16: Unified tool mode — expose only brain() instead of all 25 tools */
323
- unifiedToolMode: z.boolean().default(true),
324
-
325
- /** Phase 17: Passive learning hooks configuration */
326
- hooks: HooksConfigSchema.default({} as any),
327
-
328
- /** Phase 18: Knowledge packs configuration */
329
- packs: PacksConfigSchema.default({} as any),
330
-
331
- /** Phase 22: Intelligence features (opt-in) */
332
- intelligence: z.object({
333
- /** Enable consolidated intelligence features */
334
- enabled: z.boolean().default(false)
335
- }).default({} as any),
336
-
337
- /** Phase 26: ChromaDB configuration (now optional, SQLite FTS5 is primary) */
338
- chromadb: z.object({
339
- /** Enable ChromaDB vector storage backend */
340
- enabled: z.boolean().default(false)
341
- }).default({} as any),
342
-
343
- /** Phase 28: Code intelligence configuration */
344
- codeIntelligence: z.object({
345
- /** Enable code intelligence (project indexing and file maps) */
346
- enabled: z.boolean().default(true),
347
- }).default({} as any),
348
-
349
- /** Phase 31: Auto-update configuration */
350
- autoUpdate: z.object({
351
- /** Enable automatic update checks */
352
- enabled: z.boolean().default(true),
353
- /** Hours between update checks */
354
- checkIntervalHours: z.number().int().min(1).max(168).default(24),
355
- /** Automatically restart server after update */
356
- autoRestart: z.boolean().default(true),
357
- }).default({} as any),
358
-
359
- /** SLM Upgrade: Local model inference configuration */
360
- slm: z.object({
361
- /** Master switch for local model inference */
362
- enabled: z.boolean().default(false),
363
- /** Directory containing ONNX model files */
364
- modelsDir: z.string().default('~/.claude-brain/models'),
365
- /** Hugging Face repo for downloading pre-trained models */
366
- hfRepo: z.string().default('demgun101/claude-brain-models'),
367
- /** Minimum model confidence to use model prediction (below → regex fallback) */
368
- confidenceThreshold: z.number().min(0).max(1).default(0.7),
369
- /** Per-task mode: 'model' uses model only, 'regex' uses regex only, 'both' runs both and logs comparison */
370
- tasks: z.object({
371
- intent: z.enum(['model', 'regex', 'both']).default('regex'),
372
- entity: z.enum(['model', 'regex', 'both']).default('regex'),
373
- query: z.enum(['model', 'regex', 'both']).default('regex'),
374
- knowledge: z.enum(['model', 'regex', 'both']).default('regex'),
375
- compress: z.enum(['model', 'api', 'both']).default('api'),
376
- pattern: z.enum(['model', 'regex', 'both']).default('regex'),
377
- }).default({} as any),
378
- /** Phase 6B: Automated retraining configuration */
379
- retrain: z.object({
380
- /** Minimum new feedback entries before triggering retrain */
381
- minFeedbackCount: z.number().int().min(1).default(100),
382
- /** Maximum disagreement rate threshold to trigger retrain */
383
- maxDisagreementRate: z.number().min(0).max(1).default(0.15),
384
- /** Python executable path */
385
- pythonPath: z.string().default('python3'),
386
- /** Path to SLM training directory */
387
- trainingDir: z.string().default('~/slm-training'),
388
- }).default({} as any),
389
- }).default({} as any),
390
-
391
- /** Daemon process configuration */
392
- daemon: z.object({
393
- /** Minutes of inactivity before daemon self-terminates (0 = never) */
394
- idleTimeoutMinutes: z.number().int().min(0).default(30),
395
- }).default({} as any),
396
-
397
- /** Phase 30: Optional LLM compression for observations */
398
- compression: z.object({
399
- /** Enable LLM-based compression of long observations */
400
- enabled: z.boolean().default(false),
401
- /** LLM provider for compression */
402
- provider: z.enum(['claude', 'ollama']).default('claude'),
403
- /** Model to use for compression */
404
- model: z.string().default('claude-haiku-4-5-20251001'),
405
- /** API key (falls back to ANTHROPIC_API_KEY env var) */
406
- apiKey: z.string().optional(),
407
- /** Minimum content length to trigger compression */
408
- minContentLength: z.number().default(500),
409
- }).default({} as any)
410
- })
411
-
412
- export type Config = z.infer<typeof ConfigSchema>
413
-
414
- /** Partial config for merging with defaults */
415
- export type PartialConfig = z.input<typeof ConfigSchema>
1
+ import { z } from 'zod'
2
+ import pkg from '../../package.json'
3
+
4
+ /** Log level options for the application */
5
+ export const LogLevelSchema = z.enum(['debug', 'info', 'warn', 'error'])
6
+ export type LogLevel = z.infer<typeof LogLevelSchema>
7
+
8
+ /** Retrieval configuration for hybrid search */
9
+ export const RetrievalConfigSchema = z.object({
10
+ /** Enable hybrid retrieval pipeline (opt-in) */
11
+ enabled: z.boolean().default(false),
12
+
13
+ /** Dense (semantic) search configuration */
14
+ dense: z.object({
15
+ /** Weight for dense search in fusion (0-1) */
16
+ weight: z.number().min(0).max(1).default(0.7),
17
+ /** Maximum number of results from dense search */
18
+ limit: z.number().int().min(1).max(100).default(20),
19
+ /** Minimum similarity threshold (0-1) */
20
+ minSimilarity: z.number().min(0).max(1).default(0.3)
21
+ }).default({ weight: 0.7, limit: 20, minSimilarity: 0.3 }),
22
+
23
+ /** Sparse (BM25) search configuration */
24
+ sparse: z.object({
25
+ /** Enable sparse search */
26
+ enabled: z.boolean().default(true),
27
+ /** Weight for sparse search in fusion (0-1) */
28
+ weight: z.number().min(0).max(1).default(0.3),
29
+ /** Maximum number of results from sparse search */
30
+ limit: z.number().int().min(1).max(100).default(20)
31
+ }).default({ enabled: true, weight: 0.3, limit: 20 }),
32
+
33
+ /** Fusion configuration for combining results */
34
+ fusion: z.object({
35
+ /** Fusion method */
36
+ method: z.enum(['rrf', 'linear', 'max']).default('rrf'),
37
+ /** RRF k parameter (default 60 per original paper) */
38
+ rrfK: z.number().int().min(1).default(60)
39
+ }).default({ method: 'rrf' as const, rrfK: 60 }),
40
+
41
+ /** Cross-encoder reranking configuration */
42
+ reranker: z.object({
43
+ /** Enable cross-encoder reranking */
44
+ enabled: z.boolean().default(false),
45
+ /** Model to use for reranking */
46
+ model: z.string().default('cross-encoder/ms-marco-MiniLM-L-6-v2'),
47
+ /** Number of results to rerank */
48
+ topK: z.number().int().min(1).max(100).default(10)
49
+ }).default({ enabled: false, model: 'cross-encoder/ms-marco-MiniLM-L-6-v2', topK: 10 }),
50
+
51
+ /** Query understanding configuration */
52
+ queryUnderstanding: z.object({
53
+ /** Enable query understanding */
54
+ enabled: z.boolean().default(true),
55
+ /** Enable intent classification */
56
+ intentClassification: z.boolean().default(true),
57
+ /** Enable query expansion */
58
+ queryExpansion: z.boolean().default(true),
59
+ /** Enable temporal parsing */
60
+ temporalParsing: z.boolean().default(true)
61
+ }).default({ enabled: true, intentClassification: true, queryExpansion: true, temporalParsing: true }),
62
+
63
+ /** Feedback collection configuration */
64
+ feedback: z.object({
65
+ /** Enable feedback collection */
66
+ enabled: z.boolean().default(true),
67
+ /** Enable adaptive threshold learning */
68
+ adaptiveThresholds: z.boolean().default(true),
69
+ /** Minimum feedback count before adaptation */
70
+ minFeedbackForAdaptation: z.number().int().min(1).default(10)
71
+ }).default({ enabled: true, adaptiveThresholds: true, minFeedbackForAdaptation: 10 })
72
+ })
73
+
74
+ export type RetrievalConfig = z.infer<typeof RetrievalConfigSchema>
75
+
76
+ /** Knowledge graph and episodic memory configuration */
77
+ export const KnowledgeConfigSchema = z.object({
78
+ /** Entity extraction settings */
79
+ extraction: z.object({
80
+ /** Minimum confidence for extracted entities */
81
+ minConfidence: z.number().min(0).max(1).default(0.5),
82
+ /** Maximum entities to extract per text */
83
+ maxEntities: z.number().int().min(1).max(200).default(50)
84
+ }).default({ minConfidence: 0.5, maxEntities: 50 }),
85
+
86
+ /** Knowledge graph settings */
87
+ graph: z.object({
88
+ /** Enable knowledge graph auto-population */
89
+ enabled: z.boolean().default(true),
90
+ /** Path for graph persistence */
91
+ persistPath: z.string().default('./data/knowledge-graph.json'),
92
+ /** Auto-save interval in seconds */
93
+ autoSaveInterval: z.number().int().min(10).default(60),
94
+ /** Maximum graph traversal depth */
95
+ maxTraversalDepth: z.number().int().min(1).max(10).default(5),
96
+ /** Alpha for combined scoring (vector vs graph proximity) */
97
+ alpha: z.number().min(0).max(1).default(0.6)
98
+ }).default({ enabled: true, persistPath: './data/knowledge-graph.json', autoSaveInterval: 60, maxTraversalDepth: 5, alpha: 0.6 }),
99
+
100
+ /** Episodic memory settings */
101
+ episodic: z.object({
102
+ /** Enable episodic memory */
103
+ enabled: z.boolean().default(true),
104
+ /** Time gap in minutes to detect new session */
105
+ sessionGapMinutes: z.number().int().min(1).default(30),
106
+ /** Maximum messages per episode before auto-splitting */
107
+ maxMessagesPerEpisode: z.number().int().min(10).default(200),
108
+ /** Number of top sentences for brief summary */
109
+ briefSummarySize: z.number().int().min(1).max(10).default(2),
110
+ /** Number of top sentences for detailed summary */
111
+ detailedSummarySize: z.number().int().min(1).max(20).default(8)
112
+ }).default({ enabled: true, sessionGapMinutes: 30, maxMessagesPerEpisode: 200, briefSummarySize: 2, detailedSummarySize: 8 }),
113
+
114
+ /** Memory consolidation settings */
115
+ consolidation: z.object({
116
+ /** Enable memory consolidation */
117
+ enabled: z.boolean().default(true),
118
+ /** Similarity threshold for merge candidates */
119
+ mergeThreshold: z.number().min(0).max(1).default(0.85),
120
+ /** Importance score threshold for archival */
121
+ archiveThreshold: z.number().min(0).max(1).default(0.2),
122
+ /** Interval in minutes between automatic archival sweeps (0 = disabled) */
123
+ archiveIntervalMinutes: z.number().int().min(0).default(60),
124
+ /** Importance scoring weights */
125
+ weights: z.object({
126
+ recency: z.number().min(0).max(1).default(0.2),
127
+ frequency: z.number().min(0).max(1).default(0.2),
128
+ references: z.number().min(0).max(1).default(0.2),
129
+ feedback: z.number().min(0).max(1).default(0.2),
130
+ uniqueness: z.number().min(0).max(1).default(0.2)
131
+ }).default({ recency: 0.2, frequency: 0.2, references: 0.2, feedback: 0.2, uniqueness: 0.2 })
132
+ }).default({
133
+ enabled: true, mergeThreshold: 0.85, archiveThreshold: 0.2, archiveIntervalMinutes: 60,
134
+ weights: { recency: 0.2, frequency: 0.2, references: 0.2, feedback: 0.2, uniqueness: 0.2 }
135
+ })
136
+ })
137
+
138
+ export type KnowledgeConfig = z.infer<typeof KnowledgeConfigSchema>
139
+
140
+ /** Phase 17+20: Passive Learning via Hooks configuration */
141
+ export const HooksConfigSchema = z.object({
142
+ /** Master switch for hooks passive learning (Phase 20: enabled by default) */
143
+ enabled: z.boolean().default(true),
144
+
145
+ /** What to capture from tool calls */
146
+ capture: z.object({
147
+ /** Capture knowledge from tool use (Edit/Write) */
148
+ toolUse: z.boolean().default(true),
149
+ /** Capture knowledge from file edits */
150
+ fileEdits: z.boolean().default(true),
151
+ /** Capture knowledge from bash commands */
152
+ bashCommands: z.boolean().default(true),
153
+ /** Capture knowledge from user messages */
154
+ userMessages: z.boolean().default(true)
155
+ }).default({ toolUse: true, fileEdits: true, bashCommands: true, userMessages: true }),
156
+
157
+ /** Privacy filters */
158
+ privacy: z.object({
159
+ /** File paths to ignore (glob patterns) — Phase 20: sensible defaults */
160
+ ignorePaths: z.array(z.string()).default([
161
+ 'node_modules/**',
162
+ '.env*',
163
+ '*.key',
164
+ '*.pem',
165
+ '*.p12',
166
+ '*.pfx',
167
+ '.git/**',
168
+ 'dist/**',
169
+ 'build/**',
170
+ '*.secret',
171
+ 'credentials*',
172
+ '.aws/**',
173
+ '.ssh/**'
174
+ ]),
175
+ /** Projects to ignore */
176
+ ignoreProjects: z.array(z.string()).default([]),
177
+ /** Minimum confidence to store captured knowledge */
178
+ minConfidence: z.number().min(0).max(1).default(0.7)
179
+ }).default({
180
+ ignorePaths: [
181
+ 'node_modules/**', '.env*', '*.key', '*.pem', '*.p12', '*.pfx',
182
+ '.git/**', 'dist/**', 'build/**', '*.secret', 'credentials*', '.aws/**', '.ssh/**'
183
+ ],
184
+ ignoreProjects: [],
185
+ minConfidence: 0.7
186
+ }),
187
+
188
+ /** Session tracking settings */
189
+ sessions: z.object({
190
+ /** Enable session tracking */
191
+ enabled: z.boolean().default(true),
192
+ /** Idle timeout in minutes before summarizing */
193
+ idleTimeoutMinutes: z.number().int().min(1).default(30),
194
+ /** Minimum events required before generating summary */
195
+ minEventsForSummary: z.number().int().min(1).default(3)
196
+ }).default({ enabled: true, idleTimeoutMinutes: 30, minEventsForSummary: 3 }),
197
+
198
+ /** Deduplication thresholds */
199
+ deduplication: z.object({
200
+ /** Similarity above this skips storage (exact duplicate) */
201
+ skipThreshold: z.number().min(0).max(1).default(0.95),
202
+ /** Similarity above this merges instead of creating new */
203
+ mergeThreshold: z.number().min(0).max(1).default(0.85)
204
+ }).default({ skipThreshold: 0.95, mergeThreshold: 0.85 })
205
+ })
206
+
207
+ export type HooksConfig = z.infer<typeof HooksConfigSchema>
208
+
209
+ /** Phase 18: Knowledge Packs configuration */
210
+ export const PacksConfigSchema = z.object({
211
+ /** Master switch for knowledge packs */
212
+ enabled: z.boolean().default(true),
213
+
214
+ /** Directory name for pack files (relative to package root) */
215
+ packsDir: z.string().default('packs'),
216
+
217
+ /** Always load core/ packs regardless of tech stack */
218
+ alwaysLoadCore: z.boolean().default(true),
219
+
220
+ /** Always load meta/ packs regardless of tech stack */
221
+ alwaysLoadMeta: z.boolean().default(true),
222
+
223
+ /** Confidence multiplier for community (pack) entries (dampens scores) */
224
+ communityConfidenceMultiplier: z.number().min(0).max(1).default(0.8),
225
+
226
+ /** Search result boost for personal (user-created) entries */
227
+ personalBoost: z.number().min(1).max(2).default(1.2),
228
+
229
+ /** Search result boost for project-specific entries */
230
+ projectBoost: z.number().min(1).max(2).default(1.15)
231
+ })
232
+
233
+ export type PacksConfig = z.infer<typeof PacksConfigSchema>
234
+
235
+ /** Phase 15: Advanced Intelligence configuration */
236
+ export const AdvancedIntelligenceConfigSchema = z.object({
237
+ /** Enable advanced intelligence features (Phase 15) */
238
+ enabled: z.boolean().default(true),
239
+
240
+ /** Temporal intelligence settings */
241
+ temporal: z.object({
242
+ /** Enable temporal query processing */
243
+ enabled: z.boolean().default(true),
244
+ /** Default timeline limit */
245
+ defaultTimelineLimit: z.number().int().min(1).max(500).default(50),
246
+ /** Default trend analysis period in days */
247
+ defaultTrendPeriodDays: z.number().int().min(1).max(3650).default(90)
248
+ }).default({ enabled: true, defaultTimelineLimit: 50, defaultTrendPeriodDays: 90 }),
249
+
250
+ /** Multi-hop reasoning settings */
251
+ reasoning: z.object({
252
+ /** Enable multi-hop reasoning */
253
+ enabled: z.boolean().default(true),
254
+ /** Maximum retrieval hops */
255
+ maxHops: z.number().int().min(1).max(10).default(3),
256
+ /** Results per hop */
257
+ resultsPerHop: z.number().int().min(1).max(50).default(5)
258
+ }).default({ enabled: true, maxHops: 3, resultsPerHop: 5 }),
259
+
260
+ /** Predictive intelligence settings */
261
+ prediction: z.object({
262
+ /** Enable predictive features */
263
+ enabled: z.boolean().default(true),
264
+ /** Default recommendation limit */
265
+ defaultRecommendationLimit: z.number().int().min(1).max(50).default(10)
266
+ }).default({ enabled: true, defaultRecommendationLimit: 10 }),
267
+
268
+ /** Cross-project intelligence settings */
269
+ crossProject: z.object({
270
+ /** Enable cross-project analysis */
271
+ enabled: z.boolean().default(true),
272
+ /** Minimum projects for pattern detection */
273
+ minProjects: z.number().int().min(2).max(50).default(2)
274
+ }).default({ enabled: true, minProjects: 2 }),
275
+
276
+ /** Semantic caching settings */
277
+ cache: z.object({
278
+ /** Enable semantic caching */
279
+ enabled: z.boolean().default(true),
280
+ /** Maximum cache entries */
281
+ maxSize: z.number().int().min(10).max(10000).default(500),
282
+ /** Cache TTL in milliseconds */
283
+ ttlMs: z.number().int().min(60000).default(30 * 60 * 1000),
284
+ /** Semantic similarity threshold for cache hits */
285
+ similarityThreshold: z.number().min(0.5).max(1).default(0.85)
286
+ }).default({ enabled: true, maxSize: 500, ttlMs: 30 * 60 * 1000, similarityThreshold: 0.85 })
287
+ })
288
+
289
+ export type AdvancedIntelligenceConfig = z.infer<typeof AdvancedIntelligenceConfigSchema>
290
+
291
+ // Pre-compute defaults for complex schemas (Zod v4 requires output-typed defaults)
292
+ const retrievalDefaults = RetrievalConfigSchema.parse({})
293
+ const knowledgeDefaults = KnowledgeConfigSchema.parse({})
294
+ const advancedIntelligenceDefaults = AdvancedIntelligenceConfigSchema.parse({})
295
+ const hooksDefaults = HooksConfigSchema.parse({})
296
+ const packsDefaults = PacksConfigSchema.parse({})
297
+
298
+ /** Main configuration schema for Claude Brain */
299
+ export const ConfigSchema = z.object({
300
+ /** Absolute path to the Obsidian vault (auto-detected if empty) */
301
+ vaultPath: z.string().default(''),
302
+
303
+ /** MCP server identifier */
304
+ serverName: z.string().default('claude-brain'),
305
+
306
+ /** Server version in semver format */
307
+ serverVersion: z.string().regex(/^\d+\.\d+\.\d+$/, 'Version must be semver format').default(pkg.version),
308
+
309
+ /** Logging level */
310
+ logLevel: LogLevelSchema.default('warn'),
311
+
312
+ /** Path to log file */
313
+ logFilePath: z.string().default('./logs/claude-brain.log'),
314
+
315
+ /** Path to vector database */
316
+ dbPath: z.string().default('./data/memory.db'),
317
+
318
+ /** Port for future HTTP interface */
319
+ port: z.number().int().min(1).max(65535).default(3000),
320
+
321
+ /** Additional allowed CORS origins */
322
+ corsOrigins: z.array(z.string()).default([]),
323
+
324
+ /** API key for HTTP endpoint authentication */
325
+ apiKey: z.string().optional(),
326
+
327
+ /** Enable file watching for vault changes */
328
+ enableFileWatch: z.boolean().default(true),
329
+
330
+ /** Cache size in MB for context cache */
331
+ cacheSize: z.number().int().min(1).default(100),
332
+
333
+ /** Node environment */
334
+ nodeEnv: z.enum(['development', 'production', 'test']).default('development'),
335
+
336
+ /** Hybrid retrieval configuration */
337
+ retrieval: RetrievalConfigSchema.default(retrievalDefaults),
338
+
339
+ /** Knowledge graph and episodic memory configuration */
340
+ knowledge: KnowledgeConfigSchema.default(knowledgeDefaults),
341
+
342
+ /** Advanced intelligence configuration (Phase 15) */
343
+ advancedIntelligence: AdvancedIntelligenceConfigSchema.default(advancedIntelligenceDefaults),
344
+
345
+ /** Phase 16: Unified tool mode expose only brain() instead of all 25 tools */
346
+ unifiedToolMode: z.boolean().default(true),
347
+
348
+ /** Phase 17: Passive learning hooks configuration */
349
+ hooks: HooksConfigSchema.default(hooksDefaults),
350
+
351
+ /** Phase 18: Knowledge packs configuration */
352
+ packs: PacksConfigSchema.default(packsDefaults),
353
+
354
+ /** Phase 22: Intelligence features (opt-in) */
355
+ intelligence: z.object({
356
+ /** Enable consolidated intelligence features */
357
+ enabled: z.boolean().default(false)
358
+ }).default({ enabled: false }),
359
+
360
+ /** Phase 26: ChromaDB configuration (now optional, SQLite FTS5 is primary) */
361
+ chromadb: z.object({
362
+ /** Enable ChromaDB vector storage backend */
363
+ enabled: z.boolean().default(false)
364
+ }).default({ enabled: false }),
365
+
366
+ /** Phase 28: Code intelligence configuration */
367
+ codeIntelligence: z.object({
368
+ /** Enable code intelligence (project indexing and file maps) */
369
+ enabled: z.boolean().default(true),
370
+ }).default({ enabled: true }),
371
+
372
+ /** Phase 31: Auto-update configuration */
373
+ autoUpdate: z.object({
374
+ /** Enable automatic update checks */
375
+ enabled: z.boolean().default(true),
376
+ /** Hours between update checks */
377
+ checkIntervalHours: z.number().int().min(1).max(168).default(24),
378
+ /** Automatically restart server after update */
379
+ autoRestart: z.boolean().default(true),
380
+ }).default({ enabled: true, checkIntervalHours: 24, autoRestart: true }),
381
+
382
+ /** SLM Upgrade: Local model inference configuration */
383
+ slm: z.object({
384
+ /** Master switch for local model inference */
385
+ enabled: z.boolean().default(false),
386
+ /** Directory containing ONNX model files */
387
+ modelsDir: z.string().default('~/.claude-brain/models'),
388
+ /** Hugging Face repo for downloading pre-trained models */
389
+ hfRepo: z.string().default('demgun101/claude-brain-models'),
390
+ /** Minimum model confidence to use model prediction (below → regex fallback) */
391
+ confidenceThreshold: z.number().min(0).max(1).default(0.7),
392
+ /** Per-task mode: 'model' uses model only, 'regex' uses regex only, 'both' runs both and logs comparison */
393
+ tasks: z.object({
394
+ intent: z.enum(['model', 'regex', 'both']).default('regex'),
395
+ entity: z.enum(['model', 'regex', 'both']).default('regex'),
396
+ query: z.enum(['model', 'regex', 'both']).default('regex'),
397
+ knowledge: z.enum(['model', 'regex', 'both']).default('regex'),
398
+ compress: z.enum(['model', 'api', 'both']).default('api'),
399
+ pattern: z.enum(['model', 'regex', 'both']).default('regex'),
400
+ }).default({
401
+ intent: 'regex' as const, entity: 'regex' as const, query: 'regex' as const,
402
+ knowledge: 'regex' as const, compress: 'api' as const, pattern: 'regex' as const
403
+ }),
404
+ /** Phase 6B: Automated retraining configuration */
405
+ retrain: z.object({
406
+ /** Minimum new feedback entries before triggering retrain */
407
+ minFeedbackCount: z.number().int().min(1).default(100),
408
+ /** Maximum disagreement rate threshold to trigger retrain */
409
+ maxDisagreementRate: z.number().min(0).max(1).default(0.15),
410
+ /** Python executable path */
411
+ pythonPath: z.string().default('python3'),
412
+ /** Path to SLM training directory */
413
+ trainingDir: z.string().default('~/slm-training'),
414
+ }).default({ minFeedbackCount: 100, maxDisagreementRate: 0.15, pythonPath: 'python3', trainingDir: '~/slm-training' }),
415
+ }).default({
416
+ enabled: false, modelsDir: '~/.claude-brain/models', hfRepo: 'demgun101/claude-brain-models',
417
+ confidenceThreshold: 0.7,
418
+ tasks: { intent: 'regex' as const, entity: 'regex' as const, query: 'regex' as const, knowledge: 'regex' as const, compress: 'api' as const, pattern: 'regex' as const },
419
+ retrain: { minFeedbackCount: 100, maxDisagreementRate: 0.15, pythonPath: 'python3', trainingDir: '~/slm-training' }
420
+ }),
421
+
422
+ /** Daemon process configuration */
423
+ daemon: z.object({
424
+ /** Minutes of inactivity before daemon self-terminates (0 = never) */
425
+ idleTimeoutMinutes: z.number().int().min(0).default(30),
426
+ }).default({ idleTimeoutMinutes: 30 }),
427
+
428
+ /** Phase 30: Optional LLM compression for observations */
429
+ compression: z.object({
430
+ /** Enable LLM-based compression of long observations */
431
+ enabled: z.boolean().default(false),
432
+ /** LLM provider for compression */
433
+ provider: z.enum(['claude', 'ollama']).default('claude'),
434
+ /** Model to use for compression */
435
+ model: z.string().default('claude-haiku-4-5-20251001'),
436
+ /** API key (falls back to ANTHROPIC_API_KEY env var) */
437
+ apiKey: z.string().optional(),
438
+ /** Minimum content length to trigger compression */
439
+ minContentLength: z.number().default(500),
440
+ }).default({ enabled: false, provider: 'claude' as const, model: 'claude-haiku-4-5-20251001', minContentLength: 500 })
441
+ })
442
+
443
+ export type Config = z.infer<typeof ConfigSchema>
444
+
445
+ /** Partial config for merging with defaults */
446
+ export type PartialConfig = z.input<typeof ConfigSchema>