memento-mcp-server 0.1.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 (555) hide show
  1. package/.cursor/rules/cache-management.mdc +171 -0
  2. package/.cursor/rules/database-schema.mdc +344 -0
  3. package/.cursor/rules/deployment.mdc +596 -0
  4. package/.cursor/rules/error-logging.mdc +298 -0
  5. package/.cursor/rules/forgetting-algorithms.mdc +426 -0
  6. package/.cursor/rules/http-server.mdc +432 -0
  7. package/.cursor/rules/hybrid-search.mdc +424 -0
  8. package/.cursor/rules/implementation.mdc +369 -0
  9. package/.cursor/rules/lightweight-embedding.mdc +178 -0
  10. package/.cursor/rules/mcp-client-development.mdc +0 -0
  11. package/.cursor/rules/mcp-server-development.mdc +0 -0
  12. package/.cursor/rules/mcp-tools-architecture.mdc +205 -0
  13. package/.cursor/rules/memento-memory-rule.mdc +8 -0
  14. package/.cursor/rules/memento-project-overview.mdc +0 -0
  15. package/.cursor/rules/memory-algorithms.mdc +502 -0
  16. package/.cursor/rules/monitoring.mdc +622 -0
  17. package/.cursor/rules/performance-alerts.mdc +537 -0
  18. package/.cursor/rules/performance-monitoring.mdc +345 -0
  19. package/.cursor/rules/performance-optimization.mdc +563 -0
  20. package/.cursor/rules/project-structure.mdc +310 -0
  21. package/.cursor/rules/testing.mdc +473 -0
  22. package/.dockerignore +15 -0
  23. package/.eslintrc.json +34 -0
  24. package/.github/ISSUE_TEMPLATE/bug_report.md +51 -0
  25. package/.github/ISSUE_TEMPLATE/feature_request.md +45 -0
  26. package/.github/ISSUE_TEMPLATE/question.md +31 -0
  27. package/.github/PULL_REQUEST_TEMPLATE.md +97 -0
  28. package/AGENTS.md +28 -0
  29. package/CHANGELOG.md +416 -0
  30. package/CODE_OF_CONDUCT.md +62 -0
  31. package/CONTRIBUTING.md +165 -0
  32. package/DOCKER_SETUP_GUIDE.md +84 -0
  33. package/Dockerfile +90 -0
  34. package/INSTALL.en.md +303 -0
  35. package/INSTALL.md +303 -0
  36. package/README.en.md +330 -0
  37. package/README.md +427 -0
  38. package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +1068 -0
  39. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +46 -0
  40. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +48 -0
  41. package/dist/algorithms/forgetting-algorithm.d.ts +90 -0
  42. package/dist/algorithms/forgetting-algorithm.d.ts.map +1 -0
  43. package/dist/algorithms/forgetting-algorithm.js +160 -0
  44. package/dist/algorithms/forgetting-algorithm.js.map +1 -0
  45. package/dist/algorithms/hybrid-search-engine.d.ts +108 -0
  46. package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -0
  47. package/dist/algorithms/hybrid-search-engine.js +384 -0
  48. package/dist/algorithms/hybrid-search-engine.js.map +1 -0
  49. package/dist/algorithms/search-engine.d.ts +64 -0
  50. package/dist/algorithms/search-engine.d.ts.map +1 -0
  51. package/dist/algorithms/search-engine.js +304 -0
  52. package/dist/algorithms/search-engine.js.map +1 -0
  53. package/dist/algorithms/search-ranking.d.ts +145 -0
  54. package/dist/algorithms/search-ranking.d.ts.map +1 -0
  55. package/dist/algorithms/search-ranking.js +311 -0
  56. package/dist/algorithms/search-ranking.js.map +1 -0
  57. package/dist/algorithms/spaced-repetition.d.ts +83 -0
  58. package/dist/algorithms/spaced-repetition.d.ts.map +1 -0
  59. package/dist/algorithms/spaced-repetition.js +153 -0
  60. package/dist/algorithms/spaced-repetition.js.map +1 -0
  61. package/dist/algorithms/vector-search-engine.d.ts +96 -0
  62. package/dist/algorithms/vector-search-engine.d.ts.map +1 -0
  63. package/dist/algorithms/vector-search-engine.js +410 -0
  64. package/dist/algorithms/vector-search-engine.js.map +1 -0
  65. package/dist/client/index.d.ts +55 -0
  66. package/dist/client/index.d.ts.map +1 -0
  67. package/dist/client/index.js +179 -0
  68. package/dist/client/index.js.map +1 -0
  69. package/dist/config/index.d.ts +20 -0
  70. package/dist/config/index.d.ts.map +1 -0
  71. package/dist/config/index.js +87 -0
  72. package/dist/config/index.js.map +1 -0
  73. package/dist/database/init.d.ts +7 -0
  74. package/dist/database/init.d.ts.map +1 -0
  75. package/dist/database/init.js +117 -0
  76. package/dist/database/init.js.map +1 -0
  77. package/dist/database/migrate.d.ts +6 -0
  78. package/dist/database/migrate.d.ts.map +1 -0
  79. package/dist/database/migrate.js +84 -0
  80. package/dist/database/migrate.js.map +1 -0
  81. package/dist/database/schema.sql +159 -0
  82. package/dist/npm-client/context-injector.d.ts +106 -0
  83. package/dist/npm-client/context-injector.d.ts.map +1 -0
  84. package/dist/npm-client/context-injector.js +296 -0
  85. package/dist/npm-client/context-injector.js.map +1 -0
  86. package/dist/npm-client/index.d.ts +42 -0
  87. package/dist/npm-client/index.d.ts.map +1 -0
  88. package/dist/npm-client/index.js +43 -0
  89. package/dist/npm-client/index.js.map +1 -0
  90. package/dist/npm-client/memento-client.d.ts +114 -0
  91. package/dist/npm-client/memento-client.d.ts.map +1 -0
  92. package/dist/npm-client/memento-client.js +391 -0
  93. package/dist/npm-client/memento-client.js.map +1 -0
  94. package/dist/npm-client/memory-manager.d.ts +137 -0
  95. package/dist/npm-client/memory-manager.d.ts.map +1 -0
  96. package/dist/npm-client/memory-manager.js +341 -0
  97. package/dist/npm-client/memory-manager.js.map +1 -0
  98. package/dist/npm-client/types.d.ts +216 -0
  99. package/dist/npm-client/types.d.ts.map +1 -0
  100. package/dist/npm-client/types.js +44 -0
  101. package/dist/npm-client/types.js.map +1 -0
  102. package/dist/npm-client/utils.d.ts +91 -0
  103. package/dist/npm-client/utils.d.ts.map +1 -0
  104. package/dist/npm-client/utils.js +351 -0
  105. package/dist/npm-client/utils.js.map +1 -0
  106. package/dist/scripts/copy-assets.d.ts +3 -0
  107. package/dist/scripts/copy-assets.d.ts.map +1 -0
  108. package/dist/scripts/copy-assets.js +31 -0
  109. package/dist/scripts/copy-assets.js.map +1 -0
  110. package/dist/server/http-server.d.ts +28 -0
  111. package/dist/server/http-server.d.ts.map +1 -0
  112. package/dist/server/http-server.js +930 -0
  113. package/dist/server/http-server.js.map +1 -0
  114. package/dist/server/index-backup.d.ts +5 -0
  115. package/dist/server/index-backup.d.ts.map +1 -0
  116. package/dist/server/index-backup.js +793 -0
  117. package/dist/server/index-backup.js.map +1 -0
  118. package/dist/server/index-refactored.d.ts +6 -0
  119. package/dist/server/index-refactored.d.ts.map +1 -0
  120. package/dist/server/index-refactored.js +206 -0
  121. package/dist/server/index-refactored.js.map +1 -0
  122. package/dist/server/index.d.ts +12 -0
  123. package/dist/server/index.d.ts.map +1 -0
  124. package/dist/server/index.js +301 -0
  125. package/dist/server/index.js.map +1 -0
  126. package/dist/server/simple-mcp-server.d.ts +8 -0
  127. package/dist/server/simple-mcp-server.d.ts.map +1 -0
  128. package/dist/server/simple-mcp-server.js +152 -0
  129. package/dist/server/simple-mcp-server.js.map +1 -0
  130. package/dist/services/async-optimizer.d.ts +136 -0
  131. package/dist/services/async-optimizer.d.ts.map +1 -0
  132. package/dist/services/async-optimizer.js +406 -0
  133. package/dist/services/async-optimizer.js.map +1 -0
  134. package/dist/services/batch-scheduler.d.ts +156 -0
  135. package/dist/services/batch-scheduler.d.ts.map +1 -0
  136. package/dist/services/batch-scheduler.js +612 -0
  137. package/dist/services/batch-scheduler.js.map +1 -0
  138. package/dist/services/cache-service.d.ts +168 -0
  139. package/dist/services/cache-service.d.ts.map +1 -0
  140. package/dist/services/cache-service.js +360 -0
  141. package/dist/services/cache-service.js.map +1 -0
  142. package/dist/services/database-optimizer.d.ts +110 -0
  143. package/dist/services/database-optimizer.d.ts.map +1 -0
  144. package/dist/services/database-optimizer.js +369 -0
  145. package/dist/services/database-optimizer.js.map +1 -0
  146. package/dist/services/embedding-provider-factory.d.ts +62 -0
  147. package/dist/services/embedding-provider-factory.d.ts.map +1 -0
  148. package/dist/services/embedding-provider-factory.js +152 -0
  149. package/dist/services/embedding-provider-factory.js.map +1 -0
  150. package/dist/services/embedding-service.d.ts +95 -0
  151. package/dist/services/embedding-service.d.ts.map +1 -0
  152. package/dist/services/embedding-service.js +276 -0
  153. package/dist/services/embedding-service.js.map +1 -0
  154. package/dist/services/error-logging-service.d.ts +134 -0
  155. package/dist/services/error-logging-service.d.ts.map +1 -0
  156. package/dist/services/error-logging-service.js +271 -0
  157. package/dist/services/error-logging-service.js.map +1 -0
  158. package/dist/services/forgetting-policy-service.d.ts +94 -0
  159. package/dist/services/forgetting-policy-service.d.ts.map +1 -0
  160. package/dist/services/forgetting-policy-service.js +233 -0
  161. package/dist/services/forgetting-policy-service.js.map +1 -0
  162. package/dist/services/gemini-embedding-service.d.ts +82 -0
  163. package/dist/services/gemini-embedding-service.d.ts.map +1 -0
  164. package/dist/services/gemini-embedding-service.js +232 -0
  165. package/dist/services/gemini-embedding-service.js.map +1 -0
  166. package/dist/services/lightweight-embedding-service.d.ts +95 -0
  167. package/dist/services/lightweight-embedding-service.d.ts.map +1 -0
  168. package/dist/services/lightweight-embedding-service.js +263 -0
  169. package/dist/services/lightweight-embedding-service.js.map +1 -0
  170. package/dist/services/memory-embedding-service.d.ts +69 -0
  171. package/dist/services/memory-embedding-service.d.ts.map +1 -0
  172. package/dist/services/memory-embedding-service.js +223 -0
  173. package/dist/services/memory-embedding-service.js.map +1 -0
  174. package/dist/services/minilm-embedding-service.d.ts +92 -0
  175. package/dist/services/minilm-embedding-service.d.ts.map +1 -0
  176. package/dist/services/minilm-embedding-service.js +216 -0
  177. package/dist/services/minilm-embedding-service.js.map +1 -0
  178. package/dist/services/performance-alert-service.d.ts +142 -0
  179. package/dist/services/performance-alert-service.d.ts.map +1 -0
  180. package/dist/services/performance-alert-service.js +366 -0
  181. package/dist/services/performance-alert-service.js.map +1 -0
  182. package/dist/services/performance-monitor.d.ts +144 -0
  183. package/dist/services/performance-monitor.d.ts.map +1 -0
  184. package/dist/services/performance-monitor.js +416 -0
  185. package/dist/services/performance-monitor.js.map +1 -0
  186. package/dist/services/performance-monitoring-integration.d.ts +77 -0
  187. package/dist/services/performance-monitoring-integration.d.ts.map +1 -0
  188. package/dist/services/performance-monitoring-integration.js +177 -0
  189. package/dist/services/performance-monitoring-integration.js.map +1 -0
  190. package/dist/services/unified-embedding-service.d.ts +75 -0
  191. package/dist/services/unified-embedding-service.d.ts.map +1 -0
  192. package/dist/services/unified-embedding-service.js +211 -0
  193. package/dist/services/unified-embedding-service.js.map +1 -0
  194. package/dist/test/debug-http-v2.d.ts +5 -0
  195. package/dist/test/debug-http-v2.d.ts.map +1 -0
  196. package/dist/test/debug-http-v2.js +28 -0
  197. package/dist/test/debug-http-v2.js.map +1 -0
  198. package/dist/test/performance-benchmark.d.ts +57 -0
  199. package/dist/test/performance-benchmark.d.ts.map +1 -0
  200. package/dist/test/performance-benchmark.js +427 -0
  201. package/dist/test/performance-benchmark.js.map +1 -0
  202. package/dist/test/test-alerts-direct.d.ts +7 -0
  203. package/dist/test/test-alerts-direct.d.ts.map +1 -0
  204. package/dist/test/test-alerts-direct.js +101 -0
  205. package/dist/test/test-alerts-direct.js.map +1 -0
  206. package/dist/test/test-batch-scheduler.d.ts +2 -0
  207. package/dist/test/test-batch-scheduler.d.ts.map +1 -0
  208. package/dist/test/test-batch-scheduler.js +156 -0
  209. package/dist/test/test-batch-scheduler.js.map +1 -0
  210. package/dist/test/test-client.d.ts +5 -0
  211. package/dist/test/test-client.d.ts.map +1 -0
  212. package/dist/test/test-client.js +86 -0
  213. package/dist/test/test-client.js.map +1 -0
  214. package/dist/test/test-embedding.d.ts +6 -0
  215. package/dist/test/test-embedding.d.ts.map +1 -0
  216. package/dist/test/test-embedding.js +142 -0
  217. package/dist/test/test-embedding.js.map +1 -0
  218. package/dist/test/test-error-logging.d.ts +7 -0
  219. package/dist/test/test-error-logging.d.ts.map +1 -0
  220. package/dist/test/test-error-logging.js +105 -0
  221. package/dist/test/test-error-logging.js.map +1 -0
  222. package/dist/test/test-forgetting.d.ts +6 -0
  223. package/dist/test/test-forgetting.d.ts.map +1 -0
  224. package/dist/test/test-forgetting.js +154 -0
  225. package/dist/test/test-forgetting.js.map +1 -0
  226. package/dist/test/test-gemini-embedding.d.ts +7 -0
  227. package/dist/test/test-gemini-embedding.d.ts.map +1 -0
  228. package/dist/test/test-gemini-embedding.js +134 -0
  229. package/dist/test/test-gemini-embedding.js.map +1 -0
  230. package/dist/test/test-http-server-v2-simple.d.ts +6 -0
  231. package/dist/test/test-http-server-v2-simple.d.ts.map +1 -0
  232. package/dist/test/test-http-server-v2-simple.js +131 -0
  233. package/dist/test/test-http-server-v2-simple.js.map +1 -0
  234. package/dist/test/test-http-server-v2.d.ts +7 -0
  235. package/dist/test/test-http-server-v2.d.ts.map +1 -0
  236. package/dist/test/test-http-server-v2.js +529 -0
  237. package/dist/test/test-http-server-v2.js.map +1 -0
  238. package/dist/test/test-lightweight-embedding.d.ts +6 -0
  239. package/dist/test/test-lightweight-embedding.d.ts.map +1 -0
  240. package/dist/test/test-lightweight-embedding.js +189 -0
  241. package/dist/test/test-lightweight-embedding.js.map +1 -0
  242. package/dist/test/test-m1-completion.d.ts +7 -0
  243. package/dist/test/test-m1-completion.d.ts.map +1 -0
  244. package/dist/test/test-m1-completion.js +124 -0
  245. package/dist/test/test-m1-completion.js.map +1 -0
  246. package/dist/test/test-memory-injection-prompt.d.ts +2 -0
  247. package/dist/test/test-memory-injection-prompt.d.ts.map +1 -0
  248. package/dist/test/test-memory-injection-prompt.js +299 -0
  249. package/dist/test/test-memory-injection-prompt.js.map +1 -0
  250. package/dist/test/test-performance-alerts.d.ts +7 -0
  251. package/dist/test/test-performance-alerts.d.ts.map +1 -0
  252. package/dist/test/test-performance-alerts.js +109 -0
  253. package/dist/test/test-performance-alerts.js.map +1 -0
  254. package/dist/test/test-performance-monitor.d.ts +2 -0
  255. package/dist/test/test-performance-monitor.d.ts.map +1 -0
  256. package/dist/test/test-performance-monitor.js +182 -0
  257. package/dist/test/test-performance-monitor.js.map +1 -0
  258. package/dist/test/test-performance-monitoring.d.ts +6 -0
  259. package/dist/test/test-performance-monitoring.d.ts.map +1 -0
  260. package/dist/test/test-performance-monitoring.js +156 -0
  261. package/dist/test/test-performance-monitoring.js.map +1 -0
  262. package/dist/test/test-search.d.ts +5 -0
  263. package/dist/test/test-search.d.ts.map +1 -0
  264. package/dist/test/test-search.js +141 -0
  265. package/dist/test/test-search.js.map +1 -0
  266. package/dist/test/test-simple-alerts.d.ts +6 -0
  267. package/dist/test/test-simple-alerts.d.ts.map +1 -0
  268. package/dist/test/test-simple-alerts.js +106 -0
  269. package/dist/test/test-simple-alerts.js.map +1 -0
  270. package/dist/test/test-vector-search-engine.d.ts +2 -0
  271. package/dist/test/test-vector-search-engine.d.ts.map +1 -0
  272. package/dist/test/test-vector-search-engine.js +225 -0
  273. package/dist/test/test-vector-search-engine.js.map +1 -0
  274. package/dist/tools/base-tool.d.ts +64 -0
  275. package/dist/tools/base-tool.d.ts.map +1 -0
  276. package/dist/tools/base-tool.js +158 -0
  277. package/dist/tools/base-tool.js.map +1 -0
  278. package/dist/tools/cleanup-memory-tool.d.ts +10 -0
  279. package/dist/tools/cleanup-memory-tool.d.ts.map +1 -0
  280. package/dist/tools/cleanup-memory-tool.js +66 -0
  281. package/dist/tools/cleanup-memory-tool.js.map +1 -0
  282. package/dist/tools/database-optimize-tool.d.ts +10 -0
  283. package/dist/tools/database-optimize-tool.d.ts.map +1 -0
  284. package/dist/tools/database-optimize-tool.js +64 -0
  285. package/dist/tools/database-optimize-tool.js.map +1 -0
  286. package/dist/tools/error-stats.d.ts +93 -0
  287. package/dist/tools/error-stats.d.ts.map +1 -0
  288. package/dist/tools/error-stats.js +115 -0
  289. package/dist/tools/error-stats.js.map +1 -0
  290. package/dist/tools/forget-tool.d.ts +63 -0
  291. package/dist/tools/forget-tool.d.ts.map +1 -0
  292. package/dist/tools/forget-tool.js +340 -0
  293. package/dist/tools/forget-tool.js.map +1 -0
  294. package/dist/tools/forgetting-stats-tool.d.ts +10 -0
  295. package/dist/tools/forgetting-stats-tool.d.ts.map +1 -0
  296. package/dist/tools/forgetting-stats-tool.js +37 -0
  297. package/dist/tools/forgetting-stats-tool.js.map +1 -0
  298. package/dist/tools/index.d.ts +33 -0
  299. package/dist/tools/index.d.ts.map +1 -0
  300. package/dist/tools/index.js +55 -0
  301. package/dist/tools/index.js.map +1 -0
  302. package/dist/tools/memory-injection-prompt.d.ts +31 -0
  303. package/dist/tools/memory-injection-prompt.d.ts.map +1 -0
  304. package/dist/tools/memory-injection-prompt.js +203 -0
  305. package/dist/tools/memory-injection-prompt.js.map +1 -0
  306. package/dist/tools/performance-alerts.d.ts +127 -0
  307. package/dist/tools/performance-alerts.d.ts.map +1 -0
  308. package/dist/tools/performance-alerts.js +208 -0
  309. package/dist/tools/performance-alerts.js.map +1 -0
  310. package/dist/tools/performance-stats-tool.d.ts +10 -0
  311. package/dist/tools/performance-stats-tool.d.ts.map +1 -0
  312. package/dist/tools/performance-stats-tool.js +38 -0
  313. package/dist/tools/performance-stats-tool.js.map +1 -0
  314. package/dist/tools/pin-tool.d.ts +39 -0
  315. package/dist/tools/pin-tool.d.ts.map +1 -0
  316. package/dist/tools/pin-tool.js +211 -0
  317. package/dist/tools/pin-tool.js.map +1 -0
  318. package/dist/tools/recall-tool.d.ts +27 -0
  319. package/dist/tools/recall-tool.d.ts.map +1 -0
  320. package/dist/tools/recall-tool.js +335 -0
  321. package/dist/tools/recall-tool.js.map +1 -0
  322. package/dist/tools/remember-tool.d.ts +10 -0
  323. package/dist/tools/remember-tool.d.ts.map +1 -0
  324. package/dist/tools/remember-tool.js +101 -0
  325. package/dist/tools/remember-tool.js.map +1 -0
  326. package/dist/tools/resolve-error.d.ts +54 -0
  327. package/dist/tools/resolve-error.d.ts.map +1 -0
  328. package/dist/tools/resolve-error.js +63 -0
  329. package/dist/tools/resolve-error.js.map +1 -0
  330. package/dist/tools/tool-registry.d.ts +134 -0
  331. package/dist/tools/tool-registry.d.ts.map +1 -0
  332. package/dist/tools/tool-registry.js +337 -0
  333. package/dist/tools/tool-registry.js.map +1 -0
  334. package/dist/tools/types.d.ts +56 -0
  335. package/dist/tools/types.d.ts.map +1 -0
  336. package/dist/tools/types.js +23 -0
  337. package/dist/tools/types.js.map +1 -0
  338. package/dist/tools/unpin-tool.d.ts +43 -0
  339. package/dist/tools/unpin-tool.d.ts.map +1 -0
  340. package/dist/tools/unpin-tool.js +233 -0
  341. package/dist/tools/unpin-tool.js.map +1 -0
  342. package/dist/types/embedding.types.d.ts +65 -0
  343. package/dist/types/embedding.types.d.ts.map +1 -0
  344. package/dist/types/embedding.types.js +6 -0
  345. package/dist/types/embedding.types.js.map +1 -0
  346. package/dist/types/index.d.ts +103 -0
  347. package/dist/types/index.d.ts.map +1 -0
  348. package/dist/types/index.js +5 -0
  349. package/dist/types/index.js.map +1 -0
  350. package/dist/utils/database.d.ts +62 -0
  351. package/dist/utils/database.d.ts.map +1 -0
  352. package/dist/utils/database.js +399 -0
  353. package/dist/utils/database.js.map +1 -0
  354. package/dist/utils/stopwords.d.ts +18 -0
  355. package/dist/utils/stopwords.d.ts.map +1 -0
  356. package/dist/utils/stopwords.js +117 -0
  357. package/dist/utils/stopwords.js.map +1 -0
  358. package/docker-compose.dev.yml +50 -0
  359. package/docker-compose.prod.yml +77 -0
  360. package/docker-compose.yml +43 -0
  361. package/docs/en/Memento-Goals.md +217 -0
  362. package/docs/en/Memento-M1-DetailSpecs.md +130 -0
  363. package/docs/en/Memento-Milestones.md +135 -0
  364. package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +177 -0
  365. package/docs/en/api-reference.md +658 -0
  366. package/docs/en/architecture.md +1302 -0
  367. package/docs/en/developer-guide.md +1005 -0
  368. package/docs/en/user-manual.md +595 -0
  369. package/docs/ko/Memento-Goals.md +217 -0
  370. package/docs/ko/Memento-M1-DetailSpecs.md +130 -0
  371. package/docs/ko/Memento-Milestones.md +134 -0
  372. package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +177 -0
  373. package/docs/ko/api-reference.md +658 -0
  374. package/docs/ko/architecture.md +1302 -0
  375. package/docs/ko/developer-guide.md +1006 -0
  376. package/docs/ko/embedding-api-reference.md +122 -0
  377. package/docs/ko/embedding-configuration.md +62 -0
  378. package/docs/ko/embedding-performance-benchmark.md +62 -0
  379. package/docs/ko/embedding-service-guide.md +314 -0
  380. package/docs/ko/user-manual.md +595 -0
  381. package/env.example +49 -0
  382. package/install.sh +191 -0
  383. package/mcp-http-client.js +218 -0
  384. package/mcp.json +0 -0
  385. package/package.json +125 -0
  386. package/packages/mcp-client/docs/API-REFERENCE.md +560 -0
  387. package/packages/mcp-client/docs/BEST-PRACTICES.md +564 -0
  388. package/packages/mcp-client/docs/MIGRATION-GUIDE.md +344 -0
  389. package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +476 -0
  390. package/packages/mcp-client/docs/TROUBLESHOOTING.md +564 -0
  391. package/packages/mcp-client/package-lock.json +907 -0
  392. package/packages/mcp-client/package.json +58 -0
  393. package/packages/mcp-client/performance-optimizer.js +428 -0
  394. package/packages/mcp-client/test-basic.js +65 -0
  395. package/packages/mcp-client/test-integration.js +366 -0
  396. package/scripts/auto-setup.js +234 -0
  397. package/scripts/backup-daily.bat +28 -0
  398. package/scripts/backup-embeddings.js +108 -0
  399. package/scripts/check-db-integrity.js +93 -0
  400. package/scripts/debug-embeddings.js +184 -0
  401. package/scripts/direct-sql-migration.sql +36 -0
  402. package/scripts/docker-migration.sh +105 -0
  403. package/scripts/fix-migration.js +93 -0
  404. package/scripts/fix-vector-dimensions.js +206 -0
  405. package/scripts/migrate-embedding-data.js +307 -0
  406. package/scripts/regenerate-embeddings.js +144 -0
  407. package/scripts/restore-legacy.ps1 +60 -0
  408. package/scripts/restore-legacy.sh +62 -0
  409. package/scripts/run-migration.js +122 -0
  410. package/scripts/safe-migration.js +150 -0
  411. package/scripts/simple-migrate.js +41 -0
  412. package/scripts/simple-update.js +123 -0
  413. package/scripts/start-container.sh +10 -0
  414. package/src/algorithms/forgetting-algorithm.spec.ts +538 -0
  415. package/src/algorithms/forgetting-algorithm.ts +243 -0
  416. package/src/algorithms/hybrid-search-engine.spec.ts +484 -0
  417. package/src/algorithms/hybrid-search-engine.ts +489 -0
  418. package/src/algorithms/search-engine.spec.ts +429 -0
  419. package/src/algorithms/search-engine.ts +392 -0
  420. package/src/algorithms/search-ranking.spec.ts +293 -0
  421. package/src/algorithms/search-ranking.ts +407 -0
  422. package/src/algorithms/spaced-repetition.spec.ts +510 -0
  423. package/src/algorithms/spaced-repetition.ts +238 -0
  424. package/src/algorithms/vector-search-engine.ts +505 -0
  425. package/src/client/index.spec.ts +427 -0
  426. package/src/client/index.ts +222 -0
  427. package/src/config/index.spec.ts +339 -0
  428. package/src/config/index.ts +106 -0
  429. package/src/database/init.spec.ts +239 -0
  430. package/src/database/init.ts +130 -0
  431. package/src/database/migrate.spec.ts +293 -0
  432. package/src/database/migrate.ts +94 -0
  433. package/src/database/migrations/001_add_embedding_metadata.sql +29 -0
  434. package/src/database/schema.sql +159 -0
  435. package/src/npm-client/context-injector.spec.ts +335 -0
  436. package/src/npm-client/context-injector.ts +412 -0
  437. package/src/npm-client/index.spec.ts +108 -0
  438. package/src/npm-client/index.ts +96 -0
  439. package/src/npm-client/memento-client.spec.ts +549 -0
  440. package/src/npm-client/memento-client.ts +501 -0
  441. package/src/npm-client/memory-manager.spec.ts +374 -0
  442. package/src/npm-client/memory-manager.ts +414 -0
  443. package/src/npm-client/types.spec.ts +427 -0
  444. package/src/npm-client/types.ts +296 -0
  445. package/src/npm-client/utils.spec.ts +355 -0
  446. package/src/npm-client/utils.ts +423 -0
  447. package/src/scripts/copy-assets.js +37 -0
  448. package/src/server/http-server.spec.ts +648 -0
  449. package/src/server/http-server.ts +1030 -0
  450. package/src/server/index-backup.ts +875 -0
  451. package/src/server/index-refactored.ts +237 -0
  452. package/src/server/index.spec.ts +281 -0
  453. package/src/server/index.ts +347 -0
  454. package/src/server/simple-mcp-server.spec.ts +207 -0
  455. package/src/server/simple-mcp-server.ts +173 -0
  456. package/src/services/async-optimizer.spec.ts +569 -0
  457. package/src/services/async-optimizer.ts +484 -0
  458. package/src/services/batch-scheduler.ts +759 -0
  459. package/src/services/cache-service.spec.ts +372 -0
  460. package/src/services/cache-service.ts +434 -0
  461. package/src/services/database-optimizer.spec.ts +344 -0
  462. package/src/services/database-optimizer.ts +450 -0
  463. package/src/services/embedding-provider-factory.ts +173 -0
  464. package/src/services/embedding-service.spec.ts +342 -0
  465. package/src/services/embedding-service.ts +333 -0
  466. package/src/services/error-logging-service.spec.ts +416 -0
  467. package/src/services/error-logging-service.ts +383 -0
  468. package/src/services/forgetting-policy-service.spec.ts +140 -0
  469. package/src/services/forgetting-policy-service.ts +334 -0
  470. package/src/services/gemini-embedding-service.spec.ts +463 -0
  471. package/src/services/gemini-embedding-service.ts +283 -0
  472. package/src/services/lightweight-embedding-service.spec.ts +458 -0
  473. package/src/services/lightweight-embedding-service.ts +324 -0
  474. package/src/services/memory-embedding-service.spec.ts +417 -0
  475. package/src/services/memory-embedding-service.ts +289 -0
  476. package/src/services/minilm-embedding-service.spec.ts +104 -0
  477. package/src/services/minilm-embedding-service.ts +262 -0
  478. package/src/services/performance-alert-service.spec.ts +517 -0
  479. package/src/services/performance-alert-service.ts +477 -0
  480. package/src/services/performance-monitor.spec.ts +401 -0
  481. package/src/services/performance-monitor.ts +532 -0
  482. package/src/services/performance-monitoring-integration.spec.ts +478 -0
  483. package/src/services/performance-monitoring-integration.ts.bak +276 -0
  484. package/src/services/unified-embedding-service.spec.ts +224 -0
  485. package/src/services/unified-embedding-service.ts +255 -0
  486. package/src/test/debug-http-v2.ts +30 -0
  487. package/src/test/embedding-integration-test.spec.ts +295 -0
  488. package/src/test/embedding-integration-test.ts +295 -0
  489. package/src/test/embedding-performance-benchmark.spec.ts +354 -0
  490. package/src/test/embedding-performance-benchmark.ts +312 -0
  491. package/src/test/performance-benchmark.ts +565 -0
  492. package/src/test/test-alerts-direct.ts +136 -0
  493. package/src/test/test-batch-scheduler-simple.spec.ts +122 -0
  494. package/src/test/test-batch-scheduler.spec.ts +453 -0
  495. package/src/test/test-batch-scheduler.ts +182 -0
  496. package/src/test/test-client.ts +97 -0
  497. package/src/test/test-embedding.ts +153 -0
  498. package/src/test/test-error-handling.spec.ts +575 -0
  499. package/src/test/test-error-logging.ts +117 -0
  500. package/src/test/test-forgetting.ts +162 -0
  501. package/src/test/test-gemini-embedding.ts +159 -0
  502. package/src/test/test-http-server-v2-simple.ts +147 -0
  503. package/src/test/test-http-server-v2.ts +586 -0
  504. package/src/test/test-hybrid-search-engine.spec.ts +521 -0
  505. package/src/test/test-integration-fixed.spec.ts +612 -0
  506. package/src/test/test-integration.spec.ts +463 -0
  507. package/src/test/test-lightweight-embedding.ts +208 -0
  508. package/src/test/test-m1-completion.spec.ts +614 -0
  509. package/src/test/test-m1-completion.ts +141 -0
  510. package/src/test/test-m1-integration.spec.ts +514 -0
  511. package/src/test/test-memory-injection-prompt.spec.ts +650 -0
  512. package/src/test/test-memory-injection-prompt.ts +391 -0
  513. package/src/test/test-performance-alerts.ts +125 -0
  514. package/src/test/test-performance-monitor-updates.spec.ts +490 -0
  515. package/src/test/test-performance-monitor.spec.ts +284 -0
  516. package/src/test/test-performance-monitor.ts +228 -0
  517. package/src/test/test-performance-monitoring.ts +171 -0
  518. package/src/test/test-search.ts +151 -0
  519. package/src/test/test-simple-alerts.ts +136 -0
  520. package/src/test/test-vector-search-engine.spec.ts +408 -0
  521. package/src/test/test-vector-search-engine.ts +303 -0
  522. package/src/tools/base-tool.ts +189 -0
  523. package/src/tools/cleanup-memory-tool.ts +77 -0
  524. package/src/tools/database-optimize-tool.ts +79 -0
  525. package/src/tools/error-stats.ts +119 -0
  526. package/src/tools/forget-tool.spec.ts +613 -0
  527. package/src/tools/forget-tool.ts +454 -0
  528. package/src/tools/forgetting-stats-tool.ts +47 -0
  529. package/src/tools/index.ts +71 -0
  530. package/src/tools/memory-injection-prompt.ts +257 -0
  531. package/src/tools/performance-alerts.ts +226 -0
  532. package/src/tools/performance-stats-tool.ts +48 -0
  533. package/src/tools/pin-tool.spec.ts +497 -0
  534. package/src/tools/pin-tool.ts +277 -0
  535. package/src/tools/recall-tool.spec.ts +475 -0
  536. package/src/tools/recall-tool.ts +389 -0
  537. package/src/tools/remember-tool.spec.ts +469 -0
  538. package/src/tools/remember-tool.ts +112 -0
  539. package/src/tools/resolve-error.ts +69 -0
  540. package/src/tools/tool-registry.ts +417 -0
  541. package/src/tools/types.ts +63 -0
  542. package/src/tools/unpin-tool.spec.ts +549 -0
  543. package/src/tools/unpin-tool.ts +306 -0
  544. package/src/types/embedding.types.ts +78 -0
  545. package/src/types/index.spec.ts +420 -0
  546. package/src/types/index.ts +117 -0
  547. package/src/utils/database.spec.ts +77 -0
  548. package/src/utils/database.ts +458 -0
  549. package/src/utils/stopwords.ts +128 -0
  550. package/start-docker-setup.bat +38 -0
  551. package/static/logo.png +0 -0
  552. package/static/memento_logo.svg +2 -0
  553. package/test-docker.js +103 -0
  554. package/tsconfig.json +46 -0
  555. package/vitest.config.ts +23 -0
