@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":"advanced.js","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/postgis/advanced.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAOH,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,QAAQ,EAAE,MAAM,kCAAkC,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EACL,iBAAiB,EACjB,aAAa,EACb,sBAAsB,EACtB,kBAAkB,EAClB,oBAAoB,EACpB,gBAAgB,GACjB,MAAM,wBAAwB,CAAC;AAEhC,MAAM,UAAU,iBAAiB,CAAC,OAAwB;IACxD,OAAO;QACL,IAAI,EAAE,YAAY;QAClB,WAAW,EACT,wJAAwJ;QAC1J,KAAK,EAAE,SAAS;QAChB,WAAW,EAAE,iBAAiB,EAAE,iCAAiC;QACjE,WAAW,EAAE,QAAQ,CAAC,SAAS,CAAC;QAChC,KAAK,EAAE,YAAY,CAAC,SAAS,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC;QACnD,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,MAAM,MAAM,GAAG,aAAa,CAAC,KAAK,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;YACjD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC;YAEjC,MAAM,GAAG,GAAG;;+EAE6D,CAAC;YAE1E,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE;gBAC7C,MAAM,CAAC,GAAG;gBACV,MAAM,CAAC,GAAG;gBACV,IAAI;aACL,CAAC,CAAC;YAEH,yCAAyC;YACzC,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;gBACtB,OAAO,EAAE,CAAC;YACZ,CAAC;YACD,MAAM,QAAQ,GAA4B,EAAE,GAAG,GAAG,EAAE,CAAC;YACrD,IAAI,IAAI,KAAK,IAAI,EAAE,CAAC;gBAClB,QAAQ,CAAC,MAAM,CAAC;oBACd,2CAA2C,MAAM,CAAC,IAAI,CAAC,2DAA2D,CAAC;YACvH,CAAC;YACD,OAAO,QAAQ,CAAC;QAClB,CAAC;KACF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,sBAAsB,CACpC,OAAwB;IAExB,OAAO;QACL,IAAI,EAAE,kBAAkB;QACxB,WAAW,EACT,yEAAyE;QAC3E,KAAK,EAAE,SAAS;QAChB,WAAW,EAAE,sBAAsB,EAAE,iCAAiC;QACtE,WAAW,EAAE,QAAQ,CAAC,oBAAoB,CAAC;QAC3C,KAAK,EAAE,YAAY,CAAC,SAAS,EAAE,QAAQ,CAAC,oBAAoB,CAAC,CAAC;QAC9D,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,MAAM,MAAM,GAAG,kBAAkB,CAAC,KAAK,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;YAEtD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;YAC7C,MAAM,cAAc,GAClB,UAAU,KAAK,QAAQ;gBACrB,CAAC,CAAC,IAAI,UAAU,MAAM,MAAM,CAAC,KAAK,GAAG;gBACrC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,GAAG,CAAC;YAC1B,MAAM,UAAU,GAAG,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC;YAExC,MAAM,WAAW,GACf,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAE5D,sEAAsE;YACtE,MAAM,cAAc,GAAG,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC;YAC1C,MAAM,WAAW,GACf,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,MAAM,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAE9D,sDAAsD;YACtD,MAAM,QAAQ,GAAG;;;;;OAKhB,CAAC;YACF,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,QAAQ,EAAE;gBACrD,UAAU;gBACV,MAAM,CAAC,KAAK;aACb,CAAC,CAAC;YACH,MAAM,WAAW,GAAG,CAAC,SAAS,CAAC,IAAI,IAAI,EAAE,CAAC;iBACvC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC;iBAC/C,IAAI,CAAC,IAAI,CAAC,CAAC;YAEd,qEAAqE;YACrE,MAAM,UAAU,GACd,WAAW,CAAC,MAAM,GAAG,CAAC;gBACpB,CAAC,CAAC,GAAG,WAAW,0CAA0C,UAAU,KAAK,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,gEAAgE,UAAU,KAAK,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,0BAA0B,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,iBAAiB;gBAC5T,CAAC,CAAC,wCAAwC,UAAU,KAAK,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,gEAAgE,UAAU,KAAK,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,0BAA0B,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,iBAAiB,CAAC;YAEjT,MAAM,GAAG,GAAG,UAAU,UAAU,SAAS,cAAc,IAAI,WAAW,IAAI,WAAW,EAAE,CAAC;YAExF,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;YAE/C,yEAAyE;YACzE,MAAM,QAAQ,GAA4B;gBACxC,OAAO,EAAE,MAAM,CAAC,IAAI;gBACpB,KAAK,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC;gBAC/B,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,MAAM,EAAE,MAAM,CAAC,MAAM;aACtB,CAAC;YAEF,qDAAqD;YACrD,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,IAAI,cAAc,GAAG,CAAC,EAAE,CAAC;gBACrD,MAAM,QAAQ,GAAG,+BAA+B,cAAc,IAAI,WAAW,EAAE,CAAC;gBAChF,MAAM,WAAW,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;gBACzD,MAAM,UAAU,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;gBAE/D,IAAI,UAAU,GAAG,cAAc,EAAE,CAAC;oBAChC,QAAQ,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC;oBAC7B,QAAQ,CAAC,YAAY,CAAC,GAAG,UAAU,CAAC;oBACpC,QAAQ,CAAC,OAAO,CAAC,GAAG,cAAc,CAAC;gBACrC,CAAC;YACH,CAAC;YAED,OAAO,QAAQ,CAAC;QAClB,CAAC;KACF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,0BAA0B,CACxC,OAAwB;IAExB,OAAO;QACL,IAAI,EAAE,uBAAuB;QAC7B,WAAW,EACT,mEAAmE;QACrE,KAAK,EAAE,SAAS;QAChB,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC;YACpB,KAAK,EAAE,CAAC;iBACL,MAAM,EAAE;iBACR,QAAQ,EAAE;iBACV,QAAQ,CAAC,mDAAmD,CAAC;YAChE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC;SACtD,CAAC;QACF,WAAW,EAAE,QAAQ,CAAC,oBAAoB,CAAC;QAC3C,KAAK,EAAE,YAAY,CAAC,SAAS,EAAE,QAAQ,CAAC,oBAAoB,CAAC,CAAC;QAC9D,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,MAAM,MAAM,GAAG,MAA6C,CAAC;YAC7D,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;YAE7C,MAAM,UAAU,GAAG;;;;;;;;;;;;;;;;;;;;kBAoBP,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,oBAAoB,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE;;aAE1E,CAAC;YAER,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBAC9C,OAAO,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC,UAAU,CAAC,CAAC;gBAC9C,OAAO,CAAC,YAAY,CAClB;;;;;;;;;sBASY,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,oBAAoB,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE;;;;;;;iBAO1E,EACP,CAAC,UAAU,CAAC,CACb;aACF,CAAC,CAAC;YAEH,MAAM,eAAe,GAAa,EAAE,CAAC;YAErC,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC;gBACrC,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC9C,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC;gBAEvD,IAAI,KAAK,KAAK,CAAC,IAAI,SAAS,GAAG,IAAI,GAAG,IAAI,EAAE,CAAC;oBAC3C,eAAe,CAAC,IAAI,CAClB,UAAU,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,QAAQ,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,wBAAwB,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,yBAAyB,CAC/I,CAAC;gBACJ,CAAC;gBACD,IAAI,KAAK,GAAG,CAAC,IAAI,SAAS,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,EAAE,CAAC;oBAC/C,eAAe,CAAC,IAAI,CAClB,wBAAwB,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,MAAM,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,4DAA4D,CAC7I,CAAC;gBACJ,CAAC;YACH,CAAC;YAED,KAAK,MAAM,KAAK,IAAI,UAAU,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC;gBAC1C,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;gBACjD,MAAM,QAAQ,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,IAAI,CACxC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,YAAY,CAAC,KAAK,KAAK,CAAC,YAAY,CAAC,CACnD,CAAC;gBAEF,IAAI,QAAQ,GAAG,KAAK,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAClC,eAAe,CAAC,IAAI,CAClB,UAAU,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,SAAS,MAAM,CAAC,QAAQ,CAAC,2DAA2D,CAC1H,CAAC;gBACJ,CAAC;YACH,CAAC;YAED,sDAAsD;YACtD,IACE,MAAM,CAAC,KAAK,KAAK,SAAS;gBAC1B,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,CAAC,KAAK,CAAC;gBACjC,CAAC,UAAU,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,CAAC,KAAK,CAAC,EACpC,CAAC;gBACD,OAAO;oBACL,OAAO,EAAE,UAAU,MAAM,CAAC,KAAK,0BAA0B,UAAU,sCAAsC;oBACzG,KAAK,EAAE,MAAM,CAAC,KAAK;oBACnB,MAAM,EAAE,UAAU;oBAClB,cAAc,EAAE,EAAE;oBAClB,UAAU,EAAE,EAAE;oBACd,eAAe,EAAE;wBACf,iBAAiB,MAAM,CAAC,KAAK,8CAA8C;qBAC5E;iBACF,CAAC;YACJ,CAAC;YAED,OAAO;gBACL,cAAc,EAAE,OAAO,CAAC,IAAI;gBAC5B,UAAU,EAAE,UAAU,CAAC,IAAI;gBAC3B,eAAe,EACb,eAAe,CAAC,MAAM,GAAG,CAAC;oBACxB,CAAC,CAAC,eAAe;oBACjB,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,CAAC,KAAK,CAAC;wBACjC,CAAC,CAAC;4BACE,4FAA4F;yBAC7F;wBACH,CAAC,CAAC,CAAC,sCAAsC,CAAC;gBAChD,IAAI,EAAE;oBACJ,8CAA8C;oBAC9C,sCAAsC;oBACtC,kDAAkD;oBAClD,sDAAsD;iBACvD;aACF,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAAC,OAAwB;IAC3D,OAAO;QACL,IAAI,EAAE,gBAAgB;QACtB,WAAW,EACT,uKAAuK;QACzK,KAAK,EAAE,SAAS;QAChB,WAAW,EAAE,oBAAoB,EAAE,iCAAiC;QACpE,WAAW,EAAE,QAAQ,CAAC,aAAa,CAAC;QACpC,KAAK,EAAE,YAAY,CAAC,SAAS,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QACvD,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,MAAM,MAAM,GAAG,gBAAgB,CAAC,KAAK,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;YAEpD,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;YACzC,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;YAC7C,MAAM,cAAc,GAClB,UAAU,KAAK,QAAQ;gBACrB,CAAC,CAAC,IAAI,UAAU,MAAM,MAAM,CAAC,KAAK,GAAG;gBACrC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,GAAG,CAAC;YAC1B,MAAM,WAAW,GACf,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC5D,MAAM,WAAW,GACf,MAAM,CAAC,KAAK,KAAK,SAAS,IAAI,MAAM,CAAC,KAAK,GAAG,CAAC;gBAC5C,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;gBACjC,CAAC,CAAC,EAAE,CAAC;YAET,yBAAyB;YACzB,IAAI,OAA2B,CAAC;YAEhC,+CAA+C;YAC/C,IAAI,oBAAoB,GAAG,MAAM,CAAC,WAAW,IAAI,CAAC,CAAC;YACnD,IAAI,QAAQ,GAAG,CAAC,CAAC;YAEjB,IAAI,MAAM,KAAK,QAAQ,EAAE,CAAC;gBACxB,2BAA2B;gBAC3B,IAAI,oBAAoB,IAAI,CAAC,EAAE,CAAC;oBAC9B,OAAO;wBACL,KAAK,EAAE,iDAAiD,MAAM,CAAC,oBAAoB,CAAC,IAAI;wBACxF,MAAM;wBACN,KAAK,EAAE,MAAM,CAAC,KAAK;wBACnB,WAAW,EAAE,oBAAoB;wBACjC,UAAU,EACR,mEAAmE;qBACtE,CAAC;gBACJ,CAAC;gBAED,MAAM,WAAW,GAAG,MAAM,OAAO,CAAC,YAAY,CAC5C,+BAA+B,cAAc,IAAI,WAAW,EAAE,CAC/D,CAAC;gBACF,QAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;gBAEvD,IAAI,QAAQ,KAAK,CAAC,EAAE,CAAC;oBACnB,OAAO;wBACL,KAAK,EAAE,0BAA0B,MAAM,CAAC,KAAK,GAAG,WAAW,KAAK,EAAE,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,oCAAoC;wBAChI,MAAM;wBACN,KAAK,EAAE,MAAM,CAAC,KAAK;wBACnB,QAAQ,EAAE,CAAC;qBACZ,CAAC;gBACJ,CAAC;gBAED,4CAA4C;gBAC5C,IAAI,oBAAoB,GAAG,QAAQ,EAAE,CAAC;oBACpC,OAAO,GAAG,aAAa,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,sBAAsB,MAAM,CAAC,QAAQ,CAAC,0BAA0B,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAC;oBACtJ,oBAAoB,GAAG,QAAQ,CAAC;gBAClC,CAAC;YACH,CAAC;YAED,IAAI,eAAuB,CAAC;YAC5B,IAAI,MAAM,KAAK,QAAQ,EAAE,CAAC;gBACxB,eAAe,GAAG,qBAAqB,MAAM,CAAC,MAAM,MAAM,MAAM,CAAC,oBAAoB,CAAC,WAAW,CAAC;YACpG,CAAC;iBAAM,CAAC;gBACN,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,IAAI,GAAG,CAAC;gBAC9B,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,CAAC,CAAC;gBACxC,eAAe,GAAG,qBAAqB,MAAM,CAAC,MAAM,MAAM,MAAM,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC;YACzG,CAAC;YAED,MAAM,GAAG,GAAG;;;;0BAIQ,eAAe;2BACd,cAAc;sBACnB,WAAW;;;;;2DAK0B,MAAM,CAAC,MAAM;6DACX,MAAM,CAAC,MAAM;;;;;kBAKxD,WAAW;aAChB,CAAC;YAER,MAAM,CAAC,cAAc,EAAE,aAAa,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBACxD,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC;gBACzB,OAAO,CAAC,YAAY,CAAC;;iCAEI,eAAe;+BACjB,cAAc;0BACnB,WAAW;;;;;;;iBAOpB,CAAC;aACX,CAAC,CAAC;YAEH,2CAA2C;YAC3C,MAAM,kBAAkB,GAAG,CAAC,cAAc,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACnE,GAAG,GAAG;gBACN,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;aACxC,CAAC,CAAC,CAAC;YAEJ,sDAAsD;YACtD,MAAM,UAAU,GAAG,aAAa,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YACjD,MAAM,iBAAiB,GAAG;gBACxB,YAAY,EAAE,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;gBACrD,YAAY,EAAE,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;gBACrD,YAAY,EAAE,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;aACtD,CAAC;YAEF,iBAAiB;YACjB,MAAM,QAAQ,GAA4B;gBACxC,MAAM;gBACN,UAAU,EACR,MAAM,KAAK,QAAQ;oBACjB,CAAC,CAAC,EAAE,WAAW,EAAE,oBAAoB,EAAE;oBACvC,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,IAAI,GAAG,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,IAAI,CAAC,EAAE;gBAClE,OAAO,EAAE,iBAAiB;gBAC1B,QAAQ,EAAE,kBAAkB;aAC7B,CAAC;YAEF,+BAA+B;YAC/B,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;gBAC1B,QAAQ,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC;gBAC9B,QAAQ,CAAC,mBAAmB,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC;gBACnD,QAAQ,CAAC,gBAAgB,CAAC,GAAG,oBAAoB,CAAC;YACpD,CAAC;YAED,mDAAmD;YACnD,MAAM,WAAW,GAAG,iBAAiB,CAAC,YAAY,CAAC;YACnD,MAAM,WAAW,GAAG,iBAAiB,CAAC,YAAY,CAAC;YACnD,MAAM,WAAW,GAAG,iBAAiB,CAAC,YAAY,CAAC;YAEnD,IAAI,MAAM,KAAK,QAAQ,EAAE,CAAC;gBACxB,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,IAAI,GAAG,CAAC;gBAC9B,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,CAAC,CAAC;gBAExC,kDAAkD;gBAClD,MAAM,KAAK,GAAa,EAAE,CAAC;gBAE3B,IAAI,WAAW,KAAK,CAAC,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;oBACzC,KAAK,CAAC,IAAI,CACR,OAAO,MAAM,CAAC,WAAW,CAAC,uEAAuE,MAAM,CAAC,GAAG,CAAC,sCAAsC,CACnJ,CAAC;gBACJ,CAAC;gBAED,IAAI,WAAW,GAAG,CAAC,IAAI,WAAW,GAAG,WAAW,GAAG,GAAG,EAAE,CAAC;oBACvD,KAAK,CAAC,IAAI,CACR,GAAG,MAAM,CAAC,WAAW,CAAC,OAAO,MAAM,CAAC,WAAW,CAAC,YAAY,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,WAAW,GAAG,WAAW,CAAC,GAAG,GAAG,CAAC,CAAC,4EAA4E,MAAM,CAAC,SAAS,CAAC,IAAI,CACnN,CAAC;gBACJ,CAAC;gBAED,IAAI,WAAW,KAAK,CAAC,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;oBACzC,KAAK,CAAC,IAAI,CACR,4EAA4E,MAAM,CAAC,GAAG,CAAC,yCAAyC,MAAM,CAAC,SAAS,CAAC,IAAI,CACtJ,CAAC;gBACJ,CAAC;gBAED,QAAQ,CAAC,OAAO,CAAC;oBACf,0EAA0E,CAAC;gBAE7E,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACrB,QAAQ,CAAC,OAAO,CAAC,GAAG,KAAK,CAAC;gBAC5B,CAAC;gBAED,QAAQ,CAAC,gBAAgB,CAAC,GAAG;oBAC3B,GAAG,EAAE,iFAAiF;oBACtF,SAAS,EAAE,yFAAyF;iBACrG,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,QAAQ,CAAC,OAAO,CAAC;oBACf,oDAAoD,CAAC;YACzD,CAAC;YAED,OAAO,QAAQ,CAAC;QAClB,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL PostGIS Extension Tools - Basic Operations
|
|
3
|
+
*
|
|
4
|
+
* Core spatial tools: extension, geometry_column, point_in_polygon, distance, buffer, intersection, bounding_box, spatial_index.
|
|
5
|
+
*/
|
|
6
|
+
import type { PostgresAdapter } from "../../PostgresAdapter.js";
|
|
7
|
+
import type { ToolDefinition } from "../../../../types/index.js";
|
|
8
|
+
export declare function createPostgisExtensionTool(adapter: PostgresAdapter): ToolDefinition;
|
|
9
|
+
export declare function createGeometryColumnTool(adapter: PostgresAdapter): ToolDefinition;
|
|
10
|
+
export declare function createPointInPolygonTool(adapter: PostgresAdapter): ToolDefinition;
|
|
11
|
+
export declare function createDistanceTool(adapter: PostgresAdapter): ToolDefinition;
|
|
12
|
+
export declare function createBufferTool(adapter: PostgresAdapter): ToolDefinition;
|
|
13
|
+
export declare function createIntersectionTool(adapter: PostgresAdapter): ToolDefinition;
|
|
14
|
+
export declare function createBoundingBoxTool(adapter: PostgresAdapter): ToolDefinition;
|
|
15
|
+
export declare function createSpatialIndexTool(adapter: PostgresAdapter): ToolDefinition;
|
|
16
|
+
//# sourceMappingURL=basic.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"basic.d.ts","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/postgis/basic.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,EACV,cAAc,EAEf,MAAM,4BAA4B,CAAC;AAyBpC,wBAAgB,0BAA0B,CACxC,OAAO,EAAE,eAAe,GACvB,cAAc,CAahB;AAED,wBAAgB,wBAAwB,CACtC,OAAO,EAAE,eAAe,GACvB,cAAc,CA0EhB;AAED,wBAAgB,wBAAwB,CACtC,OAAO,EAAE,eAAe,GACvB,cAAc,CAsEhB;AAED,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,eAAe,GAAG,cAAc,CA2D3E;AAED,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,eAAe,GAAG,cAAc,CAuFzE;AAED,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,eAAe,GACvB,cAAc,CA0FhB;AAED,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,eAAe,GACvB,cAAc,CAiFhB;AAED,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,eAAe,GACvB,cAAc,CAyEhB"}
|
|
@@ -0,0 +1,479 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL PostGIS Extension Tools - Basic Operations
|
|
3
|
+
*
|
|
4
|
+
* Core spatial tools: extension, geometry_column, point_in_polygon, distance, buffer, intersection, bounding_box, spatial_index.
|
|
5
|
+
*/
|
|
6
|
+
import { z } from "zod";
|
|
7
|
+
import { readOnly, write } from "../../../../utils/annotations.js";
|
|
8
|
+
import { getToolIcons } from "../../../../utils/icons.js";
|
|
9
|
+
import { sanitizeIdentifier, sanitizeTableName, } from "../../../../utils/identifiers.js";
|
|
10
|
+
import { GeometryColumnSchemaBase, GeometryColumnSchema, GeometryDistanceSchemaBase, GeometryDistanceSchema, PointInPolygonSchemaBase, PointInPolygonSchema, SpatialIndexSchemaBase, SpatialIndexSchema, BufferSchemaBase, BufferSchema, IntersectionSchemaBase, IntersectionSchema, BoundingBoxSchemaBase, BoundingBoxSchema, } from "../../schemas/index.js";
|
|
11
|
+
export function createPostgisExtensionTool(adapter) {
|
|
12
|
+
return {
|
|
13
|
+
name: "pg_postgis_create_extension",
|
|
14
|
+
description: "Enable the PostGIS extension for geospatial operations.",
|
|
15
|
+
group: "postgis",
|
|
16
|
+
inputSchema: z.object({}),
|
|
17
|
+
annotations: write("Create PostGIS Extension"),
|
|
18
|
+
icons: getToolIcons("postgis", write("Create PostGIS Extension")),
|
|
19
|
+
handler: async (_params, _context) => {
|
|
20
|
+
await adapter.executeQuery("CREATE EXTENSION IF NOT EXISTS postgis");
|
|
21
|
+
return { success: true, message: "PostGIS extension enabled" };
|
|
22
|
+
},
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
export function createGeometryColumnTool(adapter) {
|
|
26
|
+
return {
|
|
27
|
+
name: "pg_geometry_column",
|
|
28
|
+
description: "Add a geometry column to a table. Returns alreadyExists: true if column exists.",
|
|
29
|
+
group: "postgis",
|
|
30
|
+
inputSchema: GeometryColumnSchemaBase, // Base schema for MCP visibility
|
|
31
|
+
annotations: write("Add Geometry Column"),
|
|
32
|
+
icons: getToolIcons("postgis", write("Add Geometry Column")),
|
|
33
|
+
handler: async (params, _context) => {
|
|
34
|
+
const parsed = GeometryColumnSchema.parse(params ?? {});
|
|
35
|
+
const schemaName = parsed.schema ?? "public";
|
|
36
|
+
const srid = parsed.srid ?? 4326;
|
|
37
|
+
const geomType = parsed.type ?? "GEOMETRY";
|
|
38
|
+
// Always check if column already exists (for accurate response message)
|
|
39
|
+
const checkSql = `SELECT column_name FROM information_schema.columns WHERE table_schema = $1 AND table_name = $2 AND column_name = $3`;
|
|
40
|
+
const checkResult = await adapter.executeQuery(checkSql, [
|
|
41
|
+
schemaName,
|
|
42
|
+
parsed.table,
|
|
43
|
+
parsed.column,
|
|
44
|
+
]);
|
|
45
|
+
const columnExists = checkResult.rows !== undefined && checkResult.rows.length > 0;
|
|
46
|
+
if (columnExists) {
|
|
47
|
+
if (parsed.ifNotExists === true) {
|
|
48
|
+
return {
|
|
49
|
+
success: true,
|
|
50
|
+
alreadyExists: true,
|
|
51
|
+
table: parsed.table,
|
|
52
|
+
column: parsed.column,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
// Without ifNotExists: true, this should be an error
|
|
56
|
+
return {
|
|
57
|
+
success: false,
|
|
58
|
+
error: `Column "${parsed.column}" already exists in table "${parsed.table}".`,
|
|
59
|
+
table: parsed.table,
|
|
60
|
+
column: parsed.column,
|
|
61
|
+
suggestion: "Use ifNotExists: true to skip this error if the column already exists.",
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
// Check if table exists before trying to add column
|
|
65
|
+
const tableCheckSql = `SELECT 1 FROM information_schema.tables WHERE table_schema = $1 AND table_name = $2`;
|
|
66
|
+
const tableCheckResult = await adapter.executeQuery(tableCheckSql, [
|
|
67
|
+
schemaName,
|
|
68
|
+
parsed.table,
|
|
69
|
+
]);
|
|
70
|
+
if ((tableCheckResult.rows?.length ?? 0) === 0) {
|
|
71
|
+
return {
|
|
72
|
+
success: false,
|
|
73
|
+
error: `Table "${parsed.table}" does not exist in schema "${schemaName}".`,
|
|
74
|
+
table: parsed.table,
|
|
75
|
+
schema: schemaName,
|
|
76
|
+
suggestion: "Create the table first, then add the geometry column.",
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
const sql = `SELECT AddGeometryColumn('${schemaName}', '${parsed.table}', '${parsed.column}', ${String(srid)}, '${geomType}', 2)`;
|
|
80
|
+
await adapter.executeQuery(sql);
|
|
81
|
+
return {
|
|
82
|
+
success: true,
|
|
83
|
+
table: parsed.table,
|
|
84
|
+
column: parsed.column,
|
|
85
|
+
srid,
|
|
86
|
+
type: geomType,
|
|
87
|
+
};
|
|
88
|
+
},
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
export function createPointInPolygonTool(adapter) {
|
|
92
|
+
return {
|
|
93
|
+
name: "pg_point_in_polygon",
|
|
94
|
+
description: "Check if a point is within any polygon in a table. The geometry column should contain POLYGON or MULTIPOLYGON geometries.",
|
|
95
|
+
group: "postgis",
|
|
96
|
+
inputSchema: PointInPolygonSchemaBase, // Base schema for MCP visibility
|
|
97
|
+
annotations: readOnly("Point in Polygon"),
|
|
98
|
+
icons: getToolIcons("postgis", readOnly("Point in Polygon")),
|
|
99
|
+
handler: async (params, _context) => {
|
|
100
|
+
const { table, column, point, schema } = PointInPolygonSchema.parse(params ?? {});
|
|
101
|
+
const schemaName = schema ?? "public";
|
|
102
|
+
const tableName = sanitizeTableName(table, schemaName !== "public" ? schemaName : undefined);
|
|
103
|
+
const columnName = sanitizeIdentifier(column);
|
|
104
|
+
// Check geometry type and warn if not polygon
|
|
105
|
+
const typeCheckSql = `SELECT DISTINCT GeometryType(${columnName}) as geom_type FROM ${tableName} WHERE ${columnName} IS NOT NULL LIMIT 1`;
|
|
106
|
+
const typeResult = await adapter.executeQuery(typeCheckSql);
|
|
107
|
+
const geomType = typeResult.rows?.[0]?.["geom_type"];
|
|
108
|
+
const isPolygonType = geomType?.toUpperCase()?.includes("POLYGON") ?? false;
|
|
109
|
+
// Get non-geometry columns to avoid returning raw WKB
|
|
110
|
+
const colQuery = `
|
|
111
|
+
SELECT column_name FROM information_schema.columns
|
|
112
|
+
WHERE table_schema = $1 AND table_name = $2
|
|
113
|
+
AND udt_name NOT IN ('geometry', 'geography')
|
|
114
|
+
ORDER BY ordinal_position
|
|
115
|
+
`;
|
|
116
|
+
const colResult = await adapter.executeQuery(colQuery, [
|
|
117
|
+
schemaName,
|
|
118
|
+
table,
|
|
119
|
+
]);
|
|
120
|
+
const nonGeomCols = (colResult.rows ?? [])
|
|
121
|
+
.map((row) => sanitizeIdentifier(String(row["column_name"])))
|
|
122
|
+
.join(", ");
|
|
123
|
+
// Select non-geometry columns + readable geometry representation
|
|
124
|
+
const selectCols = nonGeomCols.length > 0
|
|
125
|
+
? `${nonGeomCols}, ST_AsText(${columnName}) as geometry_text`
|
|
126
|
+
: `ST_AsText(${columnName}) as geometry_text`;
|
|
127
|
+
const sql = `SELECT ${selectCols}
|
|
128
|
+
FROM ${tableName}
|
|
129
|
+
WHERE ST_Contains(${columnName}, ST_SetSRID(ST_MakePoint($1, $2), 4326))`;
|
|
130
|
+
const result = await adapter.executeQuery(sql, [point.lng, point.lat]);
|
|
131
|
+
const response = {
|
|
132
|
+
containingPolygons: result.rows,
|
|
133
|
+
count: result.rows?.length ?? 0,
|
|
134
|
+
};
|
|
135
|
+
// Add warning if geometry type is not polygon
|
|
136
|
+
if (!isPolygonType && geomType !== undefined) {
|
|
137
|
+
response["warning"] =
|
|
138
|
+
`Column "${column}" contains ${geomType} geometries, not polygons. ST_Contains requires polygons to produce meaningful results.`;
|
|
139
|
+
}
|
|
140
|
+
return response;
|
|
141
|
+
},
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
export function createDistanceTool(adapter) {
|
|
145
|
+
return {
|
|
146
|
+
name: "pg_distance",
|
|
147
|
+
description: "Find nearby geometries within a distance from a point. Output distance_meters is always in meters; unit parameter only affects the filter threshold.",
|
|
148
|
+
group: "postgis",
|
|
149
|
+
inputSchema: GeometryDistanceSchemaBase, // Base schema for MCP visibility
|
|
150
|
+
annotations: readOnly("Distance Search"),
|
|
151
|
+
icons: getToolIcons("postgis", readOnly("Distance Search")),
|
|
152
|
+
handler: async (params, _context) => {
|
|
153
|
+
const { table, column, point, limit, maxDistance, schema } = GeometryDistanceSchema.parse(params);
|
|
154
|
+
const schemaName = schema ?? "public";
|
|
155
|
+
const tableName = sanitizeTableName(table, schemaName !== "public" ? schemaName : undefined);
|
|
156
|
+
const columnName = sanitizeIdentifier(column);
|
|
157
|
+
const limitVal = limit ?? 10;
|
|
158
|
+
const distanceFilter = maxDistance !== undefined && maxDistance > 0
|
|
159
|
+
? `WHERE distance_meters <= ${String(maxDistance)}`
|
|
160
|
+
: "";
|
|
161
|
+
// Get non-geometry columns to avoid returning raw WKB
|
|
162
|
+
const colQuery = `
|
|
163
|
+
SELECT column_name FROM information_schema.columns
|
|
164
|
+
WHERE table_schema = $1 AND table_name = $2
|
|
165
|
+
AND udt_name NOT IN ('geometry', 'geography')
|
|
166
|
+
ORDER BY ordinal_position
|
|
167
|
+
`;
|
|
168
|
+
const colResult = await adapter.executeQuery(colQuery, [
|
|
169
|
+
schemaName,
|
|
170
|
+
table,
|
|
171
|
+
]);
|
|
172
|
+
const nonGeomCols = (colResult.rows ?? [])
|
|
173
|
+
.map((row) => sanitizeIdentifier(String(row["column_name"])))
|
|
174
|
+
.join(", ");
|
|
175
|
+
// Select non-geometry columns + readable geometry representation + distance
|
|
176
|
+
const selectCols = nonGeomCols.length > 0
|
|
177
|
+
? `${nonGeomCols}, ST_AsText(${columnName}) as geometry_text, ST_Distance(${columnName}::geography, ST_SetSRID(ST_MakePoint($1, $2), 4326)::geography) as distance_meters`
|
|
178
|
+
: `ST_AsText(${columnName}) as geometry_text, ST_Distance(${columnName}::geography, ST_SetSRID(ST_MakePoint($1, $2), 4326)::geography) as distance_meters`;
|
|
179
|
+
// Use CTE for consistent distance calculation and filtering
|
|
180
|
+
const sql = `WITH distances AS (
|
|
181
|
+
SELECT ${selectCols}
|
|
182
|
+
FROM ${tableName}
|
|
183
|
+
)
|
|
184
|
+
SELECT * FROM distances
|
|
185
|
+
${distanceFilter}
|
|
186
|
+
ORDER BY distance_meters
|
|
187
|
+
LIMIT ${String(limitVal)}`;
|
|
188
|
+
const result = await adapter.executeQuery(sql, [point.lng, point.lat]);
|
|
189
|
+
return { results: result.rows, count: result.rows?.length ?? 0 };
|
|
190
|
+
},
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
export function createBufferTool(adapter) {
|
|
194
|
+
return {
|
|
195
|
+
name: "pg_buffer",
|
|
196
|
+
description: "Create a buffer zone around geometries. Default limit: 50 rows, default simplify: 10m (set simplify: 0 to disable). Simplification reduces polygon point count for LLM-friendly payloads.",
|
|
197
|
+
group: "postgis",
|
|
198
|
+
inputSchema: BufferSchemaBase, // Base schema for MCP visibility
|
|
199
|
+
annotations: readOnly("Buffer Zone"),
|
|
200
|
+
icons: getToolIcons("postgis", readOnly("Buffer Zone")),
|
|
201
|
+
handler: async (params, _context) => {
|
|
202
|
+
const parsed = BufferSchema.parse(params ?? {});
|
|
203
|
+
const whereClause = parsed.where !== undefined ? ` WHERE ${parsed.where}` : "";
|
|
204
|
+
const schemaName = parsed.schema ?? "public";
|
|
205
|
+
const qualifiedTable = sanitizeTableName(parsed.table, schemaName !== "public" ? schemaName : undefined);
|
|
206
|
+
const columnName = sanitizeIdentifier(parsed.column);
|
|
207
|
+
// Default limit of 50 to prevent large payloads, use limit: 0 for all
|
|
208
|
+
const effectiveLimit = parsed.limit ?? 50;
|
|
209
|
+
// Get non-geometry columns to avoid returning raw WKB
|
|
210
|
+
const colQuery = `
|
|
211
|
+
SELECT column_name FROM information_schema.columns
|
|
212
|
+
WHERE table_schema = $1 AND table_name = $2
|
|
213
|
+
AND udt_name NOT IN ('geometry', 'geography')
|
|
214
|
+
ORDER BY ordinal_position
|
|
215
|
+
`;
|
|
216
|
+
const colResult = await adapter.executeQuery(colQuery, [
|
|
217
|
+
schemaName,
|
|
218
|
+
parsed.table,
|
|
219
|
+
]);
|
|
220
|
+
const nonGeomCols = (colResult.rows ?? [])
|
|
221
|
+
.map((row) => sanitizeIdentifier(String(row["column_name"])))
|
|
222
|
+
.join(", ");
|
|
223
|
+
// Default simplify of 10m reduces polygon points for LLM-friendly payloads
|
|
224
|
+
// User can set simplify: 0 to disable or higher values for more aggressive reduction
|
|
225
|
+
const effectiveSimplify = parsed.simplify ?? 10;
|
|
226
|
+
// Build buffer expression with simplification (applied by default)
|
|
227
|
+
let bufferExpr = `ST_Buffer(${columnName}::geography, $1)::geometry`;
|
|
228
|
+
if (effectiveSimplify > 0) {
|
|
229
|
+
// SimplifyPreserveTopology maintains valid geometries
|
|
230
|
+
bufferExpr = `ST_SimplifyPreserveTopology(${bufferExpr}, ${String(effectiveSimplify)})`;
|
|
231
|
+
}
|
|
232
|
+
// Select non-geometry columns + readable geometry representations
|
|
233
|
+
const selectCols = nonGeomCols.length > 0
|
|
234
|
+
? `${nonGeomCols}, ST_AsText(${columnName}) as geometry_text, ST_AsGeoJSON(${bufferExpr}) as buffer_geojson`
|
|
235
|
+
: `ST_AsText(${columnName}) as geometry_text, ST_AsGeoJSON(${bufferExpr}) as buffer_geojson`;
|
|
236
|
+
const limitClause = effectiveLimit > 0 ? ` LIMIT ${String(effectiveLimit)}` : "";
|
|
237
|
+
const sql = `SELECT ${selectCols} FROM ${qualifiedTable}${whereClause}${limitClause}`;
|
|
238
|
+
const result = await adapter.executeQuery(sql, [parsed.distance]);
|
|
239
|
+
// Build response with truncation indicators if default limit was applied
|
|
240
|
+
const response = { results: result.rows };
|
|
241
|
+
// When using default limit, check if more rows exist
|
|
242
|
+
if (parsed.limit === undefined && effectiveLimit > 0) {
|
|
243
|
+
const countSql = `SELECT COUNT(*) as cnt FROM ${qualifiedTable}${whereClause}`;
|
|
244
|
+
const countResult = await adapter.executeQuery(countSql);
|
|
245
|
+
const totalCount = Number(countResult.rows?.[0]?.["cnt"] ?? 0);
|
|
246
|
+
if (totalCount > effectiveLimit) {
|
|
247
|
+
response["truncated"] = true;
|
|
248
|
+
response["totalCount"] = totalCount;
|
|
249
|
+
response["limit"] = effectiveLimit;
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
// Add simplify indicator if simplification was applied
|
|
253
|
+
if (effectiveSimplify > 0) {
|
|
254
|
+
response["simplified"] = true;
|
|
255
|
+
response["simplifyTolerance"] = effectiveSimplify;
|
|
256
|
+
}
|
|
257
|
+
return response;
|
|
258
|
+
},
|
|
259
|
+
};
|
|
260
|
+
}
|
|
261
|
+
export function createIntersectionTool(adapter) {
|
|
262
|
+
return {
|
|
263
|
+
name: "pg_intersection",
|
|
264
|
+
description: "Find geometries that intersect with a given geometry. Auto-detects SRID from target column if not specified.",
|
|
265
|
+
group: "postgis",
|
|
266
|
+
inputSchema: IntersectionSchemaBase, // Base schema for MCP visibility
|
|
267
|
+
annotations: readOnly("Intersection Search"),
|
|
268
|
+
icons: getToolIcons("postgis", readOnly("Intersection Search")),
|
|
269
|
+
handler: async (params, _context) => {
|
|
270
|
+
const parsed = IntersectionSchema.parse(params ?? {});
|
|
271
|
+
const schemaName = parsed.schema ?? "public";
|
|
272
|
+
const qualifiedTable = sanitizeTableName(parsed.table, schemaName !== "public" ? schemaName : undefined);
|
|
273
|
+
const columnName = sanitizeIdentifier(parsed.column);
|
|
274
|
+
// Build select columns - user-specified or non-geometry columns to avoid raw WKB
|
|
275
|
+
let selectCols;
|
|
276
|
+
if (parsed.select !== undefined && parsed.select.length > 0) {
|
|
277
|
+
selectCols = parsed.select.map((c) => sanitizeIdentifier(c)).join(", ");
|
|
278
|
+
}
|
|
279
|
+
else {
|
|
280
|
+
// Get non-geometry columns to avoid returning raw WKB
|
|
281
|
+
const colQuery = `
|
|
282
|
+
SELECT column_name FROM information_schema.columns
|
|
283
|
+
WHERE table_schema = $1 AND table_name = $2
|
|
284
|
+
AND udt_name NOT IN ('geometry', 'geography')
|
|
285
|
+
ORDER BY ordinal_position
|
|
286
|
+
`;
|
|
287
|
+
const colResult = await adapter.executeQuery(colQuery, [
|
|
288
|
+
schemaName,
|
|
289
|
+
parsed.table,
|
|
290
|
+
]);
|
|
291
|
+
const nonGeomCols = (colResult.rows ?? [])
|
|
292
|
+
.map((row) => sanitizeIdentifier(String(row["column_name"])))
|
|
293
|
+
.join(", ");
|
|
294
|
+
selectCols =
|
|
295
|
+
nonGeomCols.length > 0
|
|
296
|
+
? `${nonGeomCols}, ST_AsText(${columnName}) as geometry_text`
|
|
297
|
+
: `ST_AsText(${columnName}) as geometry_text`;
|
|
298
|
+
}
|
|
299
|
+
const isGeoJson = parsed.geometry.trim().startsWith("{");
|
|
300
|
+
// Auto-detect SRID from column if not provided and using WKT
|
|
301
|
+
let srid = parsed.srid;
|
|
302
|
+
if (!isGeoJson && srid === undefined) {
|
|
303
|
+
// Query the column's SRID from geometry_columns or geography_columns
|
|
304
|
+
const sridQuery = `
|
|
305
|
+
SELECT srid FROM geometry_columns
|
|
306
|
+
WHERE f_table_schema = $1 AND f_table_name = $2 AND f_geometry_column = $3
|
|
307
|
+
UNION
|
|
308
|
+
SELECT srid FROM geography_columns
|
|
309
|
+
WHERE f_table_schema = $1 AND f_table_name = $2 AND f_geography_column = $3
|
|
310
|
+
LIMIT 1
|
|
311
|
+
`;
|
|
312
|
+
const sridResult = await adapter.executeQuery(sridQuery, [
|
|
313
|
+
schemaName,
|
|
314
|
+
parsed.table,
|
|
315
|
+
parsed.column,
|
|
316
|
+
]);
|
|
317
|
+
const sridValue = sridResult.rows?.[0]?.["srid"];
|
|
318
|
+
if (sridValue !== undefined && sridValue !== null) {
|
|
319
|
+
srid = Number(sridValue);
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
// Build geometry expression with SRID if available
|
|
323
|
+
let geomExpr;
|
|
324
|
+
if (isGeoJson) {
|
|
325
|
+
geomExpr = `ST_GeomFromGeoJSON($1)`;
|
|
326
|
+
}
|
|
327
|
+
else if (srid !== undefined) {
|
|
328
|
+
geomExpr = `ST_SetSRID(ST_GeomFromText($1), ${String(srid)})`;
|
|
329
|
+
}
|
|
330
|
+
else {
|
|
331
|
+
geomExpr = `ST_GeomFromText($1)`;
|
|
332
|
+
}
|
|
333
|
+
const sql = `SELECT ${selectCols}
|
|
334
|
+
FROM ${qualifiedTable}
|
|
335
|
+
WHERE ST_Intersects(${columnName}, ${geomExpr})`;
|
|
336
|
+
const result = await adapter.executeQuery(sql, [parsed.geometry]);
|
|
337
|
+
return {
|
|
338
|
+
intersecting: result.rows,
|
|
339
|
+
count: result.rows?.length ?? 0,
|
|
340
|
+
sridUsed: srid ?? "none (explicit SRID in geometry or GeoJSON)",
|
|
341
|
+
};
|
|
342
|
+
},
|
|
343
|
+
};
|
|
344
|
+
}
|
|
345
|
+
export function createBoundingBoxTool(adapter) {
|
|
346
|
+
return {
|
|
347
|
+
name: "pg_bounding_box",
|
|
348
|
+
description: "Find geometries within a bounding box. Swapped min/max values are auto-corrected.",
|
|
349
|
+
group: "postgis",
|
|
350
|
+
inputSchema: BoundingBoxSchemaBase, // Base schema for MCP visibility
|
|
351
|
+
annotations: readOnly("Bounding Box Search"),
|
|
352
|
+
icons: getToolIcons("postgis", readOnly("Bounding Box Search")),
|
|
353
|
+
handler: async (params, _context) => {
|
|
354
|
+
const parsed = BoundingBoxSchema.parse(params ?? {});
|
|
355
|
+
const schemaName = parsed.schema ?? "public";
|
|
356
|
+
const qualifiedTable = sanitizeTableName(parsed.table, schemaName !== "public" ? schemaName : undefined);
|
|
357
|
+
const columnName = sanitizeIdentifier(parsed.column);
|
|
358
|
+
// Build select columns - user-specified or non-geometry columns to avoid raw WKB
|
|
359
|
+
let selectCols;
|
|
360
|
+
if (parsed.select !== undefined && parsed.select.length > 0) {
|
|
361
|
+
selectCols = parsed.select.map((c) => sanitizeIdentifier(c)).join(", ");
|
|
362
|
+
}
|
|
363
|
+
else {
|
|
364
|
+
// Get non-geometry columns to avoid returning raw WKB
|
|
365
|
+
const colQuery = `
|
|
366
|
+
SELECT column_name FROM information_schema.columns
|
|
367
|
+
WHERE table_schema = $1 AND table_name = $2
|
|
368
|
+
AND udt_name NOT IN ('geometry', 'geography')
|
|
369
|
+
ORDER BY ordinal_position
|
|
370
|
+
`;
|
|
371
|
+
const colResult = await adapter.executeQuery(colQuery, [
|
|
372
|
+
schemaName,
|
|
373
|
+
parsed.table,
|
|
374
|
+
]);
|
|
375
|
+
selectCols = (colResult.rows ?? [])
|
|
376
|
+
.map((row) => sanitizeIdentifier(String(row["column_name"])))
|
|
377
|
+
.join(", ");
|
|
378
|
+
}
|
|
379
|
+
// Auto-correct swapped bounds
|
|
380
|
+
const corrections = [];
|
|
381
|
+
let actualMinLng = parsed.minLng;
|
|
382
|
+
let actualMaxLng = parsed.maxLng;
|
|
383
|
+
let actualMinLat = parsed.minLat;
|
|
384
|
+
let actualMaxLat = parsed.maxLat;
|
|
385
|
+
if (parsed.minLng > parsed.maxLng) {
|
|
386
|
+
actualMinLng = parsed.maxLng;
|
|
387
|
+
actualMaxLng = parsed.minLng;
|
|
388
|
+
corrections.push("minLng/maxLng were swapped");
|
|
389
|
+
}
|
|
390
|
+
if (parsed.minLat > parsed.maxLat) {
|
|
391
|
+
actualMinLat = parsed.maxLat;
|
|
392
|
+
actualMaxLat = parsed.minLat;
|
|
393
|
+
corrections.push("minLat/maxLat were swapped");
|
|
394
|
+
}
|
|
395
|
+
const sql = `SELECT ${selectCols}, ST_AsText(${columnName}) as geometry_text
|
|
396
|
+
FROM ${qualifiedTable}
|
|
397
|
+
WHERE ${columnName} && ST_MakeEnvelope($1, $2, $3, $4, 4326)`;
|
|
398
|
+
const result = await adapter.executeQuery(sql, [
|
|
399
|
+
actualMinLng,
|
|
400
|
+
actualMinLat,
|
|
401
|
+
actualMaxLng,
|
|
402
|
+
actualMaxLat,
|
|
403
|
+
]);
|
|
404
|
+
const response = {
|
|
405
|
+
results: result.rows,
|
|
406
|
+
count: result.rows?.length ?? 0,
|
|
407
|
+
};
|
|
408
|
+
if (corrections.length > 0) {
|
|
409
|
+
response["note"] = `Auto-corrected: ${corrections.join(", ")}`;
|
|
410
|
+
}
|
|
411
|
+
return response;
|
|
412
|
+
},
|
|
413
|
+
};
|
|
414
|
+
}
|
|
415
|
+
export function createSpatialIndexTool(adapter) {
|
|
416
|
+
return {
|
|
417
|
+
name: "pg_spatial_index",
|
|
418
|
+
description: "Create a GiST spatial index for geometry column. Uses IF NOT EXISTS to avoid errors on duplicate names.",
|
|
419
|
+
group: "postgis",
|
|
420
|
+
inputSchema: SpatialIndexSchemaBase, // Base schema for MCP visibility
|
|
421
|
+
annotations: write("Create Spatial Index"),
|
|
422
|
+
icons: getToolIcons("postgis", write("Create Spatial Index")),
|
|
423
|
+
handler: async (params, _context) => {
|
|
424
|
+
const { table, column, name, ifNotExists, schema } = SpatialIndexSchema.parse(params);
|
|
425
|
+
const schemaName = schema ?? "public";
|
|
426
|
+
const indexNameRaw = name ?? `idx_${table}_${column}_gist`;
|
|
427
|
+
// Check if index already exists (for accurate response message)
|
|
428
|
+
const checkSql = `SELECT EXISTS(SELECT 1 FROM pg_indexes WHERE schemaname = $1 AND indexname = $2) as exists`;
|
|
429
|
+
const checkResult = await adapter.executeQuery(checkSql, [
|
|
430
|
+
schemaName,
|
|
431
|
+
indexNameRaw,
|
|
432
|
+
]);
|
|
433
|
+
const indexExists = checkResult.rows?.[0]?.["exists"];
|
|
434
|
+
if (indexExists) {
|
|
435
|
+
if (ifNotExists === true) {
|
|
436
|
+
return {
|
|
437
|
+
success: true,
|
|
438
|
+
alreadyExists: true,
|
|
439
|
+
index: indexNameRaw,
|
|
440
|
+
table,
|
|
441
|
+
column,
|
|
442
|
+
};
|
|
443
|
+
}
|
|
444
|
+
// Use IF NOT EXISTS to return friendly message instead of PostgreSQL error
|
|
445
|
+
return {
|
|
446
|
+
success: true,
|
|
447
|
+
alreadyExists: true,
|
|
448
|
+
index: indexNameRaw,
|
|
449
|
+
table,
|
|
450
|
+
column,
|
|
451
|
+
note: "Index already exists. Use ifNotExists: true to suppress this note.",
|
|
452
|
+
};
|
|
453
|
+
}
|
|
454
|
+
const qualifiedTable = sanitizeTableName(table, schemaName !== "public" ? schemaName : undefined);
|
|
455
|
+
const columnName = sanitizeIdentifier(column);
|
|
456
|
+
const indexName = sanitizeIdentifier(indexNameRaw);
|
|
457
|
+
// Check if table exists before trying to create index
|
|
458
|
+
const tableCheckSql = `SELECT 1 FROM information_schema.tables WHERE table_schema = $1 AND table_name = $2`;
|
|
459
|
+
const tableCheckResult = await adapter.executeQuery(tableCheckSql, [
|
|
460
|
+
schemaName,
|
|
461
|
+
table,
|
|
462
|
+
]);
|
|
463
|
+
if ((tableCheckResult.rows?.length ?? 0) === 0) {
|
|
464
|
+
return {
|
|
465
|
+
success: false,
|
|
466
|
+
error: `Table "${table}" does not exist in schema "${schemaName}".`,
|
|
467
|
+
table,
|
|
468
|
+
schema: schemaName,
|
|
469
|
+
suggestion: "Create the table first, then add the spatial index.",
|
|
470
|
+
};
|
|
471
|
+
}
|
|
472
|
+
// Always use IF NOT EXISTS to prevent unclear PostgreSQL errors
|
|
473
|
+
const sql = `CREATE INDEX IF NOT EXISTS ${indexName} ON ${qualifiedTable} USING GIST (${columnName})`;
|
|
474
|
+
await adapter.executeQuery(sql);
|
|
475
|
+
return { success: true, index: indexNameRaw, table, column };
|
|
476
|
+
},
|
|
477
|
+
};
|
|
478
|
+
}
|
|
479
|
+
//# sourceMappingURL=basic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"basic.js","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/postgis/basic.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL PostGIS Extension Tools
|
|
3
|
+
*
|
|
4
|
+
* Geospatial operations and spatial queries.
|
|
5
|
+
* 15 tools total.
|
|
6
|
+
*/
|
|
7
|
+
import type { PostgresAdapter } from "../../PostgresAdapter.js";
|
|
8
|
+
import type { ToolDefinition } from "../../../../types/index.js";
|
|
9
|
+
import { createPostgisExtensionTool, createGeometryColumnTool, createPointInPolygonTool, createDistanceTool, createBufferTool, createIntersectionTool, createBoundingBoxTool, createSpatialIndexTool } from "./basic.js";
|
|
10
|
+
import { createGeocodeTool, createGeoTransformTool, createGeoIndexOptimizeTool, createGeoClusterTool } from "./advanced.js";
|
|
11
|
+
import { createGeometryBufferTool, createGeometryIntersectionTool, createGeometryTransformTool } from "./standalone.js";
|
|
12
|
+
/**
|
|
13
|
+
* Get all PostGIS tools
|
|
14
|
+
*/
|
|
15
|
+
export declare function getPostgisTools(adapter: PostgresAdapter): ToolDefinition[];
|
|
16
|
+
export { createPostgisExtensionTool, createGeometryColumnTool, createPointInPolygonTool, createDistanceTool, createBufferTool, createIntersectionTool, createBoundingBoxTool, createSpatialIndexTool, createGeocodeTool, createGeoTransformTool, createGeoIndexOptimizeTool, createGeoClusterTool, createGeometryBufferTool, createGeometryIntersectionTool, createGeometryTransformTool, };
|
|
17
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/postgis/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAGjE,OAAO,EACL,0BAA0B,EAC1B,wBAAwB,EACxB,wBAAwB,EACxB,kBAAkB,EAClB,gBAAgB,EAChB,sBAAsB,EACtB,qBAAqB,EACrB,sBAAsB,EACvB,MAAM,YAAY,CAAC;AAGpB,OAAO,EACL,iBAAiB,EACjB,sBAAsB,EACtB,0BAA0B,EAC1B,oBAAoB,EACrB,MAAM,eAAe,CAAC;AAGvB,OAAO,EACL,wBAAwB,EACxB,8BAA8B,EAC9B,2BAA2B,EAC5B,MAAM,iBAAiB,CAAC;AAEzB;;GAEG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,eAAe,GAAG,cAAc,EAAE,CAqB1E;AAGD,OAAO,EAEL,0BAA0B,EAC1B,wBAAwB,EACxB,wBAAwB,EACxB,kBAAkB,EAClB,gBAAgB,EAChB,sBAAsB,EACtB,qBAAqB,EACrB,sBAAsB,EAEtB,iBAAiB,EACjB,sBAAsB,EACtB,0BAA0B,EAC1B,oBAAoB,EAEpB,wBAAwB,EACxB,8BAA8B,EAC9B,2BAA2B,GAC5B,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL PostGIS Extension Tools
|
|
3
|
+
*
|
|
4
|
+
* Geospatial operations and spatial queries.
|
|
5
|
+
* 15 tools total.
|
|
6
|
+
*/
|
|
7
|
+
// Basic spatial operations
|
|
8
|
+
import { createPostgisExtensionTool, createGeometryColumnTool, createPointInPolygonTool, createDistanceTool, createBufferTool, createIntersectionTool, createBoundingBoxTool, createSpatialIndexTool, } from "./basic.js";
|
|
9
|
+
// Advanced spatial operations
|
|
10
|
+
import { createGeocodeTool, createGeoTransformTool, createGeoIndexOptimizeTool, createGeoClusterTool, } from "./advanced.js";
|
|
11
|
+
// Standalone geometry operations (WKT/GeoJSON input)
|
|
12
|
+
import { createGeometryBufferTool, createGeometryIntersectionTool, createGeometryTransformTool, } from "./standalone.js";
|
|
13
|
+
/**
|
|
14
|
+
* Get all PostGIS tools
|
|
15
|
+
*/
|
|
16
|
+
export function getPostgisTools(adapter) {
|
|
17
|
+
return [
|
|
18
|
+
// Basic table-based tools
|
|
19
|
+
createPostgisExtensionTool(adapter),
|
|
20
|
+
createGeometryColumnTool(adapter),
|
|
21
|
+
createPointInPolygonTool(adapter),
|
|
22
|
+
createDistanceTool(adapter),
|
|
23
|
+
createBufferTool(adapter),
|
|
24
|
+
createIntersectionTool(adapter),
|
|
25
|
+
createBoundingBoxTool(adapter),
|
|
26
|
+
createSpatialIndexTool(adapter),
|
|
27
|
+
// Advanced table-based tools
|
|
28
|
+
createGeocodeTool(adapter),
|
|
29
|
+
createGeoTransformTool(adapter),
|
|
30
|
+
createGeoIndexOptimizeTool(adapter),
|
|
31
|
+
createGeoClusterTool(adapter),
|
|
32
|
+
// Standalone geometry tools (WKT/GeoJSON input)
|
|
33
|
+
createGeometryBufferTool(adapter),
|
|
34
|
+
createGeometryIntersectionTool(adapter),
|
|
35
|
+
createGeometryTransformTool(adapter),
|
|
36
|
+
];
|
|
37
|
+
}
|
|
38
|
+
// Re-export individual tool creators
|
|
39
|
+
export {
|
|
40
|
+
// Basic
|
|
41
|
+
createPostgisExtensionTool, createGeometryColumnTool, createPointInPolygonTool, createDistanceTool, createBufferTool, createIntersectionTool, createBoundingBoxTool, createSpatialIndexTool,
|
|
42
|
+
// Advanced
|
|
43
|
+
createGeocodeTool, createGeoTransformTool, createGeoIndexOptimizeTool, createGeoClusterTool,
|
|
44
|
+
// Standalone
|
|
45
|
+
createGeometryBufferTool, createGeometryIntersectionTool, createGeometryTransformTool, };
|
|
46
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/postgis/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,2BAA2B;AAC3B,OAAO,EACL,0BAA0B,EAC1B,wBAAwB,EACxB,wBAAwB,EACxB,kBAAkB,EAClB,gBAAgB,EAChB,sBAAsB,EACtB,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,YAAY,CAAC;AAEpB,8BAA8B;AAC9B,OAAO,EACL,iBAAiB,EACjB,sBAAsB,EACtB,0BAA0B,EAC1B,oBAAoB,GACrB,MAAM,eAAe,CAAC;AAEvB,qDAAqD;AACrD,OAAO,EACL,wBAAwB,EACxB,8BAA8B,EAC9B,2BAA2B,GAC5B,MAAM,iBAAiB,CAAC;AAEzB;;GAEG;AACH,MAAM,UAAU,eAAe,CAAC,OAAwB;IACtD,OAAO;QACL,0BAA0B;QAC1B,0BAA0B,CAAC,OAAO,CAAC;QACnC,wBAAwB,CAAC,OAAO,CAAC;QACjC,wBAAwB,CAAC,OAAO,CAAC;QACjC,kBAAkB,CAAC,OAAO,CAAC;QAC3B,gBAAgB,CAAC,OAAO,CAAC;QACzB,sBAAsB,CAAC,OAAO,CAAC;QAC/B,qBAAqB,CAAC,OAAO,CAAC;QAC9B,sBAAsB,CAAC,OAAO,CAAC;QAC/B,6BAA6B;QAC7B,iBAAiB,CAAC,OAAO,CAAC;QAC1B,sBAAsB,CAAC,OAAO,CAAC;QAC/B,0BAA0B,CAAC,OAAO,CAAC;QACnC,oBAAoB,CAAC,OAAO,CAAC;QAC7B,gDAAgD;QAChD,wBAAwB,CAAC,OAAO,CAAC;QACjC,8BAA8B,CAAC,OAAO,CAAC;QACvC,2BAA2B,CAAC,OAAO,CAAC;KACrC,CAAC;AACJ,CAAC;AAED,qCAAqC;AACrC,OAAO;AACL,QAAQ;AACR,0BAA0B,EAC1B,wBAAwB,EACxB,wBAAwB,EACxB,kBAAkB,EAClB,gBAAgB,EAChB,sBAAsB,EACtB,qBAAqB,EACrB,sBAAsB;AACtB,WAAW;AACX,iBAAiB,EACjB,sBAAsB,EACtB,0BAA0B,EAC1B,oBAAoB;AACpB,aAAa;AACb,wBAAwB,EACxB,8BAA8B,EAC9B,2BAA2B,GAC5B,CAAC"}
|