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,537 +0,0 @@
1
- ---
2
- globs: "src/services/performance-alert-service.ts,src/services/performance-monitoring-integration.ts,src/tools/performance-alerts.ts,src/test-performance-alerts.ts"
3
- description: 성능 알림 시스템 개발 규칙
4
- ---
5
-
6
- # 성능 알림 시스템 개발 규칙
7
-
8
- ## 📋 성능 알림 시스템 개요
9
-
10
- ### 현재 구현 상태
11
- - **성능 알림 서비스**: `src/services/performance-alert-service.ts`
12
- - **성능 모니터링 통합**: `src/services/performance-monitoring-integration.ts`
13
- - **성능 알림 도구**: `src/tools/performance-alerts.ts`
14
- - **성능 알림 테스트**: `src/test-performance-alerts.ts`
15
-
16
- ### 핵심 인터페이스
17
-
18
- ```typescript
19
- interface PerformanceAlertService {
20
- // 알림 생성
21
- createAlert(level: AlertLevel, type: AlertType, metric: string, value: number, threshold: number, message: string, context?: Record<string, any>): PerformanceAlert;
22
-
23
- // 알림 해결
24
- resolveAlert(alertId: string, resolvedBy: string, resolution?: string): PerformanceAlert | null;
25
-
26
- // 활성 알림 조회
27
- getActiveAlerts(): PerformanceAlert[];
28
-
29
- // 알림 검색
30
- searchAlerts(filters: AlertSearchFilters): PerformanceAlert[];
31
-
32
- // 알림 통계
33
- getStats(): AlertStats;
34
- }
35
-
36
- enum AlertLevel {
37
- INFO = 'INFO',
38
- WARNING = 'WARNING',
39
- CRITICAL = 'CRITICAL'
40
- }
41
-
42
- enum AlertType {
43
- RESPONSE_TIME = 'response_time',
44
- MEMORY_USAGE = 'memory_usage',
45
- ERROR_RATE = 'error_rate',
46
- THROUGHPUT = 'throughput',
47
- CUSTOM = 'custom'
48
- }
49
- ```
50
-
51
- ## 🔧 성능 알림 서비스 구현
52
-
53
- ### 1. 알림 생성 메서드
54
-
55
- ```typescript
56
- export class PerformanceAlertService {
57
- private alerts: Map<string, PerformanceAlert> = new Map();
58
- private logDirectory: string;
59
- private maxAlerts = 1000; // 최대 저장 알림 수
60
-
61
- constructor(logDirectory: string = './logs') {
62
- this.logDirectory = logDirectory;
63
- if (!existsSync(this.logDirectory)) {
64
- mkdirSync(this.logDirectory, { recursive: true });
65
- }
66
- }
67
-
68
- /**
69
- * 성능 알림을 생성하고 로깅합니다.
70
- */
71
- createAlert(
72
- level: AlertLevel,
73
- type: AlertType,
74
- metric: string,
75
- value: number,
76
- threshold: number,
77
- message: string,
78
- context?: Record<string, any>
79
- ): PerformanceAlert {
80
- const id = uuidv4();
81
- const alert: PerformanceAlert = {
82
- id,
83
- timestamp: new Date(),
84
- level,
85
- type,
86
- metric,
87
- value,
88
- threshold,
89
- message,
90
- context,
91
- resolved: false,
92
- };
93
-
94
- this.alerts.set(id, alert);
95
- this.cleanupOldAlerts();
96
- this.logToFile(alert);
97
- this.logToConsole(alert);
98
-
99
- return alert;
100
- }
101
- }
102
- ```
103
-
104
- ### 2. 알림 해결 처리
105
-
106
- ```typescript
107
- /**
108
- * 특정 알림을 해결 상태로 표시합니다.
109
- */
110
- resolveAlert(alertId: string, resolvedBy: string = 'system', resolution?: string): PerformanceAlert | null {
111
- const alert = this.alerts.get(alertId);
112
- if (alert) {
113
- alert.resolved = true;
114
- alert.resolvedAt = new Date();
115
- alert.resolvedBy = resolvedBy;
116
- alert.resolution = resolution;
117
- console.log(`[INFO] 알림 해결됨: ${alertId} by ${resolvedBy}`);
118
- this.logToFile(alert); // 해결된 상태로 다시 로깅
119
- return alert;
120
- }
121
- return null;
122
- }
123
- ```
124
-
125
- ### 3. 알림 검색 및 필터링
126
-
127
- ```typescript
128
- /**
129
- * 필터에 따라 알림을 검색합니다.
130
- */
131
- searchAlerts(filters: AlertSearchFilters): PerformanceAlert[] {
132
- let results = Array.from(this.alerts.values());
133
-
134
- if (filters.level) {
135
- results = results.filter(a => a.level === filters.level);
136
- }
137
- if (filters.type) {
138
- results = results.filter(a => a.type === filters.type);
139
- }
140
- if (filters.resolved !== undefined) {
141
- results = results.filter(a => a.resolved === filters.resolved);
142
- }
143
- if (filters.from) {
144
- results = results.filter(a => a.timestamp >= filters.from!);
145
- }
146
- if (filters.to) {
147
- results = results.filter(a => a.timestamp <= filters.to!);
148
- }
149
-
150
- results.sort((a, b) => b.timestamp.getTime() - a.timestamp.getTime());
151
-
152
- if (filters.limit) {
153
- results = results.slice(0, filters.limit);
154
- }
155
-
156
- return results;
157
- }
158
- ```
159
-
160
- ## 🔄 성능 모니터링 통합
161
-
162
- ### 1. 실시간 모니터링 설정
163
-
164
- ```typescript
165
- export class PerformanceMonitoringIntegration {
166
- private db: Database.Database;
167
- private performanceMonitor: PerformanceMonitor;
168
- private performanceAlertService: PerformanceAlertService;
169
- private config: MonitoringConfig;
170
- private monitoringTimer: NodeJS.Timeout | null = null;
171
-
172
- constructor(
173
- db: Database.Database,
174
- performanceAlertService: PerformanceAlertService,
175
- config: MonitoringConfig
176
- ) {
177
- this.db = db;
178
- this.performanceMonitor = new PerformanceMonitor(db);
179
- this.performanceAlertService = performanceAlertService;
180
- this.config = config;
181
- }
182
-
183
- /**
184
- * 실시간 성능 모니터링을 시작합니다.
185
- */
186
- startRealTimeMonitoring(): void {
187
- if (!this.config.enableRealTimeMonitoring) {
188
- console.log('실시간 성능 모니터링이 비활성화되어 있습니다.');
189
- return;
190
- }
191
-
192
- if (this.monitoringTimer) {
193
- console.warn('실시간 성능 모니터링이 이미 실행 중입니다.');
194
- return;
195
- }
196
-
197
- console.log(`실시간 성능 모니터링 시작. 주기: ${this.config.monitoringInterval / 1000}초`);
198
- this.monitoringTimer = setInterval(() => this.checkPerformance(), this.config.monitoringInterval);
199
- }
200
- }
201
- ```
202
-
203
- ### 2. 성능 체크 및 임계값 확인
204
-
205
- ```typescript
206
- /**
207
- * 현재 성능 지표를 확인하고 알림을 생성합니다.
208
- */
209
- private async checkPerformance(): Promise<void> {
210
- try {
211
- // 1. 시스템 메트릭 수집
212
- const systemMetrics = this.performanceMonitor.getSystemMetrics();
213
- const dbMetrics = DatabaseUtils.getDatabaseStatus(this.db);
214
-
215
- // 2. 성능 통계 가져오기
216
- const overallStats = this.performanceMonitor.getOverallStats();
217
- const queryStats = this.performanceMonitor.getQueryStats();
218
- const searchStats = this.performanceMonitor.getSearchStats();
219
-
220
- // 3. 알림 임계값 확인 및 알림 생성
221
- this.checkResponseTime(overallStats.avgResponseTime);
222
- this.checkMemoryUsage(systemMetrics.heapUsedMB);
223
- this.checkErrorRate(overallStats.errorRate);
224
- this.checkThroughput(overallStats.throughput);
225
-
226
- // 4. 데이터베이스 관련 알림
227
- if (dbMetrics.isLocked) {
228
- this.performanceAlertService.createAlert(
229
- AlertLevel.CRITICAL,
230
- AlertType.CUSTOM,
231
- 'Database Lock',
232
- 1,
233
- 0,
234
- '🔴 데이터베이스 잠금 감지! 심각한 성능 저하가 예상됩니다.',
235
- { dbStatus: dbMetrics }
236
- );
237
- }
238
- } catch (error) {
239
- console.error('❌ 성능 모니터링 중 오류 발생:', error);
240
- this.performanceAlertService.createAlert(
241
- AlertLevel.CRITICAL,
242
- AlertType.CUSTOM,
243
- 'Monitoring Error',
244
- 1,
245
- 0,
246
- `❌ 성능 모니터링 시스템 자체 오류: ${(error as Error).message}`,
247
- { error: (error as Error).stack }
248
- );
249
- }
250
- }
251
- ```
252
-
253
- ### 3. 임계값 확인 메서드들
254
-
255
- ```typescript
256
- private checkResponseTime(avgResponseTime: number): void {
257
- const { warning, critical } = this.config.alertThresholds.responseTime;
258
- if (avgResponseTime >= critical) {
259
- this.performanceAlertService.createAlert(
260
- AlertLevel.CRITICAL,
261
- AlertType.RESPONSE_TIME,
262
- '평균 응답시간',
263
- avgResponseTime,
264
- critical,
265
- `🔴 평균 응답시간이 심각한 임계값(${critical}ms)을 초과했습니다: ${avgResponseTime.toFixed(2)}ms`,
266
- { avgResponseTime }
267
- );
268
- } else if (avgResponseTime >= warning) {
269
- this.performanceAlertService.createAlert(
270
- AlertLevel.WARNING,
271
- AlertType.RESPONSE_TIME,
272
- '평균 응답시간',
273
- avgResponseTime,
274
- warning,
275
- `🟡 평균 응답시간이 임계값(${warning}ms)을 초과했습니다: ${avgResponseTime.toFixed(2)}ms`,
276
- { avgResponseTime }
277
- );
278
- }
279
- }
280
-
281
- private checkMemoryUsage(heapUsedMB: number): void {
282
- const { warning, critical } = this.config.alertThresholds.memoryUsage;
283
- if (heapUsedMB >= critical) {
284
- this.performanceAlertService.createAlert(
285
- AlertLevel.CRITICAL,
286
- AlertType.MEMORY_USAGE,
287
- '메모리 사용량',
288
- heapUsedMB,
289
- critical,
290
- `🔴 메모리 사용량이 심각한 임계값(${critical}MB)을 초과했습니다: ${heapUsedMB.toFixed(2)}MB`,
291
- { heapUsedMB }
292
- );
293
- } else if (heapUsedMB >= warning) {
294
- this.performanceAlertService.createAlert(
295
- AlertLevel.WARNING,
296
- AlertType.MEMORY_USAGE,
297
- '메모리 사용량',
298
- heapUsedMB,
299
- warning,
300
- `🟡 메모리 사용량이 임계값(${warning}MB)을 초과했습니다: ${heapUsedMB.toFixed(2)}MB`,
301
- { heapUsedMB }
302
- );
303
- }
304
- }
305
- ```
306
-
307
- ## 🛠️ MCP 도구 구현
308
-
309
- ### 1. performance_alerts 도구
310
-
311
- ```typescript
312
- export const performanceAlertsTool: ToolDefinition = {
313
- name: 'performance_alerts',
314
- description: '실시간 성능 알림을 조회, 검색 및 관리합니다.',
315
- inputSchema: z.object({
316
- action: z.enum(['stats', 'list', 'search', 'resolve']).describe('수행할 작업'),
317
- alertId: z.string().optional().describe('해결할 알림의 고유 ID (action이 "resolve"일 때 필수)'),
318
- resolvedBy: z.string().optional().describe('알림을 해결한 주체'),
319
- resolution: z.string().optional().describe('알림 해결에 대한 설명'),
320
- level: z.nativeEnum(AlertLevel).optional().describe('조회할 알림의 심각도'),
321
- type: z.nativeEnum(AlertType).optional().describe('조회할 알림의 유형'),
322
- includeResolved: z.boolean().optional().default(false).describe('해결된 알림을 포함할지 여부'),
323
- hours: z.number().min(1).optional().describe('지난 몇 시간 동안의 알림을 조회할지 지정'),
324
- limit: z.number().min(1).max(100).optional().default(10).describe('반환할 알림 로그의 최대 개수'),
325
- }),
326
- handler: async (params: z.infer<typeof performanceAlertsTool.inputSchema>, context: ToolContext) => {
327
- return executePerformanceAlerts(params, context);
328
- },
329
- };
330
- ```
331
-
332
- ### 2. 도구 핸들러 구현
333
-
334
- ```typescript
335
- export async function executePerformanceAlerts(
336
- params: z.infer<typeof performanceAlertsTool.inputSchema>,
337
- context: ToolContext
338
- ) {
339
- if (!context.services?.performanceAlertService) {
340
- throw new Error('PerformanceAlertService가 초기화되지 않았습니다.');
341
- }
342
-
343
- const { action, alertId, resolvedBy, resolution, level, type, includeResolved, hours, limit } = params;
344
-
345
- switch (action) {
346
- case 'stats':
347
- return handleStats(context);
348
- case 'list':
349
- return handleList(context, includeResolved, limit);
350
- case 'search':
351
- return handleSearch(context, { level, type, includeResolved, hours, limit });
352
- case 'resolve':
353
- if (!alertId) throw new Error('알림을 해결하려면 alertId가 필요합니다.');
354
- return handleResolve(context, alertId, resolvedBy, resolution);
355
- default:
356
- throw new Error(`알 수 없는 작업: ${action}`);
357
- }
358
- }
359
- ```
360
-
361
- ## 📊 로깅 및 모니터링
362
-
363
- ### 1. 파일 로깅
364
-
365
- ```typescript
366
- private logToFile(alert: PerformanceAlert): void {
367
- const date = alert.timestamp.toISOString().split('T')[0];
368
- const logFilePath = join(this.logDirectory, `performance-alerts-${date}.jsonl`);
369
- appendFileSync(logFilePath, JSON.stringify(alert) + '\n');
370
- }
371
- ```
372
-
373
- ### 2. 콘솔 로깅
374
-
375
- ```typescript
376
- private logToConsole(alert: PerformanceAlert): void {
377
- let color = '';
378
- switch (alert.level) {
379
- case AlertLevel.INFO:
380
- color = '\x1b[34m'; // Blue
381
- break;
382
- case AlertLevel.WARNING:
383
- color = '\x1b[33m'; // Yellow
384
- break;
385
- case AlertLevel.CRITICAL:
386
- color = '\x1b[31m'; // Red
387
- break;
388
- }
389
- const resetColor = '\x1b[0m';
390
- console.warn(`${color}[${alert.level}] ${alert.metric}${resetColor}\n ID: ${alert.id}\n Time: ${alert.timestamp.toISOString()}\n Value: ${alert.value} (Threshold: ${alert.threshold})\n Message: ${alert.message}\n Context: ${JSON.stringify(alert.context, null, 2)}\n`);
391
- }
392
- ```
393
-
394
- ### 3. 오래된 알림 정리
395
-
396
- ```typescript
397
- private cleanupOldAlerts(): void {
398
- if (this.alerts.size > this.maxAlerts) {
399
- const sortedAlerts = Array.from(this.alerts.values())
400
- .sort((a, b) => a.timestamp.getTime() - b.timestamp.getTime());
401
-
402
- for (let i = 0; i < this.alerts.size - this.maxAlerts; i++) {
403
- this.alerts.delete(sortedAlerts[i].id);
404
- }
405
- }
406
- }
407
- ```
408
-
409
- ## 🧪 테스트 작성
410
-
411
- ### 1. 성능 알림 테스트
412
-
413
- ```typescript
414
- // src/test-performance-alerts.ts
415
- import { MementoClient } from './client/index.js';
416
- import { AlertLevel, AlertType } from './services/performance-alert-service.js';
417
-
418
- async function runPerformanceAlertsTest() {
419
- console.log('🚀 성능 알림 시스템 테스트 시작');
420
- const client = new MementoClient();
421
-
422
- try {
423
- await client.connect({
424
- transport: {
425
- type: 'websocket',
426
- url: 'ws://localhost:8080/mcp'
427
- }
428
- });
429
-
430
- // 1. 초기 알림 통계 조회
431
- console.log('\n📊 초기 알림 통계:');
432
- const initialStats = await client.callTool('performance_alerts', { action: 'stats' });
433
- console.log(JSON.stringify(initialStats, null, 2));
434
-
435
- // 2. 활성 알림 목록 조회
436
- console.log('\n🚨 활성 알림 목록:');
437
- const activeAlerts = await client.callTool('performance_alerts', { action: 'list' });
438
- console.log(JSON.stringify(activeAlerts, null, 2));
439
-
440
- // 3. 알림 해결 테스트
441
- if (activeAlerts.activeAlerts && activeAlerts.activeAlerts.length > 0) {
442
- const alertToResolve = activeAlerts.activeAlerts[0];
443
- console.log(`\n🛠️ 알림 해결 테스트: ${alertToResolve.id}`);
444
- const resolveResult = await client.callTool('performance_alerts', {
445
- action: 'resolve',
446
- alertId: alertToResolve.id,
447
- resolvedBy: 'test_script',
448
- resolution: '테스트 스크립트에 의해 해결됨'
449
- });
450
- console.log(JSON.stringify(resolveResult, null, 2));
451
- }
452
-
453
- } catch (error) {
454
- console.error('❌ 성능 알림 테스트 중 오류 발생:', error);
455
- } finally {
456
- await client.disconnect();
457
- console.log('🎉 성능 알림 시스템 테스트 완료');
458
- }
459
- }
460
- ```
461
-
462
- ### 2. 간단한 알림 테스트
463
-
464
- ```typescript
465
- // src/test-simple-alerts.ts
466
- import { PerformanceAlertService, AlertLevel, AlertType } from './services/performance-alert-service.js';
467
-
468
- async function testSimpleAlerts() {
469
- console.log('🚨 간단한 성능 알림 테스트 시작');
470
-
471
- const alertService = new PerformanceAlertService('./logs');
472
-
473
- // 1. 다양한 레벨의 알림 생성
474
- const alert1 = alertService.createAlert(
475
- AlertLevel.WARNING,
476
- AlertType.RESPONSE_TIME,
477
- '응답시간',
478
- 150,
479
- 100,
480
- '🟡 응답시간 초과 임계값: 150 > 100',
481
- { component: 'search_engine', operation: 'search' }
482
- );
483
-
484
- const alert2 = alertService.createAlert(
485
- AlertLevel.CRITICAL,
486
- AlertType.MEMORY_USAGE,
487
- '메모리 사용량',
488
- 200,
489
- 150,
490
- '🔴 메모리 사용량 심각한 초과: 200 > 150',
491
- { component: 'memory_manager', heapTotal: 300 }
492
- );
493
-
494
- // 2. 알림 통계 조회
495
- const stats = alertService.getStats();
496
- console.log('📈 알림 통계:', stats);
497
-
498
- // 3. 알림 해결 테스트
499
- const resolved = alertService.resolveAlert(alert1.id, 'test_user', '테스트 해결');
500
- console.log('✅ 알림 해결:', resolved);
501
- }
502
- ```
503
-
504
- ## 📋 개발 체크리스트
505
-
506
- ### 성능 알림 서비스
507
- - [ ] PerformanceAlertService 클래스 구현
508
- - [ ] 알림 레벨 및 유형 분류
509
- - [ ] 알림 생성 및 관리
510
- - [ ] 알림 해결 추적 시스템
511
- - [ ] 파일 및 콘솔 로깅
512
- - [ ] 오래된 알림 자동 정리
513
-
514
- ### 성능 모니터링 통합
515
- - [ ] PerformanceMonitoringIntegration 클래스 구현
516
- - [ ] 실시간 모니터링 설정
517
- - [ ] 임계값 기반 알림 생성
518
- - [ ] 성능 메트릭 수집
519
- - [ ] 자동 복구 작업
520
-
521
- ### MCP 도구
522
- - [ ] performance_alerts 도구 구현
523
- - [ ] 도구 등록 및 통합
524
- - [ ] 에러 처리 및 검증
525
- - [ ] 다양한 액션 지원
526
-
527
- ### 테스트
528
- - [ ] 성능 알림 테스트 스크립트
529
- - [ ] 간단한 알림 테스트
530
- - [ ] 통합 테스트 구현
531
- - [ ] 실시간 모니터링 테스트
532
-
533
- ### 모니터링
534
- - [ ] 실시간 성능 모니터링
535
- - [ ] 임계값 설정 및 관리
536
- - [ ] 알림 패턴 분석
537
- - [ ] 대시보드 통합