@@ -0,0 +1,412 @@
1
+ /**
2
+ * ContextInjector - AI Agent의 컨텍스트에 관련 기억을 주입하는 클래스
3
+ * 대화나 작업 중에 관련된 기억을 자동으로 찾아 컨텍스트에 주입합니다.
4
+ *
5
+ * @example
6
+ * ```typescript
7
+ * import { ContextInjector } from '@memento/client';
8
+ *
9
+ * const injector = new ContextInjector(client);
10
+ *
11
+ * // 컨텍스트 주입
12
+ * const context = await injector.inject({
13
+ * query: 'React Hook에 대해 질문',
14
+ * tokenBudget: 1000
15
+ * });
16
+ *
17
+ * console.log(context.content);
18
+ * ```
19
+ */
20
+
21
+ import { MementoClient } from './memento-client.js';
22
+ import type {
23
+ ContextInjectionResult,
24
+ SearchResult,
25
+ MemoryItem
26
+ } from './types.js';
27
+
28
+ export interface ContextInjectionOptions {
29
+ /** 최대 검색 결과 수 (기본값: 10) */
30
+ maxResults?: number;
31
+ /** 토큰 예산 (기본값: 1200) */
32
+ tokenBudget?: number;
33
+ /** 컨텍스트 타입 */
34
+ contextType?: 'conversation' | 'task' | 'general';
35
+ /** 기억 타입 필터 */
36
+ memoryTypes?: Array<'working' | 'episodic' | 'semantic' | 'procedural'>;
37
+ /** 최근 기간 필터 (일 단위) */
38
+ recentDays?: number;
39
+ /** 중요도 임계값 (0-1) */
40
+ importanceThreshold?: number;
41
+ /** 고정된 기억만 포함할지 여부 */
42
+ pinnedOnly?: boolean;
43
+ }
44
+
45
+ export class ContextInjector {
46
+ constructor(private client: MementoClient) {}
47
+
48
+ /**
49
+ * 컨텍스트 주입
50
+ */
51
+ async inject(
52
+ query: string,
53
+ options: ContextInjectionOptions = {}
54
+ ): Promise<ContextInjectionResult> {
55
+ const startTime = Date.now();
56
+
57
+ const {
58
+ maxResults = 10,
59
+ tokenBudget = 1200,
60
+ contextType = 'general',
61
+ memoryTypes,
62
+ recentDays,
63
+ importanceThreshold = 0.3,
64
+ pinnedOnly = false
65
+ } = options;
66
+
67
+ // 1. 관련 기억 검색
68
+ const searchResult = await this.searchRelevantMemories(query, {
69
+ maxResults,
70
+ memoryTypes: memoryTypes || undefined,
71
+ recentDays: recentDays || undefined,
72
+ importanceThreshold,
73
+ pinnedOnly
74
+ });
75
+
76
+ // 2. 토큰 예산에 맞게 기억 압축
77
+ const compressedMemories = await this.compressMemories(
78
+ searchResult.items as MemoryItem[],
79
+ tokenBudget
80
+ );
81
+
82
+ // 3. 컨텍스트 생성
83
+ const context = this.generateContext(
84
+ query,
85
+ compressedMemories,
86
+ contextType
87
+ );
88
+
89
+ const searchTime = Date.now() - startTime;
90
+
91
+ return {
92
+ role: 'system',
93
+ content: context,
94
+ metadata: {
95
+ memories_used: compressedMemories.length,
96
+ token_count: this.estimateTokenCount(context),
97
+ search_time: searchTime
98
+ }
99
+ };
100
+ }
101
+
102
+ /**
103
+ * 관련 기억 검색
104
+ */
105
+ private async searchRelevantMemories(
106
+ query: string,
107
+ options: {
108
+ maxResults: number;
109
+ memoryTypes?: Array<'working' | 'episodic' | 'semantic' | 'procedural'>;
110
+ recentDays?: number;
111
+ importanceThreshold: number;
112
+ pinnedOnly: boolean;
113
+ }
114
+ ): Promise<SearchResult> {
115
+ const filters: any = {};
116
+
117
+ // 메모리 타입 필터
118
+ if (options.memoryTypes && options.memoryTypes.length > 0) {
119
+ filters.type = options.memoryTypes;
120
+ }
121
+
122
+ // 최근 기간 필터
123
+ if (options.recentDays) {
124
+ const timeFrom = new Date();
125
+ timeFrom.setDate(timeFrom.getDate() - options.recentDays);
126
+ filters.time_from = timeFrom.toISOString();
127
+ }
128
+
129
+ // 고정된 기억만
130
+ if (options.pinnedOnly) {
131
+ filters.pinned = true;
132
+ }
133
+
134
+ // 하이브리드 검색 사용 (의미적 유사도 + 키워드 매칭)
135
+ const hybridResult = await this.client.hybridSearch({
136
+ query,
137
+ filters,
138
+ limit: options.maxResults,
139
+ vectorWeight: 0.7, // 의미적 유사도에 더 가중치
140
+ textWeight: 0.3
141
+ });
142
+
143
+ // HybridSearchResult를 SearchResult로 변환
144
+ return {
145
+ items: hybridResult.items.map(item => ({
146
+ ...item,
147
+ score: item.finalScore
148
+ })),
149
+ total_count: hybridResult.total_count,
150
+ query_time: hybridResult.query_time
151
+ };
152
+ }
153
+
154
+ /**
155
+ * 기억 압축 (토큰 예산에 맞게)
156
+ */
157
+ private async compressMemories(
158
+ memories: MemoryItem[],
159
+ tokenBudget: number
160
+ ): Promise<MemoryItem[]> {
161
+ if (memories.length === 0) return [];
162
+
163
+ // 중요도와 점수 기준으로 정렬
164
+ const sortedMemories = memories.sort((a, b) => {
165
+ const scoreA = (a as any).score || 0;
166
+ const scoreB = (b as any).score || 0;
167
+ return (scoreB + a.importance) - (scoreA + b.importance);
168
+ });
169
+
170
+ const compressed: MemoryItem[] = [];
171
+ let currentTokens = 0;
172
+
173
+ for (const memory of sortedMemories) {
174
+ const memoryTokens = this.estimateTokenCount(memory.content);
175
+
176
+ if (currentTokens + memoryTokens <= tokenBudget) {
177
+ compressed.push(memory);
178
+ currentTokens += memoryTokens;
179
+ } else {
180
+ // 토큰 예산이 부족하면 더 짧은 요약으로 시도
181
+ const summary = this.summarizeMemory(memory);
182
+ const summaryTokens = this.estimateTokenCount(summary);
183
+
184
+ if (currentTokens + summaryTokens <= tokenBudget) {
185
+ compressed.push({
186
+ ...memory,
187
+ content: summary
188
+ });
189
+ currentTokens += summaryTokens;
190
+ }
191
+ }
192
+ }
193
+
194
+ return compressed;
195
+ }
196
+
197
+ /**
198
+ * 기억 요약
199
+ */
200
+ private summarizeMemory(memory: MemoryItem): string {
201
+ const content = memory.content;
202
+ const maxLength = 200; // 최대 200자로 제한
203
+
204
+ if (content.length <= maxLength) {
205
+ return content;
206
+ }
207
+
208
+ // 문장 단위로 자르기
209
+ const sentences = content.split(/[.!?]+/);
210
+ let summary = '';
211
+
212
+ for (const sentence of sentences) {
213
+ if (summary.length + sentence.length <= maxLength) {
214
+ summary += sentence + '.';
215
+ } else {
216
+ break;
217
+ }
218
+ }
219
+
220
+ return summary || content.substring(0, maxLength) + '...';
221
+ }
222
+
223
+ /**
224
+ * 컨텍스트 생성
225
+ */
226
+ private generateContext(
227
+ query: string,
228
+ memories: MemoryItem[],
229
+ contextType: string
230
+ ): string {
231
+ if (memories.length === 0) {
232
+ return this.generateEmptyContext(query, contextType);
233
+ }
234
+
235
+ const contextHeader = this.getContextHeader(contextType);
236
+ const memorySections = this.formatMemories(memories);
237
+ const contextFooter = this.getContextFooter(query, memories.length);
238
+
239
+ return `${contextHeader}\n\n${memorySections}\n\n${contextFooter}`;
240
+ }
241
+
242
+ /**
243
+ * 컨텍스트 헤더 생성
244
+ */
245
+ private getContextHeader(contextType: string): string {
246
+ const headers = {
247
+ conversation: '💬 관련 대화 기록:',
248
+ task: '📋 관련 작업 기록:',
249
+ general: '🧠 관련 기억:'
250
+ };
251
+
252
+ return headers[contextType as keyof typeof headers] || headers.general;
253
+ }
254
+
255
+ /**
256
+ * 기억 포맷팅
257
+ */
258
+ private formatMemories(memories: MemoryItem[]): string {
259
+ return memories.map((memory, index) => {
260
+ const typeEmoji = this.getTypeEmoji(memory.type);
261
+ const importanceBar = this.getImportanceBar(memory.importance);
262
+ const tags = memory.tags && memory.tags.length > 0
263
+ ? ` [${memory.tags.join(', ')}]`
264
+ : '';
265
+ const score = (memory as any).score ? ` (관련도: ${((memory as any).score * 100).toFixed(1)}%)` : '';
266
+
267
+ return `${index + 1}. ${typeEmoji} ${memory.content}${tags}${score}\n ${importanceBar} ${memory.created_at}`;
268
+ }).join('\n\n');
269
+ }
270
+
271
+ /**
272
+ * 타입별 이모지
273
+ */
274
+ private getTypeEmoji(type: string): string {
275
+ const emojis = {
276
+ working: '⚡',
277
+ episodic: '📅',
278
+ semantic: '🧠',
279
+ procedural: '🔧'
280
+ };
281
+ return emojis[type as keyof typeof emojis] || '📝';
282
+ }
283
+
284
+ /**
285
+ * 중요도 바 생성
286
+ */
287
+ private getImportanceBar(importance: number): string {
288
+ const filled = Math.round(importance * 5);
289
+ const empty = 5 - filled;
290
+ return '★'.repeat(filled) + '☆'.repeat(empty);
291
+ }
292
+
293
+ /**
294
+ * 컨텍스트 푸터 생성
295
+ */
296
+ private getContextFooter(query: string, memoryCount: number): string {
297
+ return `\n💡 위의 ${memoryCount}개 기억을 참고하여 "${query}"에 대해 답변해주세요.`;
298
+ }
299
+
300
+ /**
301
+ * 빈 컨텍스트 생성
302
+ */
303
+ private generateEmptyContext(query: string, contextType: string): string {
304
+ const messages = {
305
+ conversation: '💬 관련 대화 기록이 없습니다.',
306
+ task: '📋 관련 작업 기록이 없습니다.',
307
+ general: '🧠 관련 기억이 없습니다.'
308
+ };
309
+
310
+ return `${messages[contextType as keyof typeof messages] || messages.general}\n\n💡 "${query}"에 대해 새로운 정보로 답변해주세요.`;
311
+ }
312
+
313
+ /**
314
+ * 토큰 수 추정 (간단한 추정)
315
+ */
316
+ private estimateTokenCount(text: string): number {
317
+ // 대략적인 토큰 수 추정 (한국어: 1글자 = 1토큰, 영어: 1단어 = 1.3토큰)
318
+ const koreanChars = (text.match(/[가-힣]/g) || []).length;
319
+ const englishWords = (text.match(/[a-zA-Z]+/g) || []).length;
320
+ const otherChars = text.length - koreanChars - (text.match(/[a-zA-Z]/g) || []).length;
321
+
322
+ return koreanChars + Math.ceil(englishWords * 1.3) + otherChars;
323
+ }
324
+
325
+ // ============================================================================
326
+ // 고급 컨텍스트 주입 기능
327
+ // ============================================================================
328
+
329
+ /**
330
+ * 대화 컨텍스트 주입
331
+ */
332
+ async injectConversationContext(
333
+ query: string,
334
+ tokenBudget: number = 1000
335
+ ): Promise<ContextInjectionResult> {
336
+ return await this.inject(query, {
337
+ tokenBudget,
338
+ contextType: 'conversation',
339
+ memoryTypes: ['episodic', 'semantic'],
340
+ recentDays: 30,
341
+ importanceThreshold: 0.4
342
+ });
343
+ }
344
+
345
+ /**
346
+ * 작업 컨텍스트 주입
347
+ */
348
+ async injectTaskContext(
349
+ query: string,
350
+ projectId?: string,
351
+ tokenBudget: number = 1200
352
+ ): Promise<ContextInjectionResult> {
353
+ const filters: any = {};
354
+ if (projectId) {
355
+ filters.project_id = projectId;
356
+ }
357
+
358
+ return await this.inject(query, {
359
+ tokenBudget,
360
+ contextType: 'task',
361
+ memoryTypes: ['procedural', 'semantic'],
362
+ importanceThreshold: 0.5,
363
+ pinnedOnly: false
364
+ });
365
+ }
366
+
367
+ /**
368
+ * 학습 컨텍스트 주입
369
+ */
370
+ async injectLearningContext(
371
+ topic: string,
372
+ tokenBudget: number = 1500
373
+ ): Promise<ContextInjectionResult> {
374
+ return await this.inject(topic, {
375
+ tokenBudget,
376
+ contextType: 'general',
377
+ memoryTypes: ['semantic', 'procedural'],
378
+ importanceThreshold: 0.6,
379
+ pinnedOnly: false
380
+ });
381
+ }
382
+
383
+ /**
384
+ * 프로젝트 컨텍스트 주입
385
+ */
386
+ async injectProjectContext(
387
+ projectId: string,
388
+ query: string,
389
+ tokenBudget: number = 1000
390
+ ): Promise<ContextInjectionResult> {
391
+ const searchResult = await this.client.recall(query, {
392
+ project_id: projectId
393
+ }, 10);
394
+
395
+ const compressedMemories = await this.compressMemories(
396
+ searchResult.items as MemoryItem[],
397
+ tokenBudget
398
+ );
399
+
400
+ const context = this.generateContext(query, compressedMemories, 'task');
401
+
402
+ return {
403
+ role: 'system',
404
+ content: context,
405
+ metadata: {
406
+ memories_used: compressedMemories.length,
407
+ token_count: this.estimateTokenCount(context),
408
+ search_time: searchResult.query_time
409
+ }
410
+ };
411
+ }
412
+ }
@@ -0,0 +1,108 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import {
3
+ MementoClient,
4
+ MemoryManager,
5
+ ContextInjector,
6
+ MementoError,
7
+ ConnectionError,
8
+ AuthenticationError,
9
+ ValidationError,
10
+ NotFoundError
11
+ } from './index.js';
12
+
13
+ describe('NPM Client Index', () => {
14
+ describe('exports', () => {
15
+ it('MementoClient를 내보내야 함', () => {
16
+ expect(MementoClient).toBeDefined();
17
+ expect(typeof MementoClient).toBe('function');
18
+ });
19
+
20
+ it('MemoryManager를 내보내야 함', () => {
21
+ expect(MemoryManager).toBeDefined();
22
+ expect(typeof MemoryManager).toBe('function');
23
+ });
24
+
25
+ it('ContextInjector를 내보내야 함', () => {
26
+ expect(ContextInjector).toBeDefined();
27
+ expect(typeof ContextInjector).toBe('function');
28
+ });
29
+
30
+ it('에러 클래스들을 내보내야 함', () => {
31
+ expect(MementoError).toBeDefined();
32
+ expect(ConnectionError).toBeDefined();
33
+ expect(AuthenticationError).toBeDefined();
34
+ expect(ValidationError).toBeDefined();
35
+ expect(NotFoundError).toBeDefined();
36
+ });
37
+ });
38
+
39
+ describe('MementoClient', () => {
40
+ it('인스턴스를 생성할 수 있어야 함', () => {
41
+ const client = new MementoClient();
42
+ expect(client).toBeInstanceOf(MementoClient);
43
+ });
44
+
45
+ it('옵션과 함께 인스턴스를 생성할 수 있어야 함', () => {
46
+ const options = {
47
+ serverUrl: 'http://localhost:8080',
48
+ apiKey: 'test-key'
49
+ };
50
+ const client = new MementoClient(options);
51
+ expect(client).toBeInstanceOf(MementoClient);
52
+ });
53
+ });
54
+
55
+ describe('MemoryManager', () => {
56
+ it('MementoClient와 함께 인스턴스를 생성할 수 있어야 함', () => {
57
+ const client = new MementoClient();
58
+ const manager = new MemoryManager(client);
59
+ expect(manager).toBeInstanceOf(MemoryManager);
60
+ });
61
+ });
62
+
63
+ describe('ContextInjector', () => {
64
+ it('MementoClient와 함께 인스턴스를 생성할 수 있어야 함', () => {
65
+ const client = new MementoClient();
66
+ const injector = new ContextInjector(client);
67
+ expect(injector).toBeInstanceOf(ContextInjector);
68
+ });
69
+ });
70
+
71
+ describe('Error Classes', () => {
72
+ it('MementoError가 올바르게 작동해야 함', () => {
73
+ const error = new MementoError('Test error', 'TEST_ERROR');
74
+ expect(error).toBeInstanceOf(Error);
75
+ expect(error).toBeInstanceOf(MementoError);
76
+ expect(error.message).toBe('Test error');
77
+ expect(error.code).toBe('TEST_ERROR');
78
+ });
79
+
80
+ it('ConnectionError가 올바르게 작동해야 함', () => {
81
+ const error = new ConnectionError('Connection failed');
82
+ expect(error).toBeInstanceOf(MementoError);
83
+ expect(error.message).toBe('Connection failed');
84
+ expect(error.code).toBe('CONNECTION_ERROR');
85
+ });
86
+
87
+ it('AuthenticationError가 올바르게 작동해야 함', () => {
88
+ const error = new AuthenticationError('Invalid API key');
89
+ expect(error).toBeInstanceOf(MementoError);
90
+ expect(error.message).toBe('Invalid API key');
91
+ expect(error.code).toBe('AUTHENTICATION_ERROR');
92
+ });
93
+
94
+ it('ValidationError가 올바르게 작동해야 함', () => {
95
+ const error = new ValidationError('Invalid input');
96
+ expect(error).toBeInstanceOf(MementoError);
97
+ expect(error.message).toBe('Invalid input');
98
+ expect(error.code).toBe('VALIDATION_ERROR');
99
+ });
100
+
101
+ it('NotFoundError가 올바르게 작동해야 함', () => {
102
+ const error = new NotFoundError('Memory not found');
103
+ expect(error).toBeInstanceOf(MementoError);
104
+ expect(error.message).toBe('Memory not found');
105
+ expect(error.code).toBe('NOT_FOUND');
106
+ });
107
+ });
108
+ });
@@ -0,0 +1,96 @@
1
+ /**
2
+ * @memento/client - Memento MCP Server 클라이언트 라이브러리
3
+ *
4
+ * AI Agent의 기억을 관리하고 컨텍스트를 주입하는 TypeScript 라이브러리입니다.
5
+ *
6
+ * @example
7
+ * ```typescript
8
+ * import { MementoClient, MemoryManager, ContextInjector } from '@memento/client';
9
+ *
10
+ * // 클라이언트 생성 및 연결
11
+ * const client = new MementoClient({
12
+ * serverUrl: 'http://localhost:8080',
13
+ * apiKey: 'your-api-key'
14
+ * });
15
+ *
16
+ * await client.connect();
17
+ *
18
+ * // 기억 관리
19
+ * const manager = new MemoryManager(client);
20
+ * const memory = await manager.create({
21
+ * content: 'React Hook에 대해 학습했다',
22
+ * type: 'episodic',
23
+ * importance: 0.8
24
+ * });
25
+ *
26
+ * // 컨텍스트 주입
27
+ * const injector = new ContextInjector(client);
28
+ * const context = await injector.inject('React Hook 질문', {
29
+ * tokenBudget: 1000
30
+ * });
31
+ * ```
32
+ *
33
+ * @packageDocumentation
34
+ */
35
+
36
+ // 메인 클래스들
37
+ export { MementoClient } from './memento-client.js';
38
+ export { MemoryManager } from './memory-manager.js';
39
+ export { ContextInjector } from './context-injector.js';
40
+
41
+ // 에러 클래스들
42
+ export {
43
+ MementoError,
44
+ ConnectionError,
45
+ AuthenticationError,
46
+ ValidationError,
47
+ NotFoundError
48
+ } from './types.js';
49
+
50
+ // 타입들
51
+ export type {
52
+ // 클라이언트 설정
53
+ MementoClientOptions,
54
+
55
+ // 기억 관련
56
+ MemoryItem,
57
+ CreateMemoryParams,
58
+ UpdateMemoryParams,
59
+ MemoryType,
60
+ PrivacyScope,
61
+
62
+ // 검색 관련
63
+ SearchFilters,
64
+ SearchResult,
65
+ MemorySearchResult,
66
+ HybridSearchParams,
67
+ HybridSearchResult,
68
+ HybridSearchItem,
69
+
70
+ // MCP Tools 응답
71
+ RememberResult,
72
+ PinResult,
73
+ ForgetResult,
74
+ LinkResult,
75
+ ExportResult,
76
+ FeedbackResult,
77
+
78
+ // 컨텍스트 주입
79
+ ContextInjectionParams,
80
+ ContextInjectionResult,
81
+
82
+
83
+ // 이벤트 타입들
84
+ MementoClientEvents,
85
+
86
+ // 유틸리티 타입들
87
+ PaginationParams,
88
+ PaginatedResult,
89
+ HealthCheck
90
+ } from './types.js';
91
+
92
+ // ContextInjector 옵션 타입
93
+ export type { ContextInjectionOptions } from './context-injector.js';
94
+
95
+ // 편의 함수들
96
+ export * from './utils.js';