@neverinfamous/mysql-mcp 2.1.0 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (751) hide show
  1. package/.env.example +14 -4
  2. package/.github/ISSUE_TEMPLATE/bug_report.md +7 -1
  3. package/.github/ISSUE_TEMPLATE/feature_request.md +6 -1
  4. package/.github/dependabot.yml +15 -0
  5. package/.github/pull_request_template.md +5 -0
  6. package/.github/workflows/codeql.yml +41 -42
  7. package/.github/workflows/docker-publish.yml +248 -210
  8. package/.github/workflows/publish-npm.yml +16 -6
  9. package/CHANGELOG.md +272 -22
  10. package/CODE_OF_CONDUCT.md +2 -0
  11. package/DOCKER_README.md +222 -156
  12. package/Dockerfile +2 -2
  13. package/README.md +210 -176
  14. package/SECURITY.md +0 -8
  15. package/VERSION +1 -1
  16. package/dist/__tests__/mocks/adapter.d.ts +3 -3
  17. package/dist/__tests__/mocks/adapter.d.ts.map +1 -1
  18. package/dist/__tests__/mocks/adapter.js +51 -35
  19. package/dist/__tests__/mocks/adapter.js.map +1 -1
  20. package/dist/__tests__/mocks/index.d.ts +4 -4
  21. package/dist/__tests__/mocks/index.d.ts.map +1 -1
  22. package/dist/__tests__/mocks/index.js +2 -2
  23. package/dist/__tests__/mocks/index.js.map +1 -1
  24. package/dist/__tests__/mocks/mysql.d.ts +2 -2
  25. package/dist/__tests__/mocks/mysql.d.ts.map +1 -1
  26. package/dist/__tests__/mocks/mysql.js +14 -14
  27. package/dist/__tests__/mocks/mysql.js.map +1 -1
  28. package/dist/__tests__/setup.d.ts.map +1 -1
  29. package/dist/__tests__/setup.js +7 -7
  30. package/dist/__tests__/setup.js.map +1 -1
  31. package/dist/adapters/DatabaseAdapter.d.ts +2 -2
  32. package/dist/adapters/DatabaseAdapter.d.ts.map +1 -1
  33. package/dist/adapters/DatabaseAdapter.js +69 -40
  34. package/dist/adapters/DatabaseAdapter.js.map +1 -1
  35. package/dist/adapters/mysql/MySQLAdapter.d.ts +10 -4
  36. package/dist/adapters/mysql/MySQLAdapter.d.ts.map +1 -1
  37. package/dist/adapters/mysql/MySQLAdapter.js +143 -116
  38. package/dist/adapters/mysql/MySQLAdapter.js.map +1 -1
  39. package/dist/adapters/mysql/SchemaManager.d.ts +1 -1
  40. package/dist/adapters/mysql/SchemaManager.d.ts.map +1 -1
  41. package/dist/adapters/mysql/SchemaManager.js +76 -56
  42. package/dist/adapters/mysql/SchemaManager.js.map +1 -1
  43. package/dist/adapters/mysql/index.d.ts +2 -2
  44. package/dist/adapters/mysql/index.js +2 -2
  45. package/dist/adapters/mysql/prompts/backupStrategy.d.ts +1 -1
  46. package/dist/adapters/mysql/prompts/backupStrategy.d.ts.map +1 -1
  47. package/dist/adapters/mysql/prompts/backupStrategy.js +21 -9
  48. package/dist/adapters/mysql/prompts/backupStrategy.js.map +1 -1
  49. package/dist/adapters/mysql/prompts/clusterSetup.d.ts +1 -1
  50. package/dist/adapters/mysql/prompts/clusterSetup.d.ts.map +1 -1
  51. package/dist/adapters/mysql/prompts/clusterSetup.js +3 -3
  52. package/dist/adapters/mysql/prompts/clusterSetup.js.map +1 -1
  53. package/dist/adapters/mysql/prompts/docstoreSetup.d.ts +1 -1
  54. package/dist/adapters/mysql/prompts/docstoreSetup.js +3 -3
  55. package/dist/adapters/mysql/prompts/docstoreSetup.js.map +1 -1
  56. package/dist/adapters/mysql/prompts/eventScheduler.d.ts +1 -1
  57. package/dist/adapters/mysql/prompts/eventScheduler.js +3 -3
  58. package/dist/adapters/mysql/prompts/eventScheduler.js.map +1 -1
  59. package/dist/adapters/mysql/prompts/healthCheck.d.ts +1 -1
  60. package/dist/adapters/mysql/prompts/healthCheck.d.ts.map +1 -1
  61. package/dist/adapters/mysql/prompts/healthCheck.js +10 -6
  62. package/dist/adapters/mysql/prompts/healthCheck.js.map +1 -1
  63. package/dist/adapters/mysql/prompts/index.d.ts +2 -2
  64. package/dist/adapters/mysql/prompts/index.d.ts.map +1 -1
  65. package/dist/adapters/mysql/prompts/index.js +98 -62
  66. package/dist/adapters/mysql/prompts/index.js.map +1 -1
  67. package/dist/adapters/mysql/prompts/indexTuning.d.ts +1 -1
  68. package/dist/adapters/mysql/prompts/indexTuning.d.ts.map +1 -1
  69. package/dist/adapters/mysql/prompts/indexTuning.js +11 -7
  70. package/dist/adapters/mysql/prompts/indexTuning.js.map +1 -1
  71. package/dist/adapters/mysql/prompts/mysqlshSetup.d.ts +1 -1
  72. package/dist/adapters/mysql/prompts/mysqlshSetup.js +4 -4
  73. package/dist/adapters/mysql/prompts/mysqlshSetup.js.map +1 -1
  74. package/dist/adapters/mysql/prompts/proxysqlSetup.d.ts +1 -1
  75. package/dist/adapters/mysql/prompts/proxysqlSetup.js +3 -3
  76. package/dist/adapters/mysql/prompts/proxysqlSetup.js.map +1 -1
  77. package/dist/adapters/mysql/prompts/replicationSetup.d.ts +1 -1
  78. package/dist/adapters/mysql/prompts/replicationSetup.d.ts.map +1 -1
  79. package/dist/adapters/mysql/prompts/replicationSetup.js +13 -7
  80. package/dist/adapters/mysql/prompts/replicationSetup.js.map +1 -1
  81. package/dist/adapters/mysql/prompts/routerSetup.d.ts +1 -1
  82. package/dist/adapters/mysql/prompts/routerSetup.js +3 -3
  83. package/dist/adapters/mysql/prompts/routerSetup.js.map +1 -1
  84. package/dist/adapters/mysql/prompts/spatialSetup.d.ts +1 -1
  85. package/dist/adapters/mysql/prompts/spatialSetup.js +3 -3
  86. package/dist/adapters/mysql/prompts/spatialSetup.js.map +1 -1
  87. package/dist/adapters/mysql/prompts/sysSchema.d.ts +1 -1
  88. package/dist/adapters/mysql/prompts/sysSchema.d.ts.map +1 -1
  89. package/dist/adapters/mysql/prompts/sysSchema.js +3 -3
  90. package/dist/adapters/mysql/prompts/sysSchema.js.map +1 -1
  91. package/dist/adapters/mysql/resources/capabilities.d.ts +2 -2
  92. package/dist/adapters/mysql/resources/capabilities.d.ts.map +1 -1
  93. package/dist/adapters/mysql/resources/capabilities.js +17 -15
  94. package/dist/adapters/mysql/resources/capabilities.js.map +1 -1
  95. package/dist/adapters/mysql/resources/cluster.d.ts +2 -2
  96. package/dist/adapters/mysql/resources/cluster.d.ts.map +1 -1
  97. package/dist/adapters/mysql/resources/cluster.js +17 -15
  98. package/dist/adapters/mysql/resources/cluster.js.map +1 -1
  99. package/dist/adapters/mysql/resources/docstore.d.ts +2 -2
  100. package/dist/adapters/mysql/resources/docstore.d.ts.map +1 -1
  101. package/dist/adapters/mysql/resources/docstore.js +12 -12
  102. package/dist/adapters/mysql/resources/docstore.js.map +1 -1
  103. package/dist/adapters/mysql/resources/events.d.ts +2 -2
  104. package/dist/adapters/mysql/resources/events.d.ts.map +1 -1
  105. package/dist/adapters/mysql/resources/events.js +12 -12
  106. package/dist/adapters/mysql/resources/events.js.map +1 -1
  107. package/dist/adapters/mysql/resources/health.d.ts +2 -2
  108. package/dist/adapters/mysql/resources/health.d.ts.map +1 -1
  109. package/dist/adapters/mysql/resources/health.js +36 -32
  110. package/dist/adapters/mysql/resources/health.js.map +1 -1
  111. package/dist/adapters/mysql/resources/index.d.ts +2 -2
  112. package/dist/adapters/mysql/resources/index.js +19 -19
  113. package/dist/adapters/mysql/resources/index.js.map +1 -1
  114. package/dist/adapters/mysql/resources/indexes.d.ts +2 -2
  115. package/dist/adapters/mysql/resources/indexes.d.ts.map +1 -1
  116. package/dist/adapters/mysql/resources/indexes.js +12 -12
  117. package/dist/adapters/mysql/resources/indexes.js.map +1 -1
  118. package/dist/adapters/mysql/resources/innodb.d.ts +2 -2
  119. package/dist/adapters/mysql/resources/innodb.d.ts.map +1 -1
  120. package/dist/adapters/mysql/resources/innodb.js +37 -36
  121. package/dist/adapters/mysql/resources/innodb.js.map +1 -1
  122. package/dist/adapters/mysql/resources/locks.d.ts +2 -2
  123. package/dist/adapters/mysql/resources/locks.d.ts.map +1 -1
  124. package/dist/adapters/mysql/resources/locks.js +14 -14
  125. package/dist/adapters/mysql/resources/locks.js.map +1 -1
  126. package/dist/adapters/mysql/resources/performance.d.ts +2 -2
  127. package/dist/adapters/mysql/resources/performance.d.ts.map +1 -1
  128. package/dist/adapters/mysql/resources/performance.js +30 -29
  129. package/dist/adapters/mysql/resources/performance.js.map +1 -1
  130. package/dist/adapters/mysql/resources/pool.d.ts +2 -2
  131. package/dist/adapters/mysql/resources/pool.d.ts.map +1 -1
  132. package/dist/adapters/mysql/resources/pool.js +9 -9
  133. package/dist/adapters/mysql/resources/pool.js.map +1 -1
  134. package/dist/adapters/mysql/resources/processlist.d.ts +2 -2
  135. package/dist/adapters/mysql/resources/processlist.d.ts.map +1 -1
  136. package/dist/adapters/mysql/resources/processlist.js +9 -9
  137. package/dist/adapters/mysql/resources/processlist.js.map +1 -1
  138. package/dist/adapters/mysql/resources/replication.d.ts +2 -2
  139. package/dist/adapters/mysql/resources/replication.d.ts.map +1 -1
  140. package/dist/adapters/mysql/resources/replication.js +42 -35
  141. package/dist/adapters/mysql/resources/replication.js.map +1 -1
  142. package/dist/adapters/mysql/resources/schema.d.ts +2 -2
  143. package/dist/adapters/mysql/resources/schema.d.ts.map +1 -1
  144. package/dist/adapters/mysql/resources/schema.js +8 -8
  145. package/dist/adapters/mysql/resources/schema.js.map +1 -1
  146. package/dist/adapters/mysql/resources/spatial.d.ts +2 -2
  147. package/dist/adapters/mysql/resources/spatial.d.ts.map +1 -1
  148. package/dist/adapters/mysql/resources/spatial.js +9 -9
  149. package/dist/adapters/mysql/resources/spatial.js.map +1 -1
  150. package/dist/adapters/mysql/resources/status.d.ts +2 -2
  151. package/dist/adapters/mysql/resources/status.d.ts.map +1 -1
  152. package/dist/adapters/mysql/resources/status.js +10 -10
  153. package/dist/adapters/mysql/resources/status.js.map +1 -1
  154. package/dist/adapters/mysql/resources/sysschema.d.ts +2 -2
  155. package/dist/adapters/mysql/resources/sysschema.d.ts.map +1 -1
  156. package/dist/adapters/mysql/resources/sysschema.js +10 -10
  157. package/dist/adapters/mysql/resources/sysschema.js.map +1 -1
  158. package/dist/adapters/mysql/resources/tables.d.ts +2 -2
  159. package/dist/adapters/mysql/resources/tables.d.ts.map +1 -1
  160. package/dist/adapters/mysql/resources/tables.js +8 -8
  161. package/dist/adapters/mysql/resources/tables.js.map +1 -1
  162. package/dist/adapters/mysql/resources/variables.d.ts +2 -2
  163. package/dist/adapters/mysql/resources/variables.d.ts.map +1 -1
  164. package/dist/adapters/mysql/resources/variables.js +10 -10
  165. package/dist/adapters/mysql/resources/variables.js.map +1 -1
  166. package/dist/adapters/mysql/tools/admin/backup.d.ts +2 -2
  167. package/dist/adapters/mysql/tools/admin/backup.d.ts.map +1 -1
  168. package/dist/adapters/mysql/tools/admin/backup.js +191 -99
  169. package/dist/adapters/mysql/tools/admin/backup.js.map +1 -1
  170. package/dist/adapters/mysql/tools/admin/index.d.ts +2 -2
  171. package/dist/adapters/mysql/tools/admin/index.js +6 -6
  172. package/dist/adapters/mysql/tools/admin/index.js.map +1 -1
  173. package/dist/adapters/mysql/tools/admin/maintenance.d.ts +2 -2
  174. package/dist/adapters/mysql/tools/admin/maintenance.d.ts.map +1 -1
  175. package/dist/adapters/mysql/tools/admin/maintenance.js +93 -62
  176. package/dist/adapters/mysql/tools/admin/maintenance.js.map +1 -1
  177. package/dist/adapters/mysql/tools/admin/monitoring.d.ts +2 -2
  178. package/dist/adapters/mysql/tools/admin/monitoring.d.ts.map +1 -1
  179. package/dist/adapters/mysql/tools/admin/monitoring.js +215 -79
  180. package/dist/adapters/mysql/tools/admin/monitoring.js.map +1 -1
  181. package/dist/adapters/mysql/tools/cluster/group-replication.d.ts +2 -2
  182. package/dist/adapters/mysql/tools/cluster/group-replication.d.ts.map +1 -1
  183. package/dist/adapters/mysql/tools/cluster/group-replication.js +90 -74
  184. package/dist/adapters/mysql/tools/cluster/group-replication.js.map +1 -1
  185. package/dist/adapters/mysql/tools/cluster/index.d.ts +2 -2
  186. package/dist/adapters/mysql/tools/cluster/index.js +3 -3
  187. package/dist/adapters/mysql/tools/cluster/index.js.map +1 -1
  188. package/dist/adapters/mysql/tools/cluster/innodb-cluster.d.ts +2 -2
  189. package/dist/adapters/mysql/tools/cluster/innodb-cluster.d.ts.map +1 -1
  190. package/dist/adapters/mysql/tools/cluster/innodb-cluster.js +204 -97
  191. package/dist/adapters/mysql/tools/cluster/innodb-cluster.js.map +1 -1
  192. package/dist/adapters/mysql/tools/core.d.ts +2 -2
  193. package/dist/adapters/mysql/tools/core.d.ts.map +1 -1
  194. package/dist/adapters/mysql/tools/core.js +205 -97
  195. package/dist/adapters/mysql/tools/core.js.map +1 -1
  196. package/dist/adapters/mysql/tools/docstore.d.ts +2 -2
  197. package/dist/adapters/mysql/tools/docstore.d.ts.map +1 -1
  198. package/dist/adapters/mysql/tools/docstore.js +252 -117
  199. package/dist/adapters/mysql/tools/docstore.js.map +1 -1
  200. package/dist/adapters/mysql/tools/events.d.ts +2 -2
  201. package/dist/adapters/mysql/tools/events.d.ts.map +1 -1
  202. package/dist/adapters/mysql/tools/events.js +219 -108
  203. package/dist/adapters/mysql/tools/events.js.map +1 -1
  204. package/dist/adapters/mysql/tools/index.d.ts +19 -19
  205. package/dist/adapters/mysql/tools/index.d.ts.map +1 -1
  206. package/dist/adapters/mysql/tools/index.js +19 -19
  207. package/dist/adapters/mysql/tools/index.js.map +1 -1
  208. package/dist/adapters/mysql/tools/json/core.d.ts +2 -2
  209. package/dist/adapters/mysql/tools/json/core.d.ts.map +1 -1
  210. package/dist/adapters/mysql/tools/json/core.js +221 -127
  211. package/dist/adapters/mysql/tools/json/core.js.map +1 -1
  212. package/dist/adapters/mysql/tools/json/enhanced.d.ts +2 -2
  213. package/dist/adapters/mysql/tools/json/enhanced.d.ts.map +1 -1
  214. package/dist/adapters/mysql/tools/json/enhanced.js +274 -163
  215. package/dist/adapters/mysql/tools/json/enhanced.js.map +1 -1
  216. package/dist/adapters/mysql/tools/json/helpers.d.ts +2 -2
  217. package/dist/adapters/mysql/tools/json/helpers.d.ts.map +1 -1
  218. package/dist/adapters/mysql/tools/json/helpers.js +134 -56
  219. package/dist/adapters/mysql/tools/json/helpers.js.map +1 -1
  220. package/dist/adapters/mysql/tools/json/index.d.ts +2 -2
  221. package/dist/adapters/mysql/tools/json/index.js +6 -6
  222. package/dist/adapters/mysql/tools/json/index.js.map +1 -1
  223. package/dist/adapters/mysql/tools/partitioning.d.ts +2 -2
  224. package/dist/adapters/mysql/tools/partitioning.js +143 -59
  225. package/dist/adapters/mysql/tools/partitioning.js.map +1 -1
  226. package/dist/adapters/mysql/tools/performance/analysis.d.ts +2 -2
  227. package/dist/adapters/mysql/tools/performance/analysis.d.ts.map +1 -1
  228. package/dist/adapters/mysql/tools/performance/analysis.js +122 -86
  229. package/dist/adapters/mysql/tools/performance/analysis.js.map +1 -1
  230. package/dist/adapters/mysql/tools/performance/index.d.ts +2 -2
  231. package/dist/adapters/mysql/tools/performance/index.js +4 -4
  232. package/dist/adapters/mysql/tools/performance/index.js.map +1 -1
  233. package/dist/adapters/mysql/tools/performance/optimization.d.ts +3 -3
  234. package/dist/adapters/mysql/tools/performance/optimization.d.ts.map +1 -1
  235. package/dist/adapters/mysql/tools/performance/optimization.js +195 -73
  236. package/dist/adapters/mysql/tools/performance/optimization.js.map +1 -1
  237. package/dist/adapters/mysql/tools/proxysql.d.ts +2 -2
  238. package/dist/adapters/mysql/tools/proxysql.d.ts.map +1 -1
  239. package/dist/adapters/mysql/tools/proxysql.js +213 -125
  240. package/dist/adapters/mysql/tools/proxysql.js.map +1 -1
  241. package/dist/adapters/mysql/tools/replication.d.ts +2 -2
  242. package/dist/adapters/mysql/tools/replication.d.ts.map +1 -1
  243. package/dist/adapters/mysql/tools/replication.js +117 -66
  244. package/dist/adapters/mysql/tools/replication.js.map +1 -1
  245. package/dist/adapters/mysql/tools/roles.d.ts +2 -2
  246. package/dist/adapters/mysql/tools/roles.d.ts.map +1 -1
  247. package/dist/adapters/mysql/tools/roles.js +276 -84
  248. package/dist/adapters/mysql/tools/roles.js.map +1 -1
  249. package/dist/adapters/mysql/tools/router.d.ts +2 -2
  250. package/dist/adapters/mysql/tools/router.d.ts.map +1 -1
  251. package/dist/adapters/mysql/tools/router.js +174 -109
  252. package/dist/adapters/mysql/tools/router.js.map +1 -1
  253. package/dist/adapters/mysql/tools/schema/constraints.d.ts +2 -2
  254. package/dist/adapters/mysql/tools/schema/constraints.d.ts.map +1 -1
  255. package/dist/adapters/mysql/tools/schema/constraints.js +24 -15
  256. package/dist/adapters/mysql/tools/schema/constraints.js.map +1 -1
  257. package/dist/adapters/mysql/tools/schema/index.d.ts +2 -2
  258. package/dist/adapters/mysql/tools/schema/index.d.ts.map +1 -1
  259. package/dist/adapters/mysql/tools/schema/index.js +7 -7
  260. package/dist/adapters/mysql/tools/schema/index.js.map +1 -1
  261. package/dist/adapters/mysql/tools/schema/management.d.ts +2 -2
  262. package/dist/adapters/mysql/tools/schema/management.d.ts.map +1 -1
  263. package/dist/adapters/mysql/tools/schema/management.js +99 -42
  264. package/dist/adapters/mysql/tools/schema/management.js.map +1 -1
  265. package/dist/adapters/mysql/tools/schema/routines.d.ts +2 -2
  266. package/dist/adapters/mysql/tools/schema/routines.d.ts.map +1 -1
  267. package/dist/adapters/mysql/tools/schema/routines.js +36 -19
  268. package/dist/adapters/mysql/tools/schema/routines.js.map +1 -1
  269. package/dist/adapters/mysql/tools/schema/scheduled_events.d.ts +2 -2
  270. package/dist/adapters/mysql/tools/schema/scheduled_events.d.ts.map +1 -1
  271. package/dist/adapters/mysql/tools/schema/scheduled_events.js +26 -13
  272. package/dist/adapters/mysql/tools/schema/scheduled_events.js.map +1 -1
  273. package/dist/adapters/mysql/tools/schema/triggers.d.ts +2 -2
  274. package/dist/adapters/mysql/tools/schema/triggers.d.ts.map +1 -1
  275. package/dist/adapters/mysql/tools/schema/triggers.js +24 -13
  276. package/dist/adapters/mysql/tools/schema/triggers.js.map +1 -1
  277. package/dist/adapters/mysql/tools/schema/views.d.ts +2 -2
  278. package/dist/adapters/mysql/tools/schema/views.d.ts.map +1 -1
  279. package/dist/adapters/mysql/tools/schema/views.js +59 -28
  280. package/dist/adapters/mysql/tools/schema/views.js.map +1 -1
  281. package/dist/adapters/mysql/tools/security/audit.d.ts +2 -2
  282. package/dist/adapters/mysql/tools/security/audit.d.ts.map +1 -1
  283. package/dist/adapters/mysql/tools/security/audit.js +61 -55
  284. package/dist/adapters/mysql/tools/security/audit.js.map +1 -1
  285. package/dist/adapters/mysql/tools/security/data-protection.d.ts +2 -2
  286. package/dist/adapters/mysql/tools/security/data-protection.d.ts.map +1 -1
  287. package/dist/adapters/mysql/tools/security/data-protection.js +188 -80
  288. package/dist/adapters/mysql/tools/security/data-protection.js.map +1 -1
  289. package/dist/adapters/mysql/tools/security/encryption.d.ts +2 -2
  290. package/dist/adapters/mysql/tools/security/encryption.d.ts.map +1 -1
  291. package/dist/adapters/mysql/tools/security/encryption.js +86 -67
  292. package/dist/adapters/mysql/tools/security/encryption.js.map +1 -1
  293. package/dist/adapters/mysql/tools/security/index.d.ts +2 -2
  294. package/dist/adapters/mysql/tools/security/index.js +4 -4
  295. package/dist/adapters/mysql/tools/security/index.js.map +1 -1
  296. package/dist/adapters/mysql/tools/shell/backup.d.ts +1 -1
  297. package/dist/adapters/mysql/tools/shell/backup.d.ts.map +1 -1
  298. package/dist/adapters/mysql/tools/shell/backup.js +122 -63
  299. package/dist/adapters/mysql/tools/shell/backup.js.map +1 -1
  300. package/dist/adapters/mysql/tools/shell/common.d.ts.map +1 -1
  301. package/dist/adapters/mysql/tools/shell/common.js +34 -36
  302. package/dist/adapters/mysql/tools/shell/common.js.map +1 -1
  303. package/dist/adapters/mysql/tools/shell/data-transfer.d.ts +1 -1
  304. package/dist/adapters/mysql/tools/shell/data-transfer.d.ts.map +1 -1
  305. package/dist/adapters/mysql/tools/shell/data-transfer.js +125 -69
  306. package/dist/adapters/mysql/tools/shell/data-transfer.js.map +1 -1
  307. package/dist/adapters/mysql/tools/shell/index.d.ts +2 -2
  308. package/dist/adapters/mysql/tools/shell/index.js +6 -6
  309. package/dist/adapters/mysql/tools/shell/index.js.map +1 -1
  310. package/dist/adapters/mysql/tools/shell/info.d.ts +1 -1
  311. package/dist/adapters/mysql/tools/shell/info.d.ts.map +1 -1
  312. package/dist/adapters/mysql/tools/shell/info.js +12 -12
  313. package/dist/adapters/mysql/tools/shell/info.js.map +1 -1
  314. package/dist/adapters/mysql/tools/shell/restore.d.ts +1 -1
  315. package/dist/adapters/mysql/tools/shell/restore.d.ts.map +1 -1
  316. package/dist/adapters/mysql/tools/shell/restore.js +77 -42
  317. package/dist/adapters/mysql/tools/shell/restore.js.map +1 -1
  318. package/dist/adapters/mysql/tools/shell/utilities.d.ts +1 -1
  319. package/dist/adapters/mysql/tools/shell/utilities.d.ts.map +1 -1
  320. package/dist/adapters/mysql/tools/shell/utilities.js +42 -18
  321. package/dist/adapters/mysql/tools/shell/utilities.js.map +1 -1
  322. package/dist/adapters/mysql/tools/spatial/geometry.d.ts +2 -2
  323. package/dist/adapters/mysql/tools/spatial/geometry.d.ts.map +1 -1
  324. package/dist/adapters/mysql/tools/spatial/geometry.js +85 -46
  325. package/dist/adapters/mysql/tools/spatial/geometry.js.map +1 -1
  326. package/dist/adapters/mysql/tools/spatial/index.d.ts +2 -2
  327. package/dist/adapters/mysql/tools/spatial/index.js +5 -5
  328. package/dist/adapters/mysql/tools/spatial/index.js.map +1 -1
  329. package/dist/adapters/mysql/tools/spatial/operations.d.ts +2 -2
  330. package/dist/adapters/mysql/tools/spatial/operations.d.ts.map +1 -1
  331. package/dist/adapters/mysql/tools/spatial/operations.js +167 -106
  332. package/dist/adapters/mysql/tools/spatial/operations.js.map +1 -1
  333. package/dist/adapters/mysql/tools/spatial/queries.d.ts +2 -2
  334. package/dist/adapters/mysql/tools/spatial/queries.d.ts.map +1 -1
  335. package/dist/adapters/mysql/tools/spatial/queries.js +144 -100
  336. package/dist/adapters/mysql/tools/spatial/queries.js.map +1 -1
  337. package/dist/adapters/mysql/tools/spatial/setup.d.ts +2 -2
  338. package/dist/adapters/mysql/tools/spatial/setup.d.ts.map +1 -1
  339. package/dist/adapters/mysql/tools/spatial/setup.js +104 -34
  340. package/dist/adapters/mysql/tools/spatial/setup.js.map +1 -1
  341. package/dist/adapters/mysql/tools/stats/comparative.d.ts +2 -2
  342. package/dist/adapters/mysql/tools/stats/comparative.d.ts.map +1 -1
  343. package/dist/adapters/mysql/tools/stats/comparative.js +159 -107
  344. package/dist/adapters/mysql/tools/stats/comparative.js.map +1 -1
  345. package/dist/adapters/mysql/tools/stats/descriptive.d.ts +2 -2
  346. package/dist/adapters/mysql/tools/stats/descriptive.d.ts.map +1 -1
  347. package/dist/adapters/mysql/tools/stats/descriptive.js +268 -205
  348. package/dist/adapters/mysql/tools/stats/descriptive.js.map +1 -1
  349. package/dist/adapters/mysql/tools/stats/index.d.ts +2 -2
  350. package/dist/adapters/mysql/tools/stats/index.js +3 -3
  351. package/dist/adapters/mysql/tools/stats/index.js.map +1 -1
  352. package/dist/adapters/mysql/tools/sysschema/activity.d.ts +2 -2
  353. package/dist/adapters/mysql/tools/sysschema/activity.d.ts.map +1 -1
  354. package/dist/adapters/mysql/tools/sysschema/activity.js +23 -23
  355. package/dist/adapters/mysql/tools/sysschema/activity.js.map +1 -1
  356. package/dist/adapters/mysql/tools/sysschema/index.d.ts +2 -2
  357. package/dist/adapters/mysql/tools/sysschema/index.js +4 -4
  358. package/dist/adapters/mysql/tools/sysschema/index.js.map +1 -1
  359. package/dist/adapters/mysql/tools/sysschema/performance.d.ts +2 -2
  360. package/dist/adapters/mysql/tools/sysschema/performance.d.ts.map +1 -1
  361. package/dist/adapters/mysql/tools/sysschema/performance.js +58 -43
  362. package/dist/adapters/mysql/tools/sysschema/performance.js.map +1 -1
  363. package/dist/adapters/mysql/tools/sysschema/resources.d.ts +2 -2
  364. package/dist/adapters/mysql/tools/sysschema/resources.d.ts.map +1 -1
  365. package/dist/adapters/mysql/tools/sysschema/resources.js +53 -33
  366. package/dist/adapters/mysql/tools/sysschema/resources.js.map +1 -1
  367. package/dist/adapters/mysql/tools/text/fulltext.d.ts +4 -3
  368. package/dist/adapters/mysql/tools/text/fulltext.d.ts.map +1 -1
  369. package/dist/adapters/mysql/tools/text/fulltext.js +211 -54
  370. package/dist/adapters/mysql/tools/text/fulltext.js.map +1 -1
  371. package/dist/adapters/mysql/tools/text/index.d.ts +3 -3
  372. package/dist/adapters/mysql/tools/text/index.d.ts.map +1 -1
  373. package/dist/adapters/mysql/tools/text/index.js +6 -5
  374. package/dist/adapters/mysql/tools/text/index.js.map +1 -1
  375. package/dist/adapters/mysql/tools/text/processing.d.ts +2 -2
  376. package/dist/adapters/mysql/tools/text/processing.d.ts.map +1 -1
  377. package/dist/adapters/mysql/tools/text/processing.js +191 -103
  378. package/dist/adapters/mysql/tools/text/processing.js.map +1 -1
  379. package/dist/adapters/mysql/tools/transactions.d.ts +2 -2
  380. package/dist/adapters/mysql/tools/transactions.js +156 -79
  381. package/dist/adapters/mysql/tools/transactions.js.map +1 -1
  382. package/dist/adapters/mysql/types/proxysql-types.d.ts +7 -2
  383. package/dist/adapters/mysql/types/proxysql-types.d.ts.map +1 -1
  384. package/dist/adapters/mysql/types/proxysql-types.js +52 -30
  385. package/dist/adapters/mysql/types/proxysql-types.js.map +1 -1
  386. package/dist/adapters/mysql/types/router-types.d.ts +1 -1
  387. package/dist/adapters/mysql/types/router-types.js +17 -17
  388. package/dist/adapters/mysql/types/router-types.js.map +1 -1
  389. package/dist/adapters/mysql/types/shell-types.d.ts +1 -2
  390. package/dist/adapters/mysql/types/shell-types.d.ts.map +1 -1
  391. package/dist/adapters/mysql/types/shell-types.js +255 -82
  392. package/dist/adapters/mysql/types/shell-types.js.map +1 -1
  393. package/dist/adapters/mysql/types.d.ts +8 -2
  394. package/dist/adapters/mysql/types.d.ts.map +1 -1
  395. package/dist/adapters/mysql/types.js +269 -128
  396. package/dist/adapters/mysql/types.js.map +1 -1
  397. package/dist/auth/AuthorizationServerDiscovery.d.ts +1 -1
  398. package/dist/auth/AuthorizationServerDiscovery.d.ts.map +1 -1
  399. package/dist/auth/AuthorizationServerDiscovery.js +16 -14
  400. package/dist/auth/AuthorizationServerDiscovery.js.map +1 -1
  401. package/dist/auth/OAuthResourceServer.d.ts +1 -1
  402. package/dist/auth/OAuthResourceServer.d.ts.map +1 -1
  403. package/dist/auth/OAuthResourceServer.js +4 -4
  404. package/dist/auth/OAuthResourceServer.js.map +1 -1
  405. package/dist/auth/TokenValidator.d.ts +1 -1
  406. package/dist/auth/TokenValidator.d.ts.map +1 -1
  407. package/dist/auth/TokenValidator.js +30 -20
  408. package/dist/auth/TokenValidator.js.map +1 -1
  409. package/dist/auth/errors.d.ts.map +1 -1
  410. package/dist/auth/errors.js +24 -24
  411. package/dist/auth/errors.js.map +1 -1
  412. package/dist/auth/index.d.ts +7 -7
  413. package/dist/auth/index.d.ts.map +1 -1
  414. package/dist/auth/index.js +6 -6
  415. package/dist/auth/index.js.map +1 -1
  416. package/dist/auth/middleware.d.ts +2 -2
  417. package/dist/auth/middleware.d.ts.map +1 -1
  418. package/dist/auth/middleware.js +28 -24
  419. package/dist/auth/middleware.js.map +1 -1
  420. package/dist/auth/scopes.d.ts +2 -2
  421. package/dist/auth/scopes.d.ts.map +1 -1
  422. package/dist/auth/scopes.js +22 -16
  423. package/dist/auth/scopes.js.map +1 -1
  424. package/dist/auth/types.d.ts +2 -2
  425. package/dist/auth/types.d.ts.map +1 -1
  426. package/dist/cli/args.d.ts +1 -1
  427. package/dist/cli/args.d.ts.map +1 -1
  428. package/dist/cli/args.js +70 -68
  429. package/dist/cli/args.js.map +1 -1
  430. package/dist/cli.d.ts +1 -1
  431. package/dist/cli.d.ts.map +1 -1
  432. package/dist/cli.js +44 -34
  433. package/dist/cli.js.map +1 -1
  434. package/dist/constants/ServerInstructions.d.ts +2 -2
  435. package/dist/constants/ServerInstructions.d.ts.map +1 -1
  436. package/dist/constants/ServerInstructions.js +228 -36
  437. package/dist/constants/ServerInstructions.js.map +1 -1
  438. package/dist/filtering/ToolConstants.d.ts +6 -6
  439. package/dist/filtering/ToolConstants.d.ts.map +1 -1
  440. package/dist/filtering/ToolConstants.js +229 -208
  441. package/dist/filtering/ToolConstants.js.map +1 -1
  442. package/dist/filtering/ToolFilter.d.ts +2 -2
  443. package/dist/filtering/ToolFilter.d.ts.map +1 -1
  444. package/dist/filtering/ToolFilter.js +35 -36
  445. package/dist/filtering/ToolFilter.js.map +1 -1
  446. package/dist/index.d.ts +9 -9
  447. package/dist/index.d.ts.map +1 -1
  448. package/dist/index.js +7 -7
  449. package/dist/index.js.map +1 -1
  450. package/dist/logging/McpLogging.d.ts +2 -2
  451. package/dist/logging/McpLogging.d.ts.map +1 -1
  452. package/dist/logging/McpLogging.js +16 -13
  453. package/dist/logging/McpLogging.js.map +1 -1
  454. package/dist/logging/index.d.ts +1 -1
  455. package/dist/logging/index.js +1 -1
  456. package/dist/pool/ConnectionPool.d.ts +3 -3
  457. package/dist/pool/ConnectionPool.d.ts.map +1 -1
  458. package/dist/pool/ConnectionPool.js +30 -26
  459. package/dist/pool/ConnectionPool.js.map +1 -1
  460. package/dist/progress/ProgressReporter.d.ts +1 -1
  461. package/dist/progress/ProgressReporter.d.ts.map +1 -1
  462. package/dist/progress/ProgressReporter.js +5 -5
  463. package/dist/progress/ProgressReporter.js.map +1 -1
  464. package/dist/progress/index.d.ts +1 -1
  465. package/dist/progress/index.d.ts.map +1 -1
  466. package/dist/progress/index.js +1 -1
  467. package/dist/progress/index.js.map +1 -1
  468. package/dist/server/McpServer.d.ts +3 -3
  469. package/dist/server/McpServer.d.ts.map +1 -1
  470. package/dist/server/McpServer.js +58 -53
  471. package/dist/server/McpServer.js.map +1 -1
  472. package/dist/transports/http.d.ts +3 -3
  473. package/dist/transports/http.d.ts.map +1 -1
  474. package/dist/transports/http.js +36 -33
  475. package/dist/transports/http.js.map +1 -1
  476. package/dist/transports/index.d.ts +1 -1
  477. package/dist/transports/index.d.ts.map +1 -1
  478. package/dist/transports/index.js +1 -1
  479. package/dist/transports/index.js.map +1 -1
  480. package/dist/types/index.d.ts +6 -6
  481. package/dist/types/index.d.ts.map +1 -1
  482. package/dist/types/index.js +1 -1
  483. package/dist/types/index.js.map +1 -1
  484. package/dist/types/modules/database.d.ts +1 -1
  485. package/dist/types/modules/database.d.ts.map +1 -1
  486. package/dist/types/modules/errors.d.ts.map +1 -1
  487. package/dist/types/modules/errors.js +15 -15
  488. package/dist/types/modules/errors.js.map +1 -1
  489. package/dist/types/modules/oauth.d.ts +1 -1
  490. package/dist/types/modules/oauth.d.ts.map +1 -1
  491. package/dist/types/modules/query.d.ts +8 -8
  492. package/dist/types/modules/query.d.ts.map +1 -1
  493. package/dist/types/modules/server.d.ts +3 -3
  494. package/dist/types/modules/server.d.ts.map +1 -1
  495. package/dist/types/modules/tools.d.ts +6 -6
  496. package/dist/types/modules/tools.d.ts.map +1 -1
  497. package/dist/utils/logger.d.ts +2 -2
  498. package/dist/utils/logger.d.ts.map +1 -1
  499. package/dist/utils/logger.js +58 -55
  500. package/dist/utils/logger.js.map +1 -1
  501. package/dist/utils/promptGenerator.d.ts +1 -1
  502. package/dist/utils/promptGenerator.d.ts.map +1 -1
  503. package/dist/utils/promptGenerator.js +24 -16
  504. package/dist/utils/promptGenerator.js.map +1 -1
  505. package/dist/utils/validators.d.ts +21 -2
  506. package/dist/utils/validators.d.ts.map +1 -1
  507. package/dist/utils/validators.js +101 -13
  508. package/dist/utils/validators.js.map +1 -1
  509. package/eslint.config.js +117 -81
  510. package/package.json +61 -64
  511. package/releases/release-notes.md +32 -26
  512. package/releases/v2.0.0-release-notes.md +99 -51
  513. package/releases/v2.1.0-release-notes.md +14 -5
  514. package/releases/v2.2.0-release-notes.md +239 -0
  515. package/server.json +1 -1
  516. package/src/__tests__/cli.test.ts +302 -247
  517. package/src/__tests__/index.test.ts +21 -21
  518. package/src/__tests__/mocks/adapter.ts +204 -163
  519. package/src/__tests__/mocks/index.ts +30 -23
  520. package/src/__tests__/mocks/mysql.ts +94 -84
  521. package/src/__tests__/perf.test.ts +207 -203
  522. package/src/__tests__/performance.test.ts +173 -164
  523. package/src/__tests__/setup.ts +26 -21
  524. package/src/adapters/DatabaseAdapter.ts +386 -340
  525. package/src/adapters/__tests__/DatabaseAdapter.test.ts +455 -377
  526. package/src/adapters/mysql/MySQLAdapter.ts +550 -486
  527. package/src/adapters/mysql/SchemaManager.ts +251 -208
  528. package/src/adapters/mysql/__tests__/MySQLAdapter.integration.test.ts +150 -147
  529. package/src/adapters/mysql/__tests__/MySQLAdapter.test.ts +590 -477
  530. package/src/adapters/mysql/__tests__/SchemaManager.test.ts +196 -154
  531. package/src/adapters/mysql/index.ts +2 -2
  532. package/src/adapters/mysql/prompts/__tests__/indexTuning.test.ts +33 -26
  533. package/src/adapters/mysql/prompts/__tests__/prompts.test.ts +277 -239
  534. package/src/adapters/mysql/prompts/backupStrategy.ts +29 -17
  535. package/src/adapters/mysql/prompts/clusterSetup.ts +11 -10
  536. package/src/adapters/mysql/prompts/docstoreSetup.ts +10 -10
  537. package/src/adapters/mysql/prompts/eventScheduler.ts +10 -10
  538. package/src/adapters/mysql/prompts/healthCheck.ts +20 -15
  539. package/src/adapters/mysql/prompts/index.ts +194 -144
  540. package/src/adapters/mysql/prompts/indexTuning.ts +22 -17
  541. package/src/adapters/mysql/prompts/mysqlshSetup.ts +11 -11
  542. package/src/adapters/mysql/prompts/proxysqlSetup.ts +10 -10
  543. package/src/adapters/mysql/prompts/replicationSetup.ts +24 -16
  544. package/src/adapters/mysql/prompts/routerSetup.ts +10 -10
  545. package/src/adapters/mysql/prompts/spatialSetup.ts +10 -10
  546. package/src/adapters/mysql/prompts/sysSchema.ts +11 -10
  547. package/src/adapters/mysql/resources/__tests__/capabilities.test.ts +69 -47
  548. package/src/adapters/mysql/resources/__tests__/cluster.test.ts +163 -104
  549. package/src/adapters/mysql/resources/__tests__/docstore.test.ts +88 -81
  550. package/src/adapters/mysql/resources/__tests__/events.test.ts +94 -83
  551. package/src/adapters/mysql/resources/__tests__/health.test.ts +131 -91
  552. package/src/adapters/mysql/resources/__tests__/indexes.test.ts +125 -102
  553. package/src/adapters/mysql/resources/__tests__/innodb.test.ts +86 -62
  554. package/src/adapters/mysql/resources/__tests__/locks.test.ts +142 -104
  555. package/src/adapters/mysql/resources/__tests__/performance.test.ts +81 -58
  556. package/src/adapters/mysql/resources/__tests__/pool.test.ts +45 -40
  557. package/src/adapters/mysql/resources/__tests__/processlist.test.ts +39 -23
  558. package/src/adapters/mysql/resources/__tests__/replication.test.ts +265 -211
  559. package/src/adapters/mysql/resources/__tests__/resources.test.ts +121 -109
  560. package/src/adapters/mysql/resources/__tests__/schema.test.ts +29 -23
  561. package/src/adapters/mysql/resources/__tests__/spatial.test.ts +58 -45
  562. package/src/adapters/mysql/resources/__tests__/status.test.ts +62 -45
  563. package/src/adapters/mysql/resources/__tests__/sysschema.test.ts +99 -60
  564. package/src/adapters/mysql/resources/__tests__/tables.test.ts +41 -32
  565. package/src/adapters/mysql/resources/__tests__/variables.test.ts +77 -49
  566. package/src/adapters/mysql/resources/capabilities.ts +59 -42
  567. package/src/adapters/mysql/resources/cluster.ts +58 -49
  568. package/src/adapters/mysql/resources/docstore.ts +46 -41
  569. package/src/adapters/mysql/resources/events.ts +37 -31
  570. package/src/adapters/mysql/resources/health.ts +98 -74
  571. package/src/adapters/mysql/resources/index.ts +46 -46
  572. package/src/adapters/mysql/resources/indexes.ts +66 -51
  573. package/src/adapters/mysql/resources/innodb.ts +98 -81
  574. package/src/adapters/mysql/resources/locks.ts +43 -40
  575. package/src/adapters/mysql/resources/performance.ts +80 -67
  576. package/src/adapters/mysql/resources/pool.ts +23 -20
  577. package/src/adapters/mysql/resources/processlist.ts +23 -18
  578. package/src/adapters/mysql/resources/replication.ts +124 -105
  579. package/src/adapters/mysql/resources/schema.ts +23 -18
  580. package/src/adapters/mysql/resources/spatial.ts +31 -26
  581. package/src/adapters/mysql/resources/status.ts +27 -22
  582. package/src/adapters/mysql/resources/sysschema.ts +41 -36
  583. package/src/adapters/mysql/resources/tables.ts +23 -18
  584. package/src/adapters/mysql/resources/variables.ts +27 -22
  585. package/src/adapters/mysql/tools/__tests__/cluster.test.ts +419 -311
  586. package/src/adapters/mysql/tools/__tests__/core.test.ts +633 -382
  587. package/src/adapters/mysql/tools/__tests__/docstore.test.ts +782 -413
  588. package/src/adapters/mysql/tools/__tests__/events.test.ts +752 -486
  589. package/src/adapters/mysql/tools/__tests__/json_core.test.ts +326 -259
  590. package/src/adapters/mysql/tools/__tests__/json_enhanced.test.ts +452 -352
  591. package/src/adapters/mysql/tools/__tests__/json_helpers.test.ts +169 -136
  592. package/src/adapters/mysql/tools/__tests__/proxysql.test.ts +576 -340
  593. package/src/adapters/mysql/tools/__tests__/replication.test.ts +697 -393
  594. package/src/adapters/mysql/tools/__tests__/roles.test.ts +423 -166
  595. package/src/adapters/mysql/tools/__tests__/router.test.ts +644 -540
  596. package/src/adapters/mysql/tools/__tests__/security.test.ts +708 -422
  597. package/src/adapters/mysql/tools/__tests__/security_injection.test.ts +246 -173
  598. package/src/adapters/mysql/tools/__tests__/security_integration.test.ts +244 -205
  599. package/src/adapters/mysql/tools/__tests__/spatial.test.ts +413 -300
  600. package/src/adapters/mysql/tools/__tests__/spatial_handler.test.ts +503 -150
  601. package/src/adapters/mysql/tools/__tests__/stats.test.ts +861 -553
  602. package/src/adapters/mysql/tools/__tests__/transactions.test.ts +454 -263
  603. package/src/adapters/mysql/tools/admin/__tests__/backup.test.ts +612 -372
  604. package/src/adapters/mysql/tools/admin/__tests__/maintenance.test.ts +550 -257
  605. package/src/adapters/mysql/tools/admin/__tests__/monitoring.test.ts +549 -352
  606. package/src/adapters/mysql/tools/admin/backup.ts +334 -215
  607. package/src/adapters/mysql/tools/admin/index.ts +46 -46
  608. package/src/adapters/mysql/tools/admin/maintenance.ts +176 -130
  609. package/src/adapters/mysql/tools/admin/monitoring.ts +373 -199
  610. package/src/adapters/mysql/tools/cluster/__tests__/group-replication.test.ts +200 -186
  611. package/src/adapters/mysql/tools/cluster/__tests__/innodb-cluster.test.ts +364 -95
  612. package/src/adapters/mysql/tools/cluster/group-replication.ts +218 -183
  613. package/src/adapters/mysql/tools/cluster/index.ts +27 -27
  614. package/src/adapters/mysql/tools/cluster/innodb-cluster.ts +392 -251
  615. package/src/adapters/mysql/tools/core.ts +408 -285
  616. package/src/adapters/mysql/tools/docstore.ts +478 -276
  617. package/src/adapters/mysql/tools/events.ts +425 -285
  618. package/src/adapters/mysql/tools/index.ts +31 -20
  619. package/src/adapters/mysql/tools/json/__tests__/core.test.ts +456 -199
  620. package/src/adapters/mysql/tools/json/__tests__/enhanced.test.ts +554 -298
  621. package/src/adapters/mysql/tools/json/__tests__/helpers.test.ts +150 -74
  622. package/src/adapters/mysql/tools/json/__tests__/validation.test.ts +106 -72
  623. package/src/adapters/mysql/tools/json/core.ts +364 -263
  624. package/src/adapters/mysql/tools/json/enhanced.ts +368 -229
  625. package/src/adapters/mysql/tools/json/helpers.ts +195 -113
  626. package/src/adapters/mysql/tools/json/index.ts +46 -46
  627. package/src/adapters/mysql/tools/partitioning.ts +242 -140
  628. package/src/adapters/mysql/tools/performance/__tests__/analysis.test.ts +439 -247
  629. package/src/adapters/mysql/tools/performance/__tests__/optimization.test.ts +401 -179
  630. package/src/adapters/mysql/tools/performance/analysis.ts +263 -213
  631. package/src/adapters/mysql/tools/performance/index.ts +33 -33
  632. package/src/adapters/mysql/tools/performance/optimization.ts +407 -190
  633. package/src/adapters/mysql/tools/proxysql.ts +462 -320
  634. package/src/adapters/mysql/tools/replication.ts +233 -180
  635. package/src/adapters/mysql/tools/roles.ts +429 -171
  636. package/src/adapters/mysql/tools/router.ts +410 -292
  637. package/src/adapters/mysql/tools/schema/__tests__/constraints.test.ts +157 -82
  638. package/src/adapters/mysql/tools/schema/__tests__/management.test.ts +226 -101
  639. package/src/adapters/mysql/tools/schema/__tests__/routines.test.ts +80 -35
  640. package/src/adapters/mysql/tools/schema/__tests__/scheduled_events.test.ts +59 -40
  641. package/src/adapters/mysql/tools/schema/__tests__/triggers.test.ts +65 -40
  642. package/src/adapters/mysql/tools/schema/__tests__/views.test.ts +146 -77
  643. package/src/adapters/mysql/tools/schema/constraints.ts +61 -42
  644. package/src/adapters/mysql/tools/schema/index.ts +26 -35
  645. package/src/adapters/mysql/tools/schema/management.ts +167 -94
  646. package/src/adapters/mysql/tools/schema/routines.ts +79 -48
  647. package/src/adapters/mysql/tools/schema/scheduled_events.ts +53 -32
  648. package/src/adapters/mysql/tools/schema/triggers.ts +51 -33
  649. package/src/adapters/mysql/tools/schema/views.ts +96 -53
  650. package/src/adapters/mysql/tools/security/__tests__/audit.test.ts +216 -158
  651. package/src/adapters/mysql/tools/security/__tests__/data-protection.test.ts +154 -98
  652. package/src/adapters/mysql/tools/security/__tests__/encryption.test.ts +174 -138
  653. package/src/adapters/mysql/tools/security/audit.ts +213 -193
  654. package/src/adapters/mysql/tools/security/data-protection.ts +336 -198
  655. package/src/adapters/mysql/tools/security/encryption.ts +233 -193
  656. package/src/adapters/mysql/tools/security/index.ts +26 -26
  657. package/src/adapters/mysql/tools/shell/__tests__/backup.test.ts +443 -283
  658. package/src/adapters/mysql/tools/shell/__tests__/common.test.ts +138 -131
  659. package/src/adapters/mysql/tools/shell/__tests__/data-transfer.test.ts +516 -353
  660. package/src/adapters/mysql/tools/shell/__tests__/info.test.ts +65 -63
  661. package/src/adapters/mysql/tools/shell/__tests__/restore.test.ts +233 -174
  662. package/src/adapters/mysql/tools/shell/__tests__/utilities.test.ts +161 -143
  663. package/src/adapters/mysql/tools/shell/backup.ts +280 -188
  664. package/src/adapters/mysql/tools/shell/common.ts +173 -155
  665. package/src/adapters/mysql/tools/shell/data-transfer.ts +286 -200
  666. package/src/adapters/mysql/tools/shell/index.ts +29 -29
  667. package/src/adapters/mysql/tools/shell/info.ts +35 -31
  668. package/src/adapters/mysql/tools/shell/restore.ts +176 -124
  669. package/src/adapters/mysql/tools/shell/utilities.ts +86 -45
  670. package/src/adapters/mysql/tools/spatial/__tests__/geometry.test.ts +129 -89
  671. package/src/adapters/mysql/tools/spatial/__tests__/operations.test.ts +255 -148
  672. package/src/adapters/mysql/tools/spatial/__tests__/queries.test.ts +340 -245
  673. package/src/adapters/mysql/tools/spatial/geometry.ts +120 -74
  674. package/src/adapters/mysql/tools/spatial/index.ts +33 -33
  675. package/src/adapters/mysql/tools/spatial/operations.ts +243 -171
  676. package/src/adapters/mysql/tools/spatial/queries.ts +221 -165
  677. package/src/adapters/mysql/tools/spatial/setup.ts +157 -73
  678. package/src/adapters/mysql/tools/stats/__tests__/comparative.test.ts +188 -130
  679. package/src/adapters/mysql/tools/stats/comparative.ts +261 -187
  680. package/src/adapters/mysql/tools/stats/descriptive.ts +414 -322
  681. package/src/adapters/mysql/tools/stats/index.ts +23 -23
  682. package/src/adapters/mysql/tools/sysschema/__tests__/activity.test.ts +99 -71
  683. package/src/adapters/mysql/tools/sysschema/__tests__/io_summary_fix.test.ts +21 -18
  684. package/src/adapters/mysql/tools/sysschema/__tests__/performance.test.ts +149 -108
  685. package/src/adapters/mysql/tools/sysschema/__tests__/resources.test.ts +222 -104
  686. package/src/adapters/mysql/tools/sysschema/activity.ts +72 -64
  687. package/src/adapters/mysql/tools/sysschema/index.ts +24 -24
  688. package/src/adapters/mysql/tools/sysschema/performance.ts +140 -115
  689. package/src/adapters/mysql/tools/sysschema/resources.ts +135 -99
  690. package/src/adapters/mysql/tools/text/__tests__/fulltext.test.ts +526 -145
  691. package/src/adapters/mysql/tools/text/__tests__/processing.test.ts +452 -193
  692. package/src/adapters/mysql/tools/text/fulltext.ts +319 -123
  693. package/src/adapters/mysql/tools/text/index.ts +32 -30
  694. package/src/adapters/mysql/tools/text/processing.ts +310 -212
  695. package/src/adapters/mysql/tools/transactions.ts +284 -197
  696. package/src/adapters/mysql/types/__tests__/shell-types.test.ts +204 -202
  697. package/src/adapters/mysql/types/proxysql-types.ts +142 -109
  698. package/src/adapters/mysql/types/router-types.ts +36 -36
  699. package/src/adapters/mysql/types/shell-types.ts +280 -94
  700. package/src/adapters/mysql/types.ts +288 -131
  701. package/src/auth/AuthorizationServerDiscovery.ts +127 -113
  702. package/src/auth/OAuthResourceServer.ts +67 -62
  703. package/src/auth/TokenValidator.ts +136 -119
  704. package/src/auth/__tests__/AuthorizationServerDiscovery.test.ts +295 -274
  705. package/src/auth/__tests__/OAuthResourceServer.test.ts +180 -169
  706. package/src/auth/__tests__/TokenValidator.test.ts +297 -285
  707. package/src/auth/__tests__/errors.test.ts +180 -175
  708. package/src/auth/__tests__/middleware.test.ts +281 -247
  709. package/src/auth/__tests__/scopes.test.ts +136 -134
  710. package/src/auth/errors.ts +56 -56
  711. package/src/auth/index.ts +23 -17
  712. package/src/auth/middleware.ts +161 -139
  713. package/src/auth/scopes.ts +133 -107
  714. package/src/auth/types.ts +155 -155
  715. package/src/cli/__tests__/args.test.ts +241 -216
  716. package/src/cli/__tests__/main.test.ts +191 -158
  717. package/src/cli/args.ts +271 -258
  718. package/src/cli.ts +150 -127
  719. package/src/constants/ServerInstructions.ts +271 -70
  720. package/src/filtering/ToolConstants.ts +287 -266
  721. package/src/filtering/ToolFilter.ts +239 -220
  722. package/src/filtering/__tests__/ToolFilter.test.ts +442 -396
  723. package/src/index.ts +62 -57
  724. package/src/logging/McpLogging.ts +128 -119
  725. package/src/logging/__tests__/McpLogging.test.ts +223 -223
  726. package/src/logging/index.ts +2 -2
  727. package/src/pool/ConnectionPool.ts +260 -246
  728. package/src/pool/__tests__/ConnectionPool.test.ts +452 -418
  729. package/src/progress/ProgressReporter.ts +123 -123
  730. package/src/progress/__tests__/ProgressReporter.test.ts +235 -229
  731. package/src/progress/index.ts +6 -2
  732. package/src/server/McpServer.ts +305 -285
  733. package/src/server/__tests__/McpServer.test.ts +333 -291
  734. package/src/transports/__tests__/http.test.ts +658 -527
  735. package/src/transports/http.ts +237 -203
  736. package/src/transports/index.ts +6 -2
  737. package/src/types/__tests__/types.test.ts +197 -193
  738. package/src/types/index.ts +49 -37
  739. package/src/types/modules/database.ts +65 -63
  740. package/src/types/modules/errors.ts +41 -37
  741. package/src/types/modules/oauth.ts +46 -46
  742. package/src/types/modules/query.ts +75 -75
  743. package/src/types/modules/server.ts +18 -18
  744. package/src/types/modules/tools.ts +181 -178
  745. package/src/utils/__tests__/logger.test.ts +424 -414
  746. package/src/utils/__tests__/validators.test.ts +250 -165
  747. package/src/utils/logger.ts +343 -330
  748. package/src/utils/promptGenerator.ts +58 -47
  749. package/src/utils/validators.ts +217 -91
  750. package/tsconfig.json +41 -50
  751. package/vitest.config.ts +23 -23
@@ -1,380 +1,480 @@
1
1
  /**
2
2
  * mysql-mcp - JSON Enhanced Tools Unit Tests
3
- *
3
+ *
4
4
  * Tests for JSON enhanced tool definitions and handler execution.
5
5
  */
6
6
 
7
- import { describe, it, expect, vi, beforeEach } from 'vitest';
8
- import { getJsonEnhancedTools } from '../json/index.js';
9
- import type { MySQLAdapter } from '../../MySQLAdapter.js';
10
- import { createMockMySQLAdapter, createMockQueryResult, createMockRequestContext } from '../../../../__tests__/mocks/index.js';
7
+ import { describe, it, expect, vi, beforeEach } from "vitest";
8
+ import { getJsonEnhancedTools } from "../json/index.js";
9
+ import type { MySQLAdapter } from "../../MySQLAdapter.js";
10
+ import {
11
+ createMockMySQLAdapter,
12
+ createMockQueryResult,
13
+ createMockRequestContext,
14
+ } from "../../../../__tests__/mocks/index.js";
15
+
16
+ describe("getJsonEnhancedTools", () => {
17
+ let tools: ReturnType<typeof getJsonEnhancedTools>;
18
+
19
+ beforeEach(() => {
20
+ vi.clearAllMocks();
21
+ tools = getJsonEnhancedTools(
22
+ createMockMySQLAdapter() as unknown as MySQLAdapter,
23
+ );
24
+ });
25
+
26
+ it("should return 5 enhanced JSON tools", () => {
27
+ expect(tools).toHaveLength(5);
28
+ });
29
+
30
+ it("should include merge, diff, normalize, stats, index_suggest", () => {
31
+ const toolNames = tools.map((t) => t.name);
32
+ expect(toolNames).toContain("mysql_json_merge");
33
+ expect(toolNames).toContain("mysql_json_diff");
34
+ expect(toolNames).toContain("mysql_json_normalize");
35
+ expect(toolNames).toContain("mysql_json_stats");
36
+ expect(toolNames).toContain("mysql_json_index_suggest");
37
+ });
38
+
39
+ it("mysql_json_diff should be read-only", () => {
40
+ const tool = tools.find((t) => t.name === "mysql_json_diff")!;
41
+ expect(tool.annotations?.readOnlyHint).toBe(true);
42
+ });
43
+ });
11
44
 
12
- describe('getJsonEnhancedTools', () => {
13
- let tools: ReturnType<typeof getJsonEnhancedTools>;
45
+ describe("JSON Enhanced Handler Execution", () => {
46
+ let mockAdapter: ReturnType<typeof createMockMySQLAdapter>;
47
+ let tools: ReturnType<typeof getJsonEnhancedTools>;
48
+ let mockContext: ReturnType<typeof createMockRequestContext>;
49
+
50
+ beforeEach(() => {
51
+ vi.clearAllMocks();
52
+ mockAdapter = createMockMySQLAdapter();
53
+ tools = getJsonEnhancedTools(mockAdapter as unknown as MySQLAdapter);
54
+ mockContext = createMockRequestContext();
55
+ });
56
+
57
+ describe("mysql_json_merge", () => {
58
+ it("should merge JSON documents using patch mode", async () => {
59
+ mockAdapter.executeReadQuery.mockResolvedValue(
60
+ createMockQueryResult([{ merged: '{"a":1,"b":2}' }]),
61
+ );
62
+
63
+ const tool = tools.find((t) => t.name === "mysql_json_merge")!;
64
+ const result = (await tool.handler(
65
+ {
66
+ json1: '{"a":1}',
67
+ json2: '{"b":2}',
68
+ mode: "patch",
69
+ },
70
+ mockContext,
71
+ )) as { merged: unknown; mode: string };
72
+
73
+ expect(mockAdapter.executeReadQuery).toHaveBeenCalled();
74
+ const call = mockAdapter.executeReadQuery.mock.calls[0][0] as string;
75
+ expect(call).toContain("JSON_MERGE_PATCH");
76
+ expect(result.mode).toBe("patch");
77
+ });
14
78
 
15
- beforeEach(() => {
16
- vi.clearAllMocks();
17
- tools = getJsonEnhancedTools(createMockMySQLAdapter() as unknown as MySQLAdapter);
79
+ it("should merge JSON documents using preserve mode", async () => {
80
+ mockAdapter.executeReadQuery.mockResolvedValue(
81
+ createMockQueryResult([{ merged: '{"a":[1,2]}' }]),
82
+ );
83
+
84
+ const tool = tools.find((t) => t.name === "mysql_json_merge")!;
85
+ await tool.handler(
86
+ {
87
+ json1: '{"a":[1]}',
88
+ json2: '{"a":[2]}',
89
+ mode: "preserve",
90
+ },
91
+ mockContext,
92
+ );
93
+
94
+ const call = mockAdapter.executeReadQuery.mock.calls[0][0] as string;
95
+ expect(call).toContain("JSON_MERGE_PRESERVE");
96
+ });
97
+ });
98
+
99
+ describe("mysql_json_diff", () => {
100
+ it("should compute JSON diff and compare documents", async () => {
101
+ mockAdapter.executeReadQuery.mockResolvedValue(
102
+ createMockQueryResult([
103
+ {
104
+ identical: 0,
105
+ json1_contains_json2: 0,
106
+ json2_contains_json1: 0,
107
+ json1_length: 2,
108
+ json2_length: 2,
109
+ json1_keys: '["a","b"]',
110
+ json2_keys: '["a","c"]',
111
+ },
112
+ ]),
113
+ );
114
+
115
+ const tool = tools.find((t) => t.name === "mysql_json_diff")!;
116
+ const result = (await tool.handler(
117
+ {
118
+ json1: '{"a":1,"b":2}',
119
+ json2: '{"a":1,"c":3}',
120
+ },
121
+ mockContext,
122
+ )) as { identical: boolean; json1Keys: string[] };
123
+
124
+ expect(mockAdapter.executeReadQuery).toHaveBeenCalled();
125
+ expect(result.identical).toBe(false);
126
+ expect(result.json1Keys).toEqual(["a", "b"]);
18
127
  });
19
128
 
20
- it('should return 5 enhanced JSON tools', () => {
21
- expect(tools).toHaveLength(5);
129
+ it("should detect identical JSON documents", async () => {
130
+ mockAdapter.executeReadQuery.mockResolvedValue(
131
+ createMockQueryResult([
132
+ {
133
+ identical: 1,
134
+ json1_contains_json2: 1,
135
+ json2_contains_json1: 1,
136
+ json1_length: 1,
137
+ json2_length: 1,
138
+ json1_keys: '["a"]',
139
+ json2_keys: '["a"]',
140
+ },
141
+ ]),
142
+ );
143
+
144
+ const tool = tools.find((t) => t.name === "mysql_json_diff")!;
145
+ const result = (await tool.handler(
146
+ {
147
+ json1: '{"a":1}',
148
+ json2: '{"a":1}',
149
+ },
150
+ mockContext,
151
+ )) as { identical: boolean };
152
+
153
+ expect(result.identical).toBe(true);
154
+ });
155
+ });
156
+
157
+ describe("mysql_json_normalize", () => {
158
+ it("should extract unique keys from JSON column", async () => {
159
+ mockAdapter.executeQuery
160
+ .mockResolvedValueOnce(
161
+ createMockQueryResult([{ key_name: "name" }, { key_name: "email" }]),
162
+ )
163
+ .mockResolvedValue(
164
+ createMockQueryResult([{ value_type: "STRING", count: 10 }]),
165
+ );
166
+
167
+ const tool = tools.find((t) => t.name === "mysql_json_normalize")!;
168
+ const result = (await tool.handler(
169
+ {
170
+ table: "users",
171
+ column: "metadata",
172
+ limit: 100,
173
+ },
174
+ mockContext,
175
+ )) as { uniqueKeys: string[]; keyCount: number };
176
+
177
+ expect(mockAdapter.executeQuery).toHaveBeenCalled();
178
+ expect(result.uniqueKeys).toEqual(["name", "email"]);
179
+ expect(result.keyCount).toBe(2);
22
180
  });
23
181
 
24
- it('should include merge, diff, normalize, stats, index_suggest', () => {
25
- const toolNames = tools.map(t => t.name);
26
- expect(toolNames).toContain('mysql_json_merge');
27
- expect(toolNames).toContain('mysql_json_diff');
28
- expect(toolNames).toContain('mysql_json_normalize');
29
- expect(toolNames).toContain('mysql_json_stats');
30
- expect(toolNames).toContain('mysql_json_index_suggest');
182
+ it("should reject invalid table names", async () => {
183
+ const tool = tools.find((t) => t.name === "mysql_json_normalize")!;
184
+
185
+ await expect(
186
+ tool.handler(
187
+ {
188
+ table: "users; DROP TABLE--",
189
+ column: "metadata",
190
+ limit: 100,
191
+ },
192
+ mockContext,
193
+ ),
194
+ ).rejects.toThrow("Invalid table name");
31
195
  });
32
196
 
33
- it('mysql_json_diff should be read-only', () => {
34
- const tool = tools.find(t => t.name === 'mysql_json_diff')!;
35
- expect(tool.annotations?.readOnlyHint).toBe(true);
197
+ it("should reject invalid column names", async () => {
198
+ const tool = tools.find((t) => t.name === "mysql_json_normalize")!;
199
+
200
+ await expect(
201
+ tool.handler(
202
+ {
203
+ table: "users",
204
+ column: "data/*comment*/",
205
+ limit: 100,
206
+ },
207
+ mockContext,
208
+ ),
209
+ ).rejects.toThrow("Invalid column name");
210
+ });
211
+
212
+ it("should handle database errors during normalization", async () => {
213
+ mockAdapter.executeQuery.mockRejectedValue(new Error("Database error"));
214
+
215
+ const tool = tools.find((t) => t.name === "mysql_json_normalize")!;
216
+ const result = (await tool.handler(
217
+ {
218
+ table: "users",
219
+ column: "metadata",
220
+ limit: 100,
221
+ },
222
+ mockContext,
223
+ )) as { success: boolean; error: string };
224
+
225
+ expect(result.success).toBe(false);
226
+ expect(result.error).toContain("Database error");
227
+ });
228
+ });
229
+
230
+ describe("mysql_json_stats", () => {
231
+ it("should compute JSON column statistics", async () => {
232
+ mockAdapter.executeQuery.mockResolvedValue(
233
+ createMockQueryResult([
234
+ {
235
+ total_rows: 100,
236
+ null_count: 5,
237
+ avg_length: 3.5,
238
+ max_length: 10,
239
+ min_length: 1,
240
+ avg_depth: 2.1,
241
+ max_depth: 4,
242
+ avg_size_bytes: 150,
243
+ max_size_bytes: 500,
244
+ },
245
+ ]),
246
+ );
247
+
248
+ const tool = tools.find((t) => t.name === "mysql_json_stats")!;
249
+ const result = (await tool.handler(
250
+ {
251
+ table: "users",
252
+ column: "metadata",
253
+ sampleSize: 1000,
254
+ },
255
+ mockContext,
256
+ )) as {
257
+ totalSampled: number;
258
+ nullCount: number;
259
+ length: { avg: number; max: number; min: number };
260
+ depth: { avg: number; max: number };
261
+ };
262
+
263
+ expect(mockAdapter.executeQuery).toHaveBeenCalled();
264
+ expect(result.totalSampled).toBe(100);
265
+ expect(result.nullCount).toBe(5);
266
+ expect(result.length.avg).toBe(3.5);
267
+ expect(result.depth.max).toBe(4);
36
268
  });
37
- });
38
269
 
39
- describe('JSON Enhanced Handler Execution', () => {
40
- let mockAdapter: ReturnType<typeof createMockMySQLAdapter>;
41
- let tools: ReturnType<typeof getJsonEnhancedTools>;
42
- let mockContext: ReturnType<typeof createMockRequestContext>;
270
+ it("should reject invalid identifiers", async () => {
271
+ const tool = tools.find((t) => t.name === "mysql_json_stats")!;
272
+
273
+ await expect(
274
+ tool.handler(
275
+ {
276
+ table: "1invalid",
277
+ column: "metadata",
278
+ sampleSize: 100,
279
+ },
280
+ mockContext,
281
+ ),
282
+ ).rejects.toThrow("Invalid table name");
283
+ });
43
284
 
44
- beforeEach(() => {
45
- vi.clearAllMocks();
46
- mockAdapter = createMockMySQLAdapter();
47
- tools = getJsonEnhancedTools(mockAdapter as unknown as MySQLAdapter);
48
- mockContext = createMockRequestContext();
285
+ it("should handle zero rows", async () => {
286
+ mockAdapter.executeQuery.mockResolvedValue(
287
+ createMockQueryResult([
288
+ {
289
+ total_rows: 0,
290
+ null_count: 0,
291
+ },
292
+ ]),
293
+ );
294
+
295
+ const tool = tools.find((t) => t.name === "mysql_json_stats")!;
296
+ const result = await tool.handler(
297
+ {
298
+ table: "users",
299
+ column: "metadata",
300
+ sampleSize: 100,
301
+ },
302
+ mockContext,
303
+ );
304
+
305
+ expect(result).toBeDefined();
306
+ });
307
+ });
308
+
309
+ describe("mysql_json_index_suggest", () => {
310
+ it("should suggest indexes for JSON paths", async () => {
311
+ const tool = tools.find((t) => t.name === "mysql_json_index_suggest")!;
312
+
313
+ mockAdapter.executeQuery
314
+ .mockResolvedValueOnce(
315
+ createMockQueryResult([
316
+ { key_name: "user_id" },
317
+ { key_name: "email" },
318
+ ]),
319
+ )
320
+ .mockResolvedValueOnce(
321
+ createMockQueryResult([{ value_type: "INTEGER", cardinality: 100 }]),
322
+ )
323
+ .mockResolvedValue(
324
+ createMockQueryResult([{ value_type: "STRING", cardinality: 50 }]),
325
+ );
326
+
327
+ const result = (await tool.handler(
328
+ {
329
+ table: "orders",
330
+ column: "details",
331
+ sampleSize: 100,
332
+ },
333
+ mockContext,
334
+ )) as {
335
+ table: string;
336
+ suggestions: Array<{
337
+ path: string;
338
+ type: string;
339
+ cardinality: number;
340
+ indexDdl: string;
341
+ }>;
342
+ };
343
+
344
+ expect(mockAdapter.executeQuery).toHaveBeenCalled();
345
+ expect(result.table).toBe("orders");
346
+ expect(result.suggestions.length).toBeGreaterThan(0);
347
+ expect(result.suggestions[0].indexDdl).toContain("ALTER TABLE");
49
348
  });
50
349
 
51
- describe('mysql_json_merge', () => {
52
- it('should merge JSON documents using patch mode', async () => {
53
- mockAdapter.executeReadQuery.mockResolvedValue(
54
- createMockQueryResult([{ merged: '{"a":1,"b":2}' }])
55
- );
56
-
57
- const tool = tools.find(t => t.name === 'mysql_json_merge')!;
58
- const result = await tool.handler({
59
- json1: '{"a":1}',
60
- json2: '{"b":2}',
61
- mode: 'patch'
62
- }, mockContext) as { merged: unknown; mode: string };
63
-
64
- expect(mockAdapter.executeReadQuery).toHaveBeenCalled();
65
- const call = mockAdapter.executeReadQuery.mock.calls[0][0] as string;
66
- expect(call).toContain('JSON_MERGE_PATCH');
67
- expect(result.mode).toBe('patch');
68
- });
69
-
70
- it('should merge JSON documents using preserve mode', async () => {
71
- mockAdapter.executeReadQuery.mockResolvedValue(
72
- createMockQueryResult([{ merged: '{"a":[1,2]}' }])
73
- );
74
-
75
- const tool = tools.find(t => t.name === 'mysql_json_merge')!;
76
- await tool.handler({
77
- json1: '{"a":[1]}',
78
- json2: '{"a":[2]}',
79
- mode: 'preserve'
80
- }, mockContext);
81
-
82
- const call = mockAdapter.executeReadQuery.mock.calls[0][0] as string;
83
- expect(call).toContain('JSON_MERGE_PRESERVE');
84
- });
350
+ it("should handle keys with low cardinality", async () => {
351
+ const tool = tools.find((t) => t.name === "mysql_json_index_suggest")!;
352
+
353
+ mockAdapter.executeQuery
354
+ .mockResolvedValueOnce(createMockQueryResult([{ key_name: "status" }]))
355
+ .mockResolvedValue(
356
+ createMockQueryResult([{ value_type: "BOOLEAN", cardinality: 1 }]),
357
+ );
358
+
359
+ const result = (await tool.handler(
360
+ {
361
+ table: "items",
362
+ column: "flags",
363
+ sampleSize: 50,
364
+ },
365
+ mockContext,
366
+ )) as { suggestions: unknown[] };
367
+
368
+ // Cardinality of 1 should not be suggested
369
+ expect(result.suggestions.length).toBe(0);
85
370
  });
86
371
 
87
- describe('mysql_json_diff', () => {
88
- it('should compute JSON diff and compare documents', async () => {
89
- mockAdapter.executeReadQuery.mockResolvedValue(
90
- createMockQueryResult([{
91
- identical: 0,
92
- json1_contains_json2: 0,
93
- json2_contains_json1: 0,
94
- json1_length: 2,
95
- json2_length: 2,
96
- json1_keys: '["a","b"]',
97
- json2_keys: '["a","c"]'
98
- }])
99
- );
100
-
101
- const tool = tools.find(t => t.name === 'mysql_json_diff')!;
102
- const result = await tool.handler({
103
- json1: '{"a":1,"b":2}',
104
- json2: '{"a":1,"c":3}'
105
- }, mockContext) as { identical: boolean; json1Keys: string[] };
106
-
107
- expect(mockAdapter.executeReadQuery).toHaveBeenCalled();
108
- expect(result.identical).toBe(false);
109
- expect(result.json1Keys).toEqual(['a', 'b']);
110
- });
111
-
112
- it('should detect identical JSON documents', async () => {
113
- mockAdapter.executeReadQuery.mockResolvedValue(
114
- createMockQueryResult([{
115
- identical: 1,
116
- json1_contains_json2: 1,
117
- json2_contains_json1: 1,
118
- json1_length: 1,
119
- json2_length: 1,
120
- json1_keys: '["a"]',
121
- json2_keys: '["a"]'
122
- }])
123
- );
124
-
125
- const tool = tools.find(t => t.name === 'mysql_json_diff')!;
126
- const result = await tool.handler({
127
- json1: '{"a":1}',
128
- json2: '{"a":1}'
129
- }, mockContext) as { identical: boolean };
130
-
131
- expect(result.identical).toBe(true);
132
- });
372
+ it("should reject invalid identifiers", async () => {
373
+ const tool = tools.find((t) => t.name === "mysql_json_index_suggest")!;
374
+
375
+ await expect(
376
+ tool.handler(
377
+ {
378
+ table: "valid_table",
379
+ column: "column-with-dash",
380
+ sampleSize: 100,
381
+ },
382
+ mockContext,
383
+ ),
384
+ ).rejects.toThrow("Invalid column name");
133
385
  });
134
386
 
135
- describe('mysql_json_normalize', () => {
136
- it('should extract unique keys from JSON column', async () => {
137
- mockAdapter.executeQuery.mockResolvedValueOnce(
138
- createMockQueryResult([{ key_name: 'name' }, { key_name: 'email' }])
139
- ).mockResolvedValue(
140
- createMockQueryResult([{ value_type: 'STRING', count: 10 }])
141
- );
142
-
143
- const tool = tools.find(t => t.name === 'mysql_json_normalize')!;
144
- const result = await tool.handler({
145
- table: 'users',
146
- column: 'metadata',
147
- limit: 100
148
- }, mockContext) as { uniqueKeys: string[]; keyCount: number };
149
-
150
- expect(mockAdapter.executeQuery).toHaveBeenCalled();
151
- expect(result.uniqueKeys).toEqual(['name', 'email']);
152
- expect(result.keyCount).toBe(2);
153
- });
154
-
155
- it('should reject invalid table names', async () => {
156
- const tool = tools.find(t => t.name === 'mysql_json_normalize')!;
157
-
158
- await expect(tool.handler({
159
- table: 'users; DROP TABLE--',
160
- column: 'metadata',
161
- limit: 100
162
- }, mockContext)).rejects.toThrow('Invalid table name');
163
- });
164
-
165
- it('should reject invalid column names', async () => {
166
- const tool = tools.find(t => t.name === 'mysql_json_normalize')!;
167
-
168
- await expect(tool.handler({
169
- table: 'users',
170
- column: 'data/*comment*/',
171
- limit: 100
172
- }, mockContext)).rejects.toThrow('Invalid column name');
173
- });
174
-
175
- it('should handle database errors during normalization', async () => {
176
- mockAdapter.executeQuery.mockRejectedValue(new Error('Database error'));
177
-
178
- const tool = tools.find(t => t.name === 'mysql_json_normalize')!;
179
- await expect(tool.handler({
180
- table: 'users',
181
- column: 'metadata',
182
- limit: 100
183
- }, mockContext)).rejects.toThrow('Database error');
184
- });
387
+ it("should handle empty index suggestions", async () => {
388
+ const tool = tools.find((t) => t.name === "mysql_json_index_suggest")!;
389
+ mockAdapter.executeQuery.mockResolvedValue(createMockQueryResult([]));
390
+
391
+ const result = (await tool.handler(
392
+ {
393
+ table: "users",
394
+ column: "metadata",
395
+ sampleSize: 100,
396
+ },
397
+ mockContext,
398
+ )) as { suggestions: unknown[] };
399
+
400
+ expect(result.suggestions).toEqual([]);
185
401
  });
186
402
 
187
- describe('mysql_json_stats', () => {
188
- it('should compute JSON column statistics', async () => {
189
- mockAdapter.executeQuery.mockResolvedValue(
190
- createMockQueryResult([{
191
- total_rows: 100,
192
- null_count: 5,
193
- avg_length: 3.5,
194
- max_length: 10,
195
- min_length: 1,
196
- avg_depth: 2.1,
197
- max_depth: 4,
198
- avg_size_bytes: 150,
199
- max_size_bytes: 500
200
- }])
201
- );
202
-
203
- const tool = tools.find(t => t.name === 'mysql_json_stats')!;
204
- const result = await tool.handler({
205
- table: 'users',
206
- column: 'metadata',
207
- sampleSize: 1000
208
- }, mockContext) as {
209
- totalSampled: number;
210
- nullCount: number;
211
- length: { avg: number; max: number; min: number };
212
- depth: { avg: number; max: number };
213
- };
214
-
215
- expect(mockAdapter.executeQuery).toHaveBeenCalled();
216
- expect(result.totalSampled).toBe(100);
217
- expect(result.nullCount).toBe(5);
218
- expect(result.length.avg).toBe(3.5);
219
- expect(result.depth.max).toBe(4);
220
- });
221
-
222
- it('should reject invalid identifiers', async () => {
223
- const tool = tools.find(t => t.name === 'mysql_json_stats')!;
224
-
225
- await expect(tool.handler({
226
- table: '1invalid',
227
- column: 'metadata',
228
- sampleSize: 100
229
- }, mockContext)).rejects.toThrow('Invalid table name');
230
- });
231
-
232
- it('should handle zero rows', async () => {
233
- mockAdapter.executeQuery.mockResolvedValue(
234
- createMockQueryResult([{
235
- total_rows: 0,
236
- null_count: 0
237
- }])
238
- );
239
-
240
- const tool = tools.find(t => t.name === 'mysql_json_stats')!;
241
- const result = await tool.handler({
242
- table: 'users',
243
- column: 'metadata',
244
- sampleSize: 100
245
- }, mockContext);
246
-
247
- expect(result).toBeDefined();
248
- });
403
+ it("should suggest indexes for high cardinality columns with type inference", async () => {
404
+ const tool = tools.find((t) => t.name === "mysql_json_index_suggest")!;
405
+
406
+ // Mock keys query
407
+ mockAdapter.executeQuery.mockResolvedValueOnce(
408
+ createMockQueryResult([
409
+ { key_name: "email" },
410
+ { key_name: "age" },
411
+ { key_name: "active" },
412
+ ]),
413
+ );
414
+
415
+ // Mock cardinality queries
416
+ // 1. email (VARCHAR)
417
+ mockAdapter.executeQuery.mockResolvedValueOnce(
418
+ createMockQueryResult([{ value_type: "STRING", cardinality: 100 }]),
419
+ );
420
+ // 2. age (INTEGER)
421
+ mockAdapter.executeQuery.mockResolvedValueOnce(
422
+ createMockQueryResult([{ value_type: "INTEGER", cardinality: 50 }]),
423
+ );
424
+ // 3. active (BOOLEAN) - mocked cardinality > 1 to trigger suggestion
425
+ mockAdapter.executeQuery.mockResolvedValueOnce(
426
+ createMockQueryResult([{ value_type: "BOOLEAN", cardinality: 2 }]),
427
+ );
428
+
429
+ const result = await tool.handler(
430
+ {
431
+ table: "users",
432
+ column: "data",
433
+ },
434
+ mockContext,
435
+ );
436
+
437
+ const suggestions = (result as any).suggestions;
438
+ expect(suggestions).toHaveLength(3);
439
+
440
+ // Expected casts
441
+ const emailSug = suggestions.find((s: any) => s.path === "$.email");
442
+ expect(emailSug.indexDdl).toContain(
443
+ "CAST(JSON_EXTRACT(`data`, '$.email') AS VARCHAR(255))",
444
+ );
445
+
446
+ const ageSug = suggestions.find((s: any) => s.path === "$.age");
447
+ expect(ageSug.indexDdl).toContain(
448
+ "CAST(JSON_EXTRACT(`data`, '$.age') AS BIGINT)",
449
+ );
450
+
451
+ const activeSug = suggestions.find((s: any) => s.path === "$.active");
452
+ expect(activeSug.indexDdl).toContain(
453
+ "CAST(JSON_EXTRACT(`data`, '$.active') AS TINYINT(1))",
454
+ );
249
455
  });
250
456
 
251
- describe('mysql_json_index_suggest', () => {
252
- it('should suggest indexes for JSON paths', async () => {
253
- const tool = tools.find(t => t.name === 'mysql_json_index_suggest')!;
254
-
255
- mockAdapter.executeQuery
256
- .mockResolvedValueOnce(
257
- createMockQueryResult([{ key_name: 'user_id' }, { key_name: 'email' }])
258
- )
259
- .mockResolvedValueOnce(
260
- createMockQueryResult([{ value_type: 'INTEGER', cardinality: 100 }])
261
- )
262
- .mockResolvedValue(
263
- createMockQueryResult([{ value_type: 'STRING', cardinality: 50 }])
264
- );
265
-
266
- const result = await tool.handler({
267
- table: 'orders',
268
- column: 'details',
269
- sampleSize: 100
270
- }, mockContext) as {
271
- table: string;
272
- suggestions: Array<{ path: string; type: string; cardinality: number; indexDdl: string }>;
273
- };
274
-
275
- expect(mockAdapter.executeQuery).toHaveBeenCalled();
276
- expect(result.table).toBe('orders');
277
- expect(result.suggestions.length).toBeGreaterThan(0);
278
- expect(result.suggestions[0].indexDdl).toContain('ALTER TABLE');
279
- });
280
-
281
- it('should handle keys with low cardinality', async () => {
282
- const tool = tools.find(t => t.name === 'mysql_json_index_suggest')!;
283
-
284
- mockAdapter.executeQuery
285
- .mockResolvedValueOnce(
286
- createMockQueryResult([{ key_name: 'status' }])
287
- )
288
- .mockResolvedValue(
289
- createMockQueryResult([{ value_type: 'BOOLEAN', cardinality: 1 }])
290
- );
291
-
292
- const result = await tool.handler({
293
- table: 'items',
294
- column: 'flags',
295
- sampleSize: 50
296
- }, mockContext) as { suggestions: unknown[] };
297
-
298
- // Cardinality of 1 should not be suggested
299
- expect(result.suggestions.length).toBe(0);
300
- });
301
-
302
- it('should reject invalid identifiers', async () => {
303
- const tool = tools.find(t => t.name === 'mysql_json_index_suggest')!;
304
-
305
- await expect(tool.handler({
306
- table: 'valid_table',
307
- column: 'column-with-dash',
308
- sampleSize: 100
309
- }, mockContext)).rejects.toThrow('Invalid column name');
310
- });
311
-
312
- it('should handle empty index suggestions', async () => {
313
- const tool = tools.find(t => t.name === 'mysql_json_index_suggest')!;
314
- mockAdapter.executeQuery.mockResolvedValue(createMockQueryResult([]));
315
-
316
- const result = await tool.handler({
317
- table: 'users',
318
- column: 'metadata',
319
- sampleSize: 100
320
- }, mockContext) as { suggestions: unknown[] };
321
-
322
- expect(result.suggestions).toEqual([]);
323
- });
324
-
325
- it('should suggest indexes for high cardinality columns with type inference', async () => {
326
- const tool = tools.find(t => t.name === 'mysql_json_index_suggest')!;
327
-
328
- // Mock keys query
329
- mockAdapter.executeQuery.mockResolvedValueOnce(createMockQueryResult([
330
- { key_name: 'email' },
331
- { key_name: 'age' },
332
- { key_name: 'active' }
333
- ]));
334
-
335
- // Mock cardinality queries
336
- // 1. email (VARCHAR)
337
- mockAdapter.executeQuery.mockResolvedValueOnce(createMockQueryResult([{ value_type: 'STRING', cardinality: 100 }]));
338
- // 2. age (INTEGER)
339
- mockAdapter.executeQuery.mockResolvedValueOnce(createMockQueryResult([{ value_type: 'INTEGER', cardinality: 50 }]));
340
- // 3. active (BOOLEAN) - mocked cardinality > 1 to trigger suggestion
341
- mockAdapter.executeQuery.mockResolvedValueOnce(createMockQueryResult([{ value_type: 'BOOLEAN', cardinality: 2 }]));
342
-
343
- const result = await tool.handler({
344
- table: 'users',
345
- column: 'data'
346
- }, mockContext);
347
-
348
- const suggestions = (result as any).suggestions;
349
- expect(suggestions).toHaveLength(3);
350
-
351
- // Expected casts
352
- const emailSug = suggestions.find((s: any) => s.path === '$.email');
353
- expect(emailSug.indexDdl).toContain('CAST(JSON_EXTRACT(`data`, \'$.email\') AS VARCHAR(255))');
354
-
355
- const ageSug = suggestions.find((s: any) => s.path === '$.age');
356
- expect(ageSug.indexDdl).toContain('CAST(JSON_EXTRACT(`data`, \'$.age\') AS BIGINT)');
357
-
358
- const activeSug = suggestions.find((s: any) => s.path === '$.active');
359
- expect(activeSug.indexDdl).toContain('CAST(JSON_EXTRACT(`data`, \'$.active\') AS TINYINT(1))');
360
- });
361
-
362
- it('should not suggest index for cardinality <= 1', async () => {
363
- const tool = tools.find(t => t.name === 'mysql_json_index_suggest')!;
364
- // Mock keys query
365
- mockAdapter.executeQuery.mockResolvedValueOnce(createMockQueryResult([
366
- { key_name: 'status' }
367
- ]));
368
-
369
- // Mock cardinality (1)
370
- mockAdapter.executeQuery.mockResolvedValueOnce(createMockQueryResult([{ value_type: 'STRING', cardinality: 1 }]));
371
-
372
- const result = await tool.handler({
373
- table: 'users',
374
- column: 'data'
375
- }, mockContext);
376
-
377
- expect((result as any).suggestions).toHaveLength(0);
378
- });
457
+ it("should not suggest index for cardinality <= 1", async () => {
458
+ const tool = tools.find((t) => t.name === "mysql_json_index_suggest")!;
459
+ // Mock keys query
460
+ mockAdapter.executeQuery.mockResolvedValueOnce(
461
+ createMockQueryResult([{ key_name: "status" }]),
462
+ );
463
+
464
+ // Mock cardinality (1)
465
+ mockAdapter.executeQuery.mockResolvedValueOnce(
466
+ createMockQueryResult([{ value_type: "STRING", cardinality: 1 }]),
467
+ );
468
+
469
+ const result = await tool.handler(
470
+ {
471
+ table: "users",
472
+ column: "data",
473
+ },
474
+ mockContext,
475
+ );
476
+
477
+ expect((result as any).suggestions).toHaveLength(0);
379
478
  });
479
+ });
380
480
  });