@neverinfamous/postgres-mcp 1.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 (571) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +515 -0
  3. package/dist/__tests__/mocks/adapter.d.ts +80 -0
  4. package/dist/__tests__/mocks/adapter.d.ts.map +1 -0
  5. package/dist/__tests__/mocks/adapter.js +225 -0
  6. package/dist/__tests__/mocks/adapter.js.map +1 -0
  7. package/dist/__tests__/mocks/index.d.ts +11 -0
  8. package/dist/__tests__/mocks/index.d.ts.map +1 -0
  9. package/dist/__tests__/mocks/index.js +11 -0
  10. package/dist/__tests__/mocks/index.js.map +1 -0
  11. package/dist/__tests__/mocks/pool.d.ts +43 -0
  12. package/dist/__tests__/mocks/pool.d.ts.map +1 -0
  13. package/dist/__tests__/mocks/pool.js +71 -0
  14. package/dist/__tests__/mocks/pool.js.map +1 -0
  15. package/dist/adapters/DatabaseAdapter.d.ts +139 -0
  16. package/dist/adapters/DatabaseAdapter.d.ts.map +1 -0
  17. package/dist/adapters/DatabaseAdapter.js +250 -0
  18. package/dist/adapters/DatabaseAdapter.js.map +1 -0
  19. package/dist/adapters/postgresql/PostgresAdapter.d.ts +119 -0
  20. package/dist/adapters/postgresql/PostgresAdapter.d.ts.map +1 -0
  21. package/dist/adapters/postgresql/PostgresAdapter.js +902 -0
  22. package/dist/adapters/postgresql/PostgresAdapter.js.map +1 -0
  23. package/dist/adapters/postgresql/index.d.ts +5 -0
  24. package/dist/adapters/postgresql/index.d.ts.map +1 -0
  25. package/dist/adapters/postgresql/index.js +5 -0
  26. package/dist/adapters/postgresql/index.js.map +1 -0
  27. package/dist/adapters/postgresql/prompts/backup.d.ts +8 -0
  28. package/dist/adapters/postgresql/prompts/backup.d.ts.map +1 -0
  29. package/dist/adapters/postgresql/prompts/backup.js +132 -0
  30. package/dist/adapters/postgresql/prompts/backup.js.map +1 -0
  31. package/dist/adapters/postgresql/prompts/citext.d.ts +8 -0
  32. package/dist/adapters/postgresql/prompts/citext.d.ts.map +1 -0
  33. package/dist/adapters/postgresql/prompts/citext.js +227 -0
  34. package/dist/adapters/postgresql/prompts/citext.js.map +1 -0
  35. package/dist/adapters/postgresql/prompts/extensionSetup.d.ts +8 -0
  36. package/dist/adapters/postgresql/prompts/extensionSetup.d.ts.map +1 -0
  37. package/dist/adapters/postgresql/prompts/extensionSetup.js +282 -0
  38. package/dist/adapters/postgresql/prompts/extensionSetup.js.map +1 -0
  39. package/dist/adapters/postgresql/prompts/health.d.ts +8 -0
  40. package/dist/adapters/postgresql/prompts/health.d.ts.map +1 -0
  41. package/dist/adapters/postgresql/prompts/health.js +118 -0
  42. package/dist/adapters/postgresql/prompts/health.js.map +1 -0
  43. package/dist/adapters/postgresql/prompts/index.d.ts +13 -0
  44. package/dist/adapters/postgresql/prompts/index.d.ts.map +1 -0
  45. package/dist/adapters/postgresql/prompts/index.js +308 -0
  46. package/dist/adapters/postgresql/prompts/index.js.map +1 -0
  47. package/dist/adapters/postgresql/prompts/indexTuning.d.ts +8 -0
  48. package/dist/adapters/postgresql/prompts/indexTuning.d.ts.map +1 -0
  49. package/dist/adapters/postgresql/prompts/indexTuning.js +130 -0
  50. package/dist/adapters/postgresql/prompts/indexTuning.js.map +1 -0
  51. package/dist/adapters/postgresql/prompts/kcache.d.ts +8 -0
  52. package/dist/adapters/postgresql/prompts/kcache.d.ts.map +1 -0
  53. package/dist/adapters/postgresql/prompts/kcache.js +227 -0
  54. package/dist/adapters/postgresql/prompts/kcache.js.map +1 -0
  55. package/dist/adapters/postgresql/prompts/ltree.d.ts +8 -0
  56. package/dist/adapters/postgresql/prompts/ltree.d.ts.map +1 -0
  57. package/dist/adapters/postgresql/prompts/ltree.js +286 -0
  58. package/dist/adapters/postgresql/prompts/ltree.js.map +1 -0
  59. package/dist/adapters/postgresql/prompts/partman.d.ts +8 -0
  60. package/dist/adapters/postgresql/prompts/partman.d.ts.map +1 -0
  61. package/dist/adapters/postgresql/prompts/partman.js +211 -0
  62. package/dist/adapters/postgresql/prompts/partman.js.map +1 -0
  63. package/dist/adapters/postgresql/prompts/pgcron.d.ts +8 -0
  64. package/dist/adapters/postgresql/prompts/pgcron.d.ts.map +1 -0
  65. package/dist/adapters/postgresql/prompts/pgcron.js +233 -0
  66. package/dist/adapters/postgresql/prompts/pgcron.js.map +1 -0
  67. package/dist/adapters/postgresql/prompts/pgcrypto.d.ts +8 -0
  68. package/dist/adapters/postgresql/prompts/pgcrypto.d.ts.map +1 -0
  69. package/dist/adapters/postgresql/prompts/pgcrypto.js +299 -0
  70. package/dist/adapters/postgresql/prompts/pgcrypto.js.map +1 -0
  71. package/dist/adapters/postgresql/prompts/pgvector.d.ts +8 -0
  72. package/dist/adapters/postgresql/prompts/pgvector.d.ts.map +1 -0
  73. package/dist/adapters/postgresql/prompts/pgvector.js +148 -0
  74. package/dist/adapters/postgresql/prompts/pgvector.js.map +1 -0
  75. package/dist/adapters/postgresql/prompts/postgis.d.ts +8 -0
  76. package/dist/adapters/postgresql/prompts/postgis.d.ts.map +1 -0
  77. package/dist/adapters/postgresql/prompts/postgis.js +200 -0
  78. package/dist/adapters/postgresql/prompts/postgis.js.map +1 -0
  79. package/dist/adapters/postgresql/resources/activity.d.ts +9 -0
  80. package/dist/adapters/postgresql/resources/activity.d.ts.map +1 -0
  81. package/dist/adapters/postgresql/resources/activity.js +118 -0
  82. package/dist/adapters/postgresql/resources/activity.js.map +1 -0
  83. package/dist/adapters/postgresql/resources/capabilities.d.ts +9 -0
  84. package/dist/adapters/postgresql/resources/capabilities.d.ts.map +1 -0
  85. package/dist/adapters/postgresql/resources/capabilities.js +182 -0
  86. package/dist/adapters/postgresql/resources/capabilities.js.map +1 -0
  87. package/dist/adapters/postgresql/resources/cron.d.ts +9 -0
  88. package/dist/adapters/postgresql/resources/cron.d.ts.map +1 -0
  89. package/dist/adapters/postgresql/resources/cron.js +156 -0
  90. package/dist/adapters/postgresql/resources/cron.js.map +1 -0
  91. package/dist/adapters/postgresql/resources/crypto.d.ts +9 -0
  92. package/dist/adapters/postgresql/resources/crypto.d.ts.map +1 -0
  93. package/dist/adapters/postgresql/resources/crypto.js +191 -0
  94. package/dist/adapters/postgresql/resources/crypto.js.map +1 -0
  95. package/dist/adapters/postgresql/resources/extensions.d.ts +9 -0
  96. package/dist/adapters/postgresql/resources/extensions.d.ts.map +1 -0
  97. package/dist/adapters/postgresql/resources/extensions.js +85 -0
  98. package/dist/adapters/postgresql/resources/extensions.js.map +1 -0
  99. package/dist/adapters/postgresql/resources/health.d.ts +9 -0
  100. package/dist/adapters/postgresql/resources/health.d.ts.map +1 -0
  101. package/dist/adapters/postgresql/resources/health.js +185 -0
  102. package/dist/adapters/postgresql/resources/health.js.map +1 -0
  103. package/dist/adapters/postgresql/resources/index.d.ts +40 -0
  104. package/dist/adapters/postgresql/resources/index.d.ts.map +1 -0
  105. package/dist/adapters/postgresql/resources/index.js +87 -0
  106. package/dist/adapters/postgresql/resources/index.js.map +1 -0
  107. package/dist/adapters/postgresql/resources/indexes.d.ts +9 -0
  108. package/dist/adapters/postgresql/resources/indexes.d.ts.map +1 -0
  109. package/dist/adapters/postgresql/resources/indexes.js +130 -0
  110. package/dist/adapters/postgresql/resources/indexes.js.map +1 -0
  111. package/dist/adapters/postgresql/resources/kcache.d.ts +9 -0
  112. package/dist/adapters/postgresql/resources/kcache.d.ts.map +1 -0
  113. package/dist/adapters/postgresql/resources/kcache.js +219 -0
  114. package/dist/adapters/postgresql/resources/kcache.js.map +1 -0
  115. package/dist/adapters/postgresql/resources/locks.d.ts +9 -0
  116. package/dist/adapters/postgresql/resources/locks.d.ts.map +1 -0
  117. package/dist/adapters/postgresql/resources/locks.js +89 -0
  118. package/dist/adapters/postgresql/resources/locks.js.map +1 -0
  119. package/dist/adapters/postgresql/resources/partman.d.ts +9 -0
  120. package/dist/adapters/postgresql/resources/partman.d.ts.map +1 -0
  121. package/dist/adapters/postgresql/resources/partman.js +149 -0
  122. package/dist/adapters/postgresql/resources/partman.js.map +1 -0
  123. package/dist/adapters/postgresql/resources/performance.d.ts +9 -0
  124. package/dist/adapters/postgresql/resources/performance.d.ts.map +1 -0
  125. package/dist/adapters/postgresql/resources/performance.js +170 -0
  126. package/dist/adapters/postgresql/resources/performance.js.map +1 -0
  127. package/dist/adapters/postgresql/resources/pool.d.ts +9 -0
  128. package/dist/adapters/postgresql/resources/pool.d.ts.map +1 -0
  129. package/dist/adapters/postgresql/resources/pool.js +93 -0
  130. package/dist/adapters/postgresql/resources/pool.js.map +1 -0
  131. package/dist/adapters/postgresql/resources/postgis.d.ts +9 -0
  132. package/dist/adapters/postgresql/resources/postgis.d.ts.map +1 -0
  133. package/dist/adapters/postgresql/resources/postgis.js +232 -0
  134. package/dist/adapters/postgresql/resources/postgis.js.map +1 -0
  135. package/dist/adapters/postgresql/resources/replication.d.ts +9 -0
  136. package/dist/adapters/postgresql/resources/replication.d.ts.map +1 -0
  137. package/dist/adapters/postgresql/resources/replication.js +126 -0
  138. package/dist/adapters/postgresql/resources/replication.js.map +1 -0
  139. package/dist/adapters/postgresql/resources/schema.d.ts +10 -0
  140. package/dist/adapters/postgresql/resources/schema.d.ts.map +1 -0
  141. package/dist/adapters/postgresql/resources/schema.js +80 -0
  142. package/dist/adapters/postgresql/resources/schema.js.map +1 -0
  143. package/dist/adapters/postgresql/resources/settings.d.ts +9 -0
  144. package/dist/adapters/postgresql/resources/settings.d.ts.map +1 -0
  145. package/dist/adapters/postgresql/resources/settings.js +184 -0
  146. package/dist/adapters/postgresql/resources/settings.js.map +1 -0
  147. package/dist/adapters/postgresql/resources/stats.d.ts +10 -0
  148. package/dist/adapters/postgresql/resources/stats.d.ts.map +1 -0
  149. package/dist/adapters/postgresql/resources/stats.js +124 -0
  150. package/dist/adapters/postgresql/resources/stats.js.map +1 -0
  151. package/dist/adapters/postgresql/resources/tables.d.ts +9 -0
  152. package/dist/adapters/postgresql/resources/tables.d.ts.map +1 -0
  153. package/dist/adapters/postgresql/resources/tables.js +20 -0
  154. package/dist/adapters/postgresql/resources/tables.js.map +1 -0
  155. package/dist/adapters/postgresql/resources/vacuum.d.ts +9 -0
  156. package/dist/adapters/postgresql/resources/vacuum.d.ts.map +1 -0
  157. package/dist/adapters/postgresql/resources/vacuum.js +122 -0
  158. package/dist/adapters/postgresql/resources/vacuum.js.map +1 -0
  159. package/dist/adapters/postgresql/resources/vector.d.ts +9 -0
  160. package/dist/adapters/postgresql/resources/vector.d.ts.map +1 -0
  161. package/dist/adapters/postgresql/resources/vector.js +185 -0
  162. package/dist/adapters/postgresql/resources/vector.js.map +1 -0
  163. package/dist/adapters/postgresql/schemas/admin.d.ts +74 -0
  164. package/dist/adapters/postgresql/schemas/admin.d.ts.map +1 -0
  165. package/dist/adapters/postgresql/schemas/admin.js +180 -0
  166. package/dist/adapters/postgresql/schemas/admin.js.map +1 -0
  167. package/dist/adapters/postgresql/schemas/backup.d.ts +68 -0
  168. package/dist/adapters/postgresql/schemas/backup.d.ts.map +1 -0
  169. package/dist/adapters/postgresql/schemas/backup.js +114 -0
  170. package/dist/adapters/postgresql/schemas/backup.js.map +1 -0
  171. package/dist/adapters/postgresql/schemas/core.d.ts +443 -0
  172. package/dist/adapters/postgresql/schemas/core.d.ts.map +1 -0
  173. package/dist/adapters/postgresql/schemas/core.js +628 -0
  174. package/dist/adapters/postgresql/schemas/core.js.map +1 -0
  175. package/dist/adapters/postgresql/schemas/cron.d.ts +131 -0
  176. package/dist/adapters/postgresql/schemas/cron.d.ts.map +1 -0
  177. package/dist/adapters/postgresql/schemas/cron.js +218 -0
  178. package/dist/adapters/postgresql/schemas/cron.js.map +1 -0
  179. package/dist/adapters/postgresql/schemas/extensions.d.ts +403 -0
  180. package/dist/adapters/postgresql/schemas/extensions.d.ts.map +1 -0
  181. package/dist/adapters/postgresql/schemas/extensions.js +600 -0
  182. package/dist/adapters/postgresql/schemas/extensions.js.map +1 -0
  183. package/dist/adapters/postgresql/schemas/index.d.ts +21 -0
  184. package/dist/adapters/postgresql/schemas/index.d.ts.map +1 -0
  185. package/dist/adapters/postgresql/schemas/index.js +72 -0
  186. package/dist/adapters/postgresql/schemas/index.js.map +1 -0
  187. package/dist/adapters/postgresql/schemas/jsonb.d.ts +94 -0
  188. package/dist/adapters/postgresql/schemas/jsonb.d.ts.map +1 -0
  189. package/dist/adapters/postgresql/schemas/jsonb.js +198 -0
  190. package/dist/adapters/postgresql/schemas/jsonb.js.map +1 -0
  191. package/dist/adapters/postgresql/schemas/monitoring.d.ts +28 -0
  192. package/dist/adapters/postgresql/schemas/monitoring.d.ts.map +1 -0
  193. package/dist/adapters/postgresql/schemas/monitoring.js +45 -0
  194. package/dist/adapters/postgresql/schemas/monitoring.js.map +1 -0
  195. package/dist/adapters/postgresql/schemas/partitioning.d.ts +152 -0
  196. package/dist/adapters/postgresql/schemas/partitioning.d.ts.map +1 -0
  197. package/dist/adapters/postgresql/schemas/partitioning.js +399 -0
  198. package/dist/adapters/postgresql/schemas/partitioning.js.map +1 -0
  199. package/dist/adapters/postgresql/schemas/partman.d.ts +94 -0
  200. package/dist/adapters/postgresql/schemas/partman.d.ts.map +1 -0
  201. package/dist/adapters/postgresql/schemas/partman.js +264 -0
  202. package/dist/adapters/postgresql/schemas/partman.js.map +1 -0
  203. package/dist/adapters/postgresql/schemas/performance.d.ts +52 -0
  204. package/dist/adapters/postgresql/schemas/performance.d.ts.map +1 -0
  205. package/dist/adapters/postgresql/schemas/performance.js +57 -0
  206. package/dist/adapters/postgresql/schemas/performance.js.map +1 -0
  207. package/dist/adapters/postgresql/schemas/postgis.d.ts +693 -0
  208. package/dist/adapters/postgresql/schemas/postgis.d.ts.map +1 -0
  209. package/dist/adapters/postgresql/schemas/postgis.js +662 -0
  210. package/dist/adapters/postgresql/schemas/postgis.js.map +1 -0
  211. package/dist/adapters/postgresql/schemas/schema-mgmt.d.ts +171 -0
  212. package/dist/adapters/postgresql/schemas/schema-mgmt.d.ts.map +1 -0
  213. package/dist/adapters/postgresql/schemas/schema-mgmt.js +235 -0
  214. package/dist/adapters/postgresql/schemas/schema-mgmt.js.map +1 -0
  215. package/dist/adapters/postgresql/schemas/stats.d.ts +229 -0
  216. package/dist/adapters/postgresql/schemas/stats.d.ts.map +1 -0
  217. package/dist/adapters/postgresql/schemas/stats.js +587 -0
  218. package/dist/adapters/postgresql/schemas/stats.js.map +1 -0
  219. package/dist/adapters/postgresql/schemas/text-search.d.ts +83 -0
  220. package/dist/adapters/postgresql/schemas/text-search.d.ts.map +1 -0
  221. package/dist/adapters/postgresql/schemas/text-search.js +132 -0
  222. package/dist/adapters/postgresql/schemas/text-search.js.map +1 -0
  223. package/dist/adapters/postgresql/schemas/vector.d.ts +143 -0
  224. package/dist/adapters/postgresql/schemas/vector.d.ts.map +1 -0
  225. package/dist/adapters/postgresql/schemas/vector.js +123 -0
  226. package/dist/adapters/postgresql/schemas/vector.js.map +1 -0
  227. package/dist/adapters/postgresql/tools/admin.d.ts +13 -0
  228. package/dist/adapters/postgresql/tools/admin.d.ts.map +1 -0
  229. package/dist/adapters/postgresql/tools/admin.js +417 -0
  230. package/dist/adapters/postgresql/tools/admin.js.map +1 -0
  231. package/dist/adapters/postgresql/tools/backup/dump.d.ts +12 -0
  232. package/dist/adapters/postgresql/tools/backup/dump.d.ts.map +1 -0
  233. package/dist/adapters/postgresql/tools/backup/dump.js +546 -0
  234. package/dist/adapters/postgresql/tools/backup/dump.js.map +1 -0
  235. package/dist/adapters/postgresql/tools/backup/index.d.ts +16 -0
  236. package/dist/adapters/postgresql/tools/backup/index.d.ts.map +1 -0
  237. package/dist/adapters/postgresql/tools/backup/index.js +29 -0
  238. package/dist/adapters/postgresql/tools/backup/index.js.map +1 -0
  239. package/dist/adapters/postgresql/tools/backup/planning.d.ts +22 -0
  240. package/dist/adapters/postgresql/tools/backup/planning.d.ts.map +1 -0
  241. package/dist/adapters/postgresql/tools/backup/planning.js +411 -0
  242. package/dist/adapters/postgresql/tools/backup/planning.js.map +1 -0
  243. package/dist/adapters/postgresql/tools/citext.d.ts +18 -0
  244. package/dist/adapters/postgresql/tools/citext.d.ts.map +1 -0
  245. package/dist/adapters/postgresql/tools/citext.js +568 -0
  246. package/dist/adapters/postgresql/tools/citext.js.map +1 -0
  247. package/dist/adapters/postgresql/tools/codemode/index.d.ts +27 -0
  248. package/dist/adapters/postgresql/tools/codemode/index.d.ts.map +1 -0
  249. package/dist/adapters/postgresql/tools/codemode/index.js +171 -0
  250. package/dist/adapters/postgresql/tools/codemode/index.js.map +1 -0
  251. package/dist/adapters/postgresql/tools/core/convenience.d.ts +192 -0
  252. package/dist/adapters/postgresql/tools/core/convenience.d.ts.map +1 -0
  253. package/dist/adapters/postgresql/tools/core/convenience.js +617 -0
  254. package/dist/adapters/postgresql/tools/core/convenience.js.map +1 -0
  255. package/dist/adapters/postgresql/tools/core/health.d.ts +20 -0
  256. package/dist/adapters/postgresql/tools/core/health.d.ts.map +1 -0
  257. package/dist/adapters/postgresql/tools/core/health.js +360 -0
  258. package/dist/adapters/postgresql/tools/core/health.js.map +1 -0
  259. package/dist/adapters/postgresql/tools/core/index.d.ts +15 -0
  260. package/dist/adapters/postgresql/tools/core/index.d.ts.map +1 -0
  261. package/dist/adapters/postgresql/tools/core/index.js +40 -0
  262. package/dist/adapters/postgresql/tools/core/index.js.map +1 -0
  263. package/dist/adapters/postgresql/tools/core/indexes.d.ts +30 -0
  264. package/dist/adapters/postgresql/tools/core/indexes.d.ts.map +1 -0
  265. package/dist/adapters/postgresql/tools/core/indexes.js +232 -0
  266. package/dist/adapters/postgresql/tools/core/indexes.js.map +1 -0
  267. package/dist/adapters/postgresql/tools/core/objects.d.ts +20 -0
  268. package/dist/adapters/postgresql/tools/core/objects.d.ts.map +1 -0
  269. package/dist/adapters/postgresql/tools/core/objects.js +361 -0
  270. package/dist/adapters/postgresql/tools/core/objects.js.map +1 -0
  271. package/dist/adapters/postgresql/tools/core/query.d.ts +16 -0
  272. package/dist/adapters/postgresql/tools/core/query.d.ts.map +1 -0
  273. package/dist/adapters/postgresql/tools/core/query.js +87 -0
  274. package/dist/adapters/postgresql/tools/core/query.js.map +1 -0
  275. package/dist/adapters/postgresql/tools/core/schemas.d.ts +135 -0
  276. package/dist/adapters/postgresql/tools/core/schemas.d.ts.map +1 -0
  277. package/dist/adapters/postgresql/tools/core/schemas.js +221 -0
  278. package/dist/adapters/postgresql/tools/core/schemas.js.map +1 -0
  279. package/dist/adapters/postgresql/tools/core/tables.d.ts +24 -0
  280. package/dist/adapters/postgresql/tools/core/tables.d.ts.map +1 -0
  281. package/dist/adapters/postgresql/tools/core/tables.js +219 -0
  282. package/dist/adapters/postgresql/tools/core/tables.js.map +1 -0
  283. package/dist/adapters/postgresql/tools/cron.d.ts +16 -0
  284. package/dist/adapters/postgresql/tools/cron.d.ts.map +1 -0
  285. package/dist/adapters/postgresql/tools/cron.js +440 -0
  286. package/dist/adapters/postgresql/tools/cron.js.map +1 -0
  287. package/dist/adapters/postgresql/tools/jsonb/advanced.d.ts +33 -0
  288. package/dist/adapters/postgresql/tools/jsonb/advanced.d.ts.map +1 -0
  289. package/dist/adapters/postgresql/tools/jsonb/advanced.js +681 -0
  290. package/dist/adapters/postgresql/tools/jsonb/advanced.js.map +1 -0
  291. package/dist/adapters/postgresql/tools/jsonb/basic.d.ts +20 -0
  292. package/dist/adapters/postgresql/tools/jsonb/basic.d.ts.map +1 -0
  293. package/dist/adapters/postgresql/tools/jsonb/basic.js +654 -0
  294. package/dist/adapters/postgresql/tools/jsonb/basic.js.map +1 -0
  295. package/dist/adapters/postgresql/tools/jsonb/index.d.ts +16 -0
  296. package/dist/adapters/postgresql/tools/jsonb/index.d.ts.map +1 -0
  297. package/dist/adapters/postgresql/tools/jsonb/index.js +39 -0
  298. package/dist/adapters/postgresql/tools/jsonb/index.js.map +1 -0
  299. package/dist/adapters/postgresql/tools/kcache.d.ts +20 -0
  300. package/dist/adapters/postgresql/tools/kcache.d.ts.map +1 -0
  301. package/dist/adapters/postgresql/tools/kcache.js +574 -0
  302. package/dist/adapters/postgresql/tools/kcache.js.map +1 -0
  303. package/dist/adapters/postgresql/tools/ltree.d.ts +8 -0
  304. package/dist/adapters/postgresql/tools/ltree.d.ts.map +1 -0
  305. package/dist/adapters/postgresql/tools/ltree.js +390 -0
  306. package/dist/adapters/postgresql/tools/ltree.js.map +1 -0
  307. package/dist/adapters/postgresql/tools/monitoring.d.ts +13 -0
  308. package/dist/adapters/postgresql/tools/monitoring.d.ts.map +1 -0
  309. package/dist/adapters/postgresql/tools/monitoring.js +753 -0
  310. package/dist/adapters/postgresql/tools/monitoring.js.map +1 -0
  311. package/dist/adapters/postgresql/tools/partitioning.d.ts +13 -0
  312. package/dist/adapters/postgresql/tools/partitioning.d.ts.map +1 -0
  313. package/dist/adapters/postgresql/tools/partitioning.js +500 -0
  314. package/dist/adapters/postgresql/tools/partitioning.js.map +1 -0
  315. package/dist/adapters/postgresql/tools/partman/index.d.ts +19 -0
  316. package/dist/adapters/postgresql/tools/partman/index.d.ts.map +1 -0
  317. package/dist/adapters/postgresql/tools/partman/index.js +33 -0
  318. package/dist/adapters/postgresql/tools/partman/index.js.map +1 -0
  319. package/dist/adapters/postgresql/tools/partman/management.d.ts +28 -0
  320. package/dist/adapters/postgresql/tools/partman/management.d.ts.map +1 -0
  321. package/dist/adapters/postgresql/tools/partman/management.js +563 -0
  322. package/dist/adapters/postgresql/tools/partman/management.js.map +1 -0
  323. package/dist/adapters/postgresql/tools/partman/operations.d.ts +28 -0
  324. package/dist/adapters/postgresql/tools/partman/operations.d.ts.map +1 -0
  325. package/dist/adapters/postgresql/tools/partman/operations.js +632 -0
  326. package/dist/adapters/postgresql/tools/partman/operations.js.map +1 -0
  327. package/dist/adapters/postgresql/tools/performance/analysis.d.ts +9 -0
  328. package/dist/adapters/postgresql/tools/performance/analysis.d.ts.map +1 -0
  329. package/dist/adapters/postgresql/tools/performance/analysis.js +383 -0
  330. package/dist/adapters/postgresql/tools/performance/analysis.js.map +1 -0
  331. package/dist/adapters/postgresql/tools/performance/explain.d.ts +13 -0
  332. package/dist/adapters/postgresql/tools/performance/explain.d.ts.map +1 -0
  333. package/dist/adapters/postgresql/tools/performance/explain.js +71 -0
  334. package/dist/adapters/postgresql/tools/performance/explain.js.map +1 -0
  335. package/dist/adapters/postgresql/tools/performance/index.d.ts +13 -0
  336. package/dist/adapters/postgresql/tools/performance/index.d.ts.map +1 -0
  337. package/dist/adapters/postgresql/tools/performance/index.js +40 -0
  338. package/dist/adapters/postgresql/tools/performance/index.js.map +1 -0
  339. package/dist/adapters/postgresql/tools/performance/monitoring.d.ts +9 -0
  340. package/dist/adapters/postgresql/tools/performance/monitoring.d.ts.map +1 -0
  341. package/dist/adapters/postgresql/tools/performance/monitoring.js +122 -0
  342. package/dist/adapters/postgresql/tools/performance/monitoring.js.map +1 -0
  343. package/dist/adapters/postgresql/tools/performance/optimization.d.ts +9 -0
  344. package/dist/adapters/postgresql/tools/performance/optimization.d.ts.map +1 -0
  345. package/dist/adapters/postgresql/tools/performance/optimization.js +315 -0
  346. package/dist/adapters/postgresql/tools/performance/optimization.js.map +1 -0
  347. package/dist/adapters/postgresql/tools/performance/stats.d.ts +14 -0
  348. package/dist/adapters/postgresql/tools/performance/stats.d.ts.map +1 -0
  349. package/dist/adapters/postgresql/tools/performance/stats.js +559 -0
  350. package/dist/adapters/postgresql/tools/performance/stats.js.map +1 -0
  351. package/dist/adapters/postgresql/tools/pgcrypto.d.ts +8 -0
  352. package/dist/adapters/postgresql/tools/pgcrypto.d.ts.map +1 -0
  353. package/dist/adapters/postgresql/tools/pgcrypto.js +239 -0
  354. package/dist/adapters/postgresql/tools/pgcrypto.js.map +1 -0
  355. package/dist/adapters/postgresql/tools/postgis/advanced.d.ts +21 -0
  356. package/dist/adapters/postgresql/tools/postgis/advanced.d.ts.map +1 -0
  357. package/dist/adapters/postgresql/tools/postgis/advanced.js +383 -0
  358. package/dist/adapters/postgresql/tools/postgis/advanced.js.map +1 -0
  359. package/dist/adapters/postgresql/tools/postgis/basic.d.ts +16 -0
  360. package/dist/adapters/postgresql/tools/postgis/basic.d.ts.map +1 -0
  361. package/dist/adapters/postgresql/tools/postgis/basic.js +479 -0
  362. package/dist/adapters/postgresql/tools/postgis/basic.js.map +1 -0
  363. package/dist/adapters/postgresql/tools/postgis/index.d.ts +17 -0
  364. package/dist/adapters/postgresql/tools/postgis/index.d.ts.map +1 -0
  365. package/dist/adapters/postgresql/tools/postgis/index.js +46 -0
  366. package/dist/adapters/postgresql/tools/postgis/index.js.map +1 -0
  367. package/dist/adapters/postgresql/tools/postgis/standalone.d.ts +21 -0
  368. package/dist/adapters/postgresql/tools/postgis/standalone.d.ts.map +1 -0
  369. package/dist/adapters/postgresql/tools/postgis/standalone.js +150 -0
  370. package/dist/adapters/postgresql/tools/postgis/standalone.js.map +1 -0
  371. package/dist/adapters/postgresql/tools/schema.d.ts +13 -0
  372. package/dist/adapters/postgresql/tools/schema.d.ts.map +1 -0
  373. package/dist/adapters/postgresql/tools/schema.js +515 -0
  374. package/dist/adapters/postgresql/tools/schema.js.map +1 -0
  375. package/dist/adapters/postgresql/tools/stats/advanced.d.ts +24 -0
  376. package/dist/adapters/postgresql/tools/stats/advanced.d.ts.map +1 -0
  377. package/dist/adapters/postgresql/tools/stats/advanced.js +876 -0
  378. package/dist/adapters/postgresql/tools/stats/advanced.js.map +1 -0
  379. package/dist/adapters/postgresql/tools/stats/basic.d.ts +24 -0
  380. package/dist/adapters/postgresql/tools/stats/basic.d.ts.map +1 -0
  381. package/dist/adapters/postgresql/tools/stats/basic.js +501 -0
  382. package/dist/adapters/postgresql/tools/stats/basic.js.map +1 -0
  383. package/dist/adapters/postgresql/tools/stats/index.d.ts +17 -0
  384. package/dist/adapters/postgresql/tools/stats/index.d.ts.map +1 -0
  385. package/dist/adapters/postgresql/tools/stats/index.js +30 -0
  386. package/dist/adapters/postgresql/tools/stats/index.js.map +1 -0
  387. package/dist/adapters/postgresql/tools/text.d.ts +13 -0
  388. package/dist/adapters/postgresql/tools/text.d.ts.map +1 -0
  389. package/dist/adapters/postgresql/tools/text.js +708 -0
  390. package/dist/adapters/postgresql/tools/text.js.map +1 -0
  391. package/dist/adapters/postgresql/tools/transactions.d.ts +13 -0
  392. package/dist/adapters/postgresql/tools/transactions.d.ts.map +1 -0
  393. package/dist/adapters/postgresql/tools/transactions.js +201 -0
  394. package/dist/adapters/postgresql/tools/transactions.js.map +1 -0
  395. package/dist/adapters/postgresql/tools/vector/advanced.d.ts +12 -0
  396. package/dist/adapters/postgresql/tools/vector/advanced.d.ts.map +1 -0
  397. package/dist/adapters/postgresql/tools/vector/advanced.js +902 -0
  398. package/dist/adapters/postgresql/tools/vector/advanced.js.map +1 -0
  399. package/dist/adapters/postgresql/tools/vector/basic.d.ts +25 -0
  400. package/dist/adapters/postgresql/tools/vector/basic.d.ts.map +1 -0
  401. package/dist/adapters/postgresql/tools/vector/basic.js +1000 -0
  402. package/dist/adapters/postgresql/tools/vector/basic.js.map +1 -0
  403. package/dist/adapters/postgresql/tools/vector/index.d.ts +13 -0
  404. package/dist/adapters/postgresql/tools/vector/index.d.ts.map +1 -0
  405. package/dist/adapters/postgresql/tools/vector/index.js +33 -0
  406. package/dist/adapters/postgresql/tools/vector/index.js.map +1 -0
  407. package/dist/auth/AuthorizationServerDiscovery.d.ts +44 -0
  408. package/dist/auth/AuthorizationServerDiscovery.d.ts.map +1 -0
  409. package/dist/auth/AuthorizationServerDiscovery.js +117 -0
  410. package/dist/auth/AuthorizationServerDiscovery.js.map +1 -0
  411. package/dist/auth/OAuthResourceServer.d.ts +42 -0
  412. package/dist/auth/OAuthResourceServer.d.ts.map +1 -0
  413. package/dist/auth/OAuthResourceServer.js +80 -0
  414. package/dist/auth/OAuthResourceServer.js.map +1 -0
  415. package/dist/auth/TokenValidator.d.ts +36 -0
  416. package/dist/auth/TokenValidator.d.ts.map +1 -0
  417. package/dist/auth/TokenValidator.js +139 -0
  418. package/dist/auth/TokenValidator.js.map +1 -0
  419. package/dist/auth/errors.d.ts +63 -0
  420. package/dist/auth/errors.d.ts.map +1 -0
  421. package/dist/auth/errors.js +102 -0
  422. package/dist/auth/errors.js.map +1 -0
  423. package/dist/auth/index.d.ts +15 -0
  424. package/dist/auth/index.d.ts.map +1 -0
  425. package/dist/auth/index.js +16 -0
  426. package/dist/auth/index.js.map +1 -0
  427. package/dist/auth/middleware.d.ts +61 -0
  428. package/dist/auth/middleware.d.ts.map +1 -0
  429. package/dist/auth/middleware.js +156 -0
  430. package/dist/auth/middleware.js.map +1 -0
  431. package/dist/auth/scopes.d.ts +65 -0
  432. package/dist/auth/scopes.d.ts.map +1 -0
  433. package/dist/auth/scopes.js +189 -0
  434. package/dist/auth/scopes.js.map +1 -0
  435. package/dist/auth/types.d.ts +208 -0
  436. package/dist/auth/types.d.ts.map +1 -0
  437. package/dist/auth/types.js +8 -0
  438. package/dist/auth/types.js.map +1 -0
  439. package/dist/cli/args.d.ts +34 -0
  440. package/dist/cli/args.d.ts.map +1 -0
  441. package/dist/cli/args.js +308 -0
  442. package/dist/cli/args.js.map +1 -0
  443. package/dist/cli/index.d.ts +8 -0
  444. package/dist/cli/index.d.ts.map +1 -0
  445. package/dist/cli/index.js +7 -0
  446. package/dist/cli/index.js.map +1 -0
  447. package/dist/cli.d.ts +9 -0
  448. package/dist/cli.d.ts.map +1 -0
  449. package/dist/cli.js +341 -0
  450. package/dist/cli.js.map +1 -0
  451. package/dist/codemode/api.d.ts +62 -0
  452. package/dist/codemode/api.d.ts.map +1 -0
  453. package/dist/codemode/api.js +1505 -0
  454. package/dist/codemode/api.js.map +1 -0
  455. package/dist/codemode/index.d.ts +13 -0
  456. package/dist/codemode/index.d.ts.map +1 -0
  457. package/dist/codemode/index.js +17 -0
  458. package/dist/codemode/index.js.map +1 -0
  459. package/dist/codemode/sandbox-factory.d.ts +72 -0
  460. package/dist/codemode/sandbox-factory.d.ts.map +1 -0
  461. package/dist/codemode/sandbox-factory.js +88 -0
  462. package/dist/codemode/sandbox-factory.js.map +1 -0
  463. package/dist/codemode/sandbox.d.ts +96 -0
  464. package/dist/codemode/sandbox.d.ts.map +1 -0
  465. package/dist/codemode/sandbox.js +345 -0
  466. package/dist/codemode/sandbox.js.map +1 -0
  467. package/dist/codemode/security.d.ts +44 -0
  468. package/dist/codemode/security.d.ts.map +1 -0
  469. package/dist/codemode/security.js +149 -0
  470. package/dist/codemode/security.js.map +1 -0
  471. package/dist/codemode/types.d.ts +137 -0
  472. package/dist/codemode/types.d.ts.map +1 -0
  473. package/dist/codemode/types.js +46 -0
  474. package/dist/codemode/types.js.map +1 -0
  475. package/dist/codemode/worker-sandbox.d.ts +82 -0
  476. package/dist/codemode/worker-sandbox.d.ts.map +1 -0
  477. package/dist/codemode/worker-sandbox.js +244 -0
  478. package/dist/codemode/worker-sandbox.js.map +1 -0
  479. package/dist/codemode/worker-script.d.ts +8 -0
  480. package/dist/codemode/worker-script.d.ts.map +1 -0
  481. package/dist/codemode/worker-script.js +113 -0
  482. package/dist/codemode/worker-script.js.map +1 -0
  483. package/dist/constants/ServerInstructions.d.ts +13 -0
  484. package/dist/constants/ServerInstructions.d.ts.map +1 -0
  485. package/dist/constants/ServerInstructions.js +405 -0
  486. package/dist/constants/ServerInstructions.js.map +1 -0
  487. package/dist/filtering/ToolConstants.d.ts +43 -0
  488. package/dist/filtering/ToolConstants.d.ts.map +1 -0
  489. package/dist/filtering/ToolConstants.js +352 -0
  490. package/dist/filtering/ToolConstants.js.map +1 -0
  491. package/dist/filtering/ToolFilter.d.ts +90 -0
  492. package/dist/filtering/ToolFilter.d.ts.map +1 -0
  493. package/dist/filtering/ToolFilter.js +315 -0
  494. package/dist/filtering/ToolFilter.js.map +1 -0
  495. package/dist/index.d.ts +15 -0
  496. package/dist/index.d.ts.map +1 -0
  497. package/dist/index.js +19 -0
  498. package/dist/index.js.map +1 -0
  499. package/dist/pool/ConnectionPool.d.ts +70 -0
  500. package/dist/pool/ConnectionPool.d.ts.map +1 -0
  501. package/dist/pool/ConnectionPool.js +254 -0
  502. package/dist/pool/ConnectionPool.js.map +1 -0
  503. package/dist/server/McpServer.d.ts +50 -0
  504. package/dist/server/McpServer.d.ts.map +1 -0
  505. package/dist/server/McpServer.js +108 -0
  506. package/dist/server/McpServer.js.map +1 -0
  507. package/dist/transports/http.d.ts +126 -0
  508. package/dist/transports/http.d.ts.map +1 -0
  509. package/dist/transports/http.js +303 -0
  510. package/dist/transports/http.js.map +1 -0
  511. package/dist/transports/index.d.ts +8 -0
  512. package/dist/transports/index.d.ts.map +1 -0
  513. package/dist/transports/index.js +7 -0
  514. package/dist/transports/index.js.map +1 -0
  515. package/dist/types/adapters.d.ts +136 -0
  516. package/dist/types/adapters.d.ts.map +1 -0
  517. package/dist/types/adapters.js +7 -0
  518. package/dist/types/adapters.js.map +1 -0
  519. package/dist/types/database.d.ts +204 -0
  520. package/dist/types/database.d.ts.map +1 -0
  521. package/dist/types/database.js +7 -0
  522. package/dist/types/database.js.map +1 -0
  523. package/dist/types/errors.d.ts +62 -0
  524. package/dist/types/errors.d.ts.map +1 -0
  525. package/dist/types/errors.js +91 -0
  526. package/dist/types/errors.js.map +1 -0
  527. package/dist/types/filtering.d.ts +39 -0
  528. package/dist/types/filtering.d.ts.map +1 -0
  529. package/dist/types/filtering.js +7 -0
  530. package/dist/types/filtering.js.map +1 -0
  531. package/dist/types/index.d.ts +16 -0
  532. package/dist/types/index.d.ts.map +1 -0
  533. package/dist/types/index.js +11 -0
  534. package/dist/types/index.js.map +1 -0
  535. package/dist/types/mcp.d.ts +31 -0
  536. package/dist/types/mcp.d.ts.map +1 -0
  537. package/dist/types/mcp.js +7 -0
  538. package/dist/types/mcp.js.map +1 -0
  539. package/dist/types/oauth.d.ts +65 -0
  540. package/dist/types/oauth.d.ts.map +1 -0
  541. package/dist/types/oauth.js +7 -0
  542. package/dist/types/oauth.js.map +1 -0
  543. package/dist/types/schema.d.ts +110 -0
  544. package/dist/types/schema.d.ts.map +1 -0
  545. package/dist/types/schema.js +7 -0
  546. package/dist/types/schema.js.map +1 -0
  547. package/dist/utils/annotations.d.ts +42 -0
  548. package/dist/utils/annotations.d.ts.map +1 -0
  549. package/dist/utils/annotations.js +75 -0
  550. package/dist/utils/annotations.js.map +1 -0
  551. package/dist/utils/icons.d.ts +25 -0
  552. package/dist/utils/icons.d.ts.map +1 -0
  553. package/dist/utils/icons.js +212 -0
  554. package/dist/utils/icons.js.map +1 -0
  555. package/dist/utils/identifiers.d.ts +111 -0
  556. package/dist/utils/identifiers.d.ts.map +1 -0
  557. package/dist/utils/identifiers.js +270 -0
  558. package/dist/utils/identifiers.js.map +1 -0
  559. package/dist/utils/logger.d.ts +141 -0
  560. package/dist/utils/logger.d.ts.map +1 -0
  561. package/dist/utils/logger.js +304 -0
  562. package/dist/utils/logger.js.map +1 -0
  563. package/dist/utils/promptGenerator.d.ts +20 -0
  564. package/dist/utils/promptGenerator.d.ts.map +1 -0
  565. package/dist/utils/promptGenerator.js +81 -0
  566. package/dist/utils/promptGenerator.js.map +1 -0
  567. package/dist/utils/resourceAnnotations.d.ts +36 -0
  568. package/dist/utils/resourceAnnotations.d.ts.map +1 -0
  569. package/dist/utils/resourceAnnotations.js +57 -0
  570. package/dist/utils/resourceAnnotations.js.map +1 -0
  571. package/package.json +64 -0
