@neverinfamous/mysql-mcp 2.3.1 → 3.0.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 (345) hide show
  1. package/.dockerignore +1 -0
  2. package/.gitattributes +18 -0
  3. package/.github/workflows/codeql.yml +2 -2
  4. package/.github/workflows/docker-publish.yml +5 -5
  5. package/CHANGELOG.md +348 -122
  6. package/DOCKER_README.md +81 -40
  7. package/README.md +87 -46
  8. package/VERSION +1 -1
  9. package/dist/__tests__/mocks/adapter.d.ts.map +1 -1
  10. package/dist/__tests__/mocks/adapter.js +2 -0
  11. package/dist/__tests__/mocks/adapter.js.map +1 -1
  12. package/dist/adapters/DatabaseAdapter.d.ts.map +1 -1
  13. package/dist/adapters/DatabaseAdapter.js +50 -9
  14. package/dist/adapters/DatabaseAdapter.js.map +1 -1
  15. package/dist/adapters/mysql/MySQLAdapter.d.ts +6 -0
  16. package/dist/adapters/mysql/MySQLAdapter.d.ts.map +1 -1
  17. package/dist/adapters/mysql/MySQLAdapter.js +8 -0
  18. package/dist/adapters/mysql/MySQLAdapter.js.map +1 -1
  19. package/dist/adapters/mysql/SchemaManager.js +16 -15
  20. package/dist/adapters/mysql/SchemaManager.js.map +1 -1
  21. package/dist/adapters/mysql/prompts/index.js +10 -20
  22. package/dist/adapters/mysql/prompts/index.js.map +1 -1
  23. package/dist/adapters/mysql/prompts/proxysqlSetup.js +1 -1
  24. package/dist/adapters/mysql/resources/docstore.d.ts.map +1 -1
  25. package/dist/adapters/mysql/resources/docstore.js +10 -7
  26. package/dist/adapters/mysql/resources/docstore.js.map +1 -1
  27. package/dist/adapters/mysql/resources/events.js +11 -8
  28. package/dist/adapters/mysql/resources/events.js.map +1 -1
  29. package/dist/adapters/mysql/resources/indexes.d.ts.map +1 -1
  30. package/dist/adapters/mysql/resources/indexes.js +12 -15
  31. package/dist/adapters/mysql/resources/indexes.js.map +1 -1
  32. package/dist/adapters/mysql/resources/innodb.d.ts.map +1 -1
  33. package/dist/adapters/mysql/resources/innodb.js +20 -17
  34. package/dist/adapters/mysql/resources/innodb.js.map +1 -1
  35. package/dist/adapters/mysql/resources/locks.d.ts.map +1 -1
  36. package/dist/adapters/mysql/resources/locks.js +9 -6
  37. package/dist/adapters/mysql/resources/locks.js.map +1 -1
  38. package/dist/adapters/mysql/resources/performance.d.ts.map +1 -1
  39. package/dist/adapters/mysql/resources/performance.js +15 -15
  40. package/dist/adapters/mysql/resources/performance.js.map +1 -1
  41. package/dist/adapters/mysql/resources/spatial.d.ts.map +1 -1
  42. package/dist/adapters/mysql/resources/spatial.js +9 -6
  43. package/dist/adapters/mysql/resources/spatial.js.map +1 -1
  44. package/dist/adapters/mysql/resources/sysschema.d.ts.map +1 -1
  45. package/dist/adapters/mysql/resources/sysschema.js +12 -9
  46. package/dist/adapters/mysql/resources/sysschema.js.map +1 -1
  47. package/dist/adapters/mysql/tools/admin/backup.d.ts.map +1 -1
  48. package/dist/adapters/mysql/tools/admin/backup.js +170 -121
  49. package/dist/adapters/mysql/tools/admin/backup.js.map +1 -1
  50. package/dist/adapters/mysql/tools/admin/maintenance.d.ts.map +1 -1
  51. package/dist/adapters/mysql/tools/admin/maintenance.js +106 -57
  52. package/dist/adapters/mysql/tools/admin/maintenance.js.map +1 -1
  53. package/dist/adapters/mysql/tools/admin/monitoring.d.ts.map +1 -1
  54. package/dist/adapters/mysql/tools/admin/monitoring.js +183 -101
  55. package/dist/adapters/mysql/tools/admin/monitoring.js.map +1 -1
  56. package/dist/adapters/mysql/tools/cluster/group-replication.d.ts.map +1 -1
  57. package/dist/adapters/mysql/tools/cluster/group-replication.js +164 -120
  58. package/dist/adapters/mysql/tools/cluster/group-replication.js.map +1 -1
  59. package/dist/adapters/mysql/tools/cluster/innodb-cluster.d.ts.map +1 -1
  60. package/dist/adapters/mysql/tools/cluster/innodb-cluster.js +212 -145
  61. package/dist/adapters/mysql/tools/cluster/innodb-cluster.js.map +1 -1
  62. package/dist/adapters/mysql/tools/codemode/index.d.ts.map +1 -1
  63. package/dist/adapters/mysql/tools/codemode/index.js +6 -4
  64. package/dist/adapters/mysql/tools/codemode/index.js.map +1 -1
  65. package/dist/adapters/mysql/tools/core.d.ts.map +1 -1
  66. package/dist/adapters/mysql/tools/core.js +152 -29
  67. package/dist/adapters/mysql/tools/core.js.map +1 -1
  68. package/dist/adapters/mysql/tools/docstore.d.ts.map +1 -1
  69. package/dist/adapters/mysql/tools/docstore.js +340 -163
  70. package/dist/adapters/mysql/tools/docstore.js.map +1 -1
  71. package/dist/adapters/mysql/tools/events.d.ts.map +1 -1
  72. package/dist/adapters/mysql/tools/events.js +284 -198
  73. package/dist/adapters/mysql/tools/events.js.map +1 -1
  74. package/dist/adapters/mysql/tools/json/core.d.ts.map +1 -1
  75. package/dist/adapters/mysql/tools/json/core.js +11 -39
  76. package/dist/adapters/mysql/tools/json/core.js.map +1 -1
  77. package/dist/adapters/mysql/tools/json/enhanced.d.ts.map +1 -1
  78. package/dist/adapters/mysql/tools/json/enhanced.js +15 -33
  79. package/dist/adapters/mysql/tools/json/enhanced.js.map +1 -1
  80. package/dist/adapters/mysql/tools/json/helpers.d.ts.map +1 -1
  81. package/dist/adapters/mysql/tools/json/helpers.js +13 -24
  82. package/dist/adapters/mysql/tools/json/helpers.js.map +1 -1
  83. package/dist/adapters/mysql/tools/partitioning.js +3 -0
  84. package/dist/adapters/mysql/tools/partitioning.js.map +1 -1
  85. package/dist/adapters/mysql/tools/performance/analysis.d.ts.map +1 -1
  86. package/dist/adapters/mysql/tools/performance/analysis.js +89 -60
  87. package/dist/adapters/mysql/tools/performance/analysis.js.map +1 -1
  88. package/dist/adapters/mysql/tools/performance/optimization.d.ts.map +1 -1
  89. package/dist/adapters/mysql/tools/performance/optimization.js +151 -127
  90. package/dist/adapters/mysql/tools/performance/optimization.js.map +1 -1
  91. package/dist/adapters/mysql/tools/proxysql.d.ts +1 -1
  92. package/dist/adapters/mysql/tools/proxysql.d.ts.map +1 -1
  93. package/dist/adapters/mysql/tools/proxysql.js +289 -176
  94. package/dist/adapters/mysql/tools/proxysql.js.map +1 -1
  95. package/dist/adapters/mysql/tools/replication.js +75 -49
  96. package/dist/adapters/mysql/tools/replication.js.map +1 -1
  97. package/dist/adapters/mysql/tools/roles.d.ts.map +1 -1
  98. package/dist/adapters/mysql/tools/roles.js +224 -182
  99. package/dist/adapters/mysql/tools/roles.js.map +1 -1
  100. package/dist/adapters/mysql/tools/router.d.ts.map +1 -1
  101. package/dist/adapters/mysql/tools/router.js +168 -67
  102. package/dist/adapters/mysql/tools/router.js.map +1 -1
  103. package/dist/adapters/mysql/tools/schema/constraints.d.ts.map +1 -1
  104. package/dist/adapters/mysql/tools/schema/constraints.js +21 -3
  105. package/dist/adapters/mysql/tools/schema/constraints.js.map +1 -1
  106. package/dist/adapters/mysql/tools/schema/management.d.ts.map +1 -1
  107. package/dist/adapters/mysql/tools/schema/management.js +61 -14
  108. package/dist/adapters/mysql/tools/schema/management.js.map +1 -1
  109. package/dist/adapters/mysql/tools/schema/routines.d.ts.map +1 -1
  110. package/dist/adapters/mysql/tools/schema/routines.js +27 -4
  111. package/dist/adapters/mysql/tools/schema/routines.js.map +1 -1
  112. package/dist/adapters/mysql/tools/schema/scheduled_events.d.ts.map +1 -1
  113. package/dist/adapters/mysql/tools/schema/scheduled_events.js +24 -3
  114. package/dist/adapters/mysql/tools/schema/scheduled_events.js.map +1 -1
  115. package/dist/adapters/mysql/tools/schema/triggers.d.ts.map +1 -1
  116. package/dist/adapters/mysql/tools/schema/triggers.js +23 -2
  117. package/dist/adapters/mysql/tools/schema/triggers.js.map +1 -1
  118. package/dist/adapters/mysql/tools/schema/views.d.ts.map +1 -1
  119. package/dist/adapters/mysql/tools/schema/views.js +47 -7
  120. package/dist/adapters/mysql/tools/schema/views.js.map +1 -1
  121. package/dist/adapters/mysql/tools/security/audit.d.ts.map +1 -1
  122. package/dist/adapters/mysql/tools/security/audit.js +102 -34
  123. package/dist/adapters/mysql/tools/security/audit.js.map +1 -1
  124. package/dist/adapters/mysql/tools/security/data-protection.d.ts.map +1 -1
  125. package/dist/adapters/mysql/tools/security/data-protection.js +264 -205
  126. package/dist/adapters/mysql/tools/security/data-protection.js.map +1 -1
  127. package/dist/adapters/mysql/tools/security/encryption.d.ts.map +1 -1
  128. package/dist/adapters/mysql/tools/security/encryption.js +137 -104
  129. package/dist/adapters/mysql/tools/security/encryption.js.map +1 -1
  130. package/dist/adapters/mysql/tools/shell/backup.d.ts.map +1 -1
  131. package/dist/adapters/mysql/tools/shell/backup.js +71 -59
  132. package/dist/adapters/mysql/tools/shell/backup.js.map +1 -1
  133. package/dist/adapters/mysql/tools/shell/restore.d.ts.map +1 -1
  134. package/dist/adapters/mysql/tools/shell/restore.js +61 -47
  135. package/dist/adapters/mysql/tools/shell/restore.js.map +1 -1
  136. package/dist/adapters/mysql/tools/spatial/geometry.d.ts.map +1 -1
  137. package/dist/adapters/mysql/tools/spatial/geometry.js +19 -5
  138. package/dist/adapters/mysql/tools/spatial/geometry.js.map +1 -1
  139. package/dist/adapters/mysql/tools/spatial/operations.d.ts.map +1 -1
  140. package/dist/adapters/mysql/tools/spatial/operations.js +42 -17
  141. package/dist/adapters/mysql/tools/spatial/operations.js.map +1 -1
  142. package/dist/adapters/mysql/tools/spatial/queries.d.ts.map +1 -1
  143. package/dist/adapters/mysql/tools/spatial/queries.js +109 -57
  144. package/dist/adapters/mysql/tools/spatial/queries.js.map +1 -1
  145. package/dist/adapters/mysql/tools/spatial/setup.d.ts.map +1 -1
  146. package/dist/adapters/mysql/tools/spatial/setup.js +103 -50
  147. package/dist/adapters/mysql/tools/spatial/setup.js.map +1 -1
  148. package/dist/adapters/mysql/tools/stats/comparative.d.ts.map +1 -1
  149. package/dist/adapters/mysql/tools/stats/comparative.js +128 -79
  150. package/dist/adapters/mysql/tools/stats/comparative.js.map +1 -1
  151. package/dist/adapters/mysql/tools/stats/descriptive.d.ts.map +1 -1
  152. package/dist/adapters/mysql/tools/stats/descriptive.js +174 -102
  153. package/dist/adapters/mysql/tools/stats/descriptive.js.map +1 -1
  154. package/dist/adapters/mysql/tools/sysschema/activity.d.ts.map +1 -1
  155. package/dist/adapters/mysql/tools/sysschema/activity.js +50 -25
  156. package/dist/adapters/mysql/tools/sysschema/activity.js.map +1 -1
  157. package/dist/adapters/mysql/tools/sysschema/performance.d.ts.map +1 -1
  158. package/dist/adapters/mysql/tools/sysschema/performance.js +121 -66
  159. package/dist/adapters/mysql/tools/sysschema/performance.js.map +1 -1
  160. package/dist/adapters/mysql/tools/sysschema/resources.d.ts.map +1 -1
  161. package/dist/adapters/mysql/tools/sysschema/resources.js +101 -64
  162. package/dist/adapters/mysql/tools/sysschema/resources.js.map +1 -1
  163. package/dist/adapters/mysql/tools/text/fulltext.d.ts.map +1 -1
  164. package/dist/adapters/mysql/tools/text/fulltext.js +18 -32
  165. package/dist/adapters/mysql/tools/text/fulltext.js.map +1 -1
  166. package/dist/adapters/mysql/tools/transactions.d.ts.map +1 -1
  167. package/dist/adapters/mysql/tools/transactions.js +48 -23
  168. package/dist/adapters/mysql/tools/transactions.js.map +1 -1
  169. package/dist/adapters/mysql/types/proxysql-types.d.ts +15 -0
  170. package/dist/adapters/mysql/types/proxysql-types.d.ts.map +1 -1
  171. package/dist/adapters/mysql/types/proxysql-types.js +33 -1
  172. package/dist/adapters/mysql/types/proxysql-types.js.map +1 -1
  173. package/dist/adapters/mysql/types/router-types.d.ts +1 -1
  174. package/dist/adapters/mysql/types/router-types.js +1 -1
  175. package/dist/adapters/mysql/types/router-types.js.map +1 -1
  176. package/dist/adapters/mysql/types/shell-types.js +2 -2
  177. package/dist/adapters/mysql/types/shell-types.js.map +1 -1
  178. package/dist/adapters/mysql/types.d.ts +485 -21
  179. package/dist/adapters/mysql/types.d.ts.map +1 -1
  180. package/dist/adapters/mysql/types.js +546 -19
  181. package/dist/adapters/mysql/types.js.map +1 -1
  182. package/dist/auth/scopes.js +1 -1
  183. package/dist/auth/scopes.js.map +1 -1
  184. package/dist/codemode/api.d.ts +3 -2
  185. package/dist/codemode/api.d.ts.map +1 -1
  186. package/dist/codemode/api.js +80 -5
  187. package/dist/codemode/api.js.map +1 -1
  188. package/dist/codemode/sandbox-factory.js +1 -1
  189. package/dist/codemode/sandbox-factory.js.map +1 -1
  190. package/dist/codemode/types.d.ts +26 -0
  191. package/dist/codemode/types.d.ts.map +1 -1
  192. package/dist/codemode/types.js +2 -0
  193. package/dist/codemode/types.js.map +1 -1
  194. package/dist/codemode/worker-sandbox.d.ts +4 -2
  195. package/dist/codemode/worker-sandbox.d.ts.map +1 -1
  196. package/dist/codemode/worker-sandbox.js +66 -7
  197. package/dist/codemode/worker-sandbox.js.map +1 -1
  198. package/dist/codemode/worker-script.d.ts +3 -0
  199. package/dist/codemode/worker-script.d.ts.map +1 -1
  200. package/dist/codemode/worker-script.js +128 -75
  201. package/dist/codemode/worker-script.js.map +1 -1
  202. package/dist/constants/ServerInstructions.d.ts +1 -1
  203. package/dist/constants/ServerInstructions.d.ts.map +1 -1
  204. package/dist/constants/ServerInstructions.js +37 -31
  205. package/dist/constants/ServerInstructions.js.map +1 -1
  206. package/dist/filtering/ToolConstants.d.ts +1 -1
  207. package/dist/filtering/ToolConstants.d.ts.map +1 -1
  208. package/dist/filtering/ToolConstants.js +1 -2
  209. package/dist/filtering/ToolConstants.js.map +1 -1
  210. package/dist/pool/ConnectionPool.d.ts.map +1 -1
  211. package/dist/pool/ConnectionPool.js.map +1 -1
  212. package/dist/transports/http.d.ts.map +1 -1
  213. package/dist/transports/http.js +6 -0
  214. package/dist/transports/http.js.map +1 -1
  215. package/dist/utils/validators.d.ts +1 -1
  216. package/dist/utils/validators.d.ts.map +1 -1
  217. package/dist/utils/validators.js.map +1 -1
  218. package/package.json +4 -4
  219. package/releases/v3.0.0-release-notes.md +81 -0
  220. package/releases/v3.0.1-release-notes.md +20 -0
  221. package/src/__tests__/mocks/adapter.ts +3 -0
  222. package/src/__tests__/perf.test.ts +6 -6
  223. package/src/adapters/DatabaseAdapter.ts +58 -9
  224. package/src/adapters/__tests__/DatabaseAdapter.test.ts +89 -8
  225. package/src/adapters/mysql/MySQLAdapter.ts +17 -2
  226. package/src/adapters/mysql/SchemaManager.ts +21 -21
  227. package/src/adapters/mysql/__tests__/MySQLAdapter.test.ts +1 -1
  228. package/src/adapters/mysql/prompts/index.ts +12 -22
  229. package/src/adapters/mysql/prompts/proxysqlSetup.ts +1 -1
  230. package/src/adapters/mysql/resources/docstore.ts +13 -10
  231. package/src/adapters/mysql/resources/events.ts +12 -12
  232. package/src/adapters/mysql/resources/indexes.ts +17 -19
  233. package/src/adapters/mysql/resources/innodb.ts +23 -22
  234. package/src/adapters/mysql/resources/locks.ts +9 -7
  235. package/src/adapters/mysql/resources/performance.ts +23 -18
  236. package/src/adapters/mysql/resources/spatial.ts +9 -7
  237. package/src/adapters/mysql/resources/sysschema.ts +12 -11
  238. package/src/adapters/mysql/tools/__tests__/core.test.ts +126 -55
  239. package/src/adapters/mysql/tools/__tests__/docstore.test.ts +459 -88
  240. package/src/adapters/mysql/tools/__tests__/events.test.ts +281 -103
  241. package/src/adapters/mysql/tools/__tests__/proxysql.test.ts +128 -28
  242. package/src/adapters/mysql/tools/__tests__/replication.test.ts +48 -2
  243. package/src/adapters/mysql/tools/__tests__/roles.test.ts +15 -18
  244. package/src/adapters/mysql/tools/__tests__/router.test.ts +32 -5
  245. package/src/adapters/mysql/tools/__tests__/security.test.ts +126 -2
  246. package/src/adapters/mysql/tools/__tests__/security_injection.test.ts +84 -76
  247. package/src/adapters/mysql/tools/__tests__/security_integration.test.ts +47 -51
  248. package/src/adapters/mysql/tools/__tests__/spatial.test.ts +11 -10
  249. package/src/adapters/mysql/tools/__tests__/spatial_handler.test.ts +54 -38
  250. package/src/adapters/mysql/tools/__tests__/stats.test.ts +285 -152
  251. package/src/adapters/mysql/tools/__tests__/transactions.test.ts +13 -13
  252. package/src/adapters/mysql/tools/admin/__tests__/backup.test.ts +171 -25
  253. package/src/adapters/mysql/tools/admin/__tests__/maintenance.test.ts +240 -4
  254. package/src/adapters/mysql/tools/admin/__tests__/monitoring-summary.test.ts +274 -0
  255. package/src/adapters/mysql/tools/admin/__tests__/monitoring.test.ts +94 -5
  256. package/src/adapters/mysql/tools/admin/backup.ts +193 -143
  257. package/src/adapters/mysql/tools/admin/maintenance.ts +118 -69
  258. package/src/adapters/mysql/tools/admin/monitoring.ts +201 -125
  259. package/src/adapters/mysql/tools/cluster/__tests__/group-replication.test.ts +69 -0
  260. package/src/adapters/mysql/tools/cluster/__tests__/innodb-cluster.test.ts +141 -0
  261. package/src/adapters/mysql/tools/cluster/group-replication.ts +172 -132
  262. package/src/adapters/mysql/tools/cluster/innodb-cluster.ts +231 -157
  263. package/src/adapters/mysql/tools/codemode/__tests__/codemode-tool.test.ts +227 -0
  264. package/src/adapters/mysql/tools/codemode/index.ts +5 -3
  265. package/src/adapters/mysql/tools/core.ts +152 -38
  266. package/src/adapters/mysql/tools/docstore.ts +422 -205
  267. package/src/adapters/mysql/tools/events.ts +334 -233
  268. package/src/adapters/mysql/tools/json/__tests__/core.test.ts +20 -0
  269. package/src/adapters/mysql/tools/json/__tests__/enhanced.test.ts +82 -50
  270. package/src/adapters/mysql/tools/json/__tests__/helpers.test.ts +42 -3
  271. package/src/adapters/mysql/tools/json/core.ts +21 -42
  272. package/src/adapters/mysql/tools/json/enhanced.ts +22 -37
  273. package/src/adapters/mysql/tools/json/helpers.ts +21 -25
  274. package/src/adapters/mysql/tools/partitioning.ts +3 -0
  275. package/src/adapters/mysql/tools/performance/__tests__/analysis.test.ts +98 -5
  276. package/src/adapters/mysql/tools/performance/__tests__/optimization-coverage.test.ts +515 -0
  277. package/src/adapters/mysql/tools/performance/__tests__/optimization.test.ts +187 -0
  278. package/src/adapters/mysql/tools/performance/analysis.ts +95 -69
  279. package/src/adapters/mysql/tools/performance/optimization.ts +182 -153
  280. package/src/adapters/mysql/tools/proxysql.ts +314 -209
  281. package/src/adapters/mysql/tools/replication.ts +84 -57
  282. package/src/adapters/mysql/tools/roles.ts +274 -226
  283. package/src/adapters/mysql/tools/router.ts +181 -85
  284. package/src/adapters/mysql/tools/schema/__tests__/constraints.test.ts +13 -0
  285. package/src/adapters/mysql/tools/schema/__tests__/management.test.ts +60 -25
  286. package/src/adapters/mysql/tools/schema/__tests__/scheduled_events.test.ts +11 -0
  287. package/src/adapters/mysql/tools/schema/__tests__/triggers.test.ts +25 -4
  288. package/src/adapters/mysql/tools/schema/__tests__/views.test.ts +46 -14
  289. package/src/adapters/mysql/tools/schema/constraints.ts +22 -3
  290. package/src/adapters/mysql/tools/schema/management.ts +60 -15
  291. package/src/adapters/mysql/tools/schema/routines.ts +26 -4
  292. package/src/adapters/mysql/tools/schema/scheduled_events.ts +25 -3
  293. package/src/adapters/mysql/tools/schema/triggers.ts +27 -2
  294. package/src/adapters/mysql/tools/schema/views.ts +46 -8
  295. package/src/adapters/mysql/tools/security/__tests__/audit.test.ts +90 -4
  296. package/src/adapters/mysql/tools/security/audit.ts +113 -39
  297. package/src/adapters/mysql/tools/security/data-protection.ts +293 -233
  298. package/src/adapters/mysql/tools/security/encryption.ts +172 -139
  299. package/src/adapters/mysql/tools/shell/__tests__/backup.test.ts +29 -0
  300. package/src/adapters/mysql/tools/shell/backup.ts +90 -73
  301. package/src/adapters/mysql/tools/shell/restore.ts +62 -48
  302. package/src/adapters/mysql/tools/spatial/__tests__/operations.test.ts +22 -14
  303. package/src/adapters/mysql/tools/spatial/__tests__/queries.test.ts +65 -51
  304. package/src/adapters/mysql/tools/spatial/geometry.ts +23 -7
  305. package/src/adapters/mysql/tools/spatial/operations.ts +60 -31
  306. package/src/adapters/mysql/tools/spatial/queries.ts +142 -65
  307. package/src/adapters/mysql/tools/spatial/setup.ts +121 -55
  308. package/src/adapters/mysql/tools/stats/__tests__/comparative.test.ts +12 -10
  309. package/src/adapters/mysql/tools/stats/comparative.ts +150 -98
  310. package/src/adapters/mysql/tools/stats/descriptive.ts +204 -127
  311. package/src/adapters/mysql/tools/sysschema/__tests__/error-paths.test.ts +222 -0
  312. package/src/adapters/mysql/tools/sysschema/__tests__/performance.test.ts +45 -0
  313. package/src/adapters/mysql/tools/sysschema/__tests__/resources.test.ts +6 -3
  314. package/src/adapters/mysql/tools/sysschema/activity.ts +52 -27
  315. package/src/adapters/mysql/tools/sysschema/performance.ts +132 -68
  316. package/src/adapters/mysql/tools/sysschema/resources.ts +105 -67
  317. package/src/adapters/mysql/tools/text/__tests__/fulltext.test.ts +45 -17
  318. package/src/adapters/mysql/tools/text/fulltext.ts +27 -38
  319. package/src/adapters/mysql/tools/transactions.ts +49 -24
  320. package/src/adapters/mysql/types/proxysql-types.ts +38 -1
  321. package/src/adapters/mysql/types/router-types.ts +1 -1
  322. package/src/adapters/mysql/types/shell-types.ts +2 -2
  323. package/src/adapters/mysql/types.ts +632 -19
  324. package/src/auth/__tests__/scopes.test.ts +2 -2
  325. package/src/auth/scopes.ts +1 -1
  326. package/src/codemode/__tests__/api.test.ts +417 -0
  327. package/src/codemode/__tests__/sandbox-factory.test.ts +158 -0
  328. package/src/codemode/__tests__/sandbox.test.ts +301 -0
  329. package/src/codemode/__tests__/security.test.ts +368 -0
  330. package/src/codemode/__tests__/worker-sandbox.test.ts +179 -0
  331. package/src/codemode/__tests__/worker-script.test.ts +226 -0
  332. package/src/codemode/api.ts +89 -5
  333. package/src/codemode/sandbox-factory.ts +1 -1
  334. package/src/codemode/types.ts +34 -0
  335. package/src/codemode/worker-sandbox.ts +74 -7
  336. package/src/codemode/worker-script.ts +157 -86
  337. package/src/constants/ServerInstructions.ts +37 -31
  338. package/src/filtering/ToolConstants.ts +1 -2
  339. package/src/filtering/__tests__/ToolFilter.test.ts +9 -9
  340. package/src/pool/ConnectionPool.ts +4 -1
  341. package/src/transports/__tests__/http.test.ts +15 -3
  342. package/src/transports/http.ts +12 -0
  343. package/src/utils/validators.ts +2 -1
  344. package/vitest.config.ts +3 -1
  345. package/CODE_MODE.md +0 -245
