memento-mcp-server 0.1.0 → 1.7.1

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 (560) hide show
  1. package/INSTALL.en.md +303 -303
  2. package/INSTALL.md +303 -303
  3. package/README.en.md +331 -330
  4. package/README.md +432 -427
  5. package/dist/algorithms/hybrid-search-engine.d.ts +114 -44
  6. package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -1
  7. package/dist/algorithms/hybrid-search-engine.js +261 -235
  8. package/dist/algorithms/hybrid-search-engine.js.map +1 -1
  9. package/dist/algorithms/search-engine.d.ts +2 -14
  10. package/dist/algorithms/search-engine.d.ts.map +1 -1
  11. package/dist/algorithms/search-engine.js +43 -35
  12. package/dist/algorithms/search-engine.js.map +1 -1
  13. package/dist/algorithms/vector-search-engine-migration.d.ts +67 -0
  14. package/dist/algorithms/vector-search-engine-migration.d.ts.map +1 -0
  15. package/dist/algorithms/vector-search-engine-migration.js +196 -0
  16. package/dist/algorithms/vector-search-engine-migration.js.map +1 -0
  17. package/dist/algorithms/vector-search-engine-refactored.d.ts +56 -0
  18. package/dist/algorithms/vector-search-engine-refactored.d.ts.map +1 -0
  19. package/dist/algorithms/vector-search-engine-refactored.js +101 -0
  20. package/dist/algorithms/vector-search-engine-refactored.js.map +1 -0
  21. package/dist/algorithms/vector-search-engine.d.ts +9 -2
  22. package/dist/algorithms/vector-search-engine.d.ts.map +1 -1
  23. package/dist/algorithms/vector-search-engine.js +245 -121
  24. package/dist/algorithms/vector-search-engine.js.map +1 -1
  25. package/dist/client/index.d.ts.map +1 -1
  26. package/dist/client/index.js +34 -11
  27. package/dist/client/index.js.map +1 -1
  28. package/dist/config/environment.d.ts +26 -0
  29. package/dist/config/environment.d.ts.map +1 -0
  30. package/dist/config/environment.js +103 -0
  31. package/dist/config/environment.js.map +1 -0
  32. package/dist/config/index.d.ts.map +1 -1
  33. package/dist/config/index.js +29 -50
  34. package/dist/config/index.js.map +1 -1
  35. package/dist/config/vector-search.config.d.ts +25 -0
  36. package/dist/config/vector-search.config.d.ts.map +1 -0
  37. package/dist/config/vector-search.config.js +40 -0
  38. package/dist/config/vector-search.config.js.map +1 -0
  39. package/dist/database/init.d.ts.map +1 -1
  40. package/dist/database/init.js +154 -17
  41. package/dist/database/init.js.map +1 -1
  42. package/dist/database/migrate.d.ts +2 -1
  43. package/dist/database/migrate.d.ts.map +1 -1
  44. package/dist/database/migrate.js +191 -18
  45. package/dist/database/migrate.js.map +1 -1
  46. package/dist/database/schema.sql +234 -159
  47. package/dist/factories/hybrid-search.factory.d.ts +20 -0
  48. package/dist/factories/hybrid-search.factory.d.ts.map +1 -0
  49. package/dist/factories/hybrid-search.factory.js +57 -0
  50. package/dist/factories/hybrid-search.factory.js.map +1 -0
  51. package/dist/factories/spaced-repetition.factory.d.ts +48 -0
  52. package/dist/factories/spaced-repetition.factory.d.ts.map +1 -0
  53. package/dist/factories/spaced-repetition.factory.js +187 -0
  54. package/dist/factories/spaced-repetition.factory.js.map +1 -0
  55. package/dist/factories/vector-search.factory.d.ts +25 -0
  56. package/dist/factories/vector-search.factory.d.ts.map +1 -0
  57. package/dist/factories/vector-search.factory.js +47 -0
  58. package/dist/factories/vector-search.factory.js.map +1 -0
  59. package/dist/interfaces/database.interface.d.ts +36 -0
  60. package/dist/interfaces/database.interface.d.ts.map +1 -0
  61. package/dist/interfaces/database.interface.js +6 -0
  62. package/dist/interfaces/database.interface.js.map +1 -0
  63. package/dist/interfaces/spaced-repetition.interface.d.ts +63 -0
  64. package/dist/interfaces/spaced-repetition.interface.d.ts.map +1 -0
  65. package/dist/interfaces/spaced-repetition.interface.js +6 -0
  66. package/dist/interfaces/spaced-repetition.interface.js.map +1 -0
  67. package/dist/repositories/vector-performance.repository.d.ts +25 -0
  68. package/dist/repositories/vector-performance.repository.d.ts.map +1 -0
  69. package/dist/repositories/vector-performance.repository.js +134 -0
  70. package/dist/repositories/vector-performance.repository.js.map +1 -0
  71. package/dist/repositories/vector-search.repository.d.ts +43 -0
  72. package/dist/repositories/vector-search.repository.d.ts.map +1 -0
  73. package/dist/repositories/vector-search.repository.js +377 -0
  74. package/dist/repositories/vector-search.repository.js.map +1 -0
  75. package/dist/server/http-server.d.ts.map +1 -1
  76. package/dist/server/http-server.js +25 -24
  77. package/dist/server/http-server.js.map +1 -1
  78. package/dist/server/index.d.ts +1 -0
  79. package/dist/server/index.d.ts.map +1 -1
  80. package/dist/server/index.js +3 -1
  81. package/dist/server/index.js.map +1 -1
  82. package/dist/services/alert-notification-service.d.ts +16 -0
  83. package/dist/services/alert-notification-service.d.ts.map +1 -0
  84. package/dist/services/alert-notification-service.js +44 -0
  85. package/dist/services/alert-notification-service.js.map +1 -0
  86. package/dist/services/async-optimizer.d.ts +62 -8
  87. package/dist/services/async-optimizer.d.ts.map +1 -1
  88. package/dist/services/async-optimizer.js +137 -8
  89. package/dist/services/async-optimizer.js.map +1 -1
  90. package/dist/services/batch-scheduler.d.ts +6 -0
  91. package/dist/services/batch-scheduler.d.ts.map +1 -1
  92. package/dist/services/batch-scheduler.js +59 -19
  93. package/dist/services/batch-scheduler.js.map +1 -1
  94. package/dist/services/cache-service.d.ts +32 -0
  95. package/dist/services/cache-service.d.ts.map +1 -1
  96. package/dist/services/cache-service.js +81 -6
  97. package/dist/services/cache-service.js.map +1 -1
  98. package/dist/services/database-optimizer.js +63 -63
  99. package/dist/services/database-optimizer.js.map +1 -1
  100. package/dist/services/embedding-migration-service.d.ts +24 -0
  101. package/dist/services/embedding-migration-service.d.ts.map +1 -0
  102. package/dist/services/embedding-migration-service.js +360 -0
  103. package/dist/services/embedding-migration-service.js.map +1 -0
  104. package/dist/services/embedding-provider-factory.d.ts +12 -5
  105. package/dist/services/embedding-provider-factory.d.ts.map +1 -1
  106. package/dist/services/embedding-provider-factory.js +107 -26
  107. package/dist/services/embedding-provider-factory.js.map +1 -1
  108. package/dist/services/forgetting-policy-service.js +17 -17
  109. package/dist/services/gemini-embedding-service.d.ts +1 -1
  110. package/dist/services/gemini-embedding-service.d.ts.map +1 -1
  111. package/dist/services/gemini-embedding-service.js +25 -18
  112. package/dist/services/gemini-embedding-service.js.map +1 -1
  113. package/dist/services/memory-embedding-service.d.ts +8 -0
  114. package/dist/services/memory-embedding-service.d.ts.map +1 -1
  115. package/dist/services/memory-embedding-service.js +180 -71
  116. package/dist/services/memory-embedding-service.js.map +1 -1
  117. package/dist/services/migration-history-service.d.ts +14 -0
  118. package/dist/services/migration-history-service.d.ts.map +1 -0
  119. package/dist/services/migration-history-service.js +270 -0
  120. package/dist/services/migration-history-service.js.map +1 -0
  121. package/dist/services/migration-monitor-service.d.ts +24 -0
  122. package/dist/services/migration-monitor-service.d.ts.map +1 -0
  123. package/dist/services/migration-monitor-service.js +93 -0
  124. package/dist/services/migration-monitor-service.js.map +1 -0
  125. package/dist/services/model-availability-service.d.ts +22 -0
  126. package/dist/services/model-availability-service.d.ts.map +1 -0
  127. package/dist/services/model-availability-service.js +140 -0
  128. package/dist/services/model-availability-service.js.map +1 -0
  129. package/dist/services/openai-embedding-service.d.ts +36 -0
  130. package/dist/services/openai-embedding-service.d.ts.map +1 -0
  131. package/dist/services/openai-embedding-service.js +192 -0
  132. package/dist/services/openai-embedding-service.js.map +1 -0
  133. package/dist/services/performance-monitor.d.ts +154 -10
  134. package/dist/services/performance-monitor.d.ts.map +1 -1
  135. package/dist/services/performance-monitor.js +446 -60
  136. package/dist/services/performance-monitor.js.map +1 -1
  137. package/dist/services/spaced-repetition/interval-calculation.service.d.ts +38 -0
  138. package/dist/services/spaced-repetition/interval-calculation.service.d.ts.map +1 -0
  139. package/dist/services/spaced-repetition/interval-calculation.service.js +105 -0
  140. package/dist/services/spaced-repetition/interval-calculation.service.js.map +1 -0
  141. package/dist/services/spaced-repetition/optimal-interval.service.d.ts +56 -0
  142. package/dist/services/spaced-repetition/optimal-interval.service.d.ts.map +1 -0
  143. package/dist/services/spaced-repetition/optimal-interval.service.js +163 -0
  144. package/dist/services/spaced-repetition/optimal-interval.service.js.map +1 -0
  145. package/dist/services/spaced-repetition/performance-analysis.service.d.ts +48 -0
  146. package/dist/services/spaced-repetition/performance-analysis.service.d.ts.map +1 -0
  147. package/dist/services/spaced-repetition/performance-analysis.service.js +174 -0
  148. package/dist/services/spaced-repetition/performance-analysis.service.js.map +1 -0
  149. package/dist/services/spaced-repetition/priority-calculation.service.d.ts +53 -0
  150. package/dist/services/spaced-repetition/priority-calculation.service.d.ts.map +1 -0
  151. package/dist/services/spaced-repetition/priority-calculation.service.js +161 -0
  152. package/dist/services/spaced-repetition/priority-calculation.service.js.map +1 -0
  153. package/dist/services/spaced-repetition/recall-probability.service.d.ts +36 -0
  154. package/dist/services/spaced-repetition/recall-probability.service.d.ts.map +1 -0
  155. package/dist/services/spaced-repetition/recall-probability.service.js +88 -0
  156. package/dist/services/spaced-repetition/recall-probability.service.js.map +1 -0
  157. package/dist/services/spaced-repetition/review-scheduling.service.d.ts +43 -0
  158. package/dist/services/spaced-repetition/review-scheduling.service.d.ts.map +1 -0
  159. package/dist/services/spaced-repetition/review-scheduling.service.js +130 -0
  160. package/dist/services/spaced-repetition/review-scheduling.service.js.map +1 -0
  161. package/dist/services/spaced-repetition/spaced-repetition-container.d.ts +69 -0
  162. package/dist/services/spaced-repetition/spaced-repetition-container.d.ts.map +1 -0
  163. package/dist/services/spaced-repetition/spaced-repetition-container.js +136 -0
  164. package/dist/services/spaced-repetition/spaced-repetition-container.js.map +1 -0
  165. package/dist/services/unified-embedding-service.d.ts +3 -0
  166. package/dist/services/unified-embedding-service.d.ts.map +1 -1
  167. package/dist/services/unified-embedding-service.js +58 -62
  168. package/dist/services/unified-embedding-service.js.map +1 -1
  169. package/dist/services/vector-compatibility-service.d.ts +68 -0
  170. package/dist/services/vector-compatibility-service.d.ts.map +1 -0
  171. package/dist/services/vector-compatibility-service.js +373 -0
  172. package/dist/services/vector-compatibility-service.js.map +1 -0
  173. package/dist/services/vector-search/vector-index-manager.d.ts +27 -0
  174. package/dist/services/vector-search/vector-index-manager.d.ts.map +1 -0
  175. package/dist/services/vector-search/vector-index-manager.js +66 -0
  176. package/dist/services/vector-search/vector-index-manager.js.map +1 -0
  177. package/dist/services/vector-search/vector-performance-tester.d.ts +30 -0
  178. package/dist/services/vector-search/vector-performance-tester.d.ts.map +1 -0
  179. package/dist/services/vector-search/vector-performance-tester.js +87 -0
  180. package/dist/services/vector-search/vector-performance-tester.js.map +1 -0
  181. package/dist/services/vector-search/vector-search-container.d.ts +41 -0
  182. package/dist/services/vector-search/vector-search-container.d.ts.map +1 -0
  183. package/dist/services/vector-search/vector-search-container.js +74 -0
  184. package/dist/services/vector-search/vector-search-container.js.map +1 -0
  185. package/dist/services/vector-search/vector-search-facade.d.ts +63 -0
  186. package/dist/services/vector-search/vector-search-facade.d.ts.map +1 -0
  187. package/dist/services/vector-search/vector-search-facade.js +91 -0
  188. package/dist/services/vector-search/vector-search-facade.js.map +1 -0
  189. package/dist/services/vector-search/vector-search-result-normalizer.d.ts +6 -0
  190. package/dist/services/vector-search/vector-search-result-normalizer.d.ts.map +1 -0
  191. package/dist/services/vector-search/vector-search-result-normalizer.js +65 -0
  192. package/dist/services/vector-search/vector-search-result-normalizer.js.map +1 -0
  193. package/dist/services/vector-search/vector-search.service.d.ts +33 -0
  194. package/dist/services/vector-search/vector-search.service.d.ts.map +1 -0
  195. package/dist/services/vector-search/vector-search.service.js +149 -0
  196. package/dist/services/vector-search/vector-search.service.js.map +1 -0
  197. package/dist/tools/forget-tool.js +14 -14
  198. package/dist/tools/pin-tool.js +14 -14
  199. package/dist/tools/unpin-tool.js +21 -21
  200. package/dist/types/alerts.types.d.ts +26 -0
  201. package/dist/types/alerts.types.d.ts.map +1 -0
  202. package/dist/types/alerts.types.js +2 -0
  203. package/dist/types/alerts.types.js.map +1 -0
  204. package/dist/types/embedding-provider-monitoring.types.d.ts +24 -0
  205. package/dist/types/embedding-provider-monitoring.types.d.ts.map +1 -0
  206. package/dist/types/embedding-provider-monitoring.types.js +2 -0
  207. package/dist/types/embedding-provider-monitoring.types.js.map +1 -0
  208. package/dist/types/embedding.types.d.ts +36 -1
  209. package/dist/types/embedding.types.d.ts.map +1 -1
  210. package/dist/types/migration.types.d.ts +131 -0
  211. package/dist/types/migration.types.d.ts.map +1 -0
  212. package/dist/types/migration.types.js +6 -0
  213. package/dist/types/migration.types.js.map +1 -0
  214. package/dist/types/spaced-repetition.types.d.ts +61 -0
  215. package/dist/types/spaced-repetition.types.d.ts.map +1 -0
  216. package/dist/types/spaced-repetition.types.js +6 -0
  217. package/dist/types/spaced-repetition.types.js.map +1 -0
  218. package/dist/types/vector-search.types.d.ts +96 -0
  219. package/dist/types/vector-search.types.d.ts.map +1 -0
  220. package/dist/types/vector-search.types.js +2 -0
  221. package/dist/types/vector-search.types.js.map +1 -0
  222. package/dist/utils/configuration-validator.d.ts +23 -0
  223. package/dist/utils/configuration-validator.d.ts.map +1 -0
  224. package/dist/utils/configuration-validator.js +102 -0
  225. package/dist/utils/configuration-validator.js.map +1 -0
  226. package/dist/utils/database.d.ts.map +1 -1
  227. package/dist/utils/database.js +101 -95
  228. package/dist/utils/database.js.map +1 -1
  229. package/dist/utils/environment-check.d.ts +8 -0
  230. package/dist/utils/environment-check.d.ts.map +1 -0
  231. package/dist/utils/environment-check.js +25 -0
  232. package/dist/utils/environment-check.js.map +1 -0
  233. package/dist/utils/logger.d.ts +8 -0
  234. package/dist/utils/logger.d.ts.map +1 -0
  235. package/dist/utils/logger.js +33 -0
  236. package/dist/utils/logger.js.map +1 -0
  237. package/package.json +139 -125
  238. package/scripts/auto-setup.js +234 -234
  239. package/scripts/backup-daily.bat +28 -28
  240. package/scripts/backup-embeddings.js +108 -108
  241. package/scripts/check-db-integrity.js +93 -93
  242. package/scripts/debug-embeddings.js +184 -184
  243. package/scripts/direct-sql-migration.sql +36 -36
  244. package/scripts/docker-migration.sh +105 -105
  245. package/scripts/fix-migration.js +93 -93
  246. package/scripts/fix-vector-dimensions.js +206 -206
  247. package/scripts/migrate-embedding-data.js +307 -307
  248. package/scripts/regenerate-embeddings.js +144 -144
  249. package/scripts/restore-legacy.ps1 +60 -60
  250. package/scripts/run-migration.js +122 -122
  251. package/scripts/safe-migration.js +150 -150
  252. package/scripts/simple-migrate.js +41 -41
  253. package/scripts/simple-update.js +123 -123
  254. package/src/database/schema.sql +234 -159
  255. package/.cursor/rules/cache-management.mdc +0 -171
  256. package/.cursor/rules/database-schema.mdc +0 -344
  257. package/.cursor/rules/deployment.mdc +0 -596
  258. package/.cursor/rules/error-logging.mdc +0 -298
  259. package/.cursor/rules/forgetting-algorithms.mdc +0 -426
  260. package/.cursor/rules/http-server.mdc +0 -432
  261. package/.cursor/rules/hybrid-search.mdc +0 -424
  262. package/.cursor/rules/implementation.mdc +0 -369
  263. package/.cursor/rules/lightweight-embedding.mdc +0 -178
  264. package/.cursor/rules/mcp-client-development.mdc +0 -0
  265. package/.cursor/rules/mcp-server-development.mdc +0 -0
  266. package/.cursor/rules/mcp-tools-architecture.mdc +0 -205
  267. package/.cursor/rules/memento-memory-rule.mdc +0 -8
  268. package/.cursor/rules/memento-project-overview.mdc +0 -0
  269. package/.cursor/rules/memory-algorithms.mdc +0 -502
  270. package/.cursor/rules/monitoring.mdc +0 -622
  271. package/.cursor/rules/performance-alerts.mdc +0 -537
  272. package/.cursor/rules/performance-monitoring.mdc +0 -345
  273. package/.cursor/rules/performance-optimization.mdc +0 -563
  274. package/.cursor/rules/project-structure.mdc +0 -310
  275. package/.cursor/rules/testing.mdc +0 -473
  276. package/.dockerignore +0 -15
  277. package/.eslintrc.json +0 -34
  278. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -51
  279. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -45
  280. package/.github/ISSUE_TEMPLATE/question.md +0 -31
  281. package/.github/PULL_REQUEST_TEMPLATE.md +0 -97
  282. package/AGENTS.md +0 -28
  283. package/CHANGELOG.md +0 -416
  284. package/CODE_OF_CONDUCT.md +0 -62
  285. package/CONTRIBUTING.md +0 -165
  286. package/DOCKER_SETUP_GUIDE.md +0 -84
  287. package/Dockerfile +0 -90
  288. package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +0 -1068
  289. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +0 -46
  290. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +0 -48
  291. package/dist/server/index-backup.d.ts +0 -5
  292. package/dist/server/index-backup.d.ts.map +0 -1
  293. package/dist/server/index-backup.js +0 -793
  294. package/dist/server/index-backup.js.map +0 -1
  295. package/dist/server/index-refactored.d.ts +0 -6
  296. package/dist/server/index-refactored.d.ts.map +0 -1
  297. package/dist/server/index-refactored.js +0 -206
  298. package/dist/server/index-refactored.js.map +0 -1
  299. package/dist/services/performance-monitoring-integration.d.ts +0 -77
  300. package/dist/services/performance-monitoring-integration.d.ts.map +0 -1
  301. package/dist/services/performance-monitoring-integration.js +0 -177
  302. package/dist/services/performance-monitoring-integration.js.map +0 -1
  303. package/dist/test/debug-http-v2.d.ts +0 -5
  304. package/dist/test/debug-http-v2.d.ts.map +0 -1
  305. package/dist/test/debug-http-v2.js +0 -28
  306. package/dist/test/debug-http-v2.js.map +0 -1
  307. package/dist/test/performance-benchmark.d.ts +0 -57
  308. package/dist/test/performance-benchmark.d.ts.map +0 -1
  309. package/dist/test/performance-benchmark.js +0 -427
  310. package/dist/test/performance-benchmark.js.map +0 -1
  311. package/dist/test/test-alerts-direct.d.ts +0 -7
  312. package/dist/test/test-alerts-direct.d.ts.map +0 -1
  313. package/dist/test/test-alerts-direct.js +0 -101
  314. package/dist/test/test-alerts-direct.js.map +0 -1
  315. package/dist/test/test-batch-scheduler.d.ts +0 -2
  316. package/dist/test/test-batch-scheduler.d.ts.map +0 -1
  317. package/dist/test/test-batch-scheduler.js +0 -156
  318. package/dist/test/test-batch-scheduler.js.map +0 -1
  319. package/dist/test/test-client.d.ts +0 -5
  320. package/dist/test/test-client.d.ts.map +0 -1
  321. package/dist/test/test-client.js +0 -86
  322. package/dist/test/test-client.js.map +0 -1
  323. package/dist/test/test-embedding.d.ts +0 -6
  324. package/dist/test/test-embedding.d.ts.map +0 -1
  325. package/dist/test/test-embedding.js +0 -142
  326. package/dist/test/test-embedding.js.map +0 -1
  327. package/dist/test/test-error-logging.d.ts +0 -7
  328. package/dist/test/test-error-logging.d.ts.map +0 -1
  329. package/dist/test/test-error-logging.js +0 -105
  330. package/dist/test/test-error-logging.js.map +0 -1
  331. package/dist/test/test-forgetting.d.ts +0 -6
  332. package/dist/test/test-forgetting.d.ts.map +0 -1
  333. package/dist/test/test-forgetting.js +0 -154
  334. package/dist/test/test-forgetting.js.map +0 -1
  335. package/dist/test/test-gemini-embedding.d.ts +0 -7
  336. package/dist/test/test-gemini-embedding.d.ts.map +0 -1
  337. package/dist/test/test-gemini-embedding.js +0 -134
  338. package/dist/test/test-gemini-embedding.js.map +0 -1
  339. package/dist/test/test-http-server-v2-simple.d.ts +0 -6
  340. package/dist/test/test-http-server-v2-simple.d.ts.map +0 -1
  341. package/dist/test/test-http-server-v2-simple.js +0 -131
  342. package/dist/test/test-http-server-v2-simple.js.map +0 -1
  343. package/dist/test/test-http-server-v2.d.ts +0 -7
  344. package/dist/test/test-http-server-v2.d.ts.map +0 -1
  345. package/dist/test/test-http-server-v2.js +0 -529
  346. package/dist/test/test-http-server-v2.js.map +0 -1
  347. package/dist/test/test-lightweight-embedding.d.ts +0 -6
  348. package/dist/test/test-lightweight-embedding.d.ts.map +0 -1
  349. package/dist/test/test-lightweight-embedding.js +0 -189
  350. package/dist/test/test-lightweight-embedding.js.map +0 -1
  351. package/dist/test/test-m1-completion.d.ts +0 -7
  352. package/dist/test/test-m1-completion.d.ts.map +0 -1
  353. package/dist/test/test-m1-completion.js +0 -124
  354. package/dist/test/test-m1-completion.js.map +0 -1
  355. package/dist/test/test-memory-injection-prompt.d.ts +0 -2
  356. package/dist/test/test-memory-injection-prompt.d.ts.map +0 -1
  357. package/dist/test/test-memory-injection-prompt.js +0 -299
  358. package/dist/test/test-memory-injection-prompt.js.map +0 -1
  359. package/dist/test/test-performance-alerts.d.ts +0 -7
  360. package/dist/test/test-performance-alerts.d.ts.map +0 -1
  361. package/dist/test/test-performance-alerts.js +0 -109
  362. package/dist/test/test-performance-alerts.js.map +0 -1
  363. package/dist/test/test-performance-monitor.d.ts +0 -2
  364. package/dist/test/test-performance-monitor.d.ts.map +0 -1
  365. package/dist/test/test-performance-monitor.js +0 -182
  366. package/dist/test/test-performance-monitor.js.map +0 -1
  367. package/dist/test/test-performance-monitoring.d.ts +0 -6
  368. package/dist/test/test-performance-monitoring.d.ts.map +0 -1
  369. package/dist/test/test-performance-monitoring.js +0 -156
  370. package/dist/test/test-performance-monitoring.js.map +0 -1
  371. package/dist/test/test-search.d.ts +0 -5
  372. package/dist/test/test-search.d.ts.map +0 -1
  373. package/dist/test/test-search.js +0 -141
  374. package/dist/test/test-search.js.map +0 -1
  375. package/dist/test/test-simple-alerts.d.ts +0 -6
  376. package/dist/test/test-simple-alerts.d.ts.map +0 -1
  377. package/dist/test/test-simple-alerts.js +0 -106
  378. package/dist/test/test-simple-alerts.js.map +0 -1
  379. package/dist/test/test-vector-search-engine.d.ts +0 -2
  380. package/dist/test/test-vector-search-engine.d.ts.map +0 -1
  381. package/dist/test/test-vector-search-engine.js +0 -225
  382. package/dist/test/test-vector-search-engine.js.map +0 -1
  383. package/docker-compose.dev.yml +0 -50
  384. package/docker-compose.prod.yml +0 -77
  385. package/docker-compose.yml +0 -43
  386. package/docs/en/Memento-Goals.md +0 -217
  387. package/docs/en/Memento-M1-DetailSpecs.md +0 -130
  388. package/docs/en/Memento-Milestones.md +0 -135
  389. package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +0 -177
  390. package/docs/en/api-reference.md +0 -658
  391. package/docs/en/architecture.md +0 -1302
  392. package/docs/en/developer-guide.md +0 -1005
  393. package/docs/en/user-manual.md +0 -595
  394. package/docs/ko/Memento-Goals.md +0 -217
  395. package/docs/ko/Memento-M1-DetailSpecs.md +0 -130
  396. package/docs/ko/Memento-Milestones.md +0 -134
  397. package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +0 -177
  398. package/docs/ko/api-reference.md +0 -658
  399. package/docs/ko/architecture.md +0 -1302
  400. package/docs/ko/developer-guide.md +0 -1006
  401. package/docs/ko/embedding-api-reference.md +0 -122
  402. package/docs/ko/embedding-configuration.md +0 -62
  403. package/docs/ko/embedding-performance-benchmark.md +0 -62
  404. package/docs/ko/embedding-service-guide.md +0 -314
  405. package/docs/ko/user-manual.md +0 -595
  406. package/env.example +0 -49
  407. package/install.sh +0 -191
  408. package/mcp-http-client.js +0 -218
  409. package/mcp.json +0 -0
  410. package/packages/mcp-client/docs/API-REFERENCE.md +0 -560
  411. package/packages/mcp-client/docs/BEST-PRACTICES.md +0 -564
  412. package/packages/mcp-client/docs/MIGRATION-GUIDE.md +0 -344
  413. package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +0 -476
  414. package/packages/mcp-client/docs/TROUBLESHOOTING.md +0 -564
  415. package/packages/mcp-client/package-lock.json +0 -907
  416. package/packages/mcp-client/package.json +0 -58
  417. package/packages/mcp-client/performance-optimizer.js +0 -428
  418. package/packages/mcp-client/test-basic.js +0 -65
  419. package/packages/mcp-client/test-integration.js +0 -366
  420. package/src/algorithms/forgetting-algorithm.spec.ts +0 -538
  421. package/src/algorithms/forgetting-algorithm.ts +0 -243
  422. package/src/algorithms/hybrid-search-engine.spec.ts +0 -484
  423. package/src/algorithms/hybrid-search-engine.ts +0 -489
  424. package/src/algorithms/search-engine.spec.ts +0 -429
  425. package/src/algorithms/search-engine.ts +0 -392
  426. package/src/algorithms/search-ranking.spec.ts +0 -293
  427. package/src/algorithms/search-ranking.ts +0 -407
  428. package/src/algorithms/spaced-repetition.spec.ts +0 -510
  429. package/src/algorithms/spaced-repetition.ts +0 -238
  430. package/src/algorithms/vector-search-engine.ts +0 -505
  431. package/src/client/index.spec.ts +0 -427
  432. package/src/client/index.ts +0 -222
  433. package/src/config/index.spec.ts +0 -339
  434. package/src/config/index.ts +0 -106
  435. package/src/database/init.spec.ts +0 -239
  436. package/src/database/init.ts +0 -130
  437. package/src/database/migrate.spec.ts +0 -293
  438. package/src/database/migrate.ts +0 -94
  439. package/src/database/migrations/001_add_embedding_metadata.sql +0 -29
  440. package/src/npm-client/context-injector.spec.ts +0 -335
  441. package/src/npm-client/context-injector.ts +0 -412
  442. package/src/npm-client/index.spec.ts +0 -108
  443. package/src/npm-client/index.ts +0 -96
  444. package/src/npm-client/memento-client.spec.ts +0 -549
  445. package/src/npm-client/memento-client.ts +0 -501
  446. package/src/npm-client/memory-manager.spec.ts +0 -374
  447. package/src/npm-client/memory-manager.ts +0 -414
  448. package/src/npm-client/types.spec.ts +0 -427
  449. package/src/npm-client/types.ts +0 -296
  450. package/src/npm-client/utils.spec.ts +0 -355
  451. package/src/npm-client/utils.ts +0 -423
  452. package/src/scripts/copy-assets.js +0 -37
  453. package/src/server/http-server.spec.ts +0 -648
  454. package/src/server/http-server.ts +0 -1030
  455. package/src/server/index-backup.ts +0 -875
  456. package/src/server/index-refactored.ts +0 -237
  457. package/src/server/index.spec.ts +0 -281
  458. package/src/server/index.ts +0 -347
  459. package/src/server/simple-mcp-server.spec.ts +0 -207
  460. package/src/server/simple-mcp-server.ts +0 -173
  461. package/src/services/async-optimizer.spec.ts +0 -569
  462. package/src/services/async-optimizer.ts +0 -484
  463. package/src/services/batch-scheduler.ts +0 -759
  464. package/src/services/cache-service.spec.ts +0 -372
  465. package/src/services/cache-service.ts +0 -434
  466. package/src/services/database-optimizer.spec.ts +0 -344
  467. package/src/services/database-optimizer.ts +0 -450
  468. package/src/services/embedding-provider-factory.ts +0 -173
  469. package/src/services/embedding-service.spec.ts +0 -342
  470. package/src/services/embedding-service.ts +0 -333
  471. package/src/services/error-logging-service.spec.ts +0 -416
  472. package/src/services/error-logging-service.ts +0 -383
  473. package/src/services/forgetting-policy-service.spec.ts +0 -140
  474. package/src/services/forgetting-policy-service.ts +0 -334
  475. package/src/services/gemini-embedding-service.spec.ts +0 -463
  476. package/src/services/gemini-embedding-service.ts +0 -283
  477. package/src/services/lightweight-embedding-service.spec.ts +0 -458
  478. package/src/services/lightweight-embedding-service.ts +0 -324
  479. package/src/services/memory-embedding-service.spec.ts +0 -417
  480. package/src/services/memory-embedding-service.ts +0 -289
  481. package/src/services/minilm-embedding-service.spec.ts +0 -104
  482. package/src/services/minilm-embedding-service.ts +0 -262
  483. package/src/services/performance-alert-service.spec.ts +0 -517
  484. package/src/services/performance-alert-service.ts +0 -477
  485. package/src/services/performance-monitor.spec.ts +0 -401
  486. package/src/services/performance-monitor.ts +0 -532
  487. package/src/services/performance-monitoring-integration.spec.ts +0 -478
  488. package/src/services/performance-monitoring-integration.ts.bak +0 -276
  489. package/src/services/unified-embedding-service.spec.ts +0 -224
  490. package/src/services/unified-embedding-service.ts +0 -255
  491. package/src/test/debug-http-v2.ts +0 -30
  492. package/src/test/embedding-integration-test.spec.ts +0 -295
  493. package/src/test/embedding-integration-test.ts +0 -295
  494. package/src/test/embedding-performance-benchmark.spec.ts +0 -354
  495. package/src/test/embedding-performance-benchmark.ts +0 -312
  496. package/src/test/performance-benchmark.ts +0 -565
  497. package/src/test/test-alerts-direct.ts +0 -136
  498. package/src/test/test-batch-scheduler-simple.spec.ts +0 -122
  499. package/src/test/test-batch-scheduler.spec.ts +0 -453
  500. package/src/test/test-batch-scheduler.ts +0 -182
  501. package/src/test/test-client.ts +0 -97
  502. package/src/test/test-embedding.ts +0 -153
  503. package/src/test/test-error-handling.spec.ts +0 -575
  504. package/src/test/test-error-logging.ts +0 -117
  505. package/src/test/test-forgetting.ts +0 -162
  506. package/src/test/test-gemini-embedding.ts +0 -159
  507. package/src/test/test-http-server-v2-simple.ts +0 -147
  508. package/src/test/test-http-server-v2.ts +0 -586
  509. package/src/test/test-hybrid-search-engine.spec.ts +0 -521
  510. package/src/test/test-integration-fixed.spec.ts +0 -612
  511. package/src/test/test-integration.spec.ts +0 -463
  512. package/src/test/test-lightweight-embedding.ts +0 -208
  513. package/src/test/test-m1-completion.spec.ts +0 -614
  514. package/src/test/test-m1-completion.ts +0 -141
  515. package/src/test/test-m1-integration.spec.ts +0 -514
  516. package/src/test/test-memory-injection-prompt.spec.ts +0 -650
  517. package/src/test/test-memory-injection-prompt.ts +0 -391
  518. package/src/test/test-performance-alerts.ts +0 -125
  519. package/src/test/test-performance-monitor-updates.spec.ts +0 -490
  520. package/src/test/test-performance-monitor.spec.ts +0 -284
  521. package/src/test/test-performance-monitor.ts +0 -228
  522. package/src/test/test-performance-monitoring.ts +0 -171
  523. package/src/test/test-search.ts +0 -151
  524. package/src/test/test-simple-alerts.ts +0 -136
  525. package/src/test/test-vector-search-engine.spec.ts +0 -408
  526. package/src/test/test-vector-search-engine.ts +0 -303
  527. package/src/tools/base-tool.ts +0 -189
  528. package/src/tools/cleanup-memory-tool.ts +0 -77
  529. package/src/tools/database-optimize-tool.ts +0 -79
  530. package/src/tools/error-stats.ts +0 -119
  531. package/src/tools/forget-tool.spec.ts +0 -613
  532. package/src/tools/forget-tool.ts +0 -454
  533. package/src/tools/forgetting-stats-tool.ts +0 -47
  534. package/src/tools/index.ts +0 -71
  535. package/src/tools/memory-injection-prompt.ts +0 -257
  536. package/src/tools/performance-alerts.ts +0 -226
  537. package/src/tools/performance-stats-tool.ts +0 -48
  538. package/src/tools/pin-tool.spec.ts +0 -497
  539. package/src/tools/pin-tool.ts +0 -277
  540. package/src/tools/recall-tool.spec.ts +0 -475
  541. package/src/tools/recall-tool.ts +0 -389
  542. package/src/tools/remember-tool.spec.ts +0 -469
  543. package/src/tools/remember-tool.ts +0 -112
  544. package/src/tools/resolve-error.ts +0 -69
  545. package/src/tools/tool-registry.ts +0 -417
  546. package/src/tools/types.ts +0 -63
  547. package/src/tools/unpin-tool.spec.ts +0 -549
  548. package/src/tools/unpin-tool.ts +0 -306
  549. package/src/types/embedding.types.ts +0 -78
  550. package/src/types/index.spec.ts +0 -420
  551. package/src/types/index.ts +0 -117
  552. package/src/utils/database.spec.ts +0 -77
  553. package/src/utils/database.ts +0 -458
  554. package/src/utils/stopwords.ts +0 -128
  555. package/start-docker-setup.bat +0 -38
  556. package/static/logo.png +0 -0
  557. package/static/memento_logo.svg +0 -2
  558. package/test-docker.js +0 -103
  559. package/tsconfig.json +0 -46
  560. package/vitest.config.ts +0 -23
@@ -1,564 +0,0 @@
1
- # @memento/client 모범 사례
2
-
3
- ## 목차
4
-
5
- - [설계 원칙](#설계-원칙)
6
- - [성능 최적화](#성능-최적화)
7
- - [에러 처리](#에러-처리)
8
- - [보안 고려사항](#보안-고려사항)
9
- - [코드 품질](#코드-품질)
10
- - [테스트 전략](#테스트-전략)
11
- - [배포 및 운영](#배포-및-운영)
12
-
13
- ## 설계 원칙
14
-
15
- ### 1. 단일 책임 원칙 (SRP)
16
-
17
- 각 클래스는 하나의 명확한 책임을 가져야 합니다.
18
-
19
- ```typescript
20
- // ✅ 좋은 예: 각 클래스가 명확한 역할
21
- const client = new MementoClient(); // 통신 담당
22
- const manager = new MemoryManager(client); // 기억 관리 담당
23
- const injector = new ContextInjector(client); // 컨텍스트 주입 담당
24
-
25
- // ❌ 나쁜 예: 하나의 클래스가 모든 것을 담당
26
- class EverythingManager {
27
- // 통신, 기억 관리, 컨텍스트 주입을 모두 처리
28
- }
29
- ```
30
-
31
- ### 2. 의존성 주입 (DI)
32
-
33
- 의존성을 외부에서 주입하여 테스트 가능성을 높입니다.
34
-
35
- ```typescript
36
- // ✅ 좋은 예: 의존성 주입
37
- class MemoryService {
38
- constructor(
39
- private client: MementoClient,
40
- private logger: Logger
41
- ) {}
42
-
43
- async createMemory(data: CreateMemoryParams) {
44
- this.logger.info('Creating memory', data);
45
- return await this.client.remember(data);
46
- }
47
- }
48
-
49
- // ❌ 나쁜 예: 하드코딩된 의존성
50
- class MemoryService {
51
- private client = new MementoClient(); // 하드코딩
52
- private logger = new ConsoleLogger(); // 하드코딩
53
- }
54
- ```
55
-
56
- ### 3. 인터페이스 분리 원칙 (ISP)
57
-
58
- 클라이언트는 사용하지 않는 인터페이스에 의존하지 않아야 합니다.
59
-
60
- ```typescript
61
- // ✅ 좋은 예: 필요한 기능만 노출
62
- interface MemoryReader {
63
- get(id: string): Promise<MemoryItem | null>;
64
- search(query: string): Promise<SearchResult>;
65
- }
66
-
67
- interface MemoryWriter {
68
- create(params: CreateMemoryParams): Promise<MemoryItem>;
69
- update(id: string, params: UpdateMemoryParams): Promise<MemoryItem>;
70
- delete(id: string): Promise<boolean>;
71
- }
72
-
73
- // ❌ 나쁜 예: 모든 기능을 하나의 인터페이스에
74
- interface MemoryManager {
75
- get(id: string): Promise<MemoryItem | null>;
76
- search(query: string): Promise<SearchResult>;
77
- create(params: CreateMemoryParams): Promise<MemoryItem>;
78
- update(id: string, params: UpdateMemoryParams): Promise<MemoryItem>;
79
- delete(id: string): Promise<boolean>;
80
- // ... 수많은 다른 메서드들
81
- }
82
- ```
83
-
84
- ## 성능 최적화
85
-
86
- ### 1. 배치 처리 활용
87
-
88
- 대량 데이터 처리 시 배치 처리를 사용합니다.
89
-
90
- ```typescript
91
- // ✅ 좋은 예: 배치 처리
92
- const optimizer = new PerformanceOptimizer(client);
93
- const results = await optimizer.createMemoriesBatch(memories, {
94
- batchSize: 50,
95
- delayBetweenBatches: 100
96
- });
97
-
98
- // ❌ 나쁜 예: 개별 처리
99
- for (const memory of memories) {
100
- await manager.create(memory); // 네트워크 오버헤드 증가
101
- }
102
- ```
103
-
104
- ### 2. 캐싱 전략
105
-
106
- 자주 사용되는 데이터는 캐싱합니다.
107
-
108
- ```typescript
109
- // ✅ 좋은 예: 캐싱 활용
110
- const result = await optimizer.cachedSearch('frequent query', {
111
- limit: 20
112
- });
113
-
114
- // ❌ 나쁜 예: 매번 서버 요청
115
- const result = await manager.search('frequent query', { limit: 20 });
116
- ```
117
-
118
- ### 3. 병렬 처리
119
-
120
- 독립적인 작업은 병렬로 처리합니다.
121
-
122
- ```typescript
123
- // ✅ 좋은 예: 병렬 처리
124
- const queries = ['query1', 'query2', 'query3'];
125
- const results = await optimizer.parallelSearch(queries, {
126
- maxConcurrency: 5
127
- });
128
-
129
- // ❌ 나쁜 예: 순차 처리
130
- const results = [];
131
- for (const query of queries) {
132
- const result = await manager.search(query);
133
- results.push(result);
134
- }
135
- ```
136
-
137
- ### 4. 메모리 관리
138
-
139
- 대용량 데이터 처리 시 메모리 사용량을 모니터링합니다.
140
-
141
- ```typescript
142
- // ✅ 좋은 예: 메모리 모니터링
143
- class MemoryAwareProcessor {
144
- private monitor = new MemoryMonitor();
145
-
146
- async processLargeDataset(data: any[]) {
147
- for (const chunk of this.chunkArray(data, 1000)) {
148
- if (!this.monitor.checkMemoryLimit(500)) {
149
- await this.garbageCollect();
150
- }
151
- await this.processChunk(chunk);
152
- }
153
- }
154
-
155
- private async garbageCollect() {
156
- if (global.gc) {
157
- global.gc();
158
- }
159
- await new Promise(resolve => setTimeout(resolve, 1000));
160
- }
161
- }
162
- ```
163
-
164
- ## 에러 처리
165
-
166
- ### 1. 구체적인 에러 타입 사용
167
-
168
- ```typescript
169
- // ✅ 좋은 예: 구체적인 에러 처리
170
- try {
171
- await manager.create(memoryData);
172
- } catch (error) {
173
- if (error instanceof ValidationError) {
174
- console.error('입력 데이터 오류:', error.message);
175
- } else if (error instanceof ConnectionError) {
176
- console.error('연결 오류:', error.message);
177
- // 재연결 시도
178
- await client.connect();
179
- } else {
180
- console.error('알 수 없는 오류:', error);
181
- }
182
- }
183
-
184
- // ❌ 나쁜 예: 일반적인 에러 처리
185
- try {
186
- await manager.create(memoryData);
187
- } catch (error) {
188
- console.error('오류 발생:', error); // 구체적이지 않음
189
- }
190
- ```
191
-
192
- ### 2. 재시도 로직 구현
193
-
194
- ```typescript
195
- // ✅ 좋은 예: 재시도 로직
196
- async function createMemoryWithRetry(data: CreateMemoryParams, maxRetries = 3) {
197
- for (let attempt = 1; attempt <= maxRetries; attempt++) {
198
- try {
199
- return await manager.create(data);
200
- } catch (error) {
201
- if (attempt === maxRetries) {
202
- throw error;
203
- }
204
-
205
- if (error instanceof ConnectionError) {
206
- await new Promise(resolve => setTimeout(resolve, 1000 * attempt));
207
- continue;
208
- }
209
-
210
- throw error; // 재시도할 수 없는 오류
211
- }
212
- }
213
- }
214
- ```
215
-
216
- ### 3. 에러 로깅
217
-
218
- ```typescript
219
- // ✅ 좋은 예: 구조화된 에러 로깅
220
- class ErrorLogger {
221
- logError(error: Error, context: any) {
222
- const errorInfo = {
223
- message: error.message,
224
- stack: error.stack,
225
- context,
226
- timestamp: new Date().toISOString(),
227
- userId: context.userId
228
- };
229
-
230
- console.error('Memory operation failed:', errorInfo);
231
-
232
- // 외부 로깅 서비스에 전송
233
- this.sendToLoggingService(errorInfo);
234
- }
235
- }
236
- ```
237
-
238
- ## 보안 고려사항
239
-
240
- ### 1. API 키 관리
241
-
242
- ```typescript
243
- // ✅ 좋은 예: 환경 변수 사용
244
- const client = new MementoClient({
245
- apiKey: process.env.MEMENTO_API_KEY
246
- });
247
-
248
- // ❌ 나쁜 예: 하드코딩
249
- const client = new MementoClient({
250
- apiKey: 'your-secret-key' // 보안 위험
251
- });
252
- ```
253
-
254
- ### 2. 입력 검증
255
-
256
- ```typescript
257
- // ✅ 좋은 예: 입력 검증
258
- function validateMemoryData(data: any): CreateMemoryParams {
259
- if (!data.content || typeof data.content !== 'string') {
260
- throw new ValidationError('Content is required and must be a string');
261
- }
262
-
263
- if (data.importance && (data.importance < 0 || data.importance > 1)) {
264
- throw new ValidationError('Importance must be between 0 and 1');
265
- }
266
-
267
- return data as CreateMemoryParams;
268
- }
269
- ```
270
-
271
- ### 3. 민감한 데이터 처리
272
-
273
- ```typescript
274
- // ✅ 좋은 예: 민감한 데이터 마스킹
275
- class SecureMemoryManager extends MemoryManager {
276
- async create(data: CreateMemoryParams) {
277
- // 민감한 정보 마스킹
278
- const sanitizedData = this.sanitizeData(data);
279
- return await super.create(sanitizedData);
280
- }
281
-
282
- private sanitizeData(data: CreateMemoryParams): CreateMemoryParams {
283
- return {
284
- ...data,
285
- content: this.maskSensitiveInfo(data.content)
286
- };
287
- }
288
-
289
- private maskSensitiveInfo(content: string): string {
290
- // 이메일, 전화번호 등 민감한 정보 마스킹
291
- return content
292
- .replace(/\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b/g, '[EMAIL]')
293
- .replace(/\b\d{3}-\d{4}-\d{4}\b/g, '[PHONE]');
294
- }
295
- }
296
- ```
297
-
298
- ## 코드 품질
299
-
300
- ### 1. 타입 안전성
301
-
302
- ```typescript
303
- // ✅ 좋은 예: 강타입 사용
304
- interface MemorySearchOptions {
305
- query: string;
306
- filters?: SearchFilters;
307
- limit?: number;
308
- useHybrid?: boolean;
309
- }
310
-
311
- async function searchMemories(options: MemorySearchOptions): Promise<SearchResult> {
312
- return await manager.search(options.query, {
313
- filters: options.filters,
314
- limit: options.limit,
315
- useHybrid: options.useHybrid
316
- });
317
- }
318
-
319
- // ❌ 나쁜 예: any 타입 사용
320
- async function searchMemories(options: any): Promise<any> {
321
- return await manager.search(options.query, options);
322
- }
323
- ```
324
-
325
- ### 2. 함수 분리
326
-
327
- ```typescript
328
- // ✅ 좋은 예: 작은 함수로 분리
329
- class MemoryProcessor {
330
- async processMemories(memories: MemoryItem[]) {
331
- const validMemories = this.validateMemories(memories);
332
- const enrichedMemories = await this.enrichMemories(validMemories);
333
- const savedMemories = await this.saveMemories(enrichedMemories);
334
- return this.generateReport(savedMemories);
335
- }
336
-
337
- private validateMemories(memories: MemoryItem[]): MemoryItem[] {
338
- return memories.filter(memory => this.isValidMemory(memory));
339
- }
340
-
341
- private async enrichMemories(memories: MemoryItem[]): Promise<MemoryItem[]> {
342
- return Promise.all(memories.map(memory => this.enrichMemory(memory)));
343
- }
344
- }
345
- ```
346
-
347
- ### 3. 상수 사용
348
-
349
- ```typescript
350
- // ✅ 좋은 예: 상수 정의
351
- const MEMORY_CONSTANTS = {
352
- MAX_BATCH_SIZE: 100,
353
- DEFAULT_TIMEOUT: 10000,
354
- CACHE_TTL: 5 * 60 * 1000, // 5분
355
- RETRY_ATTEMPTS: 3
356
- } as const;
357
-
358
- // 사용
359
- const results = await optimizer.createMemoriesBatch(memories, {
360
- batchSize: MEMORY_CONSTANTS.MAX_BATCH_SIZE
361
- });
362
- ```
363
-
364
- ## 테스트 전략
365
-
366
- ### 1. 단위 테스트
367
-
368
- ```typescript
369
- // ✅ 좋은 예: 단위 테스트
370
- describe('MemoryManager', () => {
371
- let mockClient: jest.Mocked<MementoClient>;
372
- let manager: MemoryManager;
373
-
374
- beforeEach(() => {
375
- mockClient = createMockClient();
376
- manager = new MemoryManager(mockClient);
377
- });
378
-
379
- it('should create memory with valid data', async () => {
380
- const memoryData = {
381
- content: 'test content',
382
- type: 'episodic' as const,
383
- importance: 0.5
384
- };
385
-
386
- mockClient.remember.mockResolvedValue({
387
- id: 'test-id',
388
- ...memoryData,
389
- created_at: new Date().toISOString()
390
- });
391
-
392
- const result = await manager.create(memoryData);
393
-
394
- expect(result).toBeDefined();
395
- expect(mockClient.remember).toHaveBeenCalledWith(memoryData);
396
- });
397
- });
398
- ```
399
-
400
- ### 2. 통합 테스트
401
-
402
- ```typescript
403
- // ✅ 좋은 예: 통합 테스트
404
- describe('Integration Tests', () => {
405
- let client: MementoClient;
406
- let manager: MemoryManager;
407
-
408
- beforeAll(async () => {
409
- client = new MementoClient({
410
- serverUrl: 'http://localhost:8080'
411
- });
412
- await client.connect();
413
- manager = new MemoryManager(client);
414
- });
415
-
416
- afterAll(async () => {
417
- await client.disconnect();
418
- });
419
-
420
- it('should perform full CRUD operations', async () => {
421
- // Create
422
- const memory = await manager.create({
423
- content: 'integration test',
424
- type: 'episodic'
425
- });
426
-
427
- // Read
428
- const retrieved = await manager.get(memory.id);
429
- expect(retrieved).toBeDefined();
430
-
431
- // Update
432
- const updated = await manager.update(memory.id, {
433
- importance: 0.9
434
- });
435
- expect(updated.importance).toBe(0.9);
436
-
437
- // Delete
438
- const deleted = await manager.delete(memory.id);
439
- expect(deleted).toBe(true);
440
- });
441
- });
442
- ```
443
-
444
- ### 3. 성능 테스트
445
-
446
- ```typescript
447
- // ✅ 좋은 예: 성능 테스트
448
- describe('Performance Tests', () => {
449
- it('should handle large batch operations efficiently', async () => {
450
- const largeDataset = Array.from({ length: 1000 }, (_, i) => ({
451
- content: `test data ${i}`,
452
- type: 'episodic' as const,
453
- importance: Math.random()
454
- }));
455
-
456
- const startTime = Date.now();
457
- const results = await optimizer.createMemoriesBatch(largeDataset, {
458
- batchSize: 50
459
- });
460
- const endTime = Date.now();
461
-
462
- expect(results).toHaveLength(1000);
463
- expect(endTime - startTime).toBeLessThan(30000); // 30초 이내
464
- });
465
- });
466
- ```
467
-
468
- ## 배포 및 운영
469
-
470
- ### 1. 환경별 설정
471
-
472
- ```typescript
473
- // ✅ 좋은 예: 환경별 설정
474
- const getClientConfig = () => {
475
- const env = process.env.NODE_ENV || 'development';
476
-
477
- const configs = {
478
- development: {
479
- serverUrl: 'http://localhost:8080',
480
- logLevel: 'debug' as const,
481
- timeout: 10000
482
- },
483
- staging: {
484
- serverUrl: 'https://staging-memento.example.com',
485
- logLevel: 'info' as const,
486
- timeout: 15000
487
- },
488
- production: {
489
- serverUrl: 'https://memento.example.com',
490
- logLevel: 'warn' as const,
491
- timeout: 30000
492
- }
493
- };
494
-
495
- return configs[env];
496
- };
497
-
498
- const client = new MementoClient(getClientConfig());
499
- ```
500
-
501
- ### 2. 모니터링 설정
502
-
503
- ```typescript
504
- // ✅ 좋은 예: 모니터링 설정
505
- class MonitoredMemoryManager extends MemoryManager {
506
- private metrics = new Map<string, number>();
507
-
508
- async create(data: CreateMemoryParams): Promise<MemoryItem> {
509
- const startTime = Date.now();
510
-
511
- try {
512
- const result = await super.create(data);
513
- this.recordMetric('memory.create.success', Date.now() - startTime);
514
- return result;
515
- } catch (error) {
516
- this.recordMetric('memory.create.error', Date.now() - startTime);
517
- throw error;
518
- }
519
- }
520
-
521
- private recordMetric(metric: string, value: number) {
522
- this.metrics.set(metric, value);
523
- // 외부 모니터링 시스템에 전송
524
- this.sendToMonitoring(metric, value);
525
- }
526
- }
527
- ```
528
-
529
- ### 3. 로그 관리
530
-
531
- ```typescript
532
- // ✅ 좋은 예: 구조화된 로깅
533
- class Logger {
534
- private context: string;
535
-
536
- constructor(context: string) {
537
- this.context = context;
538
- }
539
-
540
- info(message: string, data?: any) {
541
- console.log(JSON.stringify({
542
- level: 'info',
543
- context: this.context,
544
- message,
545
- data,
546
- timestamp: new Date().toISOString()
547
- }));
548
- }
549
-
550
- error(message: string, error?: Error, data?: any) {
551
- console.error(JSON.stringify({
552
- level: 'error',
553
- context: this.context,
554
- message,
555
- error: error?.message,
556
- stack: error?.stack,
557
- data,
558
- timestamp: new Date().toISOString()
559
- }));
560
- }
561
- }
562
- ```
563
-
564
- 이 모범 사례를 따라하면 @memento/client를 안전하고 효율적으로 사용할 수 있습니다.