@@ -0,0 +1,232 @@
1
+ /**
2
+ * PostgreSQL Core Tools - Index Operations
3
+ *
4
+ * Index listing and creation tools.
5
+ */
6
+ import { readOnly, write } from "../../../../utils/annotations.js";
7
+ import { getToolIcons } from "../../../../utils/icons.js";
8
+ import { GetIndexesSchemaBase, GetIndexesSchema, CreateIndexSchemaBase, CreateIndexSchema, } from "../../schemas/index.js";
9
+ /**
10
+ * Get indexes for a table
11
+ */
12
+ export function createGetIndexesTool(adapter) {
13
+ return {
14
+ name: "pg_get_indexes",
15
+ description: "List indexes with usage statistics. When table is omitted, lists ALL database indexes (can be large). Use schema/limit to filter.",
16
+ group: "core",
17
+ inputSchema: GetIndexesSchemaBase,
18
+ annotations: readOnly("Get Indexes"),
19
+ icons: getToolIcons("core", readOnly("Get Indexes")),
20
+ handler: async (params, _context) => {
21
+ const { table, schema, limit } = GetIndexesSchema.parse(params);
22
+ // If no table specified, list all indexes in the database
23
+ if (table === undefined || table === "") {
24
+ const indexes = await adapter.getAllIndexes();
25
+ // Optionally filter by schema
26
+ const filtered = schema !== undefined
27
+ ? indexes.filter((idx) => idx.schemaName === schema)
28
+ : indexes;
29
+ // Apply limit (default 100 for all-indexes query to avoid overwhelming results)
30
+ const effectiveLimit = limit ?? 100;
31
+ const limited = filtered.slice(0, effectiveLimit);
32
+ const totalCount = filtered.length;
33
+ return {
34
+ indexes: limited,
35
+ count: limited.length,
36
+ totalCount,
37
+ // Add hint about pagination/filtering
38
+ ...(totalCount > effectiveLimit && {
39
+ truncated: true,
40
+ hint: `Showing ${String(effectiveLimit)} of ${String(totalCount)} indexes. Use 'limit' to see more, 'schema' to filter, or 'table' for specific table.`,
41
+ }),
42
+ };
43
+ }
44
+ const indexes = await adapter.getTableIndexes(table, schema);
45
+ return {
46
+ indexes,
47
+ count: indexes.length,
48
+ table: `${schema ?? "public"}.${table}`,
49
+ };
50
+ },
51
+ };
52
+ }
53
+ /**
54
+ * Create an index
55
+ */
56
+ export function createCreateIndexTool(adapter) {
57
+ return {
58
+ name: "pg_create_index",
59
+ description: "Create an index on a table. Supports btree, hash, gin, gist, brin index types.",
60
+ group: "core",
61
+ inputSchema: CreateIndexSchemaBase,
62
+ annotations: write("Create Index"),
63
+ icons: getToolIcons("core", write("Create Index")),
64
+ handler: async (params, _context) => {
65
+ const parsed = CreateIndexSchema.parse(params);
66
+ const { name, table, schema, columns, unique, type, where, concurrently, ifNotExists, } = parsed;
67
+ const schemaName = schema ?? "public";
68
+ // Track if name was auto-generated
69
+ const rawParams = params;
70
+ const wasAutoGenerated = rawParams !== null &&
71
+ rawParams["name"] === undefined &&
72
+ rawParams["indexName"] === undefined;
73
+ // If ifNotExists is true, check if index already exists BEFORE creating
74
+ if (ifNotExists === true) {
75
+ const checkSql = `
76
+ SELECT 1 FROM pg_indexes
77
+ WHERE schemaname = $1 AND indexname = $2
78
+ `;
79
+ const checkResult = await adapter.executeQuery(checkSql, [
80
+ schemaName,
81
+ name,
82
+ ]);
83
+ if (checkResult.rows && checkResult.rows.length > 0) {
84
+ return {
85
+ success: true,
86
+ index: name,
87
+ indexName: name, // Alias for clarity
88
+ table: `${schemaName}.${table}`,
89
+ ifNotExists: true,
90
+ alreadyExists: true,
91
+ message: `Index ${name} already exists`,
92
+ ...(wasAutoGenerated && { generatedName: true }),
93
+ };
94
+ }
95
+ }
96
+ const schemaPrefix = schema ? `"${schema}".` : "";
97
+ const uniqueClause = unique ? "UNIQUE " : "";
98
+ const concurrentlyClause = concurrently ? "CONCURRENTLY " : "";
99
+ const usingClause = type ? `USING ${type} ` : "";
100
+ const whereClause = where ? ` WHERE ${where}` : "";
101
+ // Support expression indexes: detect expressions (containing parentheses or operators)
102
+ // and don't quote them
103
+ const isExpression = (col) => {
104
+ return col.includes("(") || col.includes(" ") || col.includes("::");
105
+ };
106
+ const columnList = columns
107
+ .map((c) => (isExpression(c) ? c : `"${c}"`))
108
+ .join(", ");
109
+ const sql = `CREATE ${uniqueClause}INDEX ${concurrentlyClause}"${name}" ` +
110
+ `ON ${schemaPrefix}"${table}" ${usingClause}(${columnList})${whereClause}`;
111
+ try {
112
+ await adapter.executeQuery(sql);
113
+ return {
114
+ success: true,
115
+ index: name,
116
+ indexName: name, // Alias for clarity
117
+ table: `${schemaName}.${table}`,
118
+ sql,
119
+ ...(wasAutoGenerated && { generatedName: true }),
120
+ };
121
+ }
122
+ catch (error) {
123
+ // If ifNotExists is true and the error is "already exists", return success with alreadyExists flag
124
+ // (This handles race conditions where index is created between check and create)
125
+ if (ifNotExists === true && error instanceof Error) {
126
+ const msg = error.message.toLowerCase();
127
+ if (msg.includes("already exists") || msg.includes("duplicate")) {
128
+ return {
129
+ success: true,
130
+ index: name,
131
+ indexName: name,
132
+ table: `${schemaName}.${table}`,
133
+ ifNotExists: true,
134
+ alreadyExists: true,
135
+ message: `Index ${name} already exists`,
136
+ ...(wasAutoGenerated && { generatedName: true }),
137
+ };
138
+ }
139
+ }
140
+ // Re-throw other errors
141
+ throw error;
142
+ }
143
+ },
144
+ };
145
+ }
146
+ import { z } from "zod";
147
+ /**
148
+ * Preprocess table parameters for drop index
149
+ */
150
+ function preprocessDropIndexParams(input) {
151
+ if (typeof input !== "object" || input === null)
152
+ return input;
153
+ const result = { ...input };
154
+ // Alias: index/indexName → name
155
+ if (result["name"] === undefined) {
156
+ if (result["index"] !== undefined)
157
+ result["name"] = result["index"];
158
+ else if (result["indexName"] !== undefined)
159
+ result["name"] = result["indexName"];
160
+ }
161
+ // Parse schema.name format
162
+ if (typeof result["name"] === "string" &&
163
+ result["name"].includes(".") &&
164
+ result["schema"] === undefined) {
165
+ const parts = result["name"].split(".");
166
+ if (parts.length === 2) {
167
+ result["schema"] = parts[0];
168
+ result["name"] = parts[1];
169
+ }
170
+ }
171
+ return result;
172
+ }
173
+ // Base schema for MCP visibility - exported for inputSchema
174
+ export const DropIndexSchemaBase = z.object({
175
+ name: z
176
+ .string()
177
+ .optional()
178
+ .describe("Index name (supports schema.name format)"),
179
+ index: z.string().optional().describe("Alias for name"),
180
+ indexName: z.string().optional().describe("Alias for name"),
181
+ schema: z.string().optional().describe("Schema name (default: public)"),
182
+ ifExists: z
183
+ .boolean()
184
+ .optional()
185
+ .describe("Use IF EXISTS to avoid errors if index does not exist"),
186
+ cascade: z
187
+ .boolean()
188
+ .optional()
189
+ .describe("Use CASCADE to drop dependent objects"),
190
+ concurrently: z
191
+ .boolean()
192
+ .optional()
193
+ .describe("Drop concurrently (does not lock table)"),
194
+ });
195
+ // Transformed schema for handler validation
196
+ const DropIndexSchema = z
197
+ .preprocess(preprocessDropIndexParams, DropIndexSchemaBase)
198
+ .transform((data) => ({
199
+ ...data,
200
+ name: data.name ?? data.index ?? data.indexName ?? "",
201
+ }))
202
+ .refine((data) => data.name !== "", {
203
+ message: "name (or index/indexName alias) is required",
204
+ });
205
+ /**
206
+ * Drop an index
207
+ */
208
+ export function createDropIndexTool(adapter) {
209
+ return {
210
+ name: "pg_drop_index",
211
+ description: "Drop an index from a table. Supports IF EXISTS, CASCADE, and CONCURRENTLY options.",
212
+ group: "core",
213
+ inputSchema: DropIndexSchemaBase,
214
+ annotations: write("Drop Index"),
215
+ icons: getToolIcons("core", write("Drop Index")),
216
+ handler: async (params, _context) => {
217
+ const { name, schema, ifExists, cascade, concurrently } = DropIndexSchema.parse(params);
218
+ const schemaName = schema ?? "public";
219
+ const ifExistsClause = ifExists === true ? "IF EXISTS " : "";
220
+ const cascadeClause = cascade === true ? " CASCADE" : "";
221
+ const concurrentlyClause = concurrently === true ? "CONCURRENTLY " : "";
222
+ const sql = `DROP INDEX ${concurrentlyClause}${ifExistsClause}"${schemaName}"."${name}"${cascadeClause}`;
223
+ await adapter.executeQuery(sql);
224
+ return {
225
+ success: true,
226
+ index: `${schemaName}.${name}`,
227
+ sql,
228
+ };
229
+ },
230
+ };
231
+ }
232
+ //# sourceMappingURL=indexes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"indexes.js","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/core/indexes.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAOH,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EACL,oBAAoB,EACpB,gBAAgB,EAChB,qBAAqB,EACrB,iBAAiB,GAClB,MAAM,wBAAwB,CAAC;AAEhC;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAAC,OAAwB;IAC3D,OAAO;QACL,IAAI,EAAE,gBAAgB;QACtB,WAAW,EACT,mIAAmI;QACrI,KAAK,EAAE,MAAM;QACb,WAAW,EAAE,oBAAoB;QACjC,WAAW,EAAE,QAAQ,CAAC,aAAa,CAAC;QACpC,KAAK,EAAE,YAAY,CAAC,MAAM,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QACpD,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAEhE,0DAA0D;YAC1D,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,EAAE,EAAE,CAAC;gBACxC,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,aAAa,EAAE,CAAC;gBAC9C,8BAA8B;gBAC9B,MAAM,QAAQ,GACZ,MAAM,KAAK,SAAS;oBAClB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,KAAK,MAAM,CAAC;oBACpD,CAAC,CAAC,OAAO,CAAC;gBAEd,gFAAgF;gBAChF,MAAM,cAAc,GAAG,KAAK,IAAI,GAAG,CAAC;gBACpC,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC;gBAClD,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC;gBAEnC,OAAO;oBACL,OAAO,EAAE,OAAO;oBAChB,KAAK,EAAE,OAAO,CAAC,MAAM;oBACrB,UAAU;oBACV,sCAAsC;oBACtC,GAAG,CAAC,UAAU,GAAG,cAAc,IAAI;wBACjC,SAAS,EAAE,IAAI;wBACf,IAAI,EAAE,WAAW,MAAM,CAAC,cAAc,CAAC,OAAO,MAAM,CAAC,UAAU,CAAC,uFAAuF;qBACxJ,CAAC;iBACH,CAAC;YACJ,CAAC;YAED,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;YAC7D,OAAO;gBACL,OAAO;gBACP,KAAK,EAAE,OAAO,CAAC,MAAM;gBACrB,KAAK,EAAE,GAAG,MAAM,IAAI,QAAQ,IAAI,KAAK,EAAE;aACxC,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,qBAAqB,CACnC,OAAwB;IAExB,OAAO;QACL,IAAI,EAAE,iBAAiB;QACvB,WAAW,EACT,gFAAgF;QAClF,KAAK,EAAE,MAAM;QACb,WAAW,EAAE,qBAAqB;QAClC,WAAW,EAAE,KAAK,CAAC,cAAc,CAAC;QAClC,KAAK,EAAE,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC,cAAc,CAAC,CAAC;QAClD,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,MAAM,MAAM,GAAG,iBAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAC/C,MAAM,EACJ,IAAI,EACJ,KAAK,EACL,MAAM,EACN,OAAO,EACP,MAAM,EACN,IAAI,EACJ,KAAK,EACL,YAAY,EACZ,WAAW,GACZ,GAAG,MAAM,CAAC;YAEX,MAAM,UAAU,GAAG,MAAM,IAAI,QAAQ,CAAC;YAEtC,mCAAmC;YACnC,MAAM,SAAS,GAAG,MAAwC,CAAC;YAC3D,MAAM,gBAAgB,GACpB,SAAS,KAAK,IAAI;gBAClB,SAAS,CAAC,MAAM,CAAC,KAAK,SAAS;gBAC/B,SAAS,CAAC,WAAW,CAAC,KAAK,SAAS,CAAC;YAEvC,wEAAwE;YACxE,IAAI,WAAW,KAAK,IAAI,EAAE,CAAC;gBACzB,MAAM,QAAQ,GAAG;;;iBAGR,CAAC;gBACV,MAAM,WAAW,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,QAAQ,EAAE;oBACvD,UAAU;oBACV,IAAI;iBACL,CAAC,CAAC;gBACH,IAAI,WAAW,CAAC,IAAI,IAAI,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACpD,OAAO;wBACL,OAAO,EAAE,IAAI;wBACb,KAAK,EAAE,IAAI;wBACX,SAAS,EAAE,IAAI,EAAE,oBAAoB;wBACrC,KAAK,EAAE,GAAG,UAAU,IAAI,KAAK,EAAE;wBAC/B,WAAW,EAAE,IAAI;wBACjB,aAAa,EAAE,IAAI;wBACnB,OAAO,EAAE,SAAS,IAAI,iBAAiB;wBACvC,GAAG,CAAC,gBAAgB,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;qBACjD,CAAC;gBACJ,CAAC;YACH,CAAC;YAED,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YAClD,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;YAC7C,MAAM,kBAAkB,GAAG,YAAY,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC;YAC/D,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,SAAS,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;YACjD,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,UAAU,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAEnD,uFAAuF;YACvF,uBAAuB;YACvB,MAAM,YAAY,GAAG,CAAC,GAAW,EAAW,EAAE;gBAC5C,OAAO,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACtE,CAAC,CAAC;YACF,MAAM,UAAU,GAAG,OAAO;iBACvB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBAC5C,IAAI,CAAC,IAAI,CAAC,CAAC;YAEd,MAAM,GAAG,GACP,UAAU,YAAY,SAAS,kBAAkB,IAAI,IAAI,IAAI;gBAC7D,MAAM,YAAY,IAAI,KAAK,KAAK,WAAW,IAAI,UAAU,IAAI,WAAW,EAAE,CAAC;YAE7E,IAAI,CAAC;gBACH,MAAM,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;gBAChC,OAAO;oBACL,OAAO,EAAE,IAAI;oBACb,KAAK,EAAE,IAAI;oBACX,SAAS,EAAE,IAAI,EAAE,oBAAoB;oBACrC,KAAK,EAAE,GAAG,UAAU,IAAI,KAAK,EAAE;oBAC/B,GAAG;oBACH,GAAG,CAAC,gBAAgB,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;iBACjD,CAAC;YACJ,CAAC;YAAC,OAAO,KAAc,EAAE,CAAC;gBACxB,mGAAmG;gBACnG,iFAAiF;gBACjF,IAAI,WAAW,KAAK,IAAI,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;oBACnD,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;oBACxC,IAAI,GAAG,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;wBAChE,OAAO;4BACL,OAAO,EAAE,IAAI;4BACb,KAAK,EAAE,IAAI;4BACX,SAAS,EAAE,IAAI;4BACf,KAAK,EAAE,GAAG,UAAU,IAAI,KAAK,EAAE;4BAC/B,WAAW,EAAE,IAAI;4BACjB,aAAa,EAAE,IAAI;4BACnB,OAAO,EAAE,SAAS,IAAI,iBAAiB;4BACvC,GAAG,CAAC,gBAAgB,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;yBACjD,CAAC;oBACJ,CAAC;gBACH,CAAC;gBACD,wBAAwB;gBACxB,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC;AAED,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;GAEG;AACH,SAAS,yBAAyB,CAAC,KAAc;IAC/C,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAC9D,MAAM,MAAM,GAAG,EAAE,GAAI,KAAiC,EAAE,CAAC;IAEzD,gCAAgC;IAChC,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,SAAS,EAAE,CAAC;QACjC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,SAAS;YAAE,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;aAC/D,IAAI,MAAM,CAAC,WAAW,CAAC,KAAK,SAAS;YACxC,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC;IAED,2BAA2B;IAC3B,IACE,OAAO,MAAM,CAAC,MAAM,CAAC,KAAK,QAAQ;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC;QAC5B,MAAM,CAAC,QAAQ,CAAC,KAAK,SAAS,EAC9B,CAAC;QACD,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACxC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvB,MAAM,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAC5B,MAAM,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,4DAA4D;AAC5D,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,IAAI,EAAE,CAAC;SACJ,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,0CAA0C,CAAC;IACvD,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,gBAAgB,CAAC;IACvD,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,gBAAgB,CAAC;IAC3D,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,+BAA+B,CAAC;IACvE,QAAQ,EAAE,CAAC;SACR,OAAO,EAAE;SACT,QAAQ,EAAE;SACV,QAAQ,CAAC,uDAAuD,CAAC;IACpE,OAAO,EAAE,CAAC;SACP,OAAO,EAAE;SACT,QAAQ,EAAE;SACV,QAAQ,CAAC,uCAAuC,CAAC;IACpD,YAAY,EAAE,CAAC;SACZ,OAAO,EAAE;SACT,QAAQ,EAAE;SACV,QAAQ,CAAC,yCAAyC,CAAC;CACvD,CAAC,CAAC;AAEH,4CAA4C;AAC5C,MAAM,eAAe,GAAG,CAAC;KACtB,UAAU,CAAC,yBAAyB,EAAE,mBAAmB,CAAC;KAC1D,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IACpB,GAAG,IAAI;IACP,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,IAAI,EAAE;CACtD,CAAC,CAAC;KACF,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,EAAE,EAAE;IAClC,OAAO,EAAE,6CAA6C;CACvD,CAAC,CAAC;AAEL;;GAEG;AACH,MAAM,UAAU,mBAAmB,CAAC,OAAwB;IAC1D,OAAO;QACL,IAAI,EAAE,eAAe;QACrB,WAAW,EACT,oFAAoF;QACtF,KAAK,EAAE,MAAM;QACb,WAAW,EAAE,mBAAmB;QAChC,WAAW,EAAE,KAAK,CAAC,YAAY,CAAC;QAChC,KAAK,EAAE,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;QAChD,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE,GACrD,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAEhC,MAAM,UAAU,GAAG,MAAM,IAAI,QAAQ,CAAC;YACtC,MAAM,cAAc,GAAG,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;YAC7D,MAAM,aAAa,GAAG,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;YACzD,MAAM,kBAAkB,GAAG,YAAY,KAAK,IAAI,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC;YAExE,MAAM,GAAG,GAAG,cAAc,kBAAkB,GAAG,cAAc,IAAI,UAAU,MAAM,IAAI,IAAI,aAAa,EAAE,CAAC;YAEzG,MAAM,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;YAChC,OAAO;gBACL,OAAO,EAAE,IAAI;gBACb,KAAK,EAAE,GAAG,UAAU,IAAI,IAAI,EAAE;gBAC9B,GAAG;aACJ,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC"}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * PostgreSQL Core Tools - Object Operations
3
+ *
4
+ * List and describe database objects (tables, views, functions, etc.).
5
+ */
6
+ import type { PostgresAdapter } from "../../PostgresAdapter.js";
7
+ import type { ToolDefinition } from "../../../../types/index.js";
8
+ /**
9
+ * List database objects
10
+ */
11
+ export declare function createListObjectsTool(adapter: PostgresAdapter): ToolDefinition;
12
+ /**
13
+ * Get object details
14
+ */
15
+ export declare function createObjectDetailsTool(adapter: PostgresAdapter): ToolDefinition;
16
+ /**
17
+ * List installed PostgreSQL extensions
18
+ */
19
+ export declare function createListExtensionsTool(adapter: PostgresAdapter): ToolDefinition;
20
+ //# sourceMappingURL=objects.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"objects.d.ts","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/core/objects.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,EACV,cAAc,EAEf,MAAM,4BAA4B,CAAC;AAWpC;;GAEG;AACH,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,eAAe,GACvB,cAAc,CA8JhB;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CACrC,OAAO,EAAE,eAAe,GACvB,cAAc,CA0LhB;AAED;;GAEG;AACH,wBAAgB,wBAAwB,CACtC,OAAO,EAAE,eAAe,GACvB,cAAc,CA0BhB"}
@@ -0,0 +1,361 @@
1
+ /**
2
+ * PostgreSQL Core Tools - Object Operations
3
+ *
4
+ * List and describe database objects (tables, views, functions, etc.).
5
+ */
6
+ import { z } from "zod";
7
+ import { readOnly } from "../../../../utils/annotations.js";
8
+ import { getToolIcons } from "../../../../utils/icons.js";
9
+ import { ListObjectsSchemaBase, ListObjectsSchema, ObjectDetailsSchema, ObjectDetailsSchemaBase, } from "./schemas.js";
10
+ /**
11
+ * List database objects
12
+ */
13
+ export function createListObjectsTool(adapter) {
14
+ return {
15
+ name: "pg_list_objects",
16
+ description: 'List database objects filtered by type. Use type: "table" (singular) or types: ["table","view"] (array). Supports: table, view, materialized_view, function, procedure, sequence, index, trigger.',
17
+ group: "core",
18
+ annotations: readOnly("List Objects"),
19
+ icons: getToolIcons("core", readOnly("List Objects")),
20
+ inputSchema: ListObjectsSchemaBase,
21
+ handler: async (params, _context) => {
22
+ const { schema, types, limit } = ListObjectsSchema.parse(params);
23
+ const schemaFilter = schema
24
+ ? `AND n.nspname = '${schema}'`
25
+ : `AND n.nspname NOT IN ('pg_catalog', 'information_schema', 'pg_toast')`;
26
+ const typeFilters = [];
27
+ const selectedTypes = types ?? [
28
+ "table",
29
+ "view",
30
+ "materialized_view",
31
+ "function",
32
+ "sequence",
33
+ ];
34
+ if (selectedTypes.includes("table"))
35
+ typeFilters.push(`('r', 'table')`);
36
+ if (selectedTypes.includes("view"))
37
+ typeFilters.push(`('v', 'view')`);
38
+ if (selectedTypes.includes("materialized_view"))
39
+ typeFilters.push(`('m', 'materialized_view')`);
40
+ if (selectedTypes.includes("sequence"))
41
+ typeFilters.push(`('S', 'sequence')`);
42
+ const objects = [];
43
+ // Get tables, views, materialized views, sequences
44
+ if (typeFilters.length > 0) {
45
+ const sql = `
46
+ SELECT
47
+ CASE c.relkind
48
+ ${selectedTypes.includes("table") ? `WHEN 'r' THEN 'table'` : ""}
49
+ ${selectedTypes.includes("view") ? `WHEN 'v' THEN 'view'` : ""}
50
+ ${selectedTypes.includes("materialized_view") ? `WHEN 'm' THEN 'materialized_view'` : ""}
51
+ ${selectedTypes.includes("sequence") ? `WHEN 'S' THEN 'sequence'` : ""}
52
+ END as type,
53
+ n.nspname as schema,
54
+ c.relname as name,
55
+ pg_get_userbyid(c.relowner) as owner
56
+ FROM pg_class c
57
+ JOIN pg_namespace n ON n.oid = c.relnamespace
58
+ WHERE c.relkind IN (${selectedTypes
59
+ .map((t) => {
60
+ if (t === "table")
61
+ return `'r'`;
62
+ if (t === "view")
63
+ return `'v'`;
64
+ if (t === "materialized_view")
65
+ return `'m'`;
66
+ if (t === "sequence")
67
+ return `'S'`;
68
+ return null;
69
+ })
70
+ .filter(Boolean)
71
+ .join(", ")})
72
+ ${schemaFilter}
73
+ ORDER BY n.nspname, c.relname
74
+ `;
75
+ const result = await adapter.executeQuery(sql);
76
+ objects.push(...result.rows);
77
+ }
78
+ // Get functions
79
+ if (selectedTypes.includes("function") ||
80
+ selectedTypes.includes("procedure")) {
81
+ const kindFilter = [];
82
+ if (selectedTypes.includes("function"))
83
+ kindFilter.push(`'f'`, `'a'`);
84
+ if (selectedTypes.includes("procedure"))
85
+ kindFilter.push(`'p'`);
86
+ const sql = `
87
+ SELECT
88
+ CASE p.prokind WHEN 'p' THEN 'procedure' ELSE 'function' END as type,
89
+ n.nspname as schema,
90
+ p.proname as name,
91
+ pg_get_userbyid(p.proowner) as owner
92
+ FROM pg_proc p
93
+ JOIN pg_namespace n ON n.oid = p.pronamespace
94
+ WHERE p.prokind IN (${kindFilter.join(", ")})
95
+ ${schema
96
+ ? `AND n.nspname = '${schema}'`
97
+ : `AND n.nspname NOT IN ('pg_catalog', 'information_schema')`}
98
+ ORDER BY n.nspname, p.proname
99
+ `;
100
+ const result = await adapter.executeQuery(sql);
101
+ objects.push(...result.rows);
102
+ }
103
+ // Get indexes
104
+ if (selectedTypes.includes("index")) {
105
+ const sql = `
106
+ SELECT
107
+ 'index' as type,
108
+ n.nspname as schema,
109
+ c.relname as name,
110
+ pg_get_userbyid(c.relowner) as owner
111
+ FROM pg_class c
112
+ JOIN pg_namespace n ON n.oid = c.relnamespace
113
+ WHERE c.relkind = 'i'
114
+ ${schemaFilter}
115
+ ORDER BY n.nspname, c.relname
116
+ `;
117
+ const result = await adapter.executeQuery(sql);
118
+ objects.push(...result.rows);
119
+ }
120
+ // Get triggers
121
+ if (selectedTypes.includes("trigger")) {
122
+ const sql = `
123
+ SELECT DISTINCT
124
+ 'trigger' as type,
125
+ n.nspname as schema,
126
+ t.tgname as name,
127
+ pg_get_userbyid(c.relowner) as owner
128
+ FROM pg_trigger t
129
+ JOIN pg_class c ON c.oid = t.tgrelid
130
+ JOIN pg_namespace n ON n.oid = c.relnamespace
131
+ WHERE NOT t.tgisinternal
132
+ ${schemaFilter}
133
+ ORDER BY n.nspname, t.tgname
134
+ `;
135
+ const result = await adapter.executeQuery(sql);
136
+ objects.push(...result.rows);
137
+ }
138
+ // Apply default limit of 100 if not specified
139
+ const effectiveLimit = limit ?? 100;
140
+ const truncated = objects.length > effectiveLimit;
141
+ const limitedObjects = truncated
142
+ ? objects.slice(0, effectiveLimit)
143
+ : objects;
144
+ return {
145
+ objects: limitedObjects,
146
+ count: limitedObjects.length,
147
+ totalCount: objects.length, // Total before limit
148
+ byType: limitedObjects.reduce((acc, obj) => {
149
+ acc[obj.type] = (acc[obj.type] ?? 0) + 1;
150
+ return acc;
151
+ }, {}),
152
+ ...(truncated && {
153
+ truncated: true,
154
+ hint: `Showing ${String(effectiveLimit)} of ${String(objects.length)} objects. Use 'limit' to see more, or 'schema'/'types' to filter.`,
155
+ }),
156
+ };
157
+ },
158
+ };
159
+ }
160
+ /**
161
+ * Get object details
162
+ */
163
+ export function createObjectDetailsTool(adapter) {
164
+ return {
165
+ name: "pg_object_details",
166
+ description: "Get detailed metadata for a specific database object (table, view, function, sequence, index).",
167
+ group: "core",
168
+ inputSchema: ObjectDetailsSchemaBase,
169
+ annotations: readOnly("Object Details"),
170
+ icons: getToolIcons("core", readOnly("Object Details")),
171
+ handler: async (params, _context) => {
172
+ const { name, schema, type } = ObjectDetailsSchema.parse(params);
173
+ const schemaName = schema ?? "public";
174
+ // Determine the actual object type
175
+ const detectSql = `
176
+ SELECT
177
+ CASE
178
+ WHEN EXISTS (SELECT 1 FROM pg_class c JOIN pg_namespace n ON n.oid = c.relnamespace
179
+ WHERE c.relname = $1 AND n.nspname = $2 AND c.relkind = 'r') THEN 'table'
180
+ WHEN EXISTS (SELECT 1 FROM pg_class c JOIN pg_namespace n ON n.oid = c.relnamespace
181
+ WHERE c.relname = $1 AND n.nspname = $2 AND c.relkind = 'p') THEN 'partitioned_table'
182
+ WHEN EXISTS (SELECT 1 FROM pg_class c JOIN pg_namespace n ON n.oid = c.relnamespace
183
+ WHERE c.relname = $1 AND n.nspname = $2 AND c.relkind = 'v') THEN 'view'
184
+ WHEN EXISTS (SELECT 1 FROM pg_class c JOIN pg_namespace n ON n.oid = c.relnamespace
185
+ WHERE c.relname = $1 AND n.nspname = $2 AND c.relkind = 'm') THEN 'materialized_view'
186
+ WHEN EXISTS (SELECT 1 FROM pg_class c JOIN pg_namespace n ON n.oid = c.relnamespace
187
+ WHERE c.relname = $1 AND n.nspname = $2 AND c.relkind = 'i') THEN 'index'
188
+ WHEN EXISTS (SELECT 1 FROM pg_class c JOIN pg_namespace n ON n.oid = c.relnamespace
189
+ WHERE c.relname = $1 AND n.nspname = $2 AND c.relkind = 'S') THEN 'sequence'
190
+ WHEN EXISTS (SELECT 1 FROM pg_proc p JOIN pg_namespace n ON n.oid = p.pronamespace
191
+ WHERE p.proname = $1 AND n.nspname = $2) THEN 'function'
192
+ END as object_type
193
+ `;
194
+ const detectResult = await adapter.executeQuery(detectSql, [
195
+ name,
196
+ schemaName,
197
+ ]);
198
+ const detectedType = detectResult.rows?.[0]?.object_type;
199
+ // Validate type if specified
200
+ if (type && detectedType && type !== detectedType) {
201
+ throw new Error(`Object '${schemaName}.${name}' is a ${detectedType}, not a ${type}. ` +
202
+ `Use type: '${detectedType}' or omit type to auto-detect.`);
203
+ }
204
+ const objectType = type ?? detectedType;
205
+ if (!objectType) {
206
+ throw new Error(`Object '${schemaName}.${name}' not found. Use pg_list_objects to discover available objects.`);
207
+ }
208
+ let details = {
209
+ name,
210
+ schema: schemaName,
211
+ type: objectType,
212
+ };
213
+ if (objectType === "table" ||
214
+ objectType === "partitioned_table" ||
215
+ objectType === "view" ||
216
+ objectType === "materialized_view") {
217
+ const tableDetails = await adapter.describeTable(name, schemaName);
218
+ details = { ...details, ...tableDetails };
219
+ // For views and materialized views, also get the view definition SQL
220
+ if (objectType === "view" || objectType === "materialized_view") {
221
+ const relkind = objectType === "view" ? "v" : "m";
222
+ const viewDefSql = `
223
+ SELECT pg_get_viewdef(c.oid, true) as definition
224
+ FROM pg_class c
225
+ JOIN pg_namespace n ON n.oid = c.relnamespace
226
+ WHERE c.relname = $1 AND n.nspname = $2 AND c.relkind = '${relkind}'
227
+ `;
228
+ const viewDefResult = await adapter.executeQuery(viewDefSql, [
229
+ name,
230
+ schemaName,
231
+ ]);
232
+ if (viewDefResult.rows && viewDefResult.rows.length > 0) {
233
+ details["definition"] = viewDefResult.rows[0]?.["definition"];
234
+ details["hasDefinition"] = true;
235
+ }
236
+ }
237
+ }
238
+ else if (objectType === "function") {
239
+ const sql = `
240
+ SELECT
241
+ p.proname as name,
242
+ pg_get_function_arguments(p.oid) as arguments,
243
+ pg_get_function_result(p.oid) as return_type,
244
+ p.prosrc as source,
245
+ l.lanname as language,
246
+ p.provolatile as volatility,
247
+ pg_get_userbyid(p.proowner) as owner
248
+ FROM pg_proc p
249
+ JOIN pg_namespace n ON n.oid = p.pronamespace
250
+ JOIN pg_language l ON l.oid = p.prolang
251
+ WHERE p.proname = $1 AND n.nspname = $2
252
+ `;
253
+ const result = await adapter.executeQuery(sql, [name, schemaName]);
254
+ const funcRow = result.rows?.[0];
255
+ if (funcRow) {
256
+ details = {
257
+ ...details,
258
+ ...funcRow,
259
+ // Add camelCase aliases
260
+ returnType: funcRow["return_type"],
261
+ };
262
+ }
263
+ }
264
+ else if (objectType === "sequence") {
265
+ // Get sequence metadata from pg_sequence catalog
266
+ const metaSql = `
267
+ SELECT
268
+ s.seqstart as start_value,
269
+ s.seqmin as min_value,
270
+ s.seqmax as max_value,
271
+ s.seqincrement as increment,
272
+ s.seqcycle as cycle,
273
+ s.seqcache as cache,
274
+ pg_get_userbyid(c.relowner) as owner
275
+ FROM pg_sequence s
276
+ JOIN pg_class c ON c.oid = s.seqrelid
277
+ JOIN pg_namespace n ON n.oid = c.relnamespace
278
+ WHERE n.nspname = $1 AND c.relname = $2
279
+ `;
280
+ const metaResult = await adapter.executeQuery(metaSql, [
281
+ schemaName,
282
+ name,
283
+ ]);
284
+ if (metaResult.rows && metaResult.rows.length > 0) {
285
+ details = { ...details, ...metaResult.rows[0] };
286
+ }
287
+ // Get current value by querying the sequence directly
288
+ try {
289
+ const valueSql = `SELECT last_value, is_called FROM "${schemaName}"."${name}"`;
290
+ const valueResult = await adapter.executeQuery(valueSql);
291
+ if (valueResult.rows && valueResult.rows.length > 0) {
292
+ const seqRow = valueResult.rows[0];
293
+ details["last_value"] = seqRow.last_value;
294
+ details["is_called"] = seqRow.is_called;
295
+ // Add human-readable current value explanation
296
+ details["current_value"] = seqRow.is_called
297
+ ? seqRow.last_value
298
+ : `${String(seqRow.last_value)} (not yet used, next call returns this value)`;
299
+ }
300
+ }
301
+ catch {
302
+ // Sequence might not be accessible, skip current value
303
+ }
304
+ }
305
+ else if (objectType === "index") {
306
+ const sql = `
307
+ SELECT
308
+ i.relname as index_name,
309
+ t.relname as table_name,
310
+ am.amname as index_type,
311
+ pg_get_indexdef(i.oid) as definition,
312
+ ix.indisunique as is_unique,
313
+ ix.indisprimary as is_primary,
314
+ pg_size_pretty(pg_relation_size(i.oid)) as size
315
+ FROM pg_index ix
316
+ JOIN pg_class i ON i.oid = ix.indexrelid
317
+ JOIN pg_class t ON t.oid = ix.indrelid
318
+ JOIN pg_am am ON am.oid = i.relam
319
+ JOIN pg_namespace n ON n.oid = i.relnamespace
320
+ WHERE i.relname = $1 AND n.nspname = $2
321
+ `;
322
+ const result = await adapter.executeQuery(sql, [name, schemaName]);
323
+ if (result.rows && result.rows.length > 0) {
324
+ details = { ...details, ...result.rows[0] };
325
+ }
326
+ }
327
+ return details;
328
+ },
329
+ };
330
+ }
331
+ /**
332
+ * List installed PostgreSQL extensions
333
+ */
334
+ export function createListExtensionsTool(adapter) {
335
+ return {
336
+ name: "pg_list_extensions",
337
+ description: "List installed PostgreSQL extensions with versions.",
338
+ group: "core",
339
+ inputSchema: z.object({}),
340
+ annotations: readOnly("List Extensions"),
341
+ icons: getToolIcons("core", readOnly("List Extensions")),
342
+ handler: async (_params, _context) => {
343
+ const result = await adapter.executeQuery(`
344
+ SELECT
345
+ e.extname as name,
346
+ e.extversion as version,
347
+ n.nspname as schema,
348
+ c.description
349
+ FROM pg_extension e
350
+ LEFT JOIN pg_namespace n ON n.oid = e.extnamespace
351
+ LEFT JOIN pg_description c ON c.objoid = e.oid AND c.classoid = 'pg_extension'::regclass
352
+ ORDER BY e.extname
353
+ `);
354
+ return {
355
+ extensions: result.rows,
356
+ count: result.rows?.length ?? 0,
357
+ };
358
+ },
359
+ };
360
+ }
361
+ //# sourceMappingURL=objects.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"objects.js","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/core/objects.ts"],"names":[],"mappings":"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"}