@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.
- package/LICENSE +21 -0
- package/README.md +515 -0
- package/dist/__tests__/mocks/adapter.d.ts +80 -0
- package/dist/__tests__/mocks/adapter.d.ts.map +1 -0
- package/dist/__tests__/mocks/adapter.js +225 -0
- package/dist/__tests__/mocks/adapter.js.map +1 -0
- package/dist/__tests__/mocks/index.d.ts +11 -0
- package/dist/__tests__/mocks/index.d.ts.map +1 -0
- package/dist/__tests__/mocks/index.js +11 -0
- package/dist/__tests__/mocks/index.js.map +1 -0
- package/dist/__tests__/mocks/pool.d.ts +43 -0
- package/dist/__tests__/mocks/pool.d.ts.map +1 -0
- package/dist/__tests__/mocks/pool.js +71 -0
- package/dist/__tests__/mocks/pool.js.map +1 -0
- package/dist/adapters/DatabaseAdapter.d.ts +139 -0
- package/dist/adapters/DatabaseAdapter.d.ts.map +1 -0
- package/dist/adapters/DatabaseAdapter.js +250 -0
- package/dist/adapters/DatabaseAdapter.js.map +1 -0
- package/dist/adapters/postgresql/PostgresAdapter.d.ts +119 -0
- package/dist/adapters/postgresql/PostgresAdapter.d.ts.map +1 -0
- package/dist/adapters/postgresql/PostgresAdapter.js +902 -0
- package/dist/adapters/postgresql/PostgresAdapter.js.map +1 -0
- package/dist/adapters/postgresql/index.d.ts +5 -0
- package/dist/adapters/postgresql/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/index.js +5 -0
- package/dist/adapters/postgresql/index.js.map +1 -0
- package/dist/adapters/postgresql/prompts/backup.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/backup.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/backup.js +132 -0
- package/dist/adapters/postgresql/prompts/backup.js.map +1 -0
- package/dist/adapters/postgresql/prompts/citext.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/citext.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/citext.js +227 -0
- package/dist/adapters/postgresql/prompts/citext.js.map +1 -0
- package/dist/adapters/postgresql/prompts/extensionSetup.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/extensionSetup.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/extensionSetup.js +282 -0
- package/dist/adapters/postgresql/prompts/extensionSetup.js.map +1 -0
- package/dist/adapters/postgresql/prompts/health.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/health.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/health.js +118 -0
- package/dist/adapters/postgresql/prompts/health.js.map +1 -0
- package/dist/adapters/postgresql/prompts/index.d.ts +13 -0
- package/dist/adapters/postgresql/prompts/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/index.js +308 -0
- package/dist/adapters/postgresql/prompts/index.js.map +1 -0
- package/dist/adapters/postgresql/prompts/indexTuning.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/indexTuning.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/indexTuning.js +130 -0
- package/dist/adapters/postgresql/prompts/indexTuning.js.map +1 -0
- package/dist/adapters/postgresql/prompts/kcache.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/kcache.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/kcache.js +227 -0
- package/dist/adapters/postgresql/prompts/kcache.js.map +1 -0
- package/dist/adapters/postgresql/prompts/ltree.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/ltree.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/ltree.js +286 -0
- package/dist/adapters/postgresql/prompts/ltree.js.map +1 -0
- package/dist/adapters/postgresql/prompts/partman.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/partman.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/partman.js +211 -0
- package/dist/adapters/postgresql/prompts/partman.js.map +1 -0
- package/dist/adapters/postgresql/prompts/pgcron.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/pgcron.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/pgcron.js +233 -0
- package/dist/adapters/postgresql/prompts/pgcron.js.map +1 -0
- package/dist/adapters/postgresql/prompts/pgcrypto.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/pgcrypto.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/pgcrypto.js +299 -0
- package/dist/adapters/postgresql/prompts/pgcrypto.js.map +1 -0
- package/dist/adapters/postgresql/prompts/pgvector.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/pgvector.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/pgvector.js +148 -0
- package/dist/adapters/postgresql/prompts/pgvector.js.map +1 -0
- package/dist/adapters/postgresql/prompts/postgis.d.ts +8 -0
- package/dist/adapters/postgresql/prompts/postgis.d.ts.map +1 -0
- package/dist/adapters/postgresql/prompts/postgis.js +200 -0
- package/dist/adapters/postgresql/prompts/postgis.js.map +1 -0
- package/dist/adapters/postgresql/resources/activity.d.ts +9 -0
- package/dist/adapters/postgresql/resources/activity.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/activity.js +118 -0
- package/dist/adapters/postgresql/resources/activity.js.map +1 -0
- package/dist/adapters/postgresql/resources/capabilities.d.ts +9 -0
- package/dist/adapters/postgresql/resources/capabilities.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/capabilities.js +182 -0
- package/dist/adapters/postgresql/resources/capabilities.js.map +1 -0
- package/dist/adapters/postgresql/resources/cron.d.ts +9 -0
- package/dist/adapters/postgresql/resources/cron.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/cron.js +156 -0
- package/dist/adapters/postgresql/resources/cron.js.map +1 -0
- package/dist/adapters/postgresql/resources/crypto.d.ts +9 -0
- package/dist/adapters/postgresql/resources/crypto.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/crypto.js +191 -0
- package/dist/adapters/postgresql/resources/crypto.js.map +1 -0
- package/dist/adapters/postgresql/resources/extensions.d.ts +9 -0
- package/dist/adapters/postgresql/resources/extensions.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/extensions.js +85 -0
- package/dist/adapters/postgresql/resources/extensions.js.map +1 -0
- package/dist/adapters/postgresql/resources/health.d.ts +9 -0
- package/dist/adapters/postgresql/resources/health.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/health.js +185 -0
- package/dist/adapters/postgresql/resources/health.js.map +1 -0
- package/dist/adapters/postgresql/resources/index.d.ts +40 -0
- package/dist/adapters/postgresql/resources/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/index.js +87 -0
- package/dist/adapters/postgresql/resources/index.js.map +1 -0
- package/dist/adapters/postgresql/resources/indexes.d.ts +9 -0
- package/dist/adapters/postgresql/resources/indexes.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/indexes.js +130 -0
- package/dist/adapters/postgresql/resources/indexes.js.map +1 -0
- package/dist/adapters/postgresql/resources/kcache.d.ts +9 -0
- package/dist/adapters/postgresql/resources/kcache.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/kcache.js +219 -0
- package/dist/adapters/postgresql/resources/kcache.js.map +1 -0
- package/dist/adapters/postgresql/resources/locks.d.ts +9 -0
- package/dist/adapters/postgresql/resources/locks.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/locks.js +89 -0
- package/dist/adapters/postgresql/resources/locks.js.map +1 -0
- package/dist/adapters/postgresql/resources/partman.d.ts +9 -0
- package/dist/adapters/postgresql/resources/partman.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/partman.js +149 -0
- package/dist/adapters/postgresql/resources/partman.js.map +1 -0
- package/dist/adapters/postgresql/resources/performance.d.ts +9 -0
- package/dist/adapters/postgresql/resources/performance.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/performance.js +170 -0
- package/dist/adapters/postgresql/resources/performance.js.map +1 -0
- package/dist/adapters/postgresql/resources/pool.d.ts +9 -0
- package/dist/adapters/postgresql/resources/pool.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/pool.js +93 -0
- package/dist/adapters/postgresql/resources/pool.js.map +1 -0
- package/dist/adapters/postgresql/resources/postgis.d.ts +9 -0
- package/dist/adapters/postgresql/resources/postgis.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/postgis.js +232 -0
- package/dist/adapters/postgresql/resources/postgis.js.map +1 -0
- package/dist/adapters/postgresql/resources/replication.d.ts +9 -0
- package/dist/adapters/postgresql/resources/replication.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/replication.js +126 -0
- package/dist/adapters/postgresql/resources/replication.js.map +1 -0
- package/dist/adapters/postgresql/resources/schema.d.ts +10 -0
- package/dist/adapters/postgresql/resources/schema.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/schema.js +80 -0
- package/dist/adapters/postgresql/resources/schema.js.map +1 -0
- package/dist/adapters/postgresql/resources/settings.d.ts +9 -0
- package/dist/adapters/postgresql/resources/settings.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/settings.js +184 -0
- package/dist/adapters/postgresql/resources/settings.js.map +1 -0
- package/dist/adapters/postgresql/resources/stats.d.ts +10 -0
- package/dist/adapters/postgresql/resources/stats.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/stats.js +124 -0
- package/dist/adapters/postgresql/resources/stats.js.map +1 -0
- package/dist/adapters/postgresql/resources/tables.d.ts +9 -0
- package/dist/adapters/postgresql/resources/tables.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/tables.js +20 -0
- package/dist/adapters/postgresql/resources/tables.js.map +1 -0
- package/dist/adapters/postgresql/resources/vacuum.d.ts +9 -0
- package/dist/adapters/postgresql/resources/vacuum.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/vacuum.js +122 -0
- package/dist/adapters/postgresql/resources/vacuum.js.map +1 -0
- package/dist/adapters/postgresql/resources/vector.d.ts +9 -0
- package/dist/adapters/postgresql/resources/vector.d.ts.map +1 -0
- package/dist/adapters/postgresql/resources/vector.js +185 -0
- package/dist/adapters/postgresql/resources/vector.js.map +1 -0
- package/dist/adapters/postgresql/schemas/admin.d.ts +74 -0
- package/dist/adapters/postgresql/schemas/admin.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/admin.js +180 -0
- package/dist/adapters/postgresql/schemas/admin.js.map +1 -0
- package/dist/adapters/postgresql/schemas/backup.d.ts +68 -0
- package/dist/adapters/postgresql/schemas/backup.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/backup.js +114 -0
- package/dist/adapters/postgresql/schemas/backup.js.map +1 -0
- package/dist/adapters/postgresql/schemas/core.d.ts +443 -0
- package/dist/adapters/postgresql/schemas/core.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/core.js +628 -0
- package/dist/adapters/postgresql/schemas/core.js.map +1 -0
- package/dist/adapters/postgresql/schemas/cron.d.ts +131 -0
- package/dist/adapters/postgresql/schemas/cron.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/cron.js +218 -0
- package/dist/adapters/postgresql/schemas/cron.js.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions.d.ts +403 -0
- package/dist/adapters/postgresql/schemas/extensions.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions.js +600 -0
- package/dist/adapters/postgresql/schemas/extensions.js.map +1 -0
- package/dist/adapters/postgresql/schemas/index.d.ts +21 -0
- package/dist/adapters/postgresql/schemas/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/index.js +72 -0
- package/dist/adapters/postgresql/schemas/index.js.map +1 -0
- package/dist/adapters/postgresql/schemas/jsonb.d.ts +94 -0
- package/dist/adapters/postgresql/schemas/jsonb.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/jsonb.js +198 -0
- package/dist/adapters/postgresql/schemas/jsonb.js.map +1 -0
- package/dist/adapters/postgresql/schemas/monitoring.d.ts +28 -0
- package/dist/adapters/postgresql/schemas/monitoring.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/monitoring.js +45 -0
- package/dist/adapters/postgresql/schemas/monitoring.js.map +1 -0
- package/dist/adapters/postgresql/schemas/partitioning.d.ts +152 -0
- package/dist/adapters/postgresql/schemas/partitioning.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/partitioning.js +399 -0
- package/dist/adapters/postgresql/schemas/partitioning.js.map +1 -0
- package/dist/adapters/postgresql/schemas/partman.d.ts +94 -0
- package/dist/adapters/postgresql/schemas/partman.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/partman.js +264 -0
- package/dist/adapters/postgresql/schemas/partman.js.map +1 -0
- package/dist/adapters/postgresql/schemas/performance.d.ts +52 -0
- package/dist/adapters/postgresql/schemas/performance.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/performance.js +57 -0
- package/dist/adapters/postgresql/schemas/performance.js.map +1 -0
- package/dist/adapters/postgresql/schemas/postgis.d.ts +693 -0
- package/dist/adapters/postgresql/schemas/postgis.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/postgis.js +662 -0
- package/dist/adapters/postgresql/schemas/postgis.js.map +1 -0
- package/dist/adapters/postgresql/schemas/schema-mgmt.d.ts +171 -0
- package/dist/adapters/postgresql/schemas/schema-mgmt.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/schema-mgmt.js +235 -0
- package/dist/adapters/postgresql/schemas/schema-mgmt.js.map +1 -0
- package/dist/adapters/postgresql/schemas/stats.d.ts +229 -0
- package/dist/adapters/postgresql/schemas/stats.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/stats.js +587 -0
- package/dist/adapters/postgresql/schemas/stats.js.map +1 -0
- package/dist/adapters/postgresql/schemas/text-search.d.ts +83 -0
- package/dist/adapters/postgresql/schemas/text-search.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/text-search.js +132 -0
- package/dist/adapters/postgresql/schemas/text-search.js.map +1 -0
- package/dist/adapters/postgresql/schemas/vector.d.ts +143 -0
- package/dist/adapters/postgresql/schemas/vector.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/vector.js +123 -0
- package/dist/adapters/postgresql/schemas/vector.js.map +1 -0
- package/dist/adapters/postgresql/tools/admin.d.ts +13 -0
- package/dist/adapters/postgresql/tools/admin.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/admin.js +417 -0
- package/dist/adapters/postgresql/tools/admin.js.map +1 -0
- package/dist/adapters/postgresql/tools/backup/dump.d.ts +12 -0
- package/dist/adapters/postgresql/tools/backup/dump.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/backup/dump.js +546 -0
- package/dist/adapters/postgresql/tools/backup/dump.js.map +1 -0
- package/dist/adapters/postgresql/tools/backup/index.d.ts +16 -0
- package/dist/adapters/postgresql/tools/backup/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/backup/index.js +29 -0
- package/dist/adapters/postgresql/tools/backup/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/backup/planning.d.ts +22 -0
- package/dist/adapters/postgresql/tools/backup/planning.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/backup/planning.js +411 -0
- package/dist/adapters/postgresql/tools/backup/planning.js.map +1 -0
- package/dist/adapters/postgresql/tools/citext.d.ts +18 -0
- package/dist/adapters/postgresql/tools/citext.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/citext.js +568 -0
- package/dist/adapters/postgresql/tools/citext.js.map +1 -0
- package/dist/adapters/postgresql/tools/codemode/index.d.ts +27 -0
- package/dist/adapters/postgresql/tools/codemode/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/codemode/index.js +171 -0
- package/dist/adapters/postgresql/tools/codemode/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/core/convenience.d.ts +192 -0
- package/dist/adapters/postgresql/tools/core/convenience.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/convenience.js +617 -0
- package/dist/adapters/postgresql/tools/core/convenience.js.map +1 -0
- package/dist/adapters/postgresql/tools/core/health.d.ts +20 -0
- package/dist/adapters/postgresql/tools/core/health.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/health.js +360 -0
- package/dist/adapters/postgresql/tools/core/health.js.map +1 -0
- package/dist/adapters/postgresql/tools/core/index.d.ts +15 -0
- package/dist/adapters/postgresql/tools/core/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/index.js +40 -0
- package/dist/adapters/postgresql/tools/core/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/core/indexes.d.ts +30 -0
- package/dist/adapters/postgresql/tools/core/indexes.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/indexes.js +232 -0
- package/dist/adapters/postgresql/tools/core/indexes.js.map +1 -0
- package/dist/adapters/postgresql/tools/core/objects.d.ts +20 -0
- package/dist/adapters/postgresql/tools/core/objects.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/objects.js +361 -0
- package/dist/adapters/postgresql/tools/core/objects.js.map +1 -0
- package/dist/adapters/postgresql/tools/core/query.d.ts +16 -0
- package/dist/adapters/postgresql/tools/core/query.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/query.js +87 -0
- package/dist/adapters/postgresql/tools/core/query.js.map +1 -0
- package/dist/adapters/postgresql/tools/core/schemas.d.ts +135 -0
- package/dist/adapters/postgresql/tools/core/schemas.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/schemas.js +221 -0
- package/dist/adapters/postgresql/tools/core/schemas.js.map +1 -0
- package/dist/adapters/postgresql/tools/core/tables.d.ts +24 -0
- package/dist/adapters/postgresql/tools/core/tables.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/tables.js +219 -0
- package/dist/adapters/postgresql/tools/core/tables.js.map +1 -0
- package/dist/adapters/postgresql/tools/cron.d.ts +16 -0
- package/dist/adapters/postgresql/tools/cron.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/cron.js +440 -0
- package/dist/adapters/postgresql/tools/cron.js.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/advanced.d.ts +33 -0
- package/dist/adapters/postgresql/tools/jsonb/advanced.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/advanced.js +681 -0
- package/dist/adapters/postgresql/tools/jsonb/advanced.js.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/basic.d.ts +20 -0
- package/dist/adapters/postgresql/tools/jsonb/basic.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/basic.js +654 -0
- package/dist/adapters/postgresql/tools/jsonb/basic.js.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/index.d.ts +16 -0
- package/dist/adapters/postgresql/tools/jsonb/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/index.js +39 -0
- package/dist/adapters/postgresql/tools/jsonb/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/kcache.d.ts +20 -0
- package/dist/adapters/postgresql/tools/kcache.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/kcache.js +574 -0
- package/dist/adapters/postgresql/tools/kcache.js.map +1 -0
- package/dist/adapters/postgresql/tools/ltree.d.ts +8 -0
- package/dist/adapters/postgresql/tools/ltree.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/ltree.js +390 -0
- package/dist/adapters/postgresql/tools/ltree.js.map +1 -0
- package/dist/adapters/postgresql/tools/monitoring.d.ts +13 -0
- package/dist/adapters/postgresql/tools/monitoring.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/monitoring.js +753 -0
- package/dist/adapters/postgresql/tools/monitoring.js.map +1 -0
- package/dist/adapters/postgresql/tools/partitioning.d.ts +13 -0
- package/dist/adapters/postgresql/tools/partitioning.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/partitioning.js +500 -0
- package/dist/adapters/postgresql/tools/partitioning.js.map +1 -0
- package/dist/adapters/postgresql/tools/partman/index.d.ts +19 -0
- package/dist/adapters/postgresql/tools/partman/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/partman/index.js +33 -0
- package/dist/adapters/postgresql/tools/partman/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/partman/management.d.ts +28 -0
- package/dist/adapters/postgresql/tools/partman/management.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/partman/management.js +563 -0
- package/dist/adapters/postgresql/tools/partman/management.js.map +1 -0
- package/dist/adapters/postgresql/tools/partman/operations.d.ts +28 -0
- package/dist/adapters/postgresql/tools/partman/operations.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/partman/operations.js +632 -0
- package/dist/adapters/postgresql/tools/partman/operations.js.map +1 -0
- package/dist/adapters/postgresql/tools/performance/analysis.d.ts +9 -0
- package/dist/adapters/postgresql/tools/performance/analysis.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/performance/analysis.js +383 -0
- package/dist/adapters/postgresql/tools/performance/analysis.js.map +1 -0
- package/dist/adapters/postgresql/tools/performance/explain.d.ts +13 -0
- package/dist/adapters/postgresql/tools/performance/explain.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/performance/explain.js +71 -0
- package/dist/adapters/postgresql/tools/performance/explain.js.map +1 -0
- package/dist/adapters/postgresql/tools/performance/index.d.ts +13 -0
- package/dist/adapters/postgresql/tools/performance/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/performance/index.js +40 -0
- package/dist/adapters/postgresql/tools/performance/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/performance/monitoring.d.ts +9 -0
- package/dist/adapters/postgresql/tools/performance/monitoring.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/performance/monitoring.js +122 -0
- package/dist/adapters/postgresql/tools/performance/monitoring.js.map +1 -0
- package/dist/adapters/postgresql/tools/performance/optimization.d.ts +9 -0
- package/dist/adapters/postgresql/tools/performance/optimization.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/performance/optimization.js +315 -0
- package/dist/adapters/postgresql/tools/performance/optimization.js.map +1 -0
- package/dist/adapters/postgresql/tools/performance/stats.d.ts +14 -0
- package/dist/adapters/postgresql/tools/performance/stats.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/performance/stats.js +559 -0
- package/dist/adapters/postgresql/tools/performance/stats.js.map +1 -0
- package/dist/adapters/postgresql/tools/pgcrypto.d.ts +8 -0
- package/dist/adapters/postgresql/tools/pgcrypto.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/pgcrypto.js +239 -0
- package/dist/adapters/postgresql/tools/pgcrypto.js.map +1 -0
- package/dist/adapters/postgresql/tools/postgis/advanced.d.ts +21 -0
- package/dist/adapters/postgresql/tools/postgis/advanced.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/postgis/advanced.js +383 -0
- package/dist/adapters/postgresql/tools/postgis/advanced.js.map +1 -0
- package/dist/adapters/postgresql/tools/postgis/basic.d.ts +16 -0
- package/dist/adapters/postgresql/tools/postgis/basic.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/postgis/basic.js +479 -0
- package/dist/adapters/postgresql/tools/postgis/basic.js.map +1 -0
- package/dist/adapters/postgresql/tools/postgis/index.d.ts +17 -0
- package/dist/adapters/postgresql/tools/postgis/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/postgis/index.js +46 -0
- package/dist/adapters/postgresql/tools/postgis/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/postgis/standalone.d.ts +21 -0
- package/dist/adapters/postgresql/tools/postgis/standalone.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/postgis/standalone.js +150 -0
- package/dist/adapters/postgresql/tools/postgis/standalone.js.map +1 -0
- package/dist/adapters/postgresql/tools/schema.d.ts +13 -0
- package/dist/adapters/postgresql/tools/schema.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/schema.js +515 -0
- package/dist/adapters/postgresql/tools/schema.js.map +1 -0
- package/dist/adapters/postgresql/tools/stats/advanced.d.ts +24 -0
- package/dist/adapters/postgresql/tools/stats/advanced.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/stats/advanced.js +876 -0
- package/dist/adapters/postgresql/tools/stats/advanced.js.map +1 -0
- package/dist/adapters/postgresql/tools/stats/basic.d.ts +24 -0
- package/dist/adapters/postgresql/tools/stats/basic.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/stats/basic.js +501 -0
- package/dist/adapters/postgresql/tools/stats/basic.js.map +1 -0
- package/dist/adapters/postgresql/tools/stats/index.d.ts +17 -0
- package/dist/adapters/postgresql/tools/stats/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/stats/index.js +30 -0
- package/dist/adapters/postgresql/tools/stats/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/text.d.ts +13 -0
- package/dist/adapters/postgresql/tools/text.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/text.js +708 -0
- package/dist/adapters/postgresql/tools/text.js.map +1 -0
- package/dist/adapters/postgresql/tools/transactions.d.ts +13 -0
- package/dist/adapters/postgresql/tools/transactions.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/transactions.js +201 -0
- package/dist/adapters/postgresql/tools/transactions.js.map +1 -0
- package/dist/adapters/postgresql/tools/vector/advanced.d.ts +12 -0
- package/dist/adapters/postgresql/tools/vector/advanced.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/vector/advanced.js +902 -0
- package/dist/adapters/postgresql/tools/vector/advanced.js.map +1 -0
- package/dist/adapters/postgresql/tools/vector/basic.d.ts +25 -0
- package/dist/adapters/postgresql/tools/vector/basic.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/vector/basic.js +1000 -0
- package/dist/adapters/postgresql/tools/vector/basic.js.map +1 -0
- package/dist/adapters/postgresql/tools/vector/index.d.ts +13 -0
- package/dist/adapters/postgresql/tools/vector/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/vector/index.js +33 -0
- package/dist/adapters/postgresql/tools/vector/index.js.map +1 -0
- package/dist/auth/AuthorizationServerDiscovery.d.ts +44 -0
- package/dist/auth/AuthorizationServerDiscovery.d.ts.map +1 -0
- package/dist/auth/AuthorizationServerDiscovery.js +117 -0
- package/dist/auth/AuthorizationServerDiscovery.js.map +1 -0
- package/dist/auth/OAuthResourceServer.d.ts +42 -0
- package/dist/auth/OAuthResourceServer.d.ts.map +1 -0
- package/dist/auth/OAuthResourceServer.js +80 -0
- package/dist/auth/OAuthResourceServer.js.map +1 -0
- package/dist/auth/TokenValidator.d.ts +36 -0
- package/dist/auth/TokenValidator.d.ts.map +1 -0
- package/dist/auth/TokenValidator.js +139 -0
- package/dist/auth/TokenValidator.js.map +1 -0
- package/dist/auth/errors.d.ts +63 -0
- package/dist/auth/errors.d.ts.map +1 -0
- package/dist/auth/errors.js +102 -0
- package/dist/auth/errors.js.map +1 -0
- package/dist/auth/index.d.ts +15 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/index.js +16 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth/middleware.d.ts +61 -0
- package/dist/auth/middleware.d.ts.map +1 -0
- package/dist/auth/middleware.js +156 -0
- package/dist/auth/middleware.js.map +1 -0
- package/dist/auth/scopes.d.ts +65 -0
- package/dist/auth/scopes.d.ts.map +1 -0
- package/dist/auth/scopes.js +189 -0
- package/dist/auth/scopes.js.map +1 -0
- package/dist/auth/types.d.ts +208 -0
- package/dist/auth/types.d.ts.map +1 -0
- package/dist/auth/types.js +8 -0
- package/dist/auth/types.js.map +1 -0
- package/dist/cli/args.d.ts +34 -0
- package/dist/cli/args.d.ts.map +1 -0
- package/dist/cli/args.js +308 -0
- package/dist/cli/args.js.map +1 -0
- package/dist/cli/index.d.ts +8 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +7 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli.d.ts +9 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +341 -0
- package/dist/cli.js.map +1 -0
- package/dist/codemode/api.d.ts +62 -0
- package/dist/codemode/api.d.ts.map +1 -0
- package/dist/codemode/api.js +1505 -0
- package/dist/codemode/api.js.map +1 -0
- package/dist/codemode/index.d.ts +13 -0
- package/dist/codemode/index.d.ts.map +1 -0
- package/dist/codemode/index.js +17 -0
- package/dist/codemode/index.js.map +1 -0
- package/dist/codemode/sandbox-factory.d.ts +72 -0
- package/dist/codemode/sandbox-factory.d.ts.map +1 -0
- package/dist/codemode/sandbox-factory.js +88 -0
- package/dist/codemode/sandbox-factory.js.map +1 -0
- package/dist/codemode/sandbox.d.ts +96 -0
- package/dist/codemode/sandbox.d.ts.map +1 -0
- package/dist/codemode/sandbox.js +345 -0
- package/dist/codemode/sandbox.js.map +1 -0
- package/dist/codemode/security.d.ts +44 -0
- package/dist/codemode/security.d.ts.map +1 -0
- package/dist/codemode/security.js +149 -0
- package/dist/codemode/security.js.map +1 -0
- package/dist/codemode/types.d.ts +137 -0
- package/dist/codemode/types.d.ts.map +1 -0
- package/dist/codemode/types.js +46 -0
- package/dist/codemode/types.js.map +1 -0
- package/dist/codemode/worker-sandbox.d.ts +82 -0
- package/dist/codemode/worker-sandbox.d.ts.map +1 -0
- package/dist/codemode/worker-sandbox.js +244 -0
- package/dist/codemode/worker-sandbox.js.map +1 -0
- package/dist/codemode/worker-script.d.ts +8 -0
- package/dist/codemode/worker-script.d.ts.map +1 -0
- package/dist/codemode/worker-script.js +113 -0
- package/dist/codemode/worker-script.js.map +1 -0
- package/dist/constants/ServerInstructions.d.ts +13 -0
- package/dist/constants/ServerInstructions.d.ts.map +1 -0
- package/dist/constants/ServerInstructions.js +405 -0
- package/dist/constants/ServerInstructions.js.map +1 -0
- package/dist/filtering/ToolConstants.d.ts +43 -0
- package/dist/filtering/ToolConstants.d.ts.map +1 -0
- package/dist/filtering/ToolConstants.js +352 -0
- package/dist/filtering/ToolConstants.js.map +1 -0
- package/dist/filtering/ToolFilter.d.ts +90 -0
- package/dist/filtering/ToolFilter.d.ts.map +1 -0
- package/dist/filtering/ToolFilter.js +315 -0
- package/dist/filtering/ToolFilter.js.map +1 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +19 -0
- package/dist/index.js.map +1 -0
- package/dist/pool/ConnectionPool.d.ts +70 -0
- package/dist/pool/ConnectionPool.d.ts.map +1 -0
- package/dist/pool/ConnectionPool.js +254 -0
- package/dist/pool/ConnectionPool.js.map +1 -0
- package/dist/server/McpServer.d.ts +50 -0
- package/dist/server/McpServer.d.ts.map +1 -0
- package/dist/server/McpServer.js +108 -0
- package/dist/server/McpServer.js.map +1 -0
- package/dist/transports/http.d.ts +126 -0
- package/dist/transports/http.d.ts.map +1 -0
- package/dist/transports/http.js +303 -0
- package/dist/transports/http.js.map +1 -0
- package/dist/transports/index.d.ts +8 -0
- package/dist/transports/index.d.ts.map +1 -0
- package/dist/transports/index.js +7 -0
- package/dist/transports/index.js.map +1 -0
- package/dist/types/adapters.d.ts +136 -0
- package/dist/types/adapters.d.ts.map +1 -0
- package/dist/types/adapters.js +7 -0
- package/dist/types/adapters.js.map +1 -0
- package/dist/types/database.d.ts +204 -0
- package/dist/types/database.d.ts.map +1 -0
- package/dist/types/database.js +7 -0
- package/dist/types/database.js.map +1 -0
- package/dist/types/errors.d.ts +62 -0
- package/dist/types/errors.d.ts.map +1 -0
- package/dist/types/errors.js +91 -0
- package/dist/types/errors.js.map +1 -0
- package/dist/types/filtering.d.ts +39 -0
- package/dist/types/filtering.d.ts.map +1 -0
- package/dist/types/filtering.js +7 -0
- package/dist/types/filtering.js.map +1 -0
- package/dist/types/index.d.ts +16 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +11 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/mcp.d.ts +31 -0
- package/dist/types/mcp.d.ts.map +1 -0
- package/dist/types/mcp.js +7 -0
- package/dist/types/mcp.js.map +1 -0
- package/dist/types/oauth.d.ts +65 -0
- package/dist/types/oauth.d.ts.map +1 -0
- package/dist/types/oauth.js +7 -0
- package/dist/types/oauth.js.map +1 -0
- package/dist/types/schema.d.ts +110 -0
- package/dist/types/schema.d.ts.map +1 -0
- package/dist/types/schema.js +7 -0
- package/dist/types/schema.js.map +1 -0
- package/dist/utils/annotations.d.ts +42 -0
- package/dist/utils/annotations.d.ts.map +1 -0
- package/dist/utils/annotations.js +75 -0
- package/dist/utils/annotations.js.map +1 -0
- package/dist/utils/icons.d.ts +25 -0
- package/dist/utils/icons.d.ts.map +1 -0
- package/dist/utils/icons.js +212 -0
- package/dist/utils/icons.js.map +1 -0
- package/dist/utils/identifiers.d.ts +111 -0
- package/dist/utils/identifiers.d.ts.map +1 -0
- package/dist/utils/identifiers.js +270 -0
- package/dist/utils/identifiers.js.map +1 -0
- package/dist/utils/logger.d.ts +141 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +304 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/promptGenerator.d.ts +20 -0
- package/dist/utils/promptGenerator.d.ts.map +1 -0
- package/dist/utils/promptGenerator.js +81 -0
- package/dist/utils/promptGenerator.js.map +1 -0
- package/dist/utils/resourceAnnotations.d.ts +36 -0
- package/dist/utils/resourceAnnotations.d.ts.map +1 -0
- package/dist/utils/resourceAnnotations.js +57 -0
- package/dist/utils/resourceAnnotations.js.map +1 -0
- package/package.json +64 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity.d.ts","sourceRoot":"","sources":["../../../../src/adapters/postgresql/resources/activity.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EACV,kBAAkB,EAEnB,MAAM,yBAAyB,CAAC;AAoBjC,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,eAAe,GACvB,kBAAkB,CAoHpB"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Activity Resource
|
|
3
|
+
*
|
|
4
|
+
* Current database connections and running queries with blocking detection.
|
|
5
|
+
*/
|
|
6
|
+
import { HIGH_PRIORITY } from "../../../utils/resourceAnnotations.js";
|
|
7
|
+
/** Safely convert unknown value to string */
|
|
8
|
+
function toStr(value) {
|
|
9
|
+
if (typeof value === "string")
|
|
10
|
+
return value;
|
|
11
|
+
if (value === null || value === undefined)
|
|
12
|
+
return "";
|
|
13
|
+
if (typeof value === "number")
|
|
14
|
+
return value.toString();
|
|
15
|
+
if (typeof value === "object")
|
|
16
|
+
return JSON.stringify(value);
|
|
17
|
+
return "";
|
|
18
|
+
}
|
|
19
|
+
export function createActivityResource(adapter) {
|
|
20
|
+
return {
|
|
21
|
+
uri: "postgres://activity",
|
|
22
|
+
name: "Active Connections",
|
|
23
|
+
description: "Current database connections, running queries with duration, and blocking relationship detection",
|
|
24
|
+
mimeType: "application/json",
|
|
25
|
+
annotations: HIGH_PRIORITY,
|
|
26
|
+
handler: async (_uri, _context) => {
|
|
27
|
+
// Get connections with formatted duration
|
|
28
|
+
const result = await adapter.executeQuery(`
|
|
29
|
+
SELECT pid, usename, datname, client_addr, state,
|
|
30
|
+
query_start, state_change,
|
|
31
|
+
now() - query_start as duration,
|
|
32
|
+
CASE
|
|
33
|
+
WHEN now() - query_start < interval '1 second' THEN '<1s'
|
|
34
|
+
WHEN now() - query_start < interval '1 minute' THEN
|
|
35
|
+
EXTRACT(EPOCH FROM (now() - query_start))::int || 's'
|
|
36
|
+
WHEN now() - query_start < interval '1 hour' THEN
|
|
37
|
+
EXTRACT(EPOCH FROM (now() - query_start))::int / 60 || 'm ' ||
|
|
38
|
+
EXTRACT(EPOCH FROM (now() - query_start))::int % 60 || 's'
|
|
39
|
+
ELSE
|
|
40
|
+
EXTRACT(EPOCH FROM (now() - query_start))::int / 3600 || 'h ' ||
|
|
41
|
+
(EXTRACT(EPOCH FROM (now() - query_start))::int % 3600) / 60 || 'm'
|
|
42
|
+
END as duration_formatted,
|
|
43
|
+
LEFT(query, 200) as query_preview,
|
|
44
|
+
wait_event_type,
|
|
45
|
+
wait_event
|
|
46
|
+
FROM pg_stat_activity
|
|
47
|
+
WHERE pid != pg_backend_pid()
|
|
48
|
+
ORDER BY query_start NULLS LAST
|
|
49
|
+
`);
|
|
50
|
+
// Connection counts by state
|
|
51
|
+
const counts = await adapter.executeQuery(`
|
|
52
|
+
SELECT state, count(*) as count
|
|
53
|
+
FROM pg_stat_activity
|
|
54
|
+
WHERE pid != pg_backend_pid()
|
|
55
|
+
GROUP BY state
|
|
56
|
+
`);
|
|
57
|
+
// Detect blocking relationships
|
|
58
|
+
let blockingRelationships = [];
|
|
59
|
+
let blockingCount = 0;
|
|
60
|
+
let blockedCount = 0;
|
|
61
|
+
try {
|
|
62
|
+
const blockingResult = await adapter.executeQuery(`
|
|
63
|
+
SELECT
|
|
64
|
+
blocker.pid as blocker_pid,
|
|
65
|
+
LEFT(blocker.query, 100) as blocker_query,
|
|
66
|
+
blocked.pid as blocked_pid,
|
|
67
|
+
LEFT(blocked.query, 100) as blocked_query,
|
|
68
|
+
CASE
|
|
69
|
+
WHEN now() - blocked.query_start < interval '1 second' THEN '<1s'
|
|
70
|
+
WHEN now() - blocked.query_start < interval '1 minute' THEN
|
|
71
|
+
EXTRACT(EPOCH FROM (now() - blocked.query_start))::int || 's'
|
|
72
|
+
ELSE
|
|
73
|
+
EXTRACT(EPOCH FROM (now() - blocked.query_start))::int / 60 || 'm'
|
|
74
|
+
END as blocked_duration
|
|
75
|
+
FROM pg_stat_activity blocked
|
|
76
|
+
JOIN LATERAL unnest(pg_blocking_pids(blocked.pid)) as blocker_pid ON true
|
|
77
|
+
JOIN pg_stat_activity blocker ON blocker.pid = blocker_pid
|
|
78
|
+
WHERE blocked.pid != pg_backend_pid()
|
|
79
|
+
LIMIT 20
|
|
80
|
+
`);
|
|
81
|
+
if (blockingResult.rows && blockingResult.rows.length > 0) {
|
|
82
|
+
blockingRelationships = blockingResult.rows.map((row) => ({
|
|
83
|
+
blockerPid: Number(row["blocker_pid"]),
|
|
84
|
+
blockerQuery: toStr(row["blocker_query"]),
|
|
85
|
+
blockedPid: Number(row["blocked_pid"]),
|
|
86
|
+
blockedQuery: toStr(row["blocked_query"]),
|
|
87
|
+
blockedDuration: toStr(row["blocked_duration"]),
|
|
88
|
+
}));
|
|
89
|
+
// Count unique blockers and blocked
|
|
90
|
+
const blockers = new Set(blockingRelationships.map((r) => r.blockerPid));
|
|
91
|
+
const blocked = new Set(blockingRelationships.map((r) => r.blockedPid));
|
|
92
|
+
blockingCount = blockers.size;
|
|
93
|
+
blockedCount = blocked.size;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
catch {
|
|
97
|
+
// pg_blocking_pids might not be available in older versions
|
|
98
|
+
}
|
|
99
|
+
// Generate summary
|
|
100
|
+
const activeCount = result.rows?.filter((r) => r["state"] === "active").length ?? 0;
|
|
101
|
+
const idleCount = result.rows?.filter((r) => r["state"] === "idle").length ?? 0;
|
|
102
|
+
return {
|
|
103
|
+
connections: result.rows,
|
|
104
|
+
total: result.rows?.length ?? 0,
|
|
105
|
+
byState: counts.rows,
|
|
106
|
+
activeQueries: activeCount,
|
|
107
|
+
idleConnections: idleCount,
|
|
108
|
+
blockingRelationships,
|
|
109
|
+
blockingCount,
|
|
110
|
+
blockedCount,
|
|
111
|
+
summary: blockedCount > 0
|
|
112
|
+
? `${String(result.rows?.length ?? 0)} connections (${String(activeCount)} active). ${String(blockedCount)} queries blocked by ${String(blockingCount)} blocker(s).`
|
|
113
|
+
: `${String(result.rows?.length ?? 0)} connections (${String(activeCount)} active, ${String(idleCount)} idle). No blocking detected.`,
|
|
114
|
+
};
|
|
115
|
+
},
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=activity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity.js","sourceRoot":"","sources":["../../../../src/adapters/postgresql/resources/activity.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Capabilities Resource
|
|
3
|
+
*
|
|
4
|
+
* Server version, tool categories, extension status, and recommendations.
|
|
5
|
+
*/
|
|
6
|
+
import type { PostgresAdapter } from "../PostgresAdapter.js";
|
|
7
|
+
import type { ResourceDefinition } from "../../../types/index.js";
|
|
8
|
+
export declare function createCapabilitiesResource(adapter: PostgresAdapter): ResourceDefinition;
|
|
9
|
+
//# sourceMappingURL=capabilities.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"capabilities.d.ts","sourceRoot":"","sources":["../../../../src/adapters/postgresql/resources/capabilities.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EACV,kBAAkB,EAEnB,MAAM,yBAAyB,CAAC;AAiBjC,wBAAgB,0BAA0B,CACxC,OAAO,EAAE,eAAe,GACvB,kBAAkB,CAqMpB"}
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Capabilities Resource
|
|
3
|
+
*
|
|
4
|
+
* Server version, tool categories, extension status, and recommendations.
|
|
5
|
+
*/
|
|
6
|
+
import { ASSISTANT_FOCUSED } from "../../../utils/resourceAnnotations.js";
|
|
7
|
+
export function createCapabilitiesResource(adapter) {
|
|
8
|
+
return {
|
|
9
|
+
uri: "postgres://capabilities",
|
|
10
|
+
name: "Server Capabilities",
|
|
11
|
+
description: "PostgreSQL version, installed extensions, tool categories, and recommendations",
|
|
12
|
+
mimeType: "application/json",
|
|
13
|
+
annotations: ASSISTANT_FOCUSED,
|
|
14
|
+
handler: async (_uri, _context) => {
|
|
15
|
+
// Get PostgreSQL version
|
|
16
|
+
const versionResult = await adapter.executeQuery("SELECT version()");
|
|
17
|
+
const pgVersion = versionResult.rows?.[0]?.["version"] ?? "Unknown";
|
|
18
|
+
// Get installed extensions
|
|
19
|
+
const extResult = await adapter.executeQuery(`
|
|
20
|
+
SELECT extname, extversion
|
|
21
|
+
FROM pg_extension
|
|
22
|
+
ORDER BY extname
|
|
23
|
+
`);
|
|
24
|
+
const extensions = extResult.rows ?? [];
|
|
25
|
+
const installedNames = extensions.map((e) => e["extname"]);
|
|
26
|
+
// Check critical extensions
|
|
27
|
+
const hasPgStat = installedNames.includes("pg_stat_statements");
|
|
28
|
+
const hasHypopg = installedNames.includes("hypopg");
|
|
29
|
+
const hasPgvector = installedNames.includes("vector");
|
|
30
|
+
const hasPostgis = installedNames.includes("postgis");
|
|
31
|
+
// Tool categories with examples
|
|
32
|
+
const toolCategories = {
|
|
33
|
+
Core: {
|
|
34
|
+
count: 13,
|
|
35
|
+
description: "CRUD, schema, tables, indexes, health analysis",
|
|
36
|
+
examples: ["pg_query", "pg_insert", "pg_create_table"],
|
|
37
|
+
},
|
|
38
|
+
Transactions: {
|
|
39
|
+
count: 7,
|
|
40
|
+
description: "BEGIN, COMMIT, ROLLBACK, savepoints",
|
|
41
|
+
examples: ["pg_begin", "pg_commit", "pg_savepoint"],
|
|
42
|
+
},
|
|
43
|
+
JSONB: {
|
|
44
|
+
count: 19,
|
|
45
|
+
description: "jsonb_set, jsonb_extract, path queries, merge, diff",
|
|
46
|
+
examples: ["pg_jsonb_get", "pg_jsonb_set", "pg_jsonb_merge"],
|
|
47
|
+
},
|
|
48
|
+
Text: {
|
|
49
|
+
count: 11,
|
|
50
|
+
description: "Full-text search, trigram, fuzzy matching",
|
|
51
|
+
examples: ["pg_fts_search", "pg_trigram_search", "pg_fuzzy_match"],
|
|
52
|
+
},
|
|
53
|
+
Stats: {
|
|
54
|
+
count: 8,
|
|
55
|
+
description: "Descriptive stats, percentiles, correlation, regression",
|
|
56
|
+
examples: ["pg_stats_summary", "pg_percentile", "pg_correlation"],
|
|
57
|
+
},
|
|
58
|
+
Performance: {
|
|
59
|
+
count: 16,
|
|
60
|
+
description: "EXPLAIN ANALYZE, plan compare, baseline",
|
|
61
|
+
examples: [
|
|
62
|
+
"pg_explain_analyze",
|
|
63
|
+
"pg_plan_compare",
|
|
64
|
+
"pg_query_baseline",
|
|
65
|
+
],
|
|
66
|
+
},
|
|
67
|
+
Admin: {
|
|
68
|
+
count: 10,
|
|
69
|
+
description: "VACUUM, ANALYZE, REINDEX, configuration",
|
|
70
|
+
examples: ["pg_vacuum", "pg_analyze", "pg_reindex"],
|
|
71
|
+
},
|
|
72
|
+
Monitoring: {
|
|
73
|
+
count: 11,
|
|
74
|
+
description: "Database sizes, connections, replication",
|
|
75
|
+
examples: [
|
|
76
|
+
"pg_database_size",
|
|
77
|
+
"pg_active_connections",
|
|
78
|
+
"pg_replication_status",
|
|
79
|
+
],
|
|
80
|
+
},
|
|
81
|
+
Backup: {
|
|
82
|
+
count: 9,
|
|
83
|
+
description: "pg_dump, COPY, physical backup, restore validation",
|
|
84
|
+
examples: ["pg_dump_schema", "pg_copy_export", "pg_restore_command"],
|
|
85
|
+
},
|
|
86
|
+
Schema: {
|
|
87
|
+
count: 10,
|
|
88
|
+
description: "Schemas, sequences, views, functions, triggers",
|
|
89
|
+
examples: ["pg_create_schema", "pg_create_view", "pg_list_functions"],
|
|
90
|
+
},
|
|
91
|
+
Vector: {
|
|
92
|
+
count: 14,
|
|
93
|
+
description: "pgvector - similarity search, clustering",
|
|
94
|
+
examples: [
|
|
95
|
+
"pg_vector_search",
|
|
96
|
+
"pg_vector_add_column",
|
|
97
|
+
"pg_vector_create_index",
|
|
98
|
+
],
|
|
99
|
+
},
|
|
100
|
+
PostGIS: {
|
|
101
|
+
count: 12,
|
|
102
|
+
description: "Geospatial operations, spatial indexes",
|
|
103
|
+
examples: ["pg_distance", "pg_intersection", "pg_spatial_index"],
|
|
104
|
+
},
|
|
105
|
+
Partitioning: {
|
|
106
|
+
count: 6,
|
|
107
|
+
description: "Range/list/hash partitioning management",
|
|
108
|
+
examples: [
|
|
109
|
+
"pg_create_partitioned_table",
|
|
110
|
+
"pg_create_partition",
|
|
111
|
+
"pg_attach_partition",
|
|
112
|
+
],
|
|
113
|
+
},
|
|
114
|
+
};
|
|
115
|
+
// Critical extension status with explanations
|
|
116
|
+
const criticalExtensions = {
|
|
117
|
+
pg_stat_statements: {
|
|
118
|
+
installed: hasPgStat,
|
|
119
|
+
purpose: "Query performance tracking",
|
|
120
|
+
whyCritical: "Essential for identifying slow queries, optimization opportunities, and workload analysis. Without it, performance tuning is guesswork.",
|
|
121
|
+
installNote: "CREATE EXTENSION pg_stat_statements; -- Also add to shared_preload_libraries in postgresql.conf and restart",
|
|
122
|
+
requiredFor: ["pg_top_queries", "pg_slow_queries", "pg_query_stats"],
|
|
123
|
+
},
|
|
124
|
+
hypopg: {
|
|
125
|
+
installed: hasHypopg,
|
|
126
|
+
purpose: "Hypothetical index testing (zero-risk)",
|
|
127
|
+
whyCritical: "Allows testing index effectiveness without actually creating them. Prevents creating unused indexes.",
|
|
128
|
+
installNote: "CREATE EXTENSION hypopg; -- No restart required",
|
|
129
|
+
requiredFor: ["pg_explain_analyze with hypothetical indexes"],
|
|
130
|
+
},
|
|
131
|
+
pgvector: {
|
|
132
|
+
installed: hasPgvector,
|
|
133
|
+
purpose: "Vector similarity search",
|
|
134
|
+
whyCritical: "Required for AI/ML embeddings, semantic search, and recommendation systems.",
|
|
135
|
+
installNote: "CREATE EXTENSION vector; -- May need to install from packages first",
|
|
136
|
+
requiredFor: [
|
|
137
|
+
"pg_vector_search",
|
|
138
|
+
"pg_vector_create_index",
|
|
139
|
+
"all pg_vector_* tools",
|
|
140
|
+
],
|
|
141
|
+
},
|
|
142
|
+
postgis: {
|
|
143
|
+
installed: hasPostgis,
|
|
144
|
+
purpose: "Geospatial operations",
|
|
145
|
+
whyCritical: "Required for location-based queries, mapping, and geographic analysis.",
|
|
146
|
+
installNote: "CREATE EXTENSION postgis; -- May need to install from packages first",
|
|
147
|
+
requiredFor: ["pg_distance", "pg_intersection", "all pg_geo_* tools"],
|
|
148
|
+
},
|
|
149
|
+
};
|
|
150
|
+
// Generate recommendations
|
|
151
|
+
const recommendations = [];
|
|
152
|
+
if (!hasPgStat) {
|
|
153
|
+
recommendations.push({
|
|
154
|
+
priority: "HIGH",
|
|
155
|
+
extension: "pg_stat_statements",
|
|
156
|
+
sql: "CREATE EXTENSION IF NOT EXISTS pg_stat_statements;",
|
|
157
|
+
reason: "Critical for performance monitoring",
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
if (!hasHypopg) {
|
|
161
|
+
recommendations.push({
|
|
162
|
+
priority: "MEDIUM",
|
|
163
|
+
extension: "hypopg",
|
|
164
|
+
sql: "CREATE EXTENSION IF NOT EXISTS hypopg;",
|
|
165
|
+
reason: "Enables risk-free index testing",
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
return {
|
|
169
|
+
serverVersion: "0.3.0",
|
|
170
|
+
postgresqlVersion: pgVersion,
|
|
171
|
+
totalTools: 146,
|
|
172
|
+
totalResources: 15,
|
|
173
|
+
totalPrompts: 7,
|
|
174
|
+
toolCategories,
|
|
175
|
+
installedExtensions: extensions,
|
|
176
|
+
criticalExtensions,
|
|
177
|
+
recommendations,
|
|
178
|
+
};
|
|
179
|
+
},
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
//# sourceMappingURL=capabilities.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"capabilities.js","sourceRoot":"","sources":["../../../../src/adapters/postgresql/resources/capabilities.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pg_cron Status Resource
|
|
3
|
+
*
|
|
4
|
+
* Provides pg_cron job status, schedules, and execution history.
|
|
5
|
+
*/
|
|
6
|
+
import type { PostgresAdapter } from "../PostgresAdapter.js";
|
|
7
|
+
import type { ResourceDefinition } from "../../../types/index.js";
|
|
8
|
+
export declare function createCronResource(adapter: PostgresAdapter): ResourceDefinition;
|
|
9
|
+
//# sourceMappingURL=cron.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cron.d.ts","sourceRoot":"","sources":["../../../../src/adapters/postgresql/resources/cron.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAqClE,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,eAAe,GACvB,kBAAkB,CA8LpB"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pg_cron Status Resource
|
|
3
|
+
*
|
|
4
|
+
* Provides pg_cron job status, schedules, and execution history.
|
|
5
|
+
*/
|
|
6
|
+
import { LOW_PRIORITY } from "../../../utils/resourceAnnotations.js";
|
|
7
|
+
/** Safely convert unknown value to string */
|
|
8
|
+
function toStr(value) {
|
|
9
|
+
return typeof value === "string" ? value : "";
|
|
10
|
+
}
|
|
11
|
+
export function createCronResource(adapter) {
|
|
12
|
+
return {
|
|
13
|
+
uri: "postgres://cron",
|
|
14
|
+
name: "pg_cron Status",
|
|
15
|
+
description: "pg_cron job scheduling status, active jobs, and execution history",
|
|
16
|
+
mimeType: "application/json",
|
|
17
|
+
annotations: LOW_PRIORITY,
|
|
18
|
+
handler: async () => {
|
|
19
|
+
const result = {
|
|
20
|
+
extensionInstalled: false,
|
|
21
|
+
extensionVersion: null,
|
|
22
|
+
jobs: [],
|
|
23
|
+
jobCount: 0,
|
|
24
|
+
activeJobCount: 0,
|
|
25
|
+
recentRuns: {
|
|
26
|
+
total: 0,
|
|
27
|
+
successful: 0,
|
|
28
|
+
failed: 0,
|
|
29
|
+
},
|
|
30
|
+
failedJobs: [],
|
|
31
|
+
recommendations: [],
|
|
32
|
+
};
|
|
33
|
+
// Check if pg_cron is installed (outside try-catch for correct error messaging)
|
|
34
|
+
const extCheck = await adapter.executeQuery(`SELECT extversion FROM pg_extension WHERE extname = 'pg_cron'`);
|
|
35
|
+
if (!extCheck.rows || extCheck.rows.length === 0) {
|
|
36
|
+
result.recommendations.push("pg_cron is not installed. Installation steps:", "1. Add to postgresql.conf: shared_preload_libraries = 'pg_cron'", "2. Add to postgresql.conf: cron.database_name = 'your_database'", "3. Restart PostgreSQL (required for shared_preload_libraries)", "4. Run: CREATE EXTENSION pg_cron;", "Note: pg_cron requires superuser privileges and a PostgreSQL restart to enable.");
|
|
37
|
+
return JSON.stringify(result, null, 2);
|
|
38
|
+
}
|
|
39
|
+
result.extensionInstalled = true;
|
|
40
|
+
const extVersion = extCheck.rows[0]?.["extversion"];
|
|
41
|
+
result.extensionVersion =
|
|
42
|
+
typeof extVersion === "string" ? extVersion : null;
|
|
43
|
+
try {
|
|
44
|
+
// Get all jobs
|
|
45
|
+
const jobsResult = await adapter.executeQuery(`SELECT jobid, schedule, command, nodename, nodeport, database, username, active
|
|
46
|
+
FROM cron.job ORDER BY jobid`);
|
|
47
|
+
if (jobsResult.rows) {
|
|
48
|
+
for (const row of jobsResult.rows) {
|
|
49
|
+
result.jobs.push({
|
|
50
|
+
jobid: Number(row["jobid"]),
|
|
51
|
+
schedule: toStr(row["schedule"]),
|
|
52
|
+
command: toStr(row["command"]),
|
|
53
|
+
nodename: toStr(row["nodename"]),
|
|
54
|
+
nodeport: Number(row["nodeport"]),
|
|
55
|
+
database: toStr(row["database"]),
|
|
56
|
+
username: toStr(row["username"]),
|
|
57
|
+
active: Boolean(row["active"]),
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
result.jobCount = result.jobs.length;
|
|
61
|
+
result.activeJobCount = result.jobs.filter((j) => j.active).length;
|
|
62
|
+
}
|
|
63
|
+
// Get recent run statistics (last 7 days)
|
|
64
|
+
const runsResult = await adapter.executeQuery(`SELECT status, COUNT(*)::int as count
|
|
65
|
+
FROM cron.job_run_details
|
|
66
|
+
WHERE start_time > NOW() - INTERVAL '7 days'
|
|
67
|
+
GROUP BY status`);
|
|
68
|
+
if (runsResult.rows) {
|
|
69
|
+
for (const row of runsResult.rows) {
|
|
70
|
+
const count = Number(row["count"] ?? 0);
|
|
71
|
+
const status = toStr(row["status"]);
|
|
72
|
+
result.recentRuns.total += count;
|
|
73
|
+
if (status === "succeeded") {
|
|
74
|
+
result.recentRuns.successful += count;
|
|
75
|
+
}
|
|
76
|
+
else if (status === "failed") {
|
|
77
|
+
result.recentRuns.failed += count;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
// Get last run time per job
|
|
82
|
+
const lastRunResult = await adapter.executeQuery(`SELECT DISTINCT ON (jobid)
|
|
83
|
+
jobid,
|
|
84
|
+
status as last_status,
|
|
85
|
+
start_time as last_run_time,
|
|
86
|
+
end_time as last_end_time
|
|
87
|
+
FROM cron.job_run_details
|
|
88
|
+
ORDER BY jobid, start_time DESC`);
|
|
89
|
+
// Attach last run info to each job
|
|
90
|
+
const lastRunMap = new Map();
|
|
91
|
+
if (lastRunResult.rows) {
|
|
92
|
+
for (const row of lastRunResult.rows) {
|
|
93
|
+
lastRunMap.set(Number(row["jobid"]), {
|
|
94
|
+
status: toStr(row["last_status"]),
|
|
95
|
+
time: toStr(row["last_run_time"]),
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
// Enhance jobs with last run info
|
|
100
|
+
for (const job of result.jobs) {
|
|
101
|
+
const lastRun = lastRunMap.get(job.jobid);
|
|
102
|
+
if (lastRun) {
|
|
103
|
+
job["lastRunTime"] = lastRun.time;
|
|
104
|
+
job["lastRunStatus"] = lastRun.status;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
// Get failed jobs with details
|
|
108
|
+
const failedResult = await adapter.executeQuery(`SELECT j.jobid, j.command, d.return_message,
|
|
109
|
+
COUNT(*)::int as failure_count
|
|
110
|
+
FROM cron.job j
|
|
111
|
+
JOIN cron.job_run_details d ON j.jobid = d.jobid
|
|
112
|
+
WHERE d.status = 'failed'
|
|
113
|
+
AND d.start_time > NOW() - INTERVAL '7 days'
|
|
114
|
+
GROUP BY j.jobid, j.command, d.return_message
|
|
115
|
+
ORDER BY failure_count DESC
|
|
116
|
+
LIMIT 5`);
|
|
117
|
+
if (failedResult.rows) {
|
|
118
|
+
for (const row of failedResult.rows) {
|
|
119
|
+
const command = toStr(row["command"]);
|
|
120
|
+
result.failedJobs.push({
|
|
121
|
+
jobid: Number(row["jobid"]),
|
|
122
|
+
command: command.substring(0, 100),
|
|
123
|
+
lastFailure: toStr(row["return_message"]),
|
|
124
|
+
failureCount: Number(row["failure_count"]),
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
// Generate recommendations
|
|
129
|
+
if (result.jobCount === 0) {
|
|
130
|
+
result.recommendations.push("No cron jobs scheduled. Use pg_cron_schedule to create jobs.");
|
|
131
|
+
}
|
|
132
|
+
if (result.failedJobs.length > 0) {
|
|
133
|
+
result.recommendations.push(`${String(result.failedJobs.length)} jobs have failed recently. Review job_run_details for errors.`);
|
|
134
|
+
}
|
|
135
|
+
const inactiveJobs = result.jobs.filter((j) => !j.active);
|
|
136
|
+
if (inactiveJobs.length > 0) {
|
|
137
|
+
result.recommendations.push(`${String(inactiveJobs.length)} jobs are inactive. Consider removing them with pg_cron_unschedule.`);
|
|
138
|
+
}
|
|
139
|
+
// Check for old history that should be cleaned
|
|
140
|
+
const historyCheck = await adapter.executeQuery(`SELECT COUNT(*)::int as old_count
|
|
141
|
+
FROM cron.job_run_details
|
|
142
|
+
WHERE start_time < NOW() - INTERVAL '30 days'`);
|
|
143
|
+
const oldCount = Number(historyCheck.rows?.[0]?.["old_count"] ?? 0);
|
|
144
|
+
if (oldCount > 1000) {
|
|
145
|
+
result.recommendations.push(`${String(oldCount)} old history records. Use pg_cron_cleanup_history to reduce bloat.`);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
catch {
|
|
149
|
+
// Extension is installed but data queries failed (permissions, schema visibility, etc.)
|
|
150
|
+
result.recommendations.push("Error querying pg_cron data. Check permissions on cron schema tables.");
|
|
151
|
+
}
|
|
152
|
+
return JSON.stringify(result, null, 2);
|
|
153
|
+
},
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=cron.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cron.js","sourceRoot":"","sources":["../../../../src/adapters/postgresql/resources/cron.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pgcrypto Status Resource
|
|
3
|
+
*
|
|
4
|
+
* Provides pgcrypto extension availability and usage information.
|
|
5
|
+
*/
|
|
6
|
+
import type { PostgresAdapter } from "../PostgresAdapter.js";
|
|
7
|
+
import type { ResourceDefinition } from "../../../types/index.js";
|
|
8
|
+
export declare function createCryptoResource(adapter: PostgresAdapter): ResourceDefinition;
|
|
9
|
+
//# sourceMappingURL=crypto.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crypto.d.ts","sourceRoot":"","sources":["../../../../src/adapters/postgresql/resources/crypto.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAiDlE,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,eAAe,GACvB,kBAAkB,CA4NpB"}
|