@@ -4,8 +4,8 @@
4
4
  * Query optimization and index recommendation tools.
5
5
  * 4 tools: index_recommendation, query_rewrite, force_index, optimizer_trace.
6
6
  */
7
+ import { IndexRecommendationSchema, IndexRecommendationSchemaBase, ForceIndexSchema, ForceIndexSchemaBase, preprocessQueryOnlyParams, } from "../../types.js";
7
8
  import { z } from "zod";
8
- import { preprocessQueryOnlyParams } from "../../types.js";
9
9
  /** Extract key optimization decisions from full optimizer trace for summary mode */
10
10
  function extractTraceSummary(rows, query) {
11
11
  const decisions = [];
@@ -80,67 +80,70 @@ function extractTraceSummary(rows, query) {
80
80
  return { query, decisions };
81
81
  }
82
82
  export function createIndexRecommendationTool(adapter) {
83
- const schema = z.object({
84
- table: z.string().describe("Table to analyze for missing indexes"),
85
- });
86
83
  return {
87
84
  name: "mysql_index_recommendation",
88
85
  title: "MySQL Index Recommendation",
89
86
  description: "Analyze table and suggest potentially missing indexes based on query patterns.",
90
87
  group: "optimization",
91
- inputSchema: schema,
88
+ inputSchema: IndexRecommendationSchemaBase,
92
89
  requiredScopes: ["read"],
93
90
  annotations: {
94
91
  readOnlyHint: true,
95
92
  idempotentHint: true,
96
93
  },
97
94
  handler: async (params, _context) => {
98
- const { table } = schema.parse(params);
99
- // Get columns
100
- const columns = await adapter.describeTable(table);
101
- // Graceful handling for non-existent tables (P154)
102
- if (!columns.columns || columns.columns.length === 0) {
103
- return { exists: false, table };
104
- }
105
- // Get existing indexes
106
- const indexes = await adapter.getTableIndexes(table);
107
- const indexedColumns = new Set(indexes.flatMap((i) => i.columns));
108
- // Analyze which columns might benefit from indexing
109
- const recommendations = [];
110
- for (const col of columns.columns) {
111
- if (indexedColumns.has(col.name))
112
- continue;
113
- // Suggest indexes for common patterns
114
- if (col.name.endsWith("_id") || col.name === "id") {
115
- recommendations.push({
116
- column: col.name,
117
- reason: "Foreign key or ID column often benefits from indexing",
118
- });
119
- }
120
- else if (["created_at", "updated_at", "date", "timestamp"].some((s) => col.name.includes(s))) {
121
- recommendations.push({
122
- column: col.name,
123
- reason: "Timestamp columns often used in range queries",
124
- });
95
+ try {
96
+ const { table } = IndexRecommendationSchema.parse(params);
97
+ // Get columns
98
+ const columns = await adapter.describeTable(table);
99
+ // Graceful handling for non-existent tables (P154)
100
+ if (!columns.columns || columns.columns.length === 0) {
101
+ return { exists: false, table };
125
102
  }
126
- else if (col.name === "status" ||
127
- col.name === "type" ||
128
- col.name === "category") {
129
- recommendations.push({
130
- column: col.name,
131
- reason: "Status/type columns often used in filtering",
132
- });
103
+ // Get existing indexes
104
+ const indexes = await adapter.getTableIndexes(table);
105
+ const indexedColumns = new Set(indexes.flatMap((i) => i.columns));
106
+ // Analyze which columns might benefit from indexing
107
+ const recommendations = [];
108
+ for (const col of columns.columns) {
109
+ if (indexedColumns.has(col.name))
110
+ continue;
111
+ // Suggest indexes for common patterns
112
+ if (col.name.endsWith("_id") || col.name === "id") {
113
+ recommendations.push({
114
+ column: col.name,
115
+ reason: "Foreign key or ID column often benefits from indexing",
116
+ });
117
+ }
118
+ else if (["created_at", "updated_at", "date", "timestamp"].some((s) => col.name.includes(s))) {
119
+ recommendations.push({
120
+ column: col.name,
121
+ reason: "Timestamp columns often used in range queries",
122
+ });
123
+ }
124
+ else if (col.name === "status" ||
125
+ col.name === "type" ||
126
+ col.name === "category") {
127
+ recommendations.push({
128
+ column: col.name,
129
+ reason: "Status/type columns often used in filtering",
130
+ });
131
+ }
133
132
  }
133
+ return {
134
+ exists: true,
135
+ table,
136
+ existingIndexes: indexes.map((i) => ({
137
+ name: i.name,
138
+ columns: i.columns,
139
+ })),
140
+ recommendations,
141
+ };
142
+ }
143
+ catch (error) {
144
+ const msg = error instanceof Error ? error.message : String(error);
145
+ return { success: false, error: msg };
134
146
  }
135
- return {
136
- exists: true,
137
- table,
138
- existingIndexes: indexes.map((i) => ({
139
- name: i.name,
140
- columns: i.columns,
141
- })),
142
- recommendations,
143
- };
144
147
  },
145
148
  };
146
149
  }
@@ -175,101 +178,111 @@ export function createQueryRewriteTool(adapter) {
175
178
  idempotentHint: true,
176
179
  },
177
180
  handler: async (params, _context) => {
178
- const { query } = schema.parse(params);
179
- const suggestions = [];
180
- const upperQuery = query.toUpperCase();
181
- // Basic query analysis
182
- if (upperQuery.includes("SELECT *")) {
183
- suggestions.push("Consider selecting only needed columns instead of SELECT *");
184
- }
185
- if (!upperQuery.includes("LIMIT") && upperQuery.includes("SELECT")) {
186
- suggestions.push("Consider adding LIMIT to prevent large result sets");
187
- }
188
- if (upperQuery.includes("LIKE") && query.includes("%")) {
189
- if (query.includes("LIKE '%")) {
190
- suggestions.push("Leading wildcard in LIKE prevents index usage; consider FULLTEXT search");
191
- }
192
- }
193
- // Check for OR in WHERE clause (not ORDER BY, FOR, etc.)
194
- const wherePattern = /WHERE\s+(.+?)(?:ORDER BY|GROUP BY|LIMIT|$)/is;
195
- const whereMatch = wherePattern.exec(upperQuery);
196
- const whereClause = whereMatch?.[1];
197
- if (whereClause && /\bOR\b/i.test(whereClause)) {
198
- suggestions.push("OR conditions may prevent index usage; consider UNION instead");
199
- }
200
- if (upperQuery.includes("ORDER BY") && !upperQuery.includes("LIMIT")) {
201
- suggestions.push("ORDER BY without LIMIT may cause full table sort");
202
- }
203
- if (upperQuery.includes("NOT IN") || upperQuery.includes("NOT EXISTS")) {
204
- suggestions.push("NOT IN/NOT EXISTS can be slow; consider LEFT JOIN with NULL check");
205
- }
206
- // Get EXPLAIN for the query
207
- let explainResult = null;
208
- let explainError;
209
181
  try {
210
- const explainSql = `EXPLAIN FORMAT=JSON ${query}`;
211
- const result = await adapter.executeReadQuery(explainSql);
212
- if (result.rows?.[0]) {
213
- const explainStr = result.rows[0]["EXPLAIN"];
214
- if (typeof explainStr === "string") {
215
- explainResult = JSON.parse(explainStr);
182
+ const { query } = schema.parse(params);
183
+ const suggestions = [];
184
+ const upperQuery = query.toUpperCase();
185
+ // Basic query analysis
186
+ if (upperQuery.includes("SELECT *")) {
187
+ suggestions.push("Consider selecting only needed columns instead of SELECT *");
188
+ }
189
+ if (!upperQuery.includes("LIMIT") && upperQuery.includes("SELECT")) {
190
+ suggestions.push("Consider adding LIMIT to prevent large result sets");
191
+ }
192
+ if (upperQuery.includes("LIKE") && query.includes("%")) {
193
+ if (query.includes("LIKE '%")) {
194
+ suggestions.push("Leading wildcard in LIKE prevents index usage; consider FULLTEXT search");
216
195
  }
217
196
  }
197
+ // Check for OR in WHERE clause (not ORDER BY, FOR, etc.)
198
+ const wherePattern = /WHERE\s+(.+?)(?:ORDER BY|GROUP BY|LIMIT|$)/is;
199
+ const whereMatch = wherePattern.exec(upperQuery);
200
+ const whereClause = whereMatch?.[1];
201
+ if (whereClause && /\bOR\b/i.test(whereClause)) {
202
+ suggestions.push("OR conditions may prevent index usage; consider UNION instead");
203
+ }
204
+ if (upperQuery.includes("ORDER BY") && !upperQuery.includes("LIMIT")) {
205
+ suggestions.push("ORDER BY without LIMIT may cause full table sort");
206
+ }
207
+ if (upperQuery.includes("NOT IN") ||
208
+ upperQuery.includes("NOT EXISTS")) {
209
+ suggestions.push("NOT IN/NOT EXISTS can be slow; consider LEFT JOIN with NULL check");
210
+ }
211
+ // Get EXPLAIN for the query
212
+ let explainResult = null;
213
+ let explainError;
214
+ try {
215
+ const explainSql = `EXPLAIN FORMAT=JSON ${query}`;
216
+ const result = await adapter.executeReadQuery(explainSql);
217
+ if (result.rows?.[0]) {
218
+ const explainStr = result.rows[0]["EXPLAIN"];
219
+ if (typeof explainStr === "string") {
220
+ explainResult = JSON.parse(explainStr);
221
+ }
222
+ }
223
+ }
224
+ catch (err) {
225
+ const rawMsg = err instanceof Error ? err.message : "Failed to generate EXPLAIN";
226
+ explainError = rawMsg
227
+ .replace(/^Query failed:\s*/i, "")
228
+ .replace(/^Execute failed:\s*/i, "");
229
+ }
230
+ const response = {
231
+ originalQuery: query,
232
+ suggestions,
233
+ explainPlan: explainResult,
234
+ };
235
+ if (explainError) {
236
+ response["explainError"] = explainError;
237
+ }
238
+ return response;
218
239
  }
219
- catch (err) {
220
- explainError =
221
- err instanceof Error ? err.message : "Failed to generate EXPLAIN";
222
- }
223
- const response = {
224
- originalQuery: query,
225
- suggestions,
226
- explainPlan: explainResult,
227
- };
228
- if (explainError) {
229
- response["explainError"] = explainError;
240
+ catch (error) {
241
+ const msg = error instanceof Error ? error.message : String(error);
242
+ return { success: false, error: msg };
230
243
  }
231
- return response;
232
244
  },
233
245
  };
234
246
  }
235
247
  export function createForceIndexTool(adapter) {
236
- const schema = z.object({
237
- table: z.string(),
238
- query: z.string().describe("Original query"),
239
- indexName: z.string().describe("Index name to force"),
240
- });
241
248
  return {
242
249
  name: "mysql_force_index",
243
250
  title: "MySQL Force Index",
244
251
  description: "Generate a query with FORCE INDEX hint.",
245
252
  group: "optimization",
246
- inputSchema: schema,
253
+ inputSchema: ForceIndexSchemaBase,
247
254
  requiredScopes: ["read"],
248
255
  annotations: {
249
256
  readOnlyHint: true,
250
257
  idempotentHint: true,
251
258
  },
252
259
  handler: async (params, _context) => {
253
- const { table, query, indexName } = schema.parse(params);
254
- // P154: Check table existence first
255
- const tableInfo = await adapter.describeTable(table);
256
- if (!tableInfo.columns || tableInfo.columns.length === 0) {
257
- return { exists: false, table };
260
+ try {
261
+ const { table, query, indexName } = ForceIndexSchema.parse(params);
262
+ // P154: Check table existence first
263
+ const tableInfo = await adapter.describeTable(table);
264
+ if (!tableInfo.columns || tableInfo.columns.length === 0) {
265
+ return { exists: false, table };
266
+ }
267
+ // Simple replacement - insert FORCE INDEX after table name
268
+ const rewritten = query.replace(new RegExp(`FROM\\s+\`?${table}\`?`, "i"), `FROM \`${table}\` FORCE INDEX (\`${indexName}\`)`);
269
+ const response = {
270
+ originalQuery: query,
271
+ rewrittenQuery: rewritten,
272
+ hint: `FORCE INDEX (\`${indexName}\`)`,
273
+ };
274
+ // Validate index existence and warn if not found
275
+ const indexes = await adapter.getTableIndexes(table);
276
+ if (!indexes.some((idx) => idx.name === indexName)) {
277
+ response["warning"] =
278
+ `Index '${indexName}' not found on table '${table}'`;
279
+ }
280
+ return response;
258
281
  }
259
- // Simple replacement - insert FORCE INDEX after table name
260
- const rewritten = query.replace(new RegExp(`FROM\\s+\`?${table}\`?`, "i"), `FROM \`${table}\` FORCE INDEX (\`${indexName}\`)`);
261
- const response = {
262
- originalQuery: query,
263
- rewrittenQuery: rewritten,
264
- hint: `FORCE INDEX (\`${indexName}\`)`,
265
- };
266
- // Validate index existence and warn if not found
267
- const indexes = await adapter.getTableIndexes(table);
268
- if (!indexes.some((idx) => idx.name === indexName)) {
269
- response["warning"] =
270
- `Index '${indexName}' not found on table '${table}'`;
282
+ catch (error) {
283
+ const msg = error instanceof Error ? error.message : String(error);
284
+ return { success: false, error: msg };
271
285
  }
272
- return response;
273
286
  },
274
287
  };
275
288
  }
@@ -306,16 +319,21 @@ export function createOptimizerTraceTool(adapter) {
306
319
  readOnlyHint: true,
307
320
  },
308
321
  handler: async (params, _context) => {
309
- const { query, summary } = schema.parse(params);
310
- // Enable optimizer trace
311
- await adapter.executeQuery('SET optimizer_trace="enabled=on"');
322
+ let tracingEnabled = false;
312
323
  try {
324
+ const { query, summary } = schema.parse(params);
325
+ // Enable optimizer trace
326
+ await adapter.executeQuery('SET optimizer_trace="enabled=on"');
327
+ tracingEnabled = true;
313
328
  // Execute the query (may fail for nonexistent tables, etc.)
314
329
  try {
315
330
  await adapter.executeReadQuery(query);
316
331
  }
317
332
  catch (err) {
318
- const errorMsg = err instanceof Error ? err.message : "Query execution failed";
333
+ const rawMsg = err instanceof Error ? err.message : "Query execution failed";
334
+ const errorMsg = rawMsg
335
+ .replace(/^Query failed:\s*/i, "")
336
+ .replace(/^Execute failed:\s*/i, "");
319
337
  if (summary) {
320
338
  return { query, decisions: [], error: errorMsg };
321
339
  }
@@ -329,9 +347,15 @@ export function createOptimizerTraceTool(adapter) {
329
347
  }
330
348
  return { trace: traceResult.rows };
331
349
  }
350
+ catch (error) {
351
+ const msg = error instanceof Error ? error.message : String(error);
352
+ return { success: false, error: msg };
353
+ }
332
354
  finally {
333
- // Disable optimizer trace
334
- await adapter.executeQuery('SET optimizer_trace="enabled=off"');
355
+ if (tracingEnabled) {
356
+ // Disable optimizer trace
357
+ await adapter.executeQuery('SET optimizer_trace="enabled=off"');
358
+ }
335
359
  }
336
360
  },
337
361
  };
@@ -1 +1 @@
1
- {"version":3,"file":"optimization.js","sourceRoot":"","sources":["../../../../../src/adapters/mysql/tools/performance/optimization.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"optimization.js","sourceRoot":"","sources":["../../../../../src/adapters/mysql/tools/performance/optimization.ts"],"names":[],"mappings":"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"}
@@ -2,7 +2,7 @@
2
2
  * ProxySQL Management Tools
3
3
  *
4
4
  * Tools for monitoring and managing ProxySQL via its MySQL-protocol admin interface.
5
- * 12 tools total.
5
+ * 11 tools total.
6
6
  *
7
7
  * ProxySQL admin interface documentation:
8
8
  * https://proxysql.com/documentation/ProxySQL-Admin-Interface/
@@ -1 +1 @@
1
- {"version":3,"file":"proxysql.d.ts","sourceRoot":"","sources":["../../../../src/adapters/mysql/tools/proxysql.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAkB,MAAM,yBAAyB,CAAC;AAC9E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAiFvD;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,YAAY,GAAG,cAAc,EAAE,CAezE"}
1
+ {"version":3,"file":"proxysql.d.ts","sourceRoot":"","sources":["../../../../src/adapters/mysql/tools/proxysql.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,OAAO,KAAK,EAAE,cAAc,EAAkB,MAAM,yBAAyB,CAAC;AAC9E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAgGvD;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,YAAY,GAAG,cAAc,EAAE,CAczE"}