shieldcortex 2.0.0

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 (377) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +282 -0
  3. package/dashboard/components.json +22 -0
  4. package/dashboard/eslint.config.mjs +42 -0
  5. package/dashboard/next.config.ts +7 -0
  6. package/dashboard/package-lock.json +8053 -0
  7. package/dashboard/package.json +44 -0
  8. package/dashboard/postcss.config.mjs +7 -0
  9. package/dashboard/public/file.svg +1 -0
  10. package/dashboard/public/globe.svg +1 -0
  11. package/dashboard/public/next.svg +1 -0
  12. package/dashboard/public/vercel.svg +1 -0
  13. package/dashboard/public/window.svg +1 -0
  14. package/dashboard/scripts/ensure-api.mjs +76 -0
  15. package/dashboard/src/app/error.tsx +49 -0
  16. package/dashboard/src/app/favicon.ico +0 -0
  17. package/dashboard/src/app/globals.css +130 -0
  18. package/dashboard/src/app/layout.tsx +35 -0
  19. package/dashboard/src/app/page.tsx +364 -0
  20. package/dashboard/src/components/Providers.tsx +27 -0
  21. package/dashboard/src/components/brain/ActivityPulseSystem.tsx +229 -0
  22. package/dashboard/src/components/brain/BrainMesh.tsx +133 -0
  23. package/dashboard/src/components/brain/BrainRegions.tsx +254 -0
  24. package/dashboard/src/components/brain/BrainScene.tsx +255 -0
  25. package/dashboard/src/components/brain/CategoryLabels.tsx +103 -0
  26. package/dashboard/src/components/brain/CoreSphere.tsx +215 -0
  27. package/dashboard/src/components/brain/DataFlowParticles.tsx +123 -0
  28. package/dashboard/src/components/brain/DataStreamRings.tsx +161 -0
  29. package/dashboard/src/components/brain/ElectronFlow.tsx +323 -0
  30. package/dashboard/src/components/brain/HolographicGrid.tsx +235 -0
  31. package/dashboard/src/components/brain/MemoryLinks.tsx +271 -0
  32. package/dashboard/src/components/brain/MemoryNode.tsx +245 -0
  33. package/dashboard/src/components/brain/NeuralPathways.tsx +441 -0
  34. package/dashboard/src/components/brain/SynapseNodes.tsx +312 -0
  35. package/dashboard/src/components/brain/TimelineControls.tsx +205 -0
  36. package/dashboard/src/components/chip/ChipScene.tsx +497 -0
  37. package/dashboard/src/components/chip/ChipSubstrate.tsx +238 -0
  38. package/dashboard/src/components/chip/CortexCore.tsx +210 -0
  39. package/dashboard/src/components/chip/DataBus.tsx +416 -0
  40. package/dashboard/src/components/chip/MemoryCell.tsx +225 -0
  41. package/dashboard/src/components/chip/MemoryGrid.tsx +328 -0
  42. package/dashboard/src/components/chip/QuantumCell.tsx +316 -0
  43. package/dashboard/src/components/chip/SectionLabel.tsx +113 -0
  44. package/dashboard/src/components/chip/index.ts +14 -0
  45. package/dashboard/src/components/controls/ControlPanel.tsx +106 -0
  46. package/dashboard/src/components/controls/VersionPanel.tsx +185 -0
  47. package/dashboard/src/components/dashboard/StatsPanel.tsx +164 -0
  48. package/dashboard/src/components/debug/ActivityLog.tsx +250 -0
  49. package/dashboard/src/components/debug/DebugPanel.tsx +101 -0
  50. package/dashboard/src/components/debug/QueryTester.tsx +192 -0
  51. package/dashboard/src/components/debug/RelationshipGraph.tsx +403 -0
  52. package/dashboard/src/components/debug/SqlConsole.tsx +319 -0
  53. package/dashboard/src/components/graph/KnowledgeGraph.tsx +230 -0
  54. package/dashboard/src/components/graph/OntologyGraph.tsx +631 -0
  55. package/dashboard/src/components/insights/ActivityHeatmap.tsx +131 -0
  56. package/dashboard/src/components/insights/InsightsView.tsx +46 -0
  57. package/dashboard/src/components/insights/KnowledgeMapPanel.tsx +80 -0
  58. package/dashboard/src/components/insights/QualityPanel.tsx +116 -0
  59. package/dashboard/src/components/memories/MemoriesView.tsx +150 -0
  60. package/dashboard/src/components/memories/MemoryCard.tsx +103 -0
  61. package/dashboard/src/components/memory/MemoryDetail.tsx +325 -0
  62. package/dashboard/src/components/nav/NavRail.tsx +54 -0
  63. package/dashboard/src/components/ui/button.tsx +62 -0
  64. package/dashboard/src/components/ui/card.tsx +92 -0
  65. package/dashboard/src/components/ui/input.tsx +21 -0
  66. package/dashboard/src/hooks/useDebouncedValue.ts +24 -0
  67. package/dashboard/src/hooks/useMemories.ts +458 -0
  68. package/dashboard/src/hooks/useSuggestions.ts +46 -0
  69. package/dashboard/src/lib/category-colors.ts +84 -0
  70. package/dashboard/src/lib/position-algorithm.ts +177 -0
  71. package/dashboard/src/lib/simplex-noise.ts +217 -0
  72. package/dashboard/src/lib/store.ts +88 -0
  73. package/dashboard/src/lib/utils.ts +6 -0
  74. package/dashboard/src/lib/websocket.ts +249 -0
  75. package/dashboard/src/types/memory.ts +73 -0
  76. package/dashboard/tsconfig.json +34 -0
  77. package/dist/__tests__/consolidation-merge.test.d.ts +9 -0
  78. package/dist/__tests__/consolidation-merge.test.d.ts.map +1 -0
  79. package/dist/__tests__/consolidation-merge.test.js +137 -0
  80. package/dist/__tests__/consolidation-merge.test.js.map +1 -0
  81. package/dist/__tests__/contradictions.test.d.ts +8 -0
  82. package/dist/__tests__/contradictions.test.d.ts.map +1 -0
  83. package/dist/__tests__/contradictions.test.js +78 -0
  84. package/dist/__tests__/contradictions.test.js.map +1 -0
  85. package/dist/__tests__/salience-evolution.test.d.ts +7 -0
  86. package/dist/__tests__/salience-evolution.test.d.ts.map +1 -0
  87. package/dist/__tests__/salience-evolution.test.js +151 -0
  88. package/dist/__tests__/salience-evolution.test.js.map +1 -0
  89. package/dist/__tests__/store.test.d.ts +7 -0
  90. package/dist/__tests__/store.test.d.ts.map +1 -0
  91. package/dist/__tests__/store.test.js +582 -0
  92. package/dist/__tests__/store.test.js.map +1 -0
  93. package/dist/api/control.d.ts +27 -0
  94. package/dist/api/control.d.ts.map +1 -0
  95. package/dist/api/control.js +60 -0
  96. package/dist/api/control.js.map +1 -0
  97. package/dist/api/events.d.ts +159 -0
  98. package/dist/api/events.d.ts.map +1 -0
  99. package/dist/api/events.js +155 -0
  100. package/dist/api/events.js.map +1 -0
  101. package/dist/api/version.d.ts +36 -0
  102. package/dist/api/version.d.ts.map +1 -0
  103. package/dist/api/version.js +146 -0
  104. package/dist/api/version.js.map +1 -0
  105. package/dist/api/visualization-server.d.ts +11 -0
  106. package/dist/api/visualization-server.d.ts.map +1 -0
  107. package/dist/api/visualization-server.js +1186 -0
  108. package/dist/api/visualization-server.js.map +1 -0
  109. package/dist/context/project-context.d.ts +57 -0
  110. package/dist/context/project-context.d.ts.map +1 -0
  111. package/dist/context/project-context.js +135 -0
  112. package/dist/context/project-context.js.map +1 -0
  113. package/dist/database/init.d.ts +49 -0
  114. package/dist/database/init.d.ts.map +1 -0
  115. package/dist/database/init.js +567 -0
  116. package/dist/database/init.js.map +1 -0
  117. package/dist/defence/__tests__/firewall.test.d.ts +8 -0
  118. package/dist/defence/__tests__/firewall.test.d.ts.map +1 -0
  119. package/dist/defence/__tests__/firewall.test.js +123 -0
  120. package/dist/defence/__tests__/firewall.test.js.map +1 -0
  121. package/dist/defence/__tests__/fragmentation.test.d.ts +7 -0
  122. package/dist/defence/__tests__/fragmentation.test.d.ts.map +1 -0
  123. package/dist/defence/__tests__/fragmentation.test.js +51 -0
  124. package/dist/defence/__tests__/fragmentation.test.js.map +1 -0
  125. package/dist/defence/__tests__/pipeline.test.d.ts +8 -0
  126. package/dist/defence/__tests__/pipeline.test.d.ts.map +1 -0
  127. package/dist/defence/__tests__/pipeline.test.js +61 -0
  128. package/dist/defence/__tests__/pipeline.test.js.map +1 -0
  129. package/dist/defence/__tests__/sensitivity.test.d.ts +7 -0
  130. package/dist/defence/__tests__/sensitivity.test.d.ts.map +1 -0
  131. package/dist/defence/__tests__/sensitivity.test.js +61 -0
  132. package/dist/defence/__tests__/sensitivity.test.js.map +1 -0
  133. package/dist/defence/__tests__/trust.test.d.ts +7 -0
  134. package/dist/defence/__tests__/trust.test.d.ts.map +1 -0
  135. package/dist/defence/__tests__/trust.test.js +49 -0
  136. package/dist/defence/__tests__/trust.test.js.map +1 -0
  137. package/dist/defence/audit/index.d.ts +4 -0
  138. package/dist/defence/audit/index.d.ts.map +1 -0
  139. package/dist/defence/audit/index.js +3 -0
  140. package/dist/defence/audit/index.js.map +1 -0
  141. package/dist/defence/audit/logger.d.ts +14 -0
  142. package/dist/defence/audit/logger.d.ts.map +1 -0
  143. package/dist/defence/audit/logger.js +54 -0
  144. package/dist/defence/audit/logger.js.map +1 -0
  145. package/dist/defence/audit/queries.d.ts +33 -0
  146. package/dist/defence/audit/queries.d.ts.map +1 -0
  147. package/dist/defence/audit/queries.js +103 -0
  148. package/dist/defence/audit/queries.js.map +1 -0
  149. package/dist/defence/firewall/anomaly-scorer.d.ts +8 -0
  150. package/dist/defence/firewall/anomaly-scorer.d.ts.map +1 -0
  151. package/dist/defence/firewall/anomaly-scorer.js +58 -0
  152. package/dist/defence/firewall/anomaly-scorer.js.map +1 -0
  153. package/dist/defence/firewall/encoding-detector.d.ts +13 -0
  154. package/dist/defence/firewall/encoding-detector.d.ts.map +1 -0
  155. package/dist/defence/firewall/encoding-detector.js +120 -0
  156. package/dist/defence/firewall/encoding-detector.js.map +1 -0
  157. package/dist/defence/firewall/index.d.ts +21 -0
  158. package/dist/defence/firewall/index.d.ts.map +1 -0
  159. package/dist/defence/firewall/index.js +133 -0
  160. package/dist/defence/firewall/index.js.map +1 -0
  161. package/dist/defence/firewall/instruction-detector.d.ts +12 -0
  162. package/dist/defence/firewall/instruction-detector.d.ts.map +1 -0
  163. package/dist/defence/firewall/instruction-detector.js +99 -0
  164. package/dist/defence/firewall/instruction-detector.js.map +1 -0
  165. package/dist/defence/firewall/privilege-detector.d.ts +13 -0
  166. package/dist/defence/firewall/privilege-detector.d.ts.map +1 -0
  167. package/dist/defence/firewall/privilege-detector.js +89 -0
  168. package/dist/defence/firewall/privilege-detector.js.map +1 -0
  169. package/dist/defence/fragmentation/assembly-detector.d.ts +18 -0
  170. package/dist/defence/fragmentation/assembly-detector.d.ts.map +1 -0
  171. package/dist/defence/fragmentation/assembly-detector.js +72 -0
  172. package/dist/defence/fragmentation/assembly-detector.js.map +1 -0
  173. package/dist/defence/fragmentation/entity-extractor.d.ts +19 -0
  174. package/dist/defence/fragmentation/entity-extractor.d.ts.map +1 -0
  175. package/dist/defence/fragmentation/entity-extractor.js +86 -0
  176. package/dist/defence/fragmentation/entity-extractor.js.map +1 -0
  177. package/dist/defence/fragmentation/index.d.ts +23 -0
  178. package/dist/defence/fragmentation/index.d.ts.map +1 -0
  179. package/dist/defence/fragmentation/index.js +49 -0
  180. package/dist/defence/fragmentation/index.js.map +1 -0
  181. package/dist/defence/fragmentation/temporal-analyzer.d.ts +28 -0
  182. package/dist/defence/fragmentation/temporal-analyzer.d.ts.map +1 -0
  183. package/dist/defence/fragmentation/temporal-analyzer.js +41 -0
  184. package/dist/defence/fragmentation/temporal-analyzer.js.map +1 -0
  185. package/dist/defence/index.d.ts +12 -0
  186. package/dist/defence/index.d.ts.map +1 -0
  187. package/dist/defence/index.js +18 -0
  188. package/dist/defence/index.js.map +1 -0
  189. package/dist/defence/pipeline.d.ts +9 -0
  190. package/dist/defence/pipeline.d.ts.map +1 -0
  191. package/dist/defence/pipeline.js +115 -0
  192. package/dist/defence/pipeline.js.map +1 -0
  193. package/dist/defence/scanner/index.d.ts +5 -0
  194. package/dist/defence/scanner/index.d.ts.map +1 -0
  195. package/dist/defence/scanner/index.js +5 -0
  196. package/dist/defence/scanner/index.js.map +1 -0
  197. package/dist/defence/scanner/scan-existing.d.ts +34 -0
  198. package/dist/defence/scanner/scan-existing.d.ts.map +1 -0
  199. package/dist/defence/scanner/scan-existing.js +136 -0
  200. package/dist/defence/scanner/scan-existing.js.map +1 -0
  201. package/dist/defence/sensitivity/classifier.d.ts +6 -0
  202. package/dist/defence/sensitivity/classifier.d.ts.map +1 -0
  203. package/dist/defence/sensitivity/classifier.js +50 -0
  204. package/dist/defence/sensitivity/classifier.js.map +1 -0
  205. package/dist/defence/sensitivity/index.d.ts +11 -0
  206. package/dist/defence/sensitivity/index.d.ts.map +1 -0
  207. package/dist/defence/sensitivity/index.js +13 -0
  208. package/dist/defence/sensitivity/index.js.map +1 -0
  209. package/dist/defence/sensitivity/patterns.d.ts +14 -0
  210. package/dist/defence/sensitivity/patterns.d.ts.map +1 -0
  211. package/dist/defence/sensitivity/patterns.js +67 -0
  212. package/dist/defence/sensitivity/patterns.js.map +1 -0
  213. package/dist/defence/sensitivity/redaction.d.ts +17 -0
  214. package/dist/defence/sensitivity/redaction.d.ts.map +1 -0
  215. package/dist/defence/sensitivity/redaction.js +47 -0
  216. package/dist/defence/sensitivity/redaction.js.map +1 -0
  217. package/dist/defence/trust/index.d.ts +3 -0
  218. package/dist/defence/trust/index.d.ts.map +1 -0
  219. package/dist/defence/trust/index.js +3 -0
  220. package/dist/defence/trust/index.js.map +1 -0
  221. package/dist/defence/trust/recall-filter.d.ts +10 -0
  222. package/dist/defence/trust/recall-filter.d.ts.map +1 -0
  223. package/dist/defence/trust/recall-filter.js +38 -0
  224. package/dist/defence/trust/recall-filter.js.map +1 -0
  225. package/dist/defence/trust/source-scorer.d.ts +6 -0
  226. package/dist/defence/trust/source-scorer.d.ts.map +1 -0
  227. package/dist/defence/trust/source-scorer.js +34 -0
  228. package/dist/defence/trust/source-scorer.js.map +1 -0
  229. package/dist/defence/types.d.ts +88 -0
  230. package/dist/defence/types.d.ts.map +1 -0
  231. package/dist/defence/types.js +15 -0
  232. package/dist/defence/types.js.map +1 -0
  233. package/dist/embeddings/generator.d.ts +20 -0
  234. package/dist/embeddings/generator.d.ts.map +1 -0
  235. package/dist/embeddings/generator.js +83 -0
  236. package/dist/embeddings/generator.js.map +1 -0
  237. package/dist/embeddings/index.d.ts +2 -0
  238. package/dist/embeddings/index.d.ts.map +1 -0
  239. package/dist/embeddings/index.js +2 -0
  240. package/dist/embeddings/index.js.map +1 -0
  241. package/dist/errors.d.ts +74 -0
  242. package/dist/errors.d.ts.map +1 -0
  243. package/dist/errors.js +131 -0
  244. package/dist/errors.js.map +1 -0
  245. package/dist/graph/backfill.d.ts +6 -0
  246. package/dist/graph/backfill.d.ts.map +1 -0
  247. package/dist/graph/backfill.js +33 -0
  248. package/dist/graph/backfill.js.map +1 -0
  249. package/dist/graph/extract.d.ts +21 -0
  250. package/dist/graph/extract.d.ts.map +1 -0
  251. package/dist/graph/extract.js +231 -0
  252. package/dist/graph/extract.js.map +1 -0
  253. package/dist/graph/resolve.d.ts +6 -0
  254. package/dist/graph/resolve.d.ts.map +1 -0
  255. package/dist/graph/resolve.js +126 -0
  256. package/dist/graph/resolve.js.map +1 -0
  257. package/dist/index.d.ts +31 -0
  258. package/dist/index.d.ts.map +1 -0
  259. package/dist/index.js +248 -0
  260. package/dist/index.js.map +1 -0
  261. package/dist/memory/activation.d.ts +69 -0
  262. package/dist/memory/activation.d.ts.map +1 -0
  263. package/dist/memory/activation.js +168 -0
  264. package/dist/memory/activation.js.map +1 -0
  265. package/dist/memory/consolidate.d.ts +98 -0
  266. package/dist/memory/consolidate.d.ts.map +1 -0
  267. package/dist/memory/consolidate.js +511 -0
  268. package/dist/memory/consolidate.js.map +1 -0
  269. package/dist/memory/contradiction.d.ts +69 -0
  270. package/dist/memory/contradiction.d.ts.map +1 -0
  271. package/dist/memory/contradiction.js +286 -0
  272. package/dist/memory/contradiction.js.map +1 -0
  273. package/dist/memory/decay.d.ts +62 -0
  274. package/dist/memory/decay.d.ts.map +1 -0
  275. package/dist/memory/decay.js +184 -0
  276. package/dist/memory/decay.js.map +1 -0
  277. package/dist/memory/salience.d.ts +36 -0
  278. package/dist/memory/salience.d.ts.map +1 -0
  279. package/dist/memory/salience.js +216 -0
  280. package/dist/memory/salience.js.map +1 -0
  281. package/dist/memory/similarity.d.ts +57 -0
  282. package/dist/memory/similarity.d.ts.map +1 -0
  283. package/dist/memory/similarity.js +114 -0
  284. package/dist/memory/similarity.js.map +1 -0
  285. package/dist/memory/store.d.ts +179 -0
  286. package/dist/memory/store.d.ts.map +1 -0
  287. package/dist/memory/store.js +1184 -0
  288. package/dist/memory/store.js.map +1 -0
  289. package/dist/memory/types.d.ts +97 -0
  290. package/dist/memory/types.d.ts.map +1 -0
  291. package/dist/memory/types.js +30 -0
  292. package/dist/memory/types.js.map +1 -0
  293. package/dist/server.d.ts +12 -0
  294. package/dist/server.d.ts.map +1 -0
  295. package/dist/server.js +568 -0
  296. package/dist/server.js.map +1 -0
  297. package/dist/service/install.d.ts +15 -0
  298. package/dist/service/install.d.ts.map +1 -0
  299. package/dist/service/install.js +178 -0
  300. package/dist/service/install.js.map +1 -0
  301. package/dist/service/templates.d.ts +13 -0
  302. package/dist/service/templates.d.ts.map +1 -0
  303. package/dist/service/templates.js +58 -0
  304. package/dist/service/templates.js.map +1 -0
  305. package/dist/setup/claude-md.d.ts +12 -0
  306. package/dist/setup/claude-md.d.ts.map +1 -0
  307. package/dist/setup/claude-md.js +68 -0
  308. package/dist/setup/claude-md.js.map +1 -0
  309. package/dist/setup/clawdbot.d.ts +15 -0
  310. package/dist/setup/clawdbot.d.ts.map +1 -0
  311. package/dist/setup/clawdbot.js +118 -0
  312. package/dist/setup/clawdbot.js.map +1 -0
  313. package/dist/setup/doctor.d.ts +5 -0
  314. package/dist/setup/doctor.d.ts.map +1 -0
  315. package/dist/setup/doctor.js +141 -0
  316. package/dist/setup/doctor.js.map +1 -0
  317. package/dist/setup/hooks.d.ts +6 -0
  318. package/dist/setup/hooks.d.ts.map +1 -0
  319. package/dist/setup/hooks.js +36 -0
  320. package/dist/setup/hooks.js.map +1 -0
  321. package/dist/setup/migrate.d.ts +16 -0
  322. package/dist/setup/migrate.d.ts.map +1 -0
  323. package/dist/setup/migrate.js +164 -0
  324. package/dist/setup/migrate.js.map +1 -0
  325. package/dist/setup/settings-hooks.d.ts +7 -0
  326. package/dist/setup/settings-hooks.d.ts.map +1 -0
  327. package/dist/setup/settings-hooks.js +83 -0
  328. package/dist/setup/settings-hooks.js.map +1 -0
  329. package/dist/setup/uninstall.d.ts +12 -0
  330. package/dist/setup/uninstall.d.ts.map +1 -0
  331. package/dist/setup/uninstall.js +125 -0
  332. package/dist/setup/uninstall.js.map +1 -0
  333. package/dist/tools/context.d.ts +135 -0
  334. package/dist/tools/context.d.ts.map +1 -0
  335. package/dist/tools/context.js +273 -0
  336. package/dist/tools/context.js.map +1 -0
  337. package/dist/tools/forget.d.ts +53 -0
  338. package/dist/tools/forget.d.ts.map +1 -0
  339. package/dist/tools/forget.js +179 -0
  340. package/dist/tools/forget.js.map +1 -0
  341. package/dist/tools/graph.d.ts +46 -0
  342. package/dist/tools/graph.d.ts.map +1 -0
  343. package/dist/tools/graph.js +206 -0
  344. package/dist/tools/graph.js.map +1 -0
  345. package/dist/tools/recall.d.ts +79 -0
  346. package/dist/tools/recall.d.ts.map +1 -0
  347. package/dist/tools/recall.js +156 -0
  348. package/dist/tools/recall.js.map +1 -0
  349. package/dist/tools/remember.d.ts +83 -0
  350. package/dist/tools/remember.d.ts.map +1 -0
  351. package/dist/tools/remember.js +151 -0
  352. package/dist/tools/remember.js.map +1 -0
  353. package/dist/worker/brain-worker.d.ts +100 -0
  354. package/dist/worker/brain-worker.d.ts.map +1 -0
  355. package/dist/worker/brain-worker.js +283 -0
  356. package/dist/worker/brain-worker.js.map +1 -0
  357. package/dist/worker/link-discovery.d.ts +47 -0
  358. package/dist/worker/link-discovery.d.ts.map +1 -0
  359. package/dist/worker/link-discovery.js +103 -0
  360. package/dist/worker/link-discovery.js.map +1 -0
  361. package/dist/worker/predictive-consolidation.d.ts +46 -0
  362. package/dist/worker/predictive-consolidation.d.ts.map +1 -0
  363. package/dist/worker/predictive-consolidation.js +110 -0
  364. package/dist/worker/predictive-consolidation.js.map +1 -0
  365. package/dist/worker/types.d.ts +91 -0
  366. package/dist/worker/types.d.ts.map +1 -0
  367. package/dist/worker/types.js +22 -0
  368. package/dist/worker/types.js.map +1 -0
  369. package/hooks/clawdbot/cortex-memory/HOOK.md +71 -0
  370. package/hooks/clawdbot/cortex-memory/handler.js +279 -0
  371. package/package.json +73 -0
  372. package/scripts/pre-compact-hook.mjs +716 -0
  373. package/scripts/session-end-hook.mjs +548 -0
  374. package/scripts/session-start-hook.mjs +221 -0
  375. package/scripts/start-dashboard.sh +41 -0
  376. package/scripts/stop-dashboard.sh +21 -0
  377. package/scripts/stop-hook.mjs +163 -0
@@ -0,0 +1,279 @@
1
+ /**
2
+ * Cortex Memory Hook — Persistent brain-like memory for Clawdbot/Moltbot
3
+ *
4
+ * Integrates ShieldCortex MCP server via mcporter to provide:
5
+ * - Auto-extraction of important session content on /new
6
+ * - Context injection on agent bootstrap
7
+ * - Keyword-triggered memory saves
8
+ */
9
+ import { execFile } from "node:child_process";
10
+ import fs from "node:fs/promises";
11
+
12
+ // ==================== CORTEX MCP HELPER ====================
13
+
14
+ /**
15
+ * Call a ShieldCortex MCP tool via mcporter
16
+ * @param {string} tool - Tool name (e.g., "remember", "recall", "get_context")
17
+ * @param {Record<string, string>} args - Tool arguments as key:value pairs
18
+ * @returns {Promise<string|null>} Raw stdout or null on error
19
+ */
20
+ function callCortex(tool, args = {}) {
21
+ return new Promise((resolve) => {
22
+ const cmdArgs = [
23
+ "mcporter", "call", "--stdio",
24
+ "npx -y shieldcortex",
25
+ tool,
26
+ ];
27
+ for (const [key, value] of Object.entries(args)) {
28
+ // Escape single quotes by doubling them (FTS5-safe)
29
+ const safe = String(value).replace(/'/g, "''");
30
+ cmdArgs.push(`${key}:${safe}`);
31
+ }
32
+
33
+ execFile("npx", cmdArgs, {
34
+ timeout: 15000,
35
+ maxBuffer: 1024 * 256,
36
+ }, (err, stdout) => {
37
+ if (err) {
38
+ console.error(`[cortex-memory] mcporter error (${tool}):`, err.message);
39
+ resolve(null);
40
+ return;
41
+ }
42
+ resolve(stdout?.trim() || null);
43
+ });
44
+ });
45
+ }
46
+
47
+ // ==================== CONTENT EXTRACTION ====================
48
+
49
+ const PATTERNS = {
50
+ architecture: [
51
+ /\b(?:architecture|designed|structured|pattern|approach)\b.*?(?:uses?|is|with)\b/i,
52
+ /\b(?:created|implemented|refactored|built|set up)\b/i,
53
+ /\b(?:decided?\s+to|going\s+with|chose|opted?\s+for|using)\b/i,
54
+ ],
55
+ error: [
56
+ /\b(?:fixed|resolved|solved)\s+(?:by|with|using)\b/i,
57
+ /\b(?:the\s+)?(?:solution|fix|root\s*cause|bug)\s+(?:was|is)\b/i,
58
+ ],
59
+ learning: [
60
+ /\b(?:learned|discovered|turns?\s+out|figured\s+out|realized)\b/i,
61
+ /\b(?:TIL|today\s+I\s+learned)\b/i,
62
+ ],
63
+ preference: [
64
+ /\b(?:always|never|prefer|don't\s+like|should\s+always)\b/i,
65
+ ],
66
+ note: [
67
+ /\b(?:important|remember|key\s+point|crucial|note)\s*:/i,
68
+ ],
69
+ };
70
+
71
+ /**
72
+ * Extract high-salience content from session messages
73
+ * @param {string[]} messages - Array of "role: content" strings
74
+ * @returns {Array<{title: string, content: string, category: string}>}
75
+ */
76
+ function extractMemories(messages) {
77
+ const extracted = [];
78
+ const seen = new Set();
79
+
80
+ for (const msg of messages) {
81
+ if (!msg.startsWith("assistant:")) continue;
82
+ const text = msg.slice("assistant:".length).trim();
83
+ if (text.length < 20) continue;
84
+
85
+ for (const [category, patterns] of Object.entries(PATTERNS)) {
86
+ for (const pattern of patterns) {
87
+ if (pattern.test(text)) {
88
+ const title = text.slice(0, 80).replace(/["\n]/g, " ").trim();
89
+ if (seen.has(title)) break;
90
+ seen.add(title);
91
+
92
+ extracted.push({
93
+ title,
94
+ content: text.slice(0, 500),
95
+ category,
96
+ });
97
+ break;
98
+ }
99
+ }
100
+ if (extracted.length >= 5) break;
101
+ }
102
+ if (extracted.length >= 5) break;
103
+ }
104
+
105
+ return extracted;
106
+ }
107
+
108
+ // ==================== SESSION FILE READER ====================
109
+
110
+ /**
111
+ * Read recent messages from a session JSONL file
112
+ * @param {string} sessionFilePath
113
+ * @returns {Promise<string[]>} Array of "role: content" strings
114
+ */
115
+ async function getRecentMessages(sessionFilePath) {
116
+ try {
117
+ const content = await fs.readFile(sessionFilePath, "utf-8");
118
+ const lines = content.trim().split("\n");
119
+ const recentLines = lines.slice(-30);
120
+
121
+ const messages = [];
122
+ for (const line of recentLines) {
123
+ try {
124
+ const entry = JSON.parse(line);
125
+ if (entry.type === "message" && entry.message) {
126
+ const msg = entry.message;
127
+ if ((msg.role === "user" || msg.role === "assistant") && msg.content) {
128
+ const text = Array.isArray(msg.content)
129
+ ? msg.content.find((c) => c.type === "text")?.text
130
+ : msg.content;
131
+ if (text && !text.startsWith("/")) {
132
+ messages.push(`${msg.role}: ${text}`);
133
+ }
134
+ }
135
+ }
136
+ } catch {
137
+ // Skip invalid lines
138
+ }
139
+ }
140
+ return messages;
141
+ } catch {
142
+ return [];
143
+ }
144
+ }
145
+
146
+ // ==================== EVENT HANDLERS ====================
147
+
148
+ /**
149
+ * Handle command:new — extract memories from ending session
150
+ */
151
+ async function onSessionEnd(event) {
152
+ const context = event.context || {};
153
+ const sessionEntry = context.previousSessionEntry || context.sessionEntry || {};
154
+ const sessionFile = sessionEntry.sessionFile;
155
+
156
+ if (!sessionFile) {
157
+ console.log("[cortex-memory] No session file found, skipping extraction");
158
+ return;
159
+ }
160
+
161
+ const messages = await getRecentMessages(sessionFile);
162
+ if (messages.length === 0) {
163
+ console.log("[cortex-memory] No messages to extract");
164
+ return;
165
+ }
166
+
167
+ const memories = extractMemories(messages);
168
+ if (memories.length === 0) {
169
+ console.log("[cortex-memory] No high-salience content found");
170
+ return;
171
+ }
172
+
173
+ let saved = 0;
174
+ for (const mem of memories) {
175
+ const result = await callCortex("remember", {
176
+ title: mem.title,
177
+ content: mem.content,
178
+ category: mem.category,
179
+ project: "clawdbot",
180
+ scope: "global",
181
+ importance: "high",
182
+ tags: "auto-extracted,clawdbot-hook",
183
+ });
184
+ if (result) saved++;
185
+ }
186
+
187
+ console.log(`[cortex-memory] Saved ${saved}/${memories.length} memories from session`);
188
+ }
189
+
190
+ /**
191
+ * Handle agent:bootstrap — inject past context into agent
192
+ */
193
+ async function onBootstrap(event) {
194
+ const context = event.context || {};
195
+ if (!Array.isArray(context.bootstrapFiles)) return;
196
+
197
+ const result = await callCortex("get_context", {
198
+ query: "clawdbot session context",
199
+ format: "summary",
200
+ });
201
+
202
+ if (!result || result.length < 20) {
203
+ console.log("[cortex-memory] No context to inject");
204
+ return;
205
+ }
206
+
207
+ context.bootstrapFiles.push({
208
+ name: "CORTEX_MEMORY.md",
209
+ content: `# Past Session Context (from ShieldCortex)\n\n${result}`,
210
+ });
211
+
212
+ console.log("[cortex-memory] Injected past context into bootstrap");
213
+ }
214
+
215
+ /**
216
+ * Handle command events — check for keyword triggers
217
+ */
218
+ async function onKeywordTrigger(event) {
219
+ if (event.action === "new" || event.action === "stop") return;
220
+
221
+ const context = event.context || {};
222
+ const sessionEntry = context.sessionEntry || {};
223
+ const lastMessage = context.lastUserMessage || sessionEntry.lastUserMessage;
224
+ if (!lastMessage || typeof lastMessage !== "string") return;
225
+
226
+ const lower = lastMessage.toLowerCase();
227
+ const triggers = ["remember this", "don't forget", "dont forget"];
228
+ const triggered = triggers.some((t) => lower.includes(t));
229
+ if (!triggered) return;
230
+
231
+ let content = lastMessage;
232
+ for (const t of triggers) {
233
+ const idx = lower.indexOf(t);
234
+ if (idx !== -1) {
235
+ content = lastMessage.slice(idx + t.length).replace(/^[:\s]+/, "").trim();
236
+ break;
237
+ }
238
+ }
239
+
240
+ if (content.length < 5) return;
241
+
242
+ const title = content.slice(0, 80).replace(/["\n]/g, " ").trim();
243
+
244
+ const result = await callCortex("remember", {
245
+ title,
246
+ content: content.slice(0, 500),
247
+ category: "note",
248
+ project: "clawdbot",
249
+ scope: "global",
250
+ importance: "critical",
251
+ tags: "keyword-trigger,clawdbot-hook",
252
+ });
253
+
254
+ if (result) {
255
+ event.messages.push(`Saved to Cortex memory: "${title}"`);
256
+ console.log(`[cortex-memory] Keyword trigger saved: ${title}`);
257
+ }
258
+ }
259
+
260
+ // ==================== MAIN HANDLER ====================
261
+
262
+ const cortexMemoryHandler = async (event) => {
263
+ try {
264
+ if (event.type === "command" && event.action === "new") {
265
+ await onSessionEnd(event);
266
+ } else if (event.type === "agent" && event.action === "bootstrap") {
267
+ await onBootstrap(event);
268
+ } else if (event.type === "command") {
269
+ await onKeywordTrigger(event);
270
+ }
271
+ } catch (err) {
272
+ console.error(
273
+ "[cortex-memory] Error:",
274
+ err instanceof Error ? err.message : String(err)
275
+ );
276
+ }
277
+ };
278
+
279
+ export default cortexMemoryHandler;
package/package.json ADDED
@@ -0,0 +1,73 @@
1
+ {
2
+ "name": "shieldcortex",
3
+ "version": "2.0.0",
4
+ "description": "Security layer for AI agent memory — firewall, trust scoring, sensitivity classification, and audit for any memory backend",
5
+ "main": "dist/index.js",
6
+ "type": "module",
7
+ "scripts": {
8
+ "build": "tsc",
9
+ "build:all": "tsc && cd dashboard && npm run build",
10
+ "start": "node dist/index.js",
11
+ "start:api": "node dist/index.js --mode api",
12
+ "start:dashboard": "node dist/index.js --dashboard",
13
+ "dev": "tsx src/index.ts",
14
+ "dev:api": "tsx src/index.ts --mode api",
15
+ "dev:dashboard": "tsx src/index.ts --dashboard",
16
+ "watch": "tsc --watch",
17
+ "test": "node --experimental-vm-modules node_modules/jest/bin/jest.js",
18
+ "test:watch": "node --experimental-vm-modules node_modules/jest/bin/jest.js --watch",
19
+ "test:coverage": "node --experimental-vm-modules node_modules/jest/bin/jest.js --coverage",
20
+ "audit:security": "npm audit --audit-level=moderate",
21
+ "prepublishOnly": "npm run build"
22
+ },
23
+ "keywords": [
24
+ "claude",
25
+ "mcp",
26
+ "memory",
27
+ "ai",
28
+ "context"
29
+ ],
30
+ "author": "Michael Kyriacou",
31
+ "license": "MIT",
32
+ "repository": {
33
+ "type": "git",
34
+ "url": "git+https://github.com/mkdelta221/shieldcortex.git"
35
+ },
36
+ "homepage": "https://github.com/mkdelta221/shieldcortex#readme",
37
+ "bugs": {
38
+ "url": "https://github.com/mkdelta221/shieldcortex/issues"
39
+ },
40
+ "engines": {
41
+ "node": ">=18.0.0"
42
+ },
43
+ "dependencies": {
44
+ "@huggingface/transformers": "^3.7.2",
45
+ "@modelcontextprotocol/sdk": "^1.0.0",
46
+ "better-sqlite3": "^11.0.0",
47
+ "cors": "^2.8.5",
48
+ "express": "^4.21.0",
49
+ "ws": "^8.18.0",
50
+ "zod": "^3.23.0"
51
+ },
52
+ "devDependencies": {
53
+ "@types/better-sqlite3": "^7.6.11",
54
+ "@types/cors": "^2.8.17",
55
+ "@types/express": "^5.0.0",
56
+ "@types/jest": "^30.0.0",
57
+ "@types/node": "^22.0.0",
58
+ "@types/ws": "^8.5.13",
59
+ "jest": "^30.2.0",
60
+ "ts-jest": "^29.4.6",
61
+ "tsx": "^4.19.0",
62
+ "typescript": "^5.6.0"
63
+ },
64
+ "bin": {
65
+ "shieldcortex": "dist/index.js"
66
+ },
67
+ "files": [
68
+ "dist",
69
+ "dashboard",
70
+ "hooks",
71
+ "scripts"
72
+ ]
73
+ }