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,298 +0,0 @@
1
- ---
2
- globs: *error-logging*
3
- description: Memento 프로젝트의 에러 로깅 시스템 개발 규칙입니다. 구조화된 에러 로깅, 통계 수집, 해결 추적을 통한 시스템 안정성 향상을 위한 가이드라인을 제공합니다.
4
- ---
5
-
6
- # 에러 로깅 시스템 개발 규칙
7
-
8
- ## 🎯 개요
9
-
10
- 에러 로깅 시스템은 Memento MCP Server의 안정성을 보장하기 위한 핵심 컴포넌트입니다. 구조화된 에러 로깅, 통계 수집, 해결 추적을 통해 시스템의 신뢰성을 향상시킵니다.
11
-
12
- ## 📁 파일 구조
13
-
14
- ```
15
- src/services/
16
- ├── error-logging-service.ts # 메인 서비스
17
- └── test-error-logging.ts # 테스트 파일
18
- ```
19
-
20
- ## 🔧 핵심 기능
21
-
22
- ### 1. 구조화된 에러 로깅
23
- - **심각도 분류**: LOW, MEDIUM, HIGH, CRITICAL
24
- - **카테고리 분류**: DATABASE, NETWORK, TOOL_EXECUTION, VALIDATION, SYSTEM
25
- - **컨텍스트 정보**: 사용자 ID, 작업 유형, 타임스탬프
26
- - **스택 트레이스**: 상세한 에러 정보
27
-
28
- ### 2. 에러 통계 수집
29
- - **심각도별 통계**: 에러 분포 분석
30
- - **카테고리별 통계**: 문제 영역 식별
31
- - **시간별 통계**: 트렌드 분석
32
- - **해결률 통계**: 처리 효율성 측정
33
-
34
- ### 3. 에러 해결 추적
35
- - **해결 상태 관리**: PENDING, IN_PROGRESS, RESOLVED
36
- - **해결자 추적**: 담당자 식별
37
- - **해결 방법 기록**: 문제 해결 과정
38
- - **재발 방지**: 근본 원인 분석
39
-
40
- ## 🛠️ 개발 가이드라인
41
-
42
- ### 서비스 인터페이스
43
- ```typescript
44
- interface ErrorLoggingService {
45
- // 에러 로깅
46
- logError(
47
- error: Error,
48
- severity: ErrorSeverity,
49
- category: ErrorCategory,
50
- context?: Record<string, any>
51
- ): void;
52
-
53
- // 에러 통계 조회
54
- getErrorStats(filters?: ErrorFilters): Promise<ErrorStats>;
55
-
56
- // 에러 해결
57
- resolveError(
58
- errorId: string,
59
- resolvedBy: string,
60
- resolution?: string
61
- ): Promise<boolean>;
62
-
63
- // 에러 검색
64
- searchErrors(filters: ErrorSearchFilters): Promise<ErrorLog[]>;
65
- }
66
- ```
67
-
68
- ### 에러 심각도 정의
69
- ```typescript
70
- enum ErrorSeverity {
71
- LOW = 'LOW', // 정보성 에러 (로깅만)
72
- MEDIUM = 'MEDIUM', // 경고성 에러 (모니터링)
73
- HIGH = 'HIGH', // 심각한 에러 (알림 필요)
74
- CRITICAL = 'CRITICAL' // 치명적 에러 (즉시 대응)
75
- }
76
- ```
77
-
78
- ### 에러 카테고리 정의
79
- ```typescript
80
- enum ErrorCategory {
81
- UNKNOWN = 'UNKNOWN', // 알 수 없는 에러
82
- DATABASE = 'DATABASE', // 데이터베이스 관련
83
- NETWORK = 'NETWORK', // 네트워크 관련
84
- TOOL_EXECUTION = 'TOOL_EXECUTION', // 도구 실행 관련
85
- VALIDATION = 'VALIDATION', // 입력 검증 관련
86
- SYSTEM = 'SYSTEM' // 시스템 관련
87
- }
88
- ```
89
-
90
- ### 에러 로깅 예시
91
- ```typescript
92
- // 기본 에러 로깅
93
- errorLoggingService.logError(
94
- new Error('Database connection failed'),
95
- ErrorSeverity.HIGH,
96
- ErrorCategory.DATABASE,
97
- {
98
- operation: 'memory_search',
99
- userId: 'user123',
100
- timestamp: new Date().toISOString()
101
- }
102
- );
103
-
104
- // 복잡한 에러 로깅
105
- try {
106
- await riskyOperation();
107
- } catch (error) {
108
- errorLoggingService.logError(
109
- error instanceof Error ? error : new Error(String(error)),
110
- ErrorSeverity.CRITICAL,
111
- ErrorCategory.SYSTEM,
112
- {
113
- operation: 'memory_creation',
114
- userId: 'user456',
115
- memoryId: 'memory-789',
116
- stackTrace: error.stack,
117
- additionalContext: {
118
- memoryType: 'episodic',
119
- contentLength: content.length
120
- }
121
- }
122
- );
123
- }
124
- ```
125
-
126
- ## 📊 통계 및 분석
127
-
128
- ### 에러 통계 구조
129
- ```typescript
130
- interface ErrorStats {
131
- totalErrors: number;
132
- errorsBySeverity: Record<ErrorSeverity, number>;
133
- errorsByCategory: Record<ErrorCategory, number>;
134
- errorsByHour: Record<number, number>;
135
- resolutionRate: number;
136
- averageResolutionTime: number;
137
- topErrors: Array<{
138
- message: string;
139
- count: number;
140
- lastOccurred: Date;
141
- }>;
142
- }
143
- ```
144
-
145
- ### 통계 조회 예시
146
- ```typescript
147
- // 전체 통계
148
- const stats = await errorLoggingService.getErrorStats();
149
-
150
- // 필터링된 통계
151
- const highErrors = await errorLoggingService.getErrorStats({
152
- severity: ErrorSeverity.HIGH,
153
- hours: 24
154
- });
155
-
156
- // 카테고리별 통계
157
- const dbErrors = await errorLoggingService.getErrorStats({
158
- category: ErrorCategory.DATABASE,
159
- limit: 10
160
- });
161
- ```
162
-
163
- ## 🔍 에러 해결 워크플로우
164
-
165
- ### 1. 에러 발견
166
- ```typescript
167
- // 에러 로깅 시 자동으로 해결 대기 상태로 설정
168
- const errorId = errorLoggingService.logError(error, severity, category, context);
169
- ```
170
-
171
- ### 2. 에러 분석
172
- ```typescript
173
- // 에러 상세 정보 조회
174
- const errorDetails = await errorLoggingService.getErrorDetails(errorId);
175
-
176
- // 관련 에러 검색
177
- const relatedErrors = await errorLoggingService.searchErrors({
178
- message: errorDetails.message,
179
- category: errorDetails.category,
180
- timeRange: '24h'
181
- });
182
- ```
183
-
184
- ### 3. 에러 해결
185
- ```typescript
186
- // 에러 해결 처리
187
- const resolved = await errorLoggingService.resolveError(
188
- errorId,
189
- 'admin',
190
- '데이터베이스 연결 풀 크기 증가로 해결'
191
- );
192
-
193
- // 해결 확인
194
- if (resolved) {
195
- console.log('에러가 성공적으로 해결되었습니다.');
196
- }
197
- ```
198
-
199
- ## 🧪 테스트 가이드라인
200
-
201
- ### 단위 테스트
202
- ```typescript
203
- describe('ErrorLoggingService', () => {
204
- let service: ErrorLoggingService;
205
-
206
- beforeEach(() => {
207
- service = new ErrorLoggingService();
208
- });
209
-
210
- it('should log error with correct severity', () => {
211
- const error = new Error('Test error');
212
- service.logError(error, ErrorSeverity.HIGH, ErrorCategory.SYSTEM);
213
-
214
- const stats = service.getErrorStats();
215
- expect(stats.errorsBySeverity[ErrorSeverity.HIGH]).toBe(1);
216
- });
217
-
218
- it('should resolve error correctly', async () => {
219
- const error = new Error('Test error');
220
- service.logError(error, ErrorSeverity.MEDIUM, ErrorCategory.VALIDATION);
221
-
222
- const errors = service.searchErrors({ limit: 1 });
223
- const errorId = errors[0].id;
224
-
225
- const resolved = await service.resolveError(errorId, 'test_user', 'Test resolution');
226
- expect(resolved).toBe(true);
227
- });
228
- });
229
- ```
230
-
231
- ### 통합 테스트
232
- ```typescript
233
- describe('ErrorLogging Integration', () => {
234
- it('should integrate with MCP server', async () => {
235
- const server = new MCPServer();
236
- const errorService = new ErrorLoggingService();
237
-
238
- // 서버에 에러 로깅 서비스 연결
239
- server.setErrorLogger(errorService);
240
-
241
- // 에러 발생 시나리오
242
- try {
243
- await server.executeTool('invalid_tool', {});
244
- } catch (error) {
245
- // 에러가 자동으로 로깅되는지 확인
246
- const stats = errorService.getErrorStats();
247
- expect(stats.totalErrors).toBeGreaterThan(0);
248
- }
249
- });
250
- });
251
- ```
252
-
253
- ## 📈 모니터링 및 알림
254
-
255
- ### 실시간 모니터링
256
- ```typescript
257
- // 에러 발생 시 실시간 알림
258
- errorLoggingService.on('error', (errorLog) => {
259
- if (errorLog.severity === ErrorSeverity.CRITICAL) {
260
- // 즉시 알림 전송
261
- alertService.sendCriticalAlert(errorLog);
262
- }
263
- });
264
- ```
265
-
266
- ### 대시보드 메트릭
267
- - **에러 발생률**: 시간당 에러 수
268
- - **해결률**: 해결된 에러 비율
269
- - **평균 해결 시간**: 에러 해결 소요 시간
270
- - **심각도 분포**: 에러 심각도별 분포
271
-
272
- ## 🚀 배포 고려사항
273
-
274
- ### 환경 변수
275
- ```bash
276
- # 에러 로깅 설정
277
- ERROR_LOGGING_ENABLED=true
278
- ERROR_LOGGING_LEVEL=INFO
279
- ERROR_LOGGING_RETENTION_DAYS=30
280
- ERROR_LOGGING_ALERT_THRESHOLD=10
281
- ```
282
-
283
- ### 로그 저장소
284
- - **로컬 파일**: 개발 환경
285
- - **데이터베이스**: 프로덕션 환경
286
- - **외부 서비스**: ELK Stack, Splunk 등
287
-
288
- ### 성능 최적화
289
- - **비동기 로깅**: 논블로킹 에러 로깅
290
- - **배치 처리**: 여러 에러를 한 번에 처리
291
- - **압축**: 오래된 로그 압축 저장
292
-
293
- ## 📚 참고 자료
294
-
295
- - [Node.js Error Handling](https://nodejs.org/api/errors.html)
296
- - [Winston Logger](https://github.com/winstonjs/winston)
297
- - [Structured Logging](https://www.elastic.co/guide/en/ecs/current/index.html)
298
- - [Error Monitoring Best Practices](https://sentry.io/for/error-monitoring/)
@@ -1,426 +0,0 @@
1
- ---
2
- globs: "src/algorithms/forgetting-algorithm.ts,src/services/forgetting-policy-service.ts"
3
- description: 망각 알고리즘 및 망각 정책 서비스 개발 규칙
4
- ---
5
-
6
- # 망각 알고리즘 및 망각 정책 서비스 규칙
7
-
8
- ## 📋 망각 알고리즘
9
-
10
- ### 현재 구현 상태
11
- - **파일**: `src/algorithms/forgetting-algorithm.ts` (244줄)
12
- - **기능**: Memento-Goals.md의 망각 공식 구현
13
- - **특징**: 최근성, 사용성, 중복 비율, 중요도, 고정 여부를 종합한 망각 점수 계산
14
-
15
- ### 핵심 인터페이스
16
-
17
- ```typescript
18
- interface ForgettingFeatures {
19
- recency: number; // 최근성 (0-1)
20
- usage: number; // 사용성 (0-1)
21
- duplication_ratio: number; // 중복 비율 (0-1)
22
- importance: number; // 중요도 (0-1)
23
- pinned: boolean; // 고정 여부
24
- }
25
-
26
- interface ForgettingWeights {
27
- recency: number; // U1 = 0.35
28
- usage: number; // U2 = 0.25
29
- duplication: number; // U3 = 0.20
30
- importance: number; // U4 = 0.15
31
- pinned: number; // U5 = 0.30
32
- }
33
-
34
- interface ForgettingResult {
35
- memory_id: string;
36
- forget_score: number;
37
- should_forget: boolean;
38
- reason: string;
39
- features: ForgettingFeatures;
40
- }
41
- ```
42
-
43
- ### 구현 가이드라인
44
-
45
- #### 1. 망각 점수 계산
46
- ```typescript
47
- calculateForgetScore(features: ForgettingFeatures): number {
48
- const { recency, usage, duplication_ratio, importance, pinned } = features;
49
-
50
- // 망각 점수 공식: U1*(1-recency) + U2*(1-usage) + U3*duplication - U4*importance - U5*pinned
51
- const score =
52
- this.weights.recency * (1 - recency) +
53
- this.weights.usage * (1 - usage) +
54
- this.weights.duplication * duplication_ratio -
55
- this.weights.importance * importance -
56
- this.weights.pinned * (pinned ? 1 : 0);
57
-
58
- return Math.max(0, Math.min(1, score));
59
- }
60
- ```
61
-
62
- #### 2. 특징 계산
63
- ```typescript
64
- // 최근성 계산 (지수 감쇠)
65
- calculateRecency(createdAt: Date, type: string): number {
66
- const ageDays = this.getAgeInDays(createdAt);
67
- const halfLife = this.getHalfLife(type);
68
- return Math.exp(-Math.log(2) * ageDays / halfLife);
69
- }
70
-
71
- // 사용성 계산 (로그 스케일)
72
- calculateUsage(viewCount: number, citeCount: number, editCount: number): number {
73
- const rawUsage =
74
- Math.log(1 + viewCount) +
75
- 2 * Math.log(1 + citeCount) +
76
- 0.5 * Math.log(1 + editCount);
77
-
78
- return this.normalize(rawUsage, this.batchMin, this.batchMax);
79
- }
80
-
81
- // 중복 비율 계산
82
- calculateDuplicationRatio(memoryId: string, similarMemories: string[]): number {
83
- if (similarMemories.length === 0) return 0;
84
-
85
- const similarityScores = similarMemories.map(id =>
86
- this.calculateSimilarity(memoryId, id)
87
- );
88
-
89
- return Math.max(...similarityScores);
90
- }
91
- ```
92
-
93
- #### 3. 망각 결정
94
- ```typescript
95
- shouldForget(features: ForgettingFeatures, threshold: number = 0.6): boolean {
96
- const forgetScore = this.calculateForgetScore(features);
97
- return forgetScore >= threshold && !features.pinned;
98
- }
99
- ```
100
-
101
- ## 🔄 간격 반복 알고리즘
102
-
103
- ### 현재 구현 상태
104
- - **파일**: `src/algorithms/spaced-repetition.ts` (239줄)
105
- - **기능**: 중요도와 사용성 기반 리뷰 간격 계산
106
- - **특징**: 피드백에 따른 동적 간격 조정
107
-
108
- ### 핵심 인터페이스
109
-
110
- ```typescript
111
- interface SpacedRepetitionFeatures {
112
- importance: number; // 중요도 (0-1)
113
- usage: number; // 사용성 (0-1)
114
- helpful_feedback: number; // 도움됨 피드백 (0-1)
115
- bad_feedback: number; // 나쁨 피드백 (0-1)
116
- }
117
-
118
- interface ReviewSchedule {
119
- memory_id: string;
120
- current_interval: number; // 현재 간격 (일)
121
- next_review: Date; // 다음 리뷰 날짜
122
- recall_probability: number; // 리콜 확률
123
- needs_review: boolean; // 리뷰 필요 여부
124
- multiplier: number; // 간격 배수
125
- }
126
- ```
127
-
128
- ### 구현 가이드라인
129
-
130
- #### 1. 간격 계산
131
- ```typescript
132
- calculateNextInterval(
133
- currentInterval: number,
134
- features: SpacedRepetitionFeatures
135
- ): number {
136
- const multiplier = 1 +
137
- this.weights.importance * features.importance +
138
- this.weights.usage * features.usage +
139
- this.weights.helpful_feedback * features.helpful_feedback -
140
- this.weights.bad_feedback * features.bad_feedback;
141
-
142
- return Math.ceil(currentInterval * multiplier);
143
- }
144
- ```
145
-
146
- #### 2. 리콜 확률 계산
147
- ```typescript
148
- calculateRecallProbability(
149
- timeSinceLastReview: number,
150
- interval: number
151
- ): number {
152
- return Math.exp(-timeSinceLastReview / interval);
153
- }
154
- ```
155
-
156
- #### 3. 리뷰 필요 여부 판단
157
- ```typescript
158
- needsReview(
159
- timeSinceLastReview: number,
160
- interval: number,
161
- threshold: number = 0.7
162
- ): boolean {
163
- const recallProb = this.calculateRecallProbability(timeSinceLastReview, interval);
164
- return recallProb <= threshold;
165
- }
166
- ```
167
-
168
- ## 🧠 망각 정책 서비스
169
-
170
- ### 현재 구현 상태
171
- - **파일**: `src/services/forgetting-policy-service.ts` (335줄)
172
- - **기능**: 망각 알고리즘과 간격 반복을 통합한 메모리 관리
173
- - **특징**: TTL 기반 정책, 소프트/하드 삭제
174
-
175
- ### 핵심 인터페이스
176
-
177
- ```typescript
178
- interface ForgettingPolicyConfig {
179
- forgetThreshold: number; // 망각 임계값 (기본: 0.6)
180
- softDeleteThreshold: number; // 소프트 삭제 임계값 (기본: 0.6)
181
- hardDeleteThreshold: number; // 하드 삭제 임계값 (기본: 0.8)
182
-
183
- ttlSoft: {
184
- working: number;
185
- episodic: number;
186
- semantic: number;
187
- procedural: number;
188
- };
189
-
190
- ttlHard: {
191
- working: number;
192
- episodic: number;
193
- semantic: number;
194
- procedural: number;
195
- };
196
- }
197
- ```
198
-
199
- ### 구현 가이드라인
200
-
201
- #### 1. 정책 적용
202
- ```typescript
203
- async applyForgettingPolicy(): Promise<ForgettingPolicyResult> {
204
- const memories = await this.getMemoriesForReview();
205
- const results: ForgettingPolicyResult = {
206
- softDeleted: [],
207
- hardDeleted: [],
208
- scheduledForReview: []
209
- };
210
-
211
- for (const memory of memories) {
212
- const features = await this.calculateFeatures(memory);
213
- const forgetScore = this.forgettingAlgorithm.calculateForgetScore(features);
214
-
215
- if (forgetScore >= this.config.hardDeleteThreshold) {
216
- await this.hardDelete(memory.id);
217
- results.hardDeleted.push(memory.id);
218
- } else if (forgetScore >= this.config.softDeleteThreshold) {
219
- await this.softDelete(memory.id);
220
- results.softDeleted.push(memory.id);
221
- } else {
222
- const schedule = await this.scheduleReview(memory, features);
223
- if (schedule.needs_review) {
224
- results.scheduledForReview.push(schedule);
225
- }
226
- }
227
- }
228
-
229
- return results;
230
- }
231
- ```
232
-
233
- #### 2. TTL 검사
234
- ```typescript
235
- isTTLExpired(memory: MemoryItem, type: 'soft' | 'hard'): boolean {
236
- const ageDays = this.getAgeInDays(memory.created_at);
237
- const ttl = type === 'soft' ?
238
- this.config.ttlSoft[memory.type] :
239
- this.config.ttlHard[memory.type];
240
-
241
- return ageDays >= ttl;
242
- }
243
- ```
244
-
245
- #### 3. 배치 처리
246
- ```typescript
247
- async processBatchForgetting(batchSize: number = 100): Promise<void> {
248
- const memories = await this.getMemoriesBatch(batchSize);
249
-
250
- for (const memory of memories) {
251
- try {
252
- await this.processMemoryForgetting(memory);
253
- } catch (error) {
254
- console.error(`Failed to process memory ${memory.id}:`, error);
255
- }
256
- }
257
- }
258
- ```
259
-
260
- ## 🧪 테스트 가이드라인
261
-
262
- ### 망각 알고리즘 테스트
263
- ```typescript
264
- describe('ForgettingAlgorithm', () => {
265
- let algorithm: ForgettingAlgorithm;
266
-
267
- beforeEach(() => {
268
- algorithm = new ForgettingAlgorithm();
269
- });
270
-
271
- it('should calculate forget score correctly', () => {
272
- const features: ForgettingFeatures = {
273
- recency: 0.2,
274
- usage: 0.1,
275
- duplication_ratio: 0.8,
276
- importance: 0.3,
277
- pinned: false
278
- };
279
-
280
- const score = algorithm.calculateForgetScore(features);
281
- expect(score).toBeGreaterThan(0.6);
282
- });
283
-
284
- it('should not forget pinned memories', () => {
285
- const features: ForgettingFeatures = {
286
- recency: 0.1,
287
- usage: 0.1,
288
- duplication_ratio: 0.9,
289
- importance: 0.2,
290
- pinned: true
291
- };
292
-
293
- const shouldForget = algorithm.shouldForget(features);
294
- expect(shouldForget).toBe(false);
295
- });
296
- });
297
- ```
298
-
299
- ### 간격 반복 테스트
300
- ```typescript
301
- describe('SpacedRepetitionAlgorithm', () => {
302
- let algorithm: SpacedRepetitionAlgorithm;
303
-
304
- beforeEach(() => {
305
- algorithm = new SpacedRepetitionAlgorithm();
306
- });
307
-
308
- it('should calculate next interval correctly', () => {
309
- const features: SpacedRepetitionFeatures = {
310
- importance: 0.8,
311
- usage: 0.6,
312
- helpful_feedback: 0.7,
313
- bad_feedback: 0.1
314
- };
315
-
316
- const nextInterval = algorithm.calculateNextInterval(7, features);
317
- expect(nextInterval).toBeGreaterThan(7);
318
- });
319
-
320
- it('should determine review need correctly', () => {
321
- const needsReview = algorithm.needsReview(10, 7, 0.7);
322
- expect(needsReview).toBe(true);
323
- });
324
- });
325
- ```
326
-
327
- ## 📊 성능 최적화
328
-
329
- ### 1. 배치 처리
330
- ```typescript
331
- // 대량 메모리 처리 시 배치 단위로 처리
332
- async processMemoriesInBatches(memories: MemoryItem[], batchSize: number = 100) {
333
- for (let i = 0; i < memories.length; i += batchSize) {
334
- const batch = memories.slice(i, i + batchSize);
335
- await Promise.all(batch.map(memory => this.processMemory(memory)));
336
- }
337
- }
338
- ```
339
-
340
- ### 2. 캐싱
341
- ```typescript
342
- // 특징 계산 결과 캐싱
343
- private featureCache = new Map<string, ForgettingFeatures>();
344
-
345
- async getCachedFeatures(memoryId: string): Promise<ForgettingFeatures> {
346
- if (this.featureCache.has(memoryId)) {
347
- return this.featureCache.get(memoryId)!;
348
- }
349
-
350
- const features = await this.calculateFeatures(memoryId);
351
- this.featureCache.set(memoryId, features);
352
- return features;
353
- }
354
- ```
355
-
356
- ### 3. 인덱스 최적화
357
- ```sql
358
- -- 망각 정책 쿼리 최적화를 위한 인덱스
359
- CREATE INDEX idx_memory_item_forgetting ON memory_item(
360
- created_at, last_accessed, importance, pinned
361
- );
362
-
363
- CREATE INDEX idx_memory_item_type_created ON memory_item(type, created_at);
364
- ```
365
-
366
- ## 🔧 설정 관리
367
-
368
- ### 환경 변수
369
- ```bash
370
- # .env 파일
371
- FORGET_THRESHOLD=0.6
372
- SOFT_DELETE_THRESHOLD=0.6
373
- HARD_DELETE_THRESHOLD=0.8
374
-
375
- # TTL 설정 (일 단위)
376
- TTL_SOFT_WORKING=2
377
- TTL_SOFT_EPISODIC=30
378
- TTL_SOFT_SEMANTIC=180
379
- TTL_SOFT_PROCEDURAL=90
380
-
381
- TTL_HARD_WORKING=7
382
- TTL_HARD_EPISODIC=180
383
- TTL_HARD_SEMANTIC=365
384
- TTL_HARD_PROCEDURAL=180
385
- ```
386
-
387
- ### 설정 검증
388
- ```typescript
389
- private validateConfig(config: ForgettingPolicyConfig): void {
390
- if (config.forgetThreshold < 0 || config.forgetThreshold > 1) {
391
- throw new Error('forgetThreshold must be between 0 and 1');
392
- }
393
-
394
- if (config.softDeleteThreshold >= config.hardDeleteThreshold) {
395
- throw new Error('softDeleteThreshold must be less than hardDeleteThreshold');
396
- }
397
-
398
- // TTL 값 검증
399
- Object.values(config.ttlSoft).forEach(ttl => {
400
- if (ttl <= 0) throw new Error('TTL values must be positive');
401
- });
402
- }
403
- ```
404
-
405
- ## 📋 개발 체크리스트
406
-
407
- ### 망각 알고리즘
408
- - [ ] 망각 점수 계산 로직 구현
409
- - [ ] 특징 계산 함수 구현
410
- - [ ] 망각 결정 로직 구현
411
- - [ ] 에러 처리 및 로깅 추가
412
- - [ ] 단위 테스트 작성
413
-
414
- ### 간격 반복 알고리즘
415
- - [ ] 간격 계산 로직 구현
416
- - [ ] 리콜 확률 계산 함수
417
- - [ ] 리뷰 필요 여부 판단 로직
418
- - [ ] 피드백 처리 로직
419
- - [ ] 단위 테스트 작성
420
-
421
- ### 망각 정책 서비스
422
- - [ ] 정책 적용 로직 구현
423
- - [ ] TTL 검사 로직
424
- - [ ] 배치 처리 구현
425
- - [ ] 데이터베이스 연동
426
- - [ ] 통합 테스트 작성