@neverinfamous/postgres-mcp 2.0.0 → 2.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/README.md +119 -46
- package/dist/__tests__/benchmarks/codemode.bench.js +3 -3
- package/dist/__tests__/benchmarks/codemode.bench.js.map +1 -1
- package/dist/__tests__/benchmarks/connection-pool.bench.js +3 -3
- package/dist/__tests__/benchmarks/connection-pool.bench.js.map +1 -1
- package/dist/__tests__/benchmarks/introspection-migration.bench.d.ts +11 -0
- package/dist/__tests__/benchmarks/introspection-migration.bench.d.ts.map +1 -0
- package/dist/__tests__/benchmarks/introspection-migration.bench.js +143 -0
- package/dist/__tests__/benchmarks/introspection-migration.bench.js.map +1 -0
- package/dist/__tests__/benchmarks/resource-prompts.bench.js +0 -64
- package/dist/__tests__/benchmarks/resource-prompts.bench.js.map +1 -1
- package/dist/__tests__/benchmarks/schema-parsing.bench.js +5 -5
- package/dist/__tests__/benchmarks/schema-parsing.bench.js.map +1 -1
- package/dist/__tests__/benchmarks/tool-filtering.bench.js +17 -8
- package/dist/__tests__/benchmarks/tool-filtering.bench.js.map +1 -1
- package/dist/__tests__/mocks/adapter.d.ts.map +1 -1
- package/dist/__tests__/mocks/adapter.js +2 -1
- package/dist/__tests__/mocks/adapter.js.map +1 -1
- package/dist/adapters/DatabaseAdapter.d.ts +6 -5
- package/dist/adapters/DatabaseAdapter.d.ts.map +1 -1
- package/dist/adapters/DatabaseAdapter.js +11 -20
- package/dist/adapters/DatabaseAdapter.js.map +1 -1
- package/dist/adapters/postgresql/PostgresAdapter.d.ts +5 -26
- package/dist/adapters/postgresql/PostgresAdapter.d.ts.map +1 -1
- package/dist/adapters/postgresql/PostgresAdapter.js +31 -526
- package/dist/adapters/postgresql/PostgresAdapter.js.map +1 -1
- package/dist/adapters/postgresql/prompts/index.js +1 -1
- package/dist/adapters/postgresql/prompts/index.js.map +1 -1
- package/dist/adapters/postgresql/resources/index.d.ts +1 -1
- package/dist/adapters/postgresql/resources/index.js +3 -3
- package/dist/adapters/postgresql/resources/index.js.map +1 -1
- package/dist/adapters/postgresql/schema-operations.d.ts +71 -0
- package/dist/adapters/postgresql/schema-operations.d.ts.map +1 -0
- package/dist/adapters/postgresql/schema-operations.js +561 -0
- package/dist/adapters/postgresql/schema-operations.js.map +1 -0
- package/dist/adapters/postgresql/schemas/admin.d.ts +4 -4
- package/dist/adapters/postgresql/schemas/admin.js +4 -4
- package/dist/adapters/postgresql/schemas/admin.js.map +1 -1
- package/dist/adapters/postgresql/schemas/backup.d.ts +2 -2
- package/dist/adapters/postgresql/schemas/backup.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/backup.js +1 -3
- package/dist/adapters/postgresql/schemas/backup.js.map +1 -1
- package/dist/adapters/postgresql/schemas/core/index.d.ts +6 -0
- package/dist/adapters/postgresql/schemas/core/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/core/index.js +6 -0
- package/dist/adapters/postgresql/schemas/core/index.js.map +1 -0
- package/dist/adapters/postgresql/schemas/{core.d.ts → core/queries.d.ts} +16 -171
- package/dist/adapters/postgresql/schemas/core/queries.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/{core.js → core/queries.js} +5 -213
- package/dist/adapters/postgresql/schemas/core/queries.js.map +1 -0
- package/dist/adapters/postgresql/schemas/core/transactions.d.ts +149 -0
- package/dist/adapters/postgresql/schemas/core/transactions.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/core/transactions.js +239 -0
- package/dist/adapters/postgresql/schemas/core/transactions.js.map +1 -0
- package/dist/adapters/postgresql/schemas/cron.d.ts +12 -12
- package/dist/adapters/postgresql/schemas/cron.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/cron.js +38 -10
- package/dist/adapters/postgresql/schemas/cron.js.map +1 -1
- package/dist/adapters/postgresql/schemas/extensions/citext.d.ts +222 -0
- package/dist/adapters/postgresql/schemas/extensions/citext.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/citext.js +306 -0
- package/dist/adapters/postgresql/schemas/extensions/citext.js.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/index.d.ts +15 -0
- package/dist/adapters/postgresql/schemas/extensions/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/index.js +20 -0
- package/dist/adapters/postgresql/schemas/extensions/index.js.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/kcache.d.ts +164 -0
- package/dist/adapters/postgresql/schemas/extensions/kcache.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/kcache.js +225 -0
- package/dist/adapters/postgresql/schemas/extensions/kcache.js.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/ltree.d.ts +253 -0
- package/dist/adapters/postgresql/schemas/extensions/ltree.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/ltree.js +430 -0
- package/dist/adapters/postgresql/schemas/extensions/ltree.js.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/pgcrypto.d.ts +251 -0
- package/dist/adapters/postgresql/schemas/extensions/pgcrypto.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/pgcrypto.js +294 -0
- package/dist/adapters/postgresql/schemas/extensions/pgcrypto.js.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/shared.d.ts +10 -0
- package/dist/adapters/postgresql/schemas/extensions/shared.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/extensions/shared.js +15 -0
- package/dist/adapters/postgresql/schemas/extensions/shared.js.map +1 -0
- package/dist/adapters/postgresql/schemas/index.d.ts +6 -6
- package/dist/adapters/postgresql/schemas/index.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/index.js +8 -8
- package/dist/adapters/postgresql/schemas/index.js.map +1 -1
- package/dist/adapters/postgresql/schemas/introspection.d.ts +19 -42
- package/dist/adapters/postgresql/schemas/introspection.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/introspection.js +72 -27
- package/dist/adapters/postgresql/schemas/introspection.js.map +1 -1
- package/dist/adapters/postgresql/schemas/jsonb/advanced.d.ts +270 -0
- package/dist/adapters/postgresql/schemas/jsonb/advanced.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/jsonb/advanced.js +371 -0
- package/dist/adapters/postgresql/schemas/jsonb/advanced.js.map +1 -0
- package/dist/adapters/postgresql/schemas/jsonb/basic.d.ts +283 -0
- package/dist/adapters/postgresql/schemas/jsonb/basic.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/jsonb/basic.js +456 -0
- package/dist/adapters/postgresql/schemas/jsonb/basic.js.map +1 -0
- package/dist/adapters/postgresql/schemas/jsonb/index.d.ts +6 -0
- package/dist/adapters/postgresql/schemas/jsonb/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/jsonb/index.js +6 -0
- package/dist/adapters/postgresql/schemas/jsonb/index.js.map +1 -0
- package/dist/adapters/postgresql/schemas/monitoring.d.ts +4 -4
- package/dist/adapters/postgresql/schemas/monitoring.js +2 -2
- package/dist/adapters/postgresql/schemas/monitoring.js.map +1 -1
- package/dist/adapters/postgresql/schemas/partitioning.d.ts +14 -14
- package/dist/adapters/postgresql/schemas/partitioning.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/partitioning.js +64 -46
- package/dist/adapters/postgresql/schemas/partitioning.js.map +1 -1
- package/dist/adapters/postgresql/schemas/partman.d.ts +16 -14
- package/dist/adapters/postgresql/schemas/partman.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/partman.js +9 -9
- package/dist/adapters/postgresql/schemas/partman.js.map +1 -1
- package/dist/adapters/postgresql/schemas/postgis/advanced.d.ts +429 -0
- package/dist/adapters/postgresql/schemas/postgis/advanced.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/postgis/advanced.js +495 -0
- package/dist/adapters/postgresql/schemas/postgis/advanced.js.map +1 -0
- package/dist/adapters/postgresql/schemas/{postgis.d.ts → postgis/basic.d.ts} +1 -423
- package/dist/adapters/postgresql/schemas/postgis/basic.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/{postgis.js → postgis/basic.js} +1 -486
- package/dist/adapters/postgresql/schemas/postgis/basic.js.map +1 -0
- package/dist/adapters/postgresql/schemas/postgis/index.d.ts +6 -0
- package/dist/adapters/postgresql/schemas/postgis/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/postgis/index.js +6 -0
- package/dist/adapters/postgresql/schemas/postgis/index.js.map +1 -0
- package/dist/adapters/postgresql/schemas/schema-mgmt.d.ts +35 -25
- package/dist/adapters/postgresql/schemas/schema-mgmt.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/schema-mgmt.js +57 -19
- package/dist/adapters/postgresql/schemas/schema-mgmt.js.map +1 -1
- package/dist/adapters/postgresql/schemas/stats/index.d.ts +6 -0
- package/dist/adapters/postgresql/schemas/stats/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/stats/index.js +6 -0
- package/dist/adapters/postgresql/schemas/stats/index.js.map +1 -0
- package/dist/adapters/postgresql/schemas/stats/input.d.ts +260 -0
- package/dist/adapters/postgresql/schemas/stats/input.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/{stats.js → stats/input.js} +2 -331
- package/dist/adapters/postgresql/schemas/stats/input.js.map +1 -0
- package/dist/adapters/postgresql/schemas/{stats.d.ts → stats/output.d.ts} +3 -246
- package/dist/adapters/postgresql/schemas/stats/output.d.ts.map +1 -0
- package/dist/adapters/postgresql/schemas/stats/output.js +334 -0
- package/dist/adapters/postgresql/schemas/stats/output.js.map +1 -0
- package/dist/adapters/postgresql/schemas/text-search.d.ts +18 -18
- package/dist/adapters/postgresql/schemas/text-search.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/text-search.js +12 -27
- package/dist/adapters/postgresql/schemas/text-search.js.map +1 -1
- package/dist/adapters/postgresql/schemas/vector.d.ts +10 -10
- package/dist/adapters/postgresql/schemas/vector.d.ts.map +1 -1
- package/dist/adapters/postgresql/schemas/vector.js +9 -15
- package/dist/adapters/postgresql/schemas/vector.js.map +1 -1
- package/dist/adapters/postgresql/tools/backup/dump.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/backup/dump.js +95 -76
- package/dist/adapters/postgresql/tools/backup/dump.js.map +1 -1
- package/dist/adapters/postgresql/tools/backup/planning.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/backup/planning.js +345 -287
- package/dist/adapters/postgresql/tools/backup/planning.js.map +1 -1
- package/dist/adapters/postgresql/tools/citext/analysis.d.ts +24 -0
- package/dist/adapters/postgresql/tools/citext/analysis.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/{citext.js → citext/analysis.js} +50 -232
- package/dist/adapters/postgresql/tools/citext/analysis.js.map +1 -0
- package/dist/adapters/postgresql/tools/citext/index.d.ts +15 -0
- package/dist/adapters/postgresql/tools/citext/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/citext/index.js +23 -0
- package/dist/adapters/postgresql/tools/citext/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/citext/setup.d.ts +16 -0
- package/dist/adapters/postgresql/tools/citext/setup.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/citext/setup.js +193 -0
- package/dist/adapters/postgresql/tools/citext/setup.js.map +1 -0
- package/dist/adapters/postgresql/tools/codemode/index.js +1 -1
- package/dist/adapters/postgresql/tools/codemode/index.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/convenience.d.ts +12 -22
- package/dist/adapters/postgresql/tools/core/convenience.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/convenience.js +100 -210
- package/dist/adapters/postgresql/tools/core/convenience.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/error-helpers.d.ts +1 -0
- package/dist/adapters/postgresql/tools/core/error-helpers.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/error-helpers.js +8 -1
- package/dist/adapters/postgresql/tools/core/error-helpers.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/health.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/health.js +124 -114
- package/dist/adapters/postgresql/tools/core/health.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/index.d.ts +2 -1
- package/dist/adapters/postgresql/tools/core/index.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/index.js +3 -2
- package/dist/adapters/postgresql/tools/core/index.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/indexes.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/indexes.js +151 -127
- package/dist/adapters/postgresql/tools/core/indexes.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/objects.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/objects.js +186 -161
- package/dist/adapters/postgresql/tools/core/objects.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/query.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/query.js +37 -25
- package/dist/adapters/postgresql/tools/core/query.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/schemas.d.ts +6 -3
- package/dist/adapters/postgresql/tools/core/schemas.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/schemas.js +11 -2
- package/dist/adapters/postgresql/tools/core/schemas.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/tables.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/core/tables.js +156 -129
- package/dist/adapters/postgresql/tools/core/tables.js.map +1 -1
- package/dist/adapters/postgresql/tools/core/utility.d.ts +26 -0
- package/dist/adapters/postgresql/tools/core/utility.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/core/utility.js +174 -0
- package/dist/adapters/postgresql/tools/core/utility.js.map +1 -0
- package/dist/adapters/postgresql/tools/cron.js +90 -43
- package/dist/adapters/postgresql/tools/cron.js.map +1 -1
- package/dist/adapters/postgresql/tools/introspection/analysis.d.ts +12 -0
- package/dist/adapters/postgresql/tools/introspection/analysis.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/introspection/analysis.js +605 -0
- package/dist/adapters/postgresql/tools/introspection/analysis.js.map +1 -0
- package/dist/adapters/postgresql/tools/introspection/graph.d.ts +55 -0
- package/dist/adapters/postgresql/tools/introspection/graph.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/introspection/graph.js +621 -0
- package/dist/adapters/postgresql/tools/introspection/graph.js.map +1 -0
- package/dist/adapters/postgresql/tools/introspection/index.d.ts +21 -0
- package/dist/adapters/postgresql/tools/introspection/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/introspection/index.js +31 -0
- package/dist/adapters/postgresql/tools/introspection/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/introspection/migration.d.ts +15 -0
- package/dist/adapters/postgresql/tools/introspection/migration.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/introspection/migration.js +575 -0
- package/dist/adapters/postgresql/tools/introspection/migration.js.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/analytics.d.ts +20 -0
- package/dist/adapters/postgresql/tools/jsonb/analytics.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/analytics.js +367 -0
- package/dist/adapters/postgresql/tools/jsonb/analytics.js.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/index.d.ts +4 -2
- package/dist/adapters/postgresql/tools/jsonb/index.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/jsonb/index.js +8 -4
- package/dist/adapters/postgresql/tools/jsonb/index.js.map +1 -1
- package/dist/adapters/postgresql/tools/jsonb/read.d.ts +38 -0
- package/dist/adapters/postgresql/tools/jsonb/read.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/{basic.js → read.js} +41 -482
- package/dist/adapters/postgresql/tools/jsonb/read.js.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/{advanced.d.ts → transform.d.ts} +1 -13
- package/dist/adapters/postgresql/tools/jsonb/transform.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/{advanced.js → transform.js} +26 -357
- package/dist/adapters/postgresql/tools/jsonb/transform.js.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/write.d.ts +14 -0
- package/dist/adapters/postgresql/tools/jsonb/write.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/jsonb/write.js +468 -0
- package/dist/adapters/postgresql/tools/jsonb/write.js.map +1 -0
- package/dist/adapters/postgresql/tools/kcache.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/kcache.js +116 -51
- package/dist/adapters/postgresql/tools/kcache.js.map +1 -1
- package/dist/adapters/postgresql/tools/ltree.js +346 -260
- package/dist/adapters/postgresql/tools/ltree.js.map +1 -1
- package/dist/adapters/postgresql/tools/migration/index.d.ts +15 -0
- package/dist/adapters/postgresql/tools/migration/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/migration/index.js +23 -0
- package/dist/adapters/postgresql/tools/migration/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/monitoring/analysis.d.ts +15 -0
- package/dist/adapters/postgresql/tools/monitoring/analysis.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/{monitoring.js → monitoring/analysis.js} +24 -359
- package/dist/adapters/postgresql/tools/monitoring/analysis.js.map +1 -0
- package/dist/adapters/postgresql/tools/monitoring/basic.d.ts +17 -0
- package/dist/adapters/postgresql/tools/monitoring/basic.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/monitoring/basic.js +432 -0
- package/dist/adapters/postgresql/tools/monitoring/basic.js.map +1 -0
- package/dist/adapters/postgresql/tools/monitoring/index.d.ts +16 -0
- package/dist/adapters/postgresql/tools/monitoring/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/monitoring/index.js +31 -0
- package/dist/adapters/postgresql/tools/monitoring/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/partitioning/index.d.ts +15 -0
- package/dist/adapters/postgresql/tools/partitioning/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/partitioning/index.js +23 -0
- package/dist/adapters/postgresql/tools/partitioning/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/partitioning/info.d.ts +11 -0
- package/dist/adapters/postgresql/tools/partitioning/info.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/partitioning/info.js +302 -0
- package/dist/adapters/postgresql/tools/partitioning/info.js.map +1 -0
- package/dist/adapters/postgresql/tools/partitioning/management.d.ts +28 -0
- package/dist/adapters/postgresql/tools/partitioning/management.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/{partitioning.js → partitioning/management.js} +48 -307
- package/dist/adapters/postgresql/tools/partitioning/management.js.map +1 -0
- package/dist/adapters/postgresql/tools/partman/helpers.d.ts +29 -0
- package/dist/adapters/postgresql/tools/partman/helpers.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/partman/helpers.js +59 -0
- package/dist/adapters/postgresql/tools/partman/helpers.js.map +1 -0
- package/dist/adapters/postgresql/tools/partman/index.d.ts +2 -1
- package/dist/adapters/postgresql/tools/partman/index.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/partman/index.js +4 -2
- package/dist/adapters/postgresql/tools/partman/index.js.map +1 -1
- package/dist/adapters/postgresql/tools/partman/maintenance.d.ts +20 -0
- package/dist/adapters/postgresql/tools/partman/maintenance.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/partman/maintenance.js +496 -0
- package/dist/adapters/postgresql/tools/partman/maintenance.js.map +1 -0
- package/dist/adapters/postgresql/tools/partman/management.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/partman/management.js +438 -383
- package/dist/adapters/postgresql/tools/partman/management.js.map +1 -1
- package/dist/adapters/postgresql/tools/partman/operations.d.ts +1 -13
- package/dist/adapters/postgresql/tools/partman/operations.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/partman/operations.js +171 -652
- package/dist/adapters/postgresql/tools/partman/operations.js.map +1 -1
- package/dist/adapters/postgresql/tools/performance/analysis.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/performance/analysis.js +69 -42
- package/dist/adapters/postgresql/tools/performance/analysis.js.map +1 -1
- package/dist/adapters/postgresql/tools/performance/anomaly-detection.d.ts +18 -0
- package/dist/adapters/postgresql/tools/performance/anomaly-detection.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/performance/anomaly-detection.js +533 -0
- package/dist/adapters/postgresql/tools/performance/anomaly-detection.js.map +1 -0
- package/dist/adapters/postgresql/tools/performance/diagnostics.d.ts +11 -0
- package/dist/adapters/postgresql/tools/performance/diagnostics.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/performance/diagnostics.js +332 -0
- package/dist/adapters/postgresql/tools/performance/diagnostics.js.map +1 -0
- package/dist/adapters/postgresql/tools/performance/index.d.ts +1 -1
- package/dist/adapters/postgresql/tools/performance/index.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/performance/index.js +7 -1
- package/dist/adapters/postgresql/tools/performance/index.js.map +1 -1
- package/dist/adapters/postgresql/tools/performance/monitoring.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/performance/monitoring.js +80 -55
- package/dist/adapters/postgresql/tools/performance/monitoring.js.map +1 -1
- package/dist/adapters/postgresql/tools/performance/optimization.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/performance/optimization.js +18 -11
- package/dist/adapters/postgresql/tools/performance/optimization.js.map +1 -1
- package/dist/adapters/postgresql/tools/performance/stats.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/performance/stats.js +439 -318
- package/dist/adapters/postgresql/tools/performance/stats.js.map +1 -1
- package/dist/adapters/postgresql/tools/pgcrypto.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/pgcrypto.js +45 -77
- package/dist/adapters/postgresql/tools/pgcrypto.js.map +1 -1
- package/dist/adapters/postgresql/tools/postgis/basic.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/postgis/basic.js +121 -93
- package/dist/adapters/postgresql/tools/postgis/basic.js.map +1 -1
- package/dist/adapters/postgresql/tools/schema/index.d.ts +16 -0
- package/dist/adapters/postgresql/tools/schema/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/schema/index.js +32 -0
- package/dist/adapters/postgresql/tools/schema/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/schema/objects.d.ts +15 -0
- package/dist/adapters/postgresql/tools/schema/objects.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/schema/objects.js +378 -0
- package/dist/adapters/postgresql/tools/schema/objects.js.map +1 -0
- package/dist/adapters/postgresql/tools/schema/views.d.ts +15 -0
- package/dist/adapters/postgresql/tools/schema/views.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/{schema.js → schema/views.js} +64 -386
- package/dist/adapters/postgresql/tools/schema/views.js.map +1 -0
- package/dist/adapters/postgresql/tools/stats/advanced.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/stats/advanced.js +1 -218
- package/dist/adapters/postgresql/tools/stats/advanced.js.map +1 -1
- package/dist/adapters/postgresql/tools/stats/math-utils.d.ts +33 -0
- package/dist/adapters/postgresql/tools/stats/math-utils.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/stats/math-utils.js +225 -0
- package/dist/adapters/postgresql/tools/stats/math-utils.js.map +1 -0
- package/dist/adapters/postgresql/tools/text/index.d.ts +16 -0
- package/dist/adapters/postgresql/tools/text/index.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/text/index.js +33 -0
- package/dist/adapters/postgresql/tools/text/index.js.map +1 -0
- package/dist/adapters/postgresql/tools/text/matching.d.ts +17 -0
- package/dist/adapters/postgresql/tools/text/matching.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/text/matching.js +565 -0
- package/dist/adapters/postgresql/tools/text/matching.js.map +1 -0
- package/dist/adapters/postgresql/tools/text/search.d.ts +17 -0
- package/dist/adapters/postgresql/tools/text/search.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/text/search.js +653 -0
- package/dist/adapters/postgresql/tools/text/search.js.map +1 -0
- package/dist/adapters/postgresql/tools/transactions.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/transactions.js +11 -27
- package/dist/adapters/postgresql/tools/transactions.js.map +1 -1
- package/dist/adapters/postgresql/tools/vector/{basic.d.ts → data.d.ts} +10 -8
- package/dist/adapters/postgresql/tools/vector/data.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/vector/data.js +540 -0
- package/dist/adapters/postgresql/tools/vector/data.js.map +1 -0
- package/dist/adapters/postgresql/tools/vector/index.d.ts.map +1 -1
- package/dist/adapters/postgresql/tools/vector/index.js +6 -2
- package/dist/adapters/postgresql/tools/vector/index.js.map +1 -1
- package/dist/adapters/postgresql/tools/vector/management.d.ts +11 -0
- package/dist/adapters/postgresql/tools/vector/management.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/vector/management.js +425 -0
- package/dist/adapters/postgresql/tools/vector/management.js.map +1 -0
- package/dist/adapters/postgresql/tools/vector/query.d.ts +14 -0
- package/dist/adapters/postgresql/tools/vector/query.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/vector/query.js +767 -0
- package/dist/adapters/postgresql/tools/vector/query.js.map +1 -0
- package/dist/adapters/postgresql/tools/vector/{advanced.d.ts → search-advanced.d.ts} +4 -5
- package/dist/adapters/postgresql/tools/vector/search-advanced.d.ts.map +1 -0
- package/dist/adapters/postgresql/tools/vector/search-advanced.js +626 -0
- package/dist/adapters/postgresql/tools/vector/search-advanced.js.map +1 -0
- package/dist/auth/scopes.d.ts.map +1 -1
- package/dist/auth/scopes.js +3 -1
- package/dist/auth/scopes.js.map +1 -1
- package/dist/cli/args.d.ts +3 -2
- package/dist/cli/args.d.ts.map +1 -1
- package/dist/cli/args.js +4 -3
- package/dist/cli/args.js.map +1 -1
- package/dist/cli.js +16 -4
- package/dist/cli.js.map +1 -1
- package/dist/codemode/api/aliases.d.ts +14 -0
- package/dist/codemode/api/aliases.d.ts.map +1 -0
- package/dist/codemode/api/aliases.js +503 -0
- package/dist/codemode/api/aliases.js.map +1 -0
- package/dist/codemode/api/group-api.d.ts +23 -0
- package/dist/codemode/api/group-api.d.ts.map +1 -0
- package/dist/codemode/api/group-api.js +179 -0
- package/dist/codemode/api/group-api.js.map +1 -0
- package/dist/codemode/{api.d.ts → api/index.d.ts} +5 -4
- package/dist/codemode/api/index.d.ts.map +1 -0
- package/dist/codemode/api/index.js +195 -0
- package/dist/codemode/api/index.js.map +1 -0
- package/dist/codemode/api/maps.d.ts +47 -0
- package/dist/codemode/api/maps.d.ts.map +1 -0
- package/dist/codemode/api/maps.js +529 -0
- package/dist/codemode/api/maps.js.map +1 -0
- package/dist/codemode/api/normalize.d.ts +13 -0
- package/dist/codemode/api/normalize.d.ts.map +1 -0
- package/dist/codemode/api/normalize.js +120 -0
- package/dist/codemode/api/normalize.js.map +1 -0
- package/dist/codemode/index.d.ts +1 -1
- package/dist/codemode/index.d.ts.map +1 -1
- package/dist/codemode/index.js +1 -1
- package/dist/codemode/index.js.map +1 -1
- package/dist/codemode/sandbox.d.ts.map +1 -1
- package/dist/codemode/sandbox.js +8 -25
- package/dist/codemode/sandbox.js.map +1 -1
- package/dist/filtering/ToolConstants.d.ts +11 -11
- package/dist/filtering/ToolConstants.d.ts.map +1 -1
- package/dist/filtering/ToolConstants.js +28 -15
- package/dist/filtering/ToolConstants.js.map +1 -1
- package/dist/filtering/ToolFilter.d.ts +0 -32
- package/dist/filtering/ToolFilter.d.ts.map +1 -1
- package/dist/filtering/ToolFilter.js +0 -43
- package/dist/filtering/ToolFilter.js.map +1 -1
- package/dist/server/McpServer.d.ts +1 -1
- package/dist/server/McpServer.d.ts.map +1 -1
- package/dist/server/McpServer.js +1 -2
- package/dist/server/McpServer.js.map +1 -1
- package/dist/transports/http.d.ts +55 -10
- package/dist/transports/http.d.ts.map +1 -1
- package/dist/transports/http.js +301 -50
- package/dist/transports/http.js.map +1 -1
- package/dist/types/filtering.d.ts +1 -1
- package/dist/types/filtering.d.ts.map +1 -1
- package/dist/types/index.d.ts +2 -2
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js.map +1 -1
- package/dist/types/mcp.d.ts +0 -21
- package/dist/types/mcp.d.ts.map +1 -1
- package/dist/types/schema.d.ts +0 -79
- package/dist/types/schema.d.ts.map +1 -1
- package/dist/utils/fts-config.d.ts +0 -6
- package/dist/utils/fts-config.d.ts.map +1 -1
- package/dist/utils/fts-config.js +1 -1
- package/dist/utils/fts-config.js.map +1 -1
- package/dist/utils/icons.d.ts.map +1 -1
- package/dist/utils/icons.js +5 -0
- package/dist/utils/icons.js.map +1 -1
- package/dist/utils/identifiers.d.ts.map +1 -1
- package/dist/utils/identifiers.js +6 -6
- package/dist/utils/identifiers.js.map +1 -1
- package/dist/utils/logger.d.ts +6 -6
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +18 -15
- package/dist/utils/logger.js.map +1 -1
- package/dist/utils/progress-utils.d.ts +3 -14
- package/dist/utils/progress-utils.d.ts.map +1 -1
- package/dist/utils/progress-utils.js +2 -21
- package/dist/utils/progress-utils.js.map +1 -1
- package/dist/utils/version.d.ts +9 -0
- package/dist/utils/version.d.ts.map +1 -0
- package/dist/utils/version.js +12 -0
- package/dist/utils/version.js.map +1 -0
- package/dist/utils/where-clause.d.ts +4 -0
- package/dist/utils/where-clause.d.ts.map +1 -1
- package/dist/utils/where-clause.js +16 -0
- package/dist/utils/where-clause.js.map +1 -1
- package/package.json +6 -4
- package/dist/adapters/postgresql/schemas/core.d.ts.map +0 -1
- package/dist/adapters/postgresql/schemas/core.js.map +0 -1
- package/dist/adapters/postgresql/schemas/extensions.d.ts +0 -852
- package/dist/adapters/postgresql/schemas/extensions.d.ts.map +0 -1
- package/dist/adapters/postgresql/schemas/extensions.js +0 -1202
- package/dist/adapters/postgresql/schemas/extensions.js.map +0 -1
- package/dist/adapters/postgresql/schemas/jsonb.d.ts +0 -541
- package/dist/adapters/postgresql/schemas/jsonb.d.ts.map +0 -1
- package/dist/adapters/postgresql/schemas/jsonb.js +0 -814
- package/dist/adapters/postgresql/schemas/jsonb.js.map +0 -1
- package/dist/adapters/postgresql/schemas/postgis.d.ts.map +0 -1
- package/dist/adapters/postgresql/schemas/postgis.js.map +0 -1
- package/dist/adapters/postgresql/schemas/stats.d.ts.map +0 -1
- package/dist/adapters/postgresql/schemas/stats.js.map +0 -1
- package/dist/adapters/postgresql/tools/citext.d.ts +0 -18
- package/dist/adapters/postgresql/tools/citext.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/citext.js.map +0 -1
- package/dist/adapters/postgresql/tools/introspection.d.ts +0 -15
- package/dist/adapters/postgresql/tools/introspection.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/introspection.js +0 -1682
- package/dist/adapters/postgresql/tools/introspection.js.map +0 -1
- package/dist/adapters/postgresql/tools/jsonb/advanced.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/jsonb/advanced.js.map +0 -1
- package/dist/adapters/postgresql/tools/jsonb/basic.d.ts +0 -20
- package/dist/adapters/postgresql/tools/jsonb/basic.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/jsonb/basic.js.map +0 -1
- package/dist/adapters/postgresql/tools/monitoring.d.ts +0 -13
- package/dist/adapters/postgresql/tools/monitoring.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/monitoring.js.map +0 -1
- package/dist/adapters/postgresql/tools/partitioning.d.ts +0 -13
- package/dist/adapters/postgresql/tools/partitioning.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/partitioning.js.map +0 -1
- package/dist/adapters/postgresql/tools/schema.d.ts +0 -13
- package/dist/adapters/postgresql/tools/schema.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/schema.js.map +0 -1
- package/dist/adapters/postgresql/tools/text.d.ts +0 -13
- package/dist/adapters/postgresql/tools/text.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/text.js +0 -1082
- package/dist/adapters/postgresql/tools/text.js.map +0 -1
- package/dist/adapters/postgresql/tools/vector/advanced.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/vector/advanced.js +0 -958
- package/dist/adapters/postgresql/tools/vector/advanced.js.map +0 -1
- package/dist/adapters/postgresql/tools/vector/basic.d.ts.map +0 -1
- package/dist/adapters/postgresql/tools/vector/basic.js +0 -1165
- package/dist/adapters/postgresql/tools/vector/basic.js.map +0 -1
- package/dist/codemode/api.d.ts.map +0 -1
- package/dist/codemode/api.js +0 -1544
- package/dist/codemode/api.js.map +0 -1
- package/dist/utils/promptGenerator.d.ts +0 -20
- package/dist/utils/promptGenerator.d.ts.map +0 -1
- package/dist/utils/promptGenerator.js +0 -81
- package/dist/utils/promptGenerator.js.map +0 -1
|
@@ -0,0 +1,540 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL pgvector - Data Operations
|
|
3
|
+
*
|
|
4
|
+
* Write tools: extension, addColumn, insert, batchInsert.
|
|
5
|
+
* Also exports shared utilities: parseVector, truncateVector, checkTableAndColumn.
|
|
6
|
+
*/
|
|
7
|
+
import { z } from "zod";
|
|
8
|
+
import { write } from "../../../../utils/annotations.js";
|
|
9
|
+
import { getToolIcons } from "../../../../utils/icons.js";
|
|
10
|
+
import { formatPostgresError } from "../core/error-helpers.js";
|
|
11
|
+
import { sanitizeIdentifier, sanitizeTableName, } from "../../../../utils/identifiers.js";
|
|
12
|
+
import { VectorCreateExtensionOutputSchema, VectorAddColumnOutputSchema, VectorInsertOutputSchema, } from "../../schemas/index.js";
|
|
13
|
+
/**
|
|
14
|
+
* Parse a PostgreSQL vector string to a number array.
|
|
15
|
+
* Handles formats like "[0.1,0.2,0.3]" or "(0.1,0.2,0.3)"
|
|
16
|
+
*/
|
|
17
|
+
export function parseVector(vecStr) {
|
|
18
|
+
if (typeof vecStr !== "string")
|
|
19
|
+
return null;
|
|
20
|
+
try {
|
|
21
|
+
const cleaned = vecStr.replace(/[[\]()]/g, "");
|
|
22
|
+
return cleaned.split(",").map(Number);
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Truncate a vector for display, showing first/last N values.
|
|
30
|
+
* For vectors <= maxDisplay, returns the full vector.
|
|
31
|
+
*/
|
|
32
|
+
export function truncateVector(vec, maxDisplay = 10) {
|
|
33
|
+
if (vec === null || vec === undefined) {
|
|
34
|
+
return { preview: null, dimensions: 0, truncated: false };
|
|
35
|
+
}
|
|
36
|
+
if (vec.length <= maxDisplay) {
|
|
37
|
+
return { preview: vec, dimensions: vec.length, truncated: false };
|
|
38
|
+
}
|
|
39
|
+
// Show first 5 and last 5
|
|
40
|
+
const half = Math.floor(maxDisplay / 2);
|
|
41
|
+
const preview = [...vec.slice(0, half), ...vec.slice(-half)];
|
|
42
|
+
return { preview, dimensions: vec.length, truncated: true };
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Two-step existence check: table first, then column.
|
|
46
|
+
* Returns null if both exist, or {error, suggestion} if either is missing.
|
|
47
|
+
*/
|
|
48
|
+
export async function checkTableAndColumn(adapter, table, column, schema) {
|
|
49
|
+
// Step 1: check column existence (fast path — covers the common success case)
|
|
50
|
+
const colSql = `
|
|
51
|
+
SELECT 1 FROM information_schema.columns
|
|
52
|
+
WHERE table_schema = $1 AND table_name = $2 AND column_name = $3
|
|
53
|
+
`;
|
|
54
|
+
const colResult = await adapter.executeQuery(colSql, [schema, table, column]);
|
|
55
|
+
if ((colResult.rows?.length ?? 0) > 0)
|
|
56
|
+
return null; // both exist
|
|
57
|
+
// Step 2: disambiguate — is it the table or the column?
|
|
58
|
+
const tblSql = `
|
|
59
|
+
SELECT 1 FROM information_schema.tables
|
|
60
|
+
WHERE table_schema = $1 AND table_name = $2
|
|
61
|
+
`;
|
|
62
|
+
const tblResult = await adapter.executeQuery(tblSql, [schema, table]);
|
|
63
|
+
if ((tblResult.rows?.length ?? 0) === 0) {
|
|
64
|
+
return {
|
|
65
|
+
error: `Table '${table}' does not exist in schema '${schema}'`,
|
|
66
|
+
suggestion: "Use pg_list_tables to find available tables",
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
return {
|
|
70
|
+
error: `Column '${column}' does not exist in table '${table}'`,
|
|
71
|
+
suggestion: "Use pg_describe_table to find available columns",
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
export function createVectorExtensionTool(adapter) {
|
|
75
|
+
return {
|
|
76
|
+
name: "pg_vector_create_extension",
|
|
77
|
+
description: "Enable the pgvector extension for vector similarity search.",
|
|
78
|
+
group: "vector",
|
|
79
|
+
inputSchema: z.object({}),
|
|
80
|
+
outputSchema: VectorCreateExtensionOutputSchema,
|
|
81
|
+
annotations: write("Create Vector Extension"),
|
|
82
|
+
icons: getToolIcons("vector", write("Create Vector Extension")),
|
|
83
|
+
handler: async (_params, _context) => {
|
|
84
|
+
try {
|
|
85
|
+
await adapter.executeQuery("CREATE EXTENSION IF NOT EXISTS vector");
|
|
86
|
+
return { success: true, message: "pgvector extension enabled" };
|
|
87
|
+
}
|
|
88
|
+
catch (error) {
|
|
89
|
+
return {
|
|
90
|
+
success: false,
|
|
91
|
+
error: formatPostgresError(error, {
|
|
92
|
+
tool: "pg_vector_create_extension",
|
|
93
|
+
}),
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
},
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
export function createVectorAddColumnTool(adapter) {
|
|
100
|
+
// Base schema for MCP visibility (Split Schema pattern)
|
|
101
|
+
const AddColumnSchemaBase = z.object({
|
|
102
|
+
table: z.string().optional().describe("Table name"),
|
|
103
|
+
tableName: z.string().optional().describe("Alias for table"),
|
|
104
|
+
column: z.string().optional().describe("Column name"),
|
|
105
|
+
col: z.string().optional().describe("Alias for column"),
|
|
106
|
+
dimensions: z.coerce
|
|
107
|
+
.number()
|
|
108
|
+
.describe("Vector dimensions (e.g., 1536 for OpenAI)"),
|
|
109
|
+
schema: z.string().optional().describe("Database schema (default: public)"),
|
|
110
|
+
ifNotExists: z
|
|
111
|
+
.boolean()
|
|
112
|
+
.optional()
|
|
113
|
+
.describe("Skip if column already exists (default: false)"),
|
|
114
|
+
});
|
|
115
|
+
// Transformed schema with alias resolution for handler
|
|
116
|
+
const AddColumnSchema = AddColumnSchemaBase.transform((data) => ({
|
|
117
|
+
table: data.table ?? data.tableName ?? "",
|
|
118
|
+
column: data.column ?? data.col ?? "",
|
|
119
|
+
dimensions: data.dimensions,
|
|
120
|
+
schema: data.schema,
|
|
121
|
+
ifNotExists: data.ifNotExists ?? false,
|
|
122
|
+
}));
|
|
123
|
+
return {
|
|
124
|
+
name: "pg_vector_add_column",
|
|
125
|
+
description: "Add a vector column to a table. Requires: table, column, dimensions.",
|
|
126
|
+
group: "vector",
|
|
127
|
+
// Use base schema for MCP visibility
|
|
128
|
+
inputSchema: AddColumnSchemaBase,
|
|
129
|
+
outputSchema: VectorAddColumnOutputSchema,
|
|
130
|
+
annotations: write("Add Vector Column"),
|
|
131
|
+
icons: getToolIcons("vector", write("Add Vector Column")),
|
|
132
|
+
handler: async (params, _context) => {
|
|
133
|
+
try {
|
|
134
|
+
const parsed = AddColumnSchema.parse(params);
|
|
135
|
+
// Validate required params with clear errors
|
|
136
|
+
if (parsed.table === "") {
|
|
137
|
+
return {
|
|
138
|
+
success: false,
|
|
139
|
+
error: "table (or tableName) parameter is required",
|
|
140
|
+
requiredParams: ["table", "column", "dimensions"],
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
if (parsed.column === "") {
|
|
144
|
+
return {
|
|
145
|
+
success: false,
|
|
146
|
+
error: "column (or col) parameter is required",
|
|
147
|
+
requiredParams: ["table", "column", "dimensions"],
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
const schemaName = parsed.schema ?? "public";
|
|
151
|
+
const tableName = sanitizeTableName(parsed.table, parsed.schema);
|
|
152
|
+
const columnName = sanitizeIdentifier(parsed.column);
|
|
153
|
+
// Verify table exists before ALTER TABLE
|
|
154
|
+
const tblCheckSql = `
|
|
155
|
+
SELECT 1 FROM information_schema.tables
|
|
156
|
+
WHERE table_schema = $1 AND table_name = $2
|
|
157
|
+
`;
|
|
158
|
+
const tblCheckResult = await adapter.executeQuery(tblCheckSql, [
|
|
159
|
+
schemaName,
|
|
160
|
+
parsed.table,
|
|
161
|
+
]);
|
|
162
|
+
if ((tblCheckResult.rows?.length ?? 0) === 0) {
|
|
163
|
+
return {
|
|
164
|
+
success: false,
|
|
165
|
+
error: `Table '${parsed.table}' does not exist in schema '${schemaName}'`,
|
|
166
|
+
suggestion: "Use pg_list_tables to find available tables",
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
// Check if column exists when ifNotExists is true
|
|
170
|
+
if (parsed.ifNotExists) {
|
|
171
|
+
const checkSql = `
|
|
172
|
+
SELECT 1 FROM information_schema.columns
|
|
173
|
+
WHERE table_schema = $1 AND table_name = $2 AND column_name = $3
|
|
174
|
+
`;
|
|
175
|
+
const checkResult = await adapter.executeQuery(checkSql, [
|
|
176
|
+
schemaName,
|
|
177
|
+
parsed.table,
|
|
178
|
+
parsed.column,
|
|
179
|
+
]);
|
|
180
|
+
if (checkResult.rows && checkResult.rows.length > 0) {
|
|
181
|
+
return {
|
|
182
|
+
success: true,
|
|
183
|
+
table: parsed.table,
|
|
184
|
+
column: parsed.column,
|
|
185
|
+
dimensions: parsed.dimensions,
|
|
186
|
+
ifNotExists: true,
|
|
187
|
+
alreadyExists: true,
|
|
188
|
+
message: `Column ${parsed.column} already exists on table ${parsed.table}`,
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
const sql = `ALTER TABLE ${tableName} ADD COLUMN ${columnName} vector(${String(parsed.dimensions)})`;
|
|
193
|
+
try {
|
|
194
|
+
await adapter.executeQuery(sql);
|
|
195
|
+
return {
|
|
196
|
+
success: true,
|
|
197
|
+
table: parsed.table,
|
|
198
|
+
column: parsed.column,
|
|
199
|
+
dimensions: parsed.dimensions,
|
|
200
|
+
ifNotExists: parsed.ifNotExists,
|
|
201
|
+
};
|
|
202
|
+
}
|
|
203
|
+
catch (err) {
|
|
204
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
205
|
+
// Duplicate column: PG code 42701
|
|
206
|
+
if (msg.includes("already exists")) {
|
|
207
|
+
return {
|
|
208
|
+
success: false,
|
|
209
|
+
error: `Column '${parsed.column}' already exists on table '${parsed.table}'`,
|
|
210
|
+
suggestion: "Use ifNotExists: true to skip if column already exists",
|
|
211
|
+
};
|
|
212
|
+
}
|
|
213
|
+
throw err;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
catch (error) {
|
|
217
|
+
return {
|
|
218
|
+
success: false,
|
|
219
|
+
error: formatPostgresError(error, { tool: "pg_vector_add_column" }),
|
|
220
|
+
};
|
|
221
|
+
}
|
|
222
|
+
},
|
|
223
|
+
};
|
|
224
|
+
}
|
|
225
|
+
export function createVectorInsertTool(adapter) {
|
|
226
|
+
// Base schema for MCP visibility (Split Schema pattern)
|
|
227
|
+
const VectorInsertSchemaBase = z.object({
|
|
228
|
+
table: z.string().optional().describe("Table name"),
|
|
229
|
+
tableName: z.string().optional().describe("Alias for table"),
|
|
230
|
+
column: z.string().optional().describe("Column name"),
|
|
231
|
+
col: z.string().optional().describe("Alias for column"),
|
|
232
|
+
vector: z.array(z.number()),
|
|
233
|
+
additionalColumns: z.record(z.string(), z.unknown()).optional(),
|
|
234
|
+
schema: z.string().optional(),
|
|
235
|
+
updateExisting: z
|
|
236
|
+
.boolean()
|
|
237
|
+
.optional()
|
|
238
|
+
.describe("Update vector on existing row (requires conflictColumn and conflictValue)"),
|
|
239
|
+
conflictColumn: z
|
|
240
|
+
.string()
|
|
241
|
+
.optional()
|
|
242
|
+
.describe("Column to match for updates (e.g., id)"),
|
|
243
|
+
conflictValue: z
|
|
244
|
+
.union([z.string(), z.number()])
|
|
245
|
+
.optional()
|
|
246
|
+
.describe("Value of conflictColumn to match (e.g., 123)"),
|
|
247
|
+
});
|
|
248
|
+
// Transformed schema with alias resolution for handler
|
|
249
|
+
const VectorInsertSchema = VectorInsertSchemaBase.transform((data) => ({
|
|
250
|
+
table: data.table ?? data.tableName ?? "",
|
|
251
|
+
column: data.column ?? data.col ?? "",
|
|
252
|
+
vector: data.vector,
|
|
253
|
+
additionalColumns: data.additionalColumns,
|
|
254
|
+
schema: data.schema,
|
|
255
|
+
updateExisting: data.updateExisting,
|
|
256
|
+
conflictColumn: data.conflictColumn,
|
|
257
|
+
conflictValue: data.conflictValue,
|
|
258
|
+
}));
|
|
259
|
+
return {
|
|
260
|
+
name: "pg_vector_insert",
|
|
261
|
+
description: "Insert a vector into a table, or update an existing row's vector. For upsert: use updateExisting + conflictColumn + conflictValue to UPDATE existing rows (avoids NOT NULL issues).",
|
|
262
|
+
group: "vector",
|
|
263
|
+
// Use base schema for MCP visibility
|
|
264
|
+
inputSchema: VectorInsertSchemaBase,
|
|
265
|
+
outputSchema: VectorInsertOutputSchema,
|
|
266
|
+
annotations: write("Insert Vector"),
|
|
267
|
+
icons: getToolIcons("vector", write("Insert Vector")),
|
|
268
|
+
handler: async (params, _context) => {
|
|
269
|
+
try {
|
|
270
|
+
// Use transformed schema for alias resolution
|
|
271
|
+
const parsed = VectorInsertSchema.parse(params);
|
|
272
|
+
// Validate required params with clear errors
|
|
273
|
+
if (parsed.table === "") {
|
|
274
|
+
return {
|
|
275
|
+
success: false,
|
|
276
|
+
error: "table (or tableName) parameter is required",
|
|
277
|
+
requiredParams: ["table", "column", "vector"],
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
if (parsed.column === "") {
|
|
281
|
+
return {
|
|
282
|
+
success: false,
|
|
283
|
+
error: "column (or col) parameter is required",
|
|
284
|
+
requiredParams: ["table", "column", "vector"],
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
if (parsed.vector === undefined ||
|
|
288
|
+
!Array.isArray(parsed.vector) ||
|
|
289
|
+
parsed.vector.length === 0) {
|
|
290
|
+
return {
|
|
291
|
+
success: false,
|
|
292
|
+
error: "vector parameter is required and must be a non-empty array of numbers",
|
|
293
|
+
requiredParams: ["table", "column", "vector"],
|
|
294
|
+
};
|
|
295
|
+
}
|
|
296
|
+
// Validate upsert mode parameters
|
|
297
|
+
if (parsed.updateExisting === true) {
|
|
298
|
+
if (parsed.conflictColumn === undefined ||
|
|
299
|
+
parsed.conflictValue === undefined) {
|
|
300
|
+
return {
|
|
301
|
+
success: false,
|
|
302
|
+
error: "updateExisting requires both conflictColumn and conflictValue parameters",
|
|
303
|
+
suggestion: 'Specify conflictColumn (e.g., "id") and conflictValue (e.g., 123) to identify the row to update',
|
|
304
|
+
example: '{ updateExisting: true, conflictColumn: "id", conflictValue: 42, vector: [...] }',
|
|
305
|
+
};
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
// Parse schema.table format (embedded schema takes priority over explicit schema param)
|
|
309
|
+
let resolvedTable = parsed.table;
|
|
310
|
+
let resolvedSchema = parsed.schema;
|
|
311
|
+
if (parsed.table.includes(".")) {
|
|
312
|
+
const parts = parsed.table.split(".");
|
|
313
|
+
resolvedSchema = parts[0] ?? parsed.schema ?? "public";
|
|
314
|
+
resolvedTable = parts[1] ?? parsed.table;
|
|
315
|
+
}
|
|
316
|
+
const insertSchemaName = resolvedSchema ?? "public";
|
|
317
|
+
const tableName = sanitizeTableName(resolvedTable, resolvedSchema);
|
|
318
|
+
const columnName = sanitizeIdentifier(parsed.column);
|
|
319
|
+
const vectorStr = `[${parsed.vector.join(",")}]`;
|
|
320
|
+
// Pre-validate table and column exist
|
|
321
|
+
const missing = await checkTableAndColumn(adapter, resolvedTable, parsed.column, insertSchemaName);
|
|
322
|
+
if (missing) {
|
|
323
|
+
return { success: false, ...missing };
|
|
324
|
+
}
|
|
325
|
+
// Use direct UPDATE for updateExisting mode (avoids NOT NULL constraint issues)
|
|
326
|
+
if (parsed.updateExisting === true &&
|
|
327
|
+
parsed.conflictColumn !== undefined &&
|
|
328
|
+
parsed.conflictValue !== undefined) {
|
|
329
|
+
const conflictCol = sanitizeIdentifier(parsed.conflictColumn);
|
|
330
|
+
// Build SET clause including vector and additionalColumns
|
|
331
|
+
const setClauses = [`${columnName} = $1::vector`];
|
|
332
|
+
const queryParams = [vectorStr, parsed.conflictValue];
|
|
333
|
+
let paramIndex = 3; // $1 = vector, $2 = conflictValue
|
|
334
|
+
if (parsed.additionalColumns !== undefined) {
|
|
335
|
+
for (const [col, val] of Object.entries(parsed.additionalColumns)) {
|
|
336
|
+
setClauses.push(`${sanitizeIdentifier(col)} = $${String(paramIndex)}`);
|
|
337
|
+
queryParams.push(val);
|
|
338
|
+
paramIndex++;
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
const sql = `UPDATE ${tableName} SET ${setClauses.join(", ")} WHERE ${conflictCol} = $2`;
|
|
342
|
+
const result = await adapter.executeQuery(sql, queryParams);
|
|
343
|
+
if (result.rowsAffected === 0) {
|
|
344
|
+
return {
|
|
345
|
+
success: false,
|
|
346
|
+
error: `No row found with ${parsed.conflictColumn} = ${String(parsed.conflictValue)}`,
|
|
347
|
+
suggestion: "Use insert mode (without updateExisting) to create new rows, or verify the conflictValue exists",
|
|
348
|
+
};
|
|
349
|
+
}
|
|
350
|
+
return {
|
|
351
|
+
success: true,
|
|
352
|
+
rowsAffected: result.rowsAffected,
|
|
353
|
+
mode: "update",
|
|
354
|
+
columnsUpdated: setClauses.length,
|
|
355
|
+
};
|
|
356
|
+
}
|
|
357
|
+
// Standard INSERT mode
|
|
358
|
+
const columns = [columnName];
|
|
359
|
+
const values = [vectorStr];
|
|
360
|
+
const params_ = [];
|
|
361
|
+
let paramIndex = 1;
|
|
362
|
+
if (parsed.additionalColumns !== undefined) {
|
|
363
|
+
for (const [col, val] of Object.entries(parsed.additionalColumns)) {
|
|
364
|
+
columns.push(sanitizeIdentifier(col));
|
|
365
|
+
values.push(`$${String(paramIndex++)}`);
|
|
366
|
+
params_.push(val);
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
const sql = `INSERT INTO ${tableName} (${columns.join(", ")}) VALUES ('${vectorStr}'${params_.length > 0 ? ", " + values.slice(1).join(", ") : ""})`;
|
|
370
|
+
try {
|
|
371
|
+
const result = await adapter.executeQuery(sql, params_);
|
|
372
|
+
return { success: true, rowsAffected: result.rowsAffected };
|
|
373
|
+
}
|
|
374
|
+
catch (error) {
|
|
375
|
+
// Parse dimension mismatch errors for user-friendly message
|
|
376
|
+
if (error instanceof Error) {
|
|
377
|
+
const dimMatch = /expected (\d+) dimensions?, not (\d+)/.exec(error.message);
|
|
378
|
+
if (dimMatch) {
|
|
379
|
+
const expectedDim = dimMatch[1] ?? "0";
|
|
380
|
+
const providedDim = dimMatch[2] ?? "0";
|
|
381
|
+
return {
|
|
382
|
+
success: false,
|
|
383
|
+
error: "Vector dimension mismatch",
|
|
384
|
+
expectedDimensions: parseInt(expectedDim, 10),
|
|
385
|
+
providedDimensions: parseInt(providedDim, 10),
|
|
386
|
+
suggestion: `Column expects ${expectedDim} dimensions but vector has ${providedDim}. Resize vector or check embedding model.`,
|
|
387
|
+
};
|
|
388
|
+
}
|
|
389
|
+
// Check for NOT NULL constraint violation
|
|
390
|
+
if (error.message.includes("NOT NULL") ||
|
|
391
|
+
error.message.includes("null value in column")) {
|
|
392
|
+
return {
|
|
393
|
+
success: false,
|
|
394
|
+
error: "NOT NULL constraint violation",
|
|
395
|
+
rawError: error.message,
|
|
396
|
+
suggestion: "Table has NOT NULL columns that require values. Use additionalColumns param or updateExisting mode to update existing rows.",
|
|
397
|
+
};
|
|
398
|
+
}
|
|
399
|
+
// Catch relation/column not found from UPDATE path
|
|
400
|
+
if (error.message.includes("does not exist")) {
|
|
401
|
+
return {
|
|
402
|
+
success: false,
|
|
403
|
+
error: error.message,
|
|
404
|
+
suggestion: "Verify the table and column names using pg_list_tables and pg_describe_table",
|
|
405
|
+
};
|
|
406
|
+
}
|
|
407
|
+
}
|
|
408
|
+
throw error;
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
catch (error) {
|
|
412
|
+
return {
|
|
413
|
+
success: false,
|
|
414
|
+
error: formatPostgresError(error, { tool: "pg_vector_insert" }),
|
|
415
|
+
};
|
|
416
|
+
}
|
|
417
|
+
},
|
|
418
|
+
};
|
|
419
|
+
}
|
|
420
|
+
export function createVectorBatchInsertTool(adapter) {
|
|
421
|
+
// Base schema for MCP visibility (Split Schema pattern)
|
|
422
|
+
const BatchInsertSchemaBase = z.object({
|
|
423
|
+
table: z.string().optional().describe("Table name"),
|
|
424
|
+
tableName: z.string().optional().describe("Alias for table"),
|
|
425
|
+
column: z.string().optional().describe("Vector column"),
|
|
426
|
+
col: z.string().optional().describe("Alias for column"),
|
|
427
|
+
vectors: z
|
|
428
|
+
.array(z.object({
|
|
429
|
+
vector: z.array(z.number()),
|
|
430
|
+
data: z
|
|
431
|
+
.record(z.string(), z.unknown())
|
|
432
|
+
.optional()
|
|
433
|
+
.describe("Additional column values"),
|
|
434
|
+
}))
|
|
435
|
+
.describe("Array of vectors with optional additional data"),
|
|
436
|
+
schema: z.string().optional().describe("Database schema (default: public)"),
|
|
437
|
+
});
|
|
438
|
+
// Transformed schema with alias resolution for handler
|
|
439
|
+
const BatchInsertSchema = BatchInsertSchemaBase.transform((data) => ({
|
|
440
|
+
table: data.table ?? data.tableName ?? "",
|
|
441
|
+
column: data.column ?? data.col ?? "",
|
|
442
|
+
vectors: data.vectors,
|
|
443
|
+
schema: data.schema,
|
|
444
|
+
}));
|
|
445
|
+
return {
|
|
446
|
+
name: "pg_vector_batch_insert",
|
|
447
|
+
description: 'Efficiently insert multiple vectors. vectors param expects array of {vector: [...], data?: {...}} objects, NOT raw arrays. Example: vectors: [{vector: [0.1, 0.2], data: {name: "a"}}]',
|
|
448
|
+
group: "vector",
|
|
449
|
+
// Use base schema for MCP visibility
|
|
450
|
+
inputSchema: BatchInsertSchemaBase,
|
|
451
|
+
annotations: write("Batch Insert Vectors"),
|
|
452
|
+
icons: getToolIcons("vector", write("Batch Insert Vectors")),
|
|
453
|
+
handler: async (params, _context) => {
|
|
454
|
+
try {
|
|
455
|
+
const parsed = BatchInsertSchema.parse(params);
|
|
456
|
+
// Parse schema.table format (embedded schema takes priority over explicit schema param)
|
|
457
|
+
let resolvedTable = parsed.table;
|
|
458
|
+
let resolvedSchema = parsed.schema;
|
|
459
|
+
if (parsed.table.includes(".")) {
|
|
460
|
+
const parts = parsed.table.split(".");
|
|
461
|
+
resolvedSchema = parts[0] ?? parsed.schema ?? "public";
|
|
462
|
+
resolvedTable = parts[1] ?? parsed.table;
|
|
463
|
+
}
|
|
464
|
+
const tableName = sanitizeTableName(resolvedTable, resolvedSchema);
|
|
465
|
+
const columnName = sanitizeIdentifier(parsed.column);
|
|
466
|
+
// P154: Pre-validate table and column exist
|
|
467
|
+
const existenceError = await checkTableAndColumn(adapter, resolvedTable, parsed.column, resolvedSchema ?? "public");
|
|
468
|
+
if (existenceError !== null) {
|
|
469
|
+
return { success: false, ...existenceError };
|
|
470
|
+
}
|
|
471
|
+
if (parsed.vectors.length === 0) {
|
|
472
|
+
return {
|
|
473
|
+
success: true,
|
|
474
|
+
rowsInserted: 0,
|
|
475
|
+
message: "No vectors to insert",
|
|
476
|
+
};
|
|
477
|
+
}
|
|
478
|
+
// Build batch INSERT with VALUES clause
|
|
479
|
+
const allDataKeys = new Set();
|
|
480
|
+
for (const v of parsed.vectors) {
|
|
481
|
+
if (v.data !== undefined) {
|
|
482
|
+
for (const k of Object.keys(v.data)) {
|
|
483
|
+
allDataKeys.add(k);
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
const dataColumns = Array.from(allDataKeys);
|
|
488
|
+
const columns = [
|
|
489
|
+
columnName,
|
|
490
|
+
...dataColumns.map((c) => sanitizeIdentifier(c)),
|
|
491
|
+
];
|
|
492
|
+
const valueRows = [];
|
|
493
|
+
const allParams = [];
|
|
494
|
+
let paramIndex = 1;
|
|
495
|
+
for (const v of parsed.vectors) {
|
|
496
|
+
const vectorStr = `'[${v.vector.join(", ")}]':: vector`;
|
|
497
|
+
const rowValues = [vectorStr];
|
|
498
|
+
for (const col of dataColumns) {
|
|
499
|
+
rowValues.push(`$${String(paramIndex++)} `);
|
|
500
|
+
allParams.push(v.data?.[col] ?? null);
|
|
501
|
+
}
|
|
502
|
+
valueRows.push(`(${rowValues.join(", ")})`);
|
|
503
|
+
}
|
|
504
|
+
const sql = `INSERT INTO ${tableName} (${columns.join(", ")}) VALUES ${valueRows.join(", ")} `;
|
|
505
|
+
try {
|
|
506
|
+
const result = await adapter.executeQuery(sql, allParams);
|
|
507
|
+
return {
|
|
508
|
+
success: true,
|
|
509
|
+
rowsInserted: parsed.vectors.length,
|
|
510
|
+
rowsAffected: result.rowsAffected,
|
|
511
|
+
};
|
|
512
|
+
}
|
|
513
|
+
catch (error) {
|
|
514
|
+
if (error instanceof Error) {
|
|
515
|
+
const dimMatch = /expected (\d+) dimensions?, not (\d+)/.exec(error.message);
|
|
516
|
+
if (dimMatch) {
|
|
517
|
+
const expectedDim = dimMatch[1] ?? "0";
|
|
518
|
+
const providedDim = dimMatch[2] ?? "0";
|
|
519
|
+
return {
|
|
520
|
+
success: false,
|
|
521
|
+
error: "Vector dimension mismatch",
|
|
522
|
+
expectedDimensions: parseInt(expectedDim, 10),
|
|
523
|
+
providedDimensions: parseInt(providedDim, 10),
|
|
524
|
+
suggestion: `Column expects ${expectedDim} dimensions but vectors have ${providedDim}. Resize vectors or check embedding model.`,
|
|
525
|
+
};
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
throw error;
|
|
529
|
+
}
|
|
530
|
+
}
|
|
531
|
+
catch (error) {
|
|
532
|
+
return {
|
|
533
|
+
success: false,
|
|
534
|
+
error: formatPostgresError(error, { tool: "pg_vector_batch_insert" }),
|
|
535
|
+
};
|
|
536
|
+
}
|
|
537
|
+
},
|
|
538
|
+
};
|
|
539
|
+
}
|
|
540
|
+
//# sourceMappingURL=data.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data.js","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/vector/data.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAOH,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EACL,kBAAkB,EAClB,iBAAiB,GAClB,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EACL,iCAAiC,EACjC,2BAA2B,EAC3B,wBAAwB,GACzB,MAAM,wBAAwB,CAAC;AAEhC;;;GAGG;AACH,MAAM,UAAU,WAAW,CAAC,MAAe;IACzC,IAAI,OAAO,MAAM,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAC5C,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;QAC/C,OAAO,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,cAAc,CAC5B,GAAgC,EAChC,UAAU,GAAG,EAAE;IAMf,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;QACtC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;IAC5D,CAAC;IACD,IAAI,GAAG,CAAC,MAAM,IAAI,UAAU,EAAE,CAAC;QAC7B,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;IACpE,CAAC;IACD,0BAA0B;IAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;IACxC,MAAM,OAAO,GAAG,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAC7D,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;AAC9D,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CACvC,OAAwB,EACxB,KAAa,EACb,MAAc,EACd,MAAc;IAEd,8EAA8E;IAC9E,MAAM,MAAM,GAAG;;;GAGd,CAAC;IACF,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;IAC9E,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC;QAAE,OAAO,IAAI,CAAC,CAAC,aAAa;IAEjE,wDAAwD;IACxD,MAAM,MAAM,GAAG;;;GAGd,CAAC;IACF,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;IACtE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;QACxC,OAAO;YACL,KAAK,EAAE,UAAU,KAAK,+BAA+B,MAAM,GAAG;YAC9D,UAAU,EAAE,6CAA6C;SAC1D,CAAC;IACJ,CAAC;IACD,OAAO;QACL,KAAK,EAAE,WAAW,MAAM,8BAA8B,KAAK,GAAG;QAC9D,UAAU,EAAE,iDAAiD;KAC9D,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,yBAAyB,CACvC,OAAwB;IAExB,OAAO;QACL,IAAI,EAAE,4BAA4B;QAClC,WAAW,EAAE,6DAA6D;QAC1E,KAAK,EAAE,QAAQ;QACf,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;QACzB,YAAY,EAAE,iCAAiC;QAC/C,WAAW,EAAE,KAAK,CAAC,yBAAyB,CAAC;QAC7C,KAAK,EAAE,YAAY,CAAC,QAAQ,EAAE,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC/D,OAAO,EAAE,KAAK,EAAE,OAAgB,EAAE,QAAwB,EAAE,EAAE;YAC5D,IAAI,CAAC;gBACH,MAAM,OAAO,CAAC,YAAY,CAAC,uCAAuC,CAAC,CAAC;gBACpE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,4BAA4B,EAAE,CAAC;YAClE,CAAC;YAAC,OAAO,KAAc,EAAE,CAAC;gBACxB,OAAO;oBACL,OAAO,EAAE,KAAc;oBACvB,KAAK,EAAE,mBAAmB,CAAC,KAAK,EAAE;wBAChC,IAAI,EAAE,4BAA4B;qBACnC,CAAC;iBACH,CAAC;YACJ,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,yBAAyB,CACvC,OAAwB;IAExB,wDAAwD;IACxD,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC;QACnC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC;QACnD,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QAC5D,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC;QACrD,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,kBAAkB,CAAC;QACvD,UAAU,EAAE,CAAC,CAAC,MAAM;aACjB,MAAM,EAAE;aACR,QAAQ,CAAC,2CAA2C,CAAC;QACxD,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,mCAAmC,CAAC;QAC3E,WAAW,EAAE,CAAC;aACX,OAAO,EAAE;aACT,QAAQ,EAAE;aACV,QAAQ,CAAC,gDAAgD,CAAC;KAC9D,CAAC,CAAC;IAEH,uDAAuD;IACvD,MAAM,eAAe,GAAG,mBAAmB,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAC/D,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,IAAI,EAAE;QACzC,MAAM,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,GAAG,IAAI,EAAE;QACrC,UAAU,EAAE,IAAI,CAAC,UAAU;QAC3B,MAAM,EAAE,IAAI,CAAC,MAAM;QACnB,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,KAAK;KACvC,CAAC,CAAC,CAAC;IAEJ,OAAO;QACL,IAAI,EAAE,sBAAsB;QAC5B,WAAW,EACT,sEAAsE;QACxE,KAAK,EAAE,QAAQ;QACf,qCAAqC;QACrC,WAAW,EAAE,mBAAmB;QAChC,YAAY,EAAE,2BAA2B;QACzC,WAAW,EAAE,KAAK,CAAC,mBAAmB,CAAC;QACvC,KAAK,EAAE,YAAY,CAAC,QAAQ,EAAE,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACzD,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBAE7C,6CAA6C;gBAC7C,IAAI,MAAM,CAAC,KAAK,KAAK,EAAE,EAAE,CAAC;oBACxB,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,4CAA4C;wBACnD,cAAc,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,CAAC;qBAClD,CAAC;gBACJ,CAAC;gBACD,IAAI,MAAM,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;oBACzB,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,uCAAuC;wBAC9C,cAAc,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,CAAC;qBAClD,CAAC;gBACJ,CAAC;gBAED,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;gBAC7C,MAAM,SAAS,GAAG,iBAAiB,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;gBACjE,MAAM,UAAU,GAAG,kBAAkB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBAErD,yCAAyC;gBACzC,MAAM,WAAW,GAAG;;;OAGrB,CAAC;gBACA,MAAM,cAAc,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,WAAW,EAAE;oBAC7D,UAAU;oBACV,MAAM,CAAC,KAAK;iBACb,CAAC,CAAC;gBACH,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;oBAC7C,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,UAAU,MAAM,CAAC,KAAK,+BAA+B,UAAU,GAAG;wBACzE,UAAU,EAAE,6CAA6C;qBAC1D,CAAC;gBACJ,CAAC;gBAED,kDAAkD;gBAClD,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;oBACvB,MAAM,QAAQ,GAAG;;;SAGlB,CAAC;oBACA,MAAM,WAAW,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,QAAQ,EAAE;wBACvD,UAAU;wBACV,MAAM,CAAC,KAAK;wBACZ,MAAM,CAAC,MAAM;qBACd,CAAC,CAAC;oBACH,IAAI,WAAW,CAAC,IAAI,IAAI,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBACpD,OAAO;4BACL,OAAO,EAAE,IAAI;4BACb,KAAK,EAAE,MAAM,CAAC,KAAK;4BACnB,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,UAAU,EAAE,MAAM,CAAC,UAAU;4BAC7B,WAAW,EAAE,IAAI;4BACjB,aAAa,EAAE,IAAI;4BACnB,OAAO,EAAE,UAAU,MAAM,CAAC,MAAM,4BAA4B,MAAM,CAAC,KAAK,EAAE;yBAC3E,CAAC;oBACJ,CAAC;gBACH,CAAC;gBAED,MAAM,GAAG,GAAG,eAAe,SAAS,eAAe,UAAU,WAAW,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC;gBACrG,IAAI,CAAC;oBACH,MAAM,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;oBAChC,OAAO;wBACL,OAAO,EAAE,IAAI;wBACb,KAAK,EAAE,MAAM,CAAC,KAAK;wBACnB,MAAM,EAAE,MAAM,CAAC,MAAM;wBACrB,UAAU,EAAE,MAAM,CAAC,UAAU;wBAC7B,WAAW,EAAE,MAAM,CAAC,WAAW;qBAChC,CAAC;gBACJ,CAAC;gBAAC,OAAO,GAAY,EAAE,CAAC;oBACtB,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;oBAC7D,kCAAkC;oBAClC,IAAI,GAAG,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC;wBACnC,OAAO;4BACL,OAAO,EAAE,KAAK;4BACd,KAAK,EAAE,WAAW,MAAM,CAAC,MAAM,8BAA8B,MAAM,CAAC,KAAK,GAAG;4BAC5E,UAAU,EACR,wDAAwD;yBAC3D,CAAC;oBACJ,CAAC;oBACD,MAAM,GAAG,CAAC;gBACZ,CAAC;YACH,CAAC;YAAC,OAAO,KAAc,EAAE,CAAC;gBACxB,OAAO;oBACL,OAAO,EAAE,KAAc;oBACvB,KAAK,EAAE,mBAAmB,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE,CAAC;iBACpE,CAAC;YACJ,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,sBAAsB,CACpC,OAAwB;IAExB,wDAAwD;IACxD,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC;QACtC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC;QACnD,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QAC5D,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC;QACrD,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,kBAAkB,CAAC;QACvD,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;QAC3B,iBAAiB,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,EAAE;QAC/D,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;QAC7B,cAAc,EAAE,CAAC;aACd,OAAO,EAAE;aACT,QAAQ,EAAE;aACV,QAAQ,CACP,2EAA2E,CAC5E;QACH,cAAc,EAAE,CAAC;aACd,MAAM,EAAE;aACR,QAAQ,EAAE;aACV,QAAQ,CAAC,wCAAwC,CAAC;QACrD,aAAa,EAAE,CAAC;aACb,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;aAC/B,QAAQ,EAAE;aACV,QAAQ,CAAC,8CAA8C,CAAC;KAC5D,CAAC,CAAC;IAEH,uDAAuD;IACvD,MAAM,kBAAkB,GAAG,sBAAsB,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACrE,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,IAAI,EAAE;QACzC,MAAM,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,GAAG,IAAI,EAAE;QACrC,MAAM,EAAE,IAAI,CAAC,MAAM;QACnB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;QACzC,MAAM,EAAE,IAAI,CAAC,MAAM;QACnB,cAAc,EAAE,IAAI,CAAC,cAAc;QACnC,cAAc,EAAE,IAAI,CAAC,cAAc;QACnC,aAAa,EAAE,IAAI,CAAC,aAAa;KAClC,CAAC,CAAC,CAAC;IAEJ,OAAO;QACL,IAAI,EAAE,kBAAkB;QACxB,WAAW,EACT,qLAAqL;QACvL,KAAK,EAAE,QAAQ;QACf,qCAAqC;QACrC,WAAW,EAAE,sBAAsB;QACnC,YAAY,EAAE,wBAAwB;QACtC,WAAW,EAAE,KAAK,CAAC,eAAe,CAAC;QACnC,KAAK,EAAE,YAAY,CAAC,QAAQ,EAAE,KAAK,CAAC,eAAe,CAAC,CAAC;QACrD,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,IAAI,CAAC;gBACH,8CAA8C;gBAC9C,MAAM,MAAM,GAAG,kBAAkB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBAEhD,6CAA6C;gBAC7C,IAAI,MAAM,CAAC,KAAK,KAAK,EAAE,EAAE,CAAC;oBACxB,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,4CAA4C;wBACnD,cAAc,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC;qBAC9C,CAAC;gBACJ,CAAC;gBACD,IAAI,MAAM,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;oBACzB,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,uCAAuC;wBAC9C,cAAc,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC;qBAC9C,CAAC;gBACJ,CAAC;gBACD,IACE,MAAM,CAAC,MAAM,KAAK,SAAS;oBAC3B,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC;oBAC7B,MAAM,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAC1B,CAAC;oBACD,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EACH,uEAAuE;wBACzE,cAAc,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC;qBAC9C,CAAC;gBACJ,CAAC;gBAED,kCAAkC;gBAClC,IAAI,MAAM,CAAC,cAAc,KAAK,IAAI,EAAE,CAAC;oBACnC,IACE,MAAM,CAAC,cAAc,KAAK,SAAS;wBACnC,MAAM,CAAC,aAAa,KAAK,SAAS,EAClC,CAAC;wBACD,OAAO;4BACL,OAAO,EAAE,KAAK;4BACd,KAAK,EACH,0EAA0E;4BAC5E,UAAU,EACR,iGAAiG;4BACnG,OAAO,EACL,kFAAkF;yBACrF,CAAC;oBACJ,CAAC;gBACH,CAAC;gBAED,wFAAwF;gBACxF,IAAI,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC;gBACjC,IAAI,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC;gBACnC,IAAI,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;oBAC/B,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBACtC,cAAc,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;oBACvD,aAAa,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC;gBAC3C,CAAC;gBAED,MAAM,gBAAgB,GAAG,cAAc,IAAI,QAAQ,CAAC;gBACpD,MAAM,SAAS,GAAG,iBAAiB,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC;gBACnE,MAAM,UAAU,GAAG,kBAAkB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACrD,MAAM,SAAS,GAAG,IAAI,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;gBAEjD,sCAAsC;gBACtC,MAAM,OAAO,GAAG,MAAM,mBAAmB,CACvC,OAAO,EACP,aAAa,EACb,MAAM,CAAC,MAAM,EACb,gBAAgB,CACjB,CAAC;gBACF,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,OAAO,EAAE,CAAC;gBACxC,CAAC;gBAED,gFAAgF;gBAChF,IACE,MAAM,CAAC,cAAc,KAAK,IAAI;oBAC9B,MAAM,CAAC,cAAc,KAAK,SAAS;oBACnC,MAAM,CAAC,aAAa,KAAK,SAAS,EAClC,CAAC;oBACD,MAAM,WAAW,GAAG,kBAAkB,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;oBAE9D,0DAA0D;oBAC1D,MAAM,UAAU,GAAa,CAAC,GAAG,UAAU,eAAe,CAAC,CAAC;oBAC5D,MAAM,WAAW,GAAc,CAAC,SAAS,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC;oBACjE,IAAI,UAAU,GAAG,CAAC,CAAC,CAAC,kCAAkC;oBAEtD,IAAI,MAAM,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;wBAC3C,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE,CAAC;4BAClE,UAAU,CAAC,IAAI,CACb,GAAG,kBAAkB,CAAC,GAAG,CAAC,OAAO,MAAM,CAAC,UAAU,CAAC,EAAE,CACtD,CAAC;4BACF,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;4BACtB,UAAU,EAAE,CAAC;wBACf,CAAC;oBACH,CAAC;oBAED,MAAM,GAAG,GAAG,UAAU,SAAS,QAAQ,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,WAAW,OAAO,CAAC;oBACzF,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;oBAE5D,IAAI,MAAM,CAAC,YAAY,KAAK,CAAC,EAAE,CAAC;wBAC9B,OAAO;4BACL,OAAO,EAAE,KAAK;4BACd,KAAK,EAAE,qBAAqB,MAAM,CAAC,cAAc,MAAM,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE;4BACrF,UAAU,EACR,iGAAiG;yBACpG,CAAC;oBACJ,CAAC;oBAED,OAAO;wBACL,OAAO,EAAE,IAAI;wBACb,YAAY,EAAE,MAAM,CAAC,YAAY;wBACjC,IAAI,EAAE,QAAQ;wBACd,cAAc,EAAE,UAAU,CAAC,MAAM;qBAClC,CAAC;gBACJ,CAAC;gBAED,uBAAuB;gBACvB,MAAM,OAAO,GAAG,CAAC,UAAU,CAAC,CAAC;gBAC7B,MAAM,MAAM,GAAG,CAAC,SAAS,CAAC,CAAC;gBAC3B,MAAM,OAAO,GAAc,EAAE,CAAC;gBAC9B,IAAI,UAAU,GAAG,CAAC,CAAC;gBAEnB,IAAI,MAAM,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;oBAC3C,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE,CAAC;wBAClE,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC;wBACtC,MAAM,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;wBACxC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBACpB,CAAC;gBACH,CAAC;gBAED,MAAM,GAAG,GAAG,eAAe,SAAS,KAAK,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,SAAS,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC;gBACrJ,IAAI,CAAC;oBACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;oBACxD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,MAAM,CAAC,YAAY,EAAE,CAAC;gBAC9D,CAAC;gBAAC,OAAO,KAAc,EAAE,CAAC;oBACxB,4DAA4D;oBAC5D,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;wBAC3B,MAAM,QAAQ,GAAG,uCAAuC,CAAC,IAAI,CAC3D,KAAK,CAAC,OAAO,CACd,CAAC;wBACF,IAAI,QAAQ,EAAE,CAAC;4BACb,MAAM,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;4BACvC,MAAM,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;4BACvC,OAAO;gCACL,OAAO,EAAE,KAAK;gCACd,KAAK,EAAE,2BAA2B;gCAClC,kBAAkB,EAAE,QAAQ,CAAC,WAAW,EAAE,EAAE,CAAC;gCAC7C,kBAAkB,EAAE,QAAQ,CAAC,WAAW,EAAE,EAAE,CAAC;gCAC7C,UAAU,EAAE,kBAAkB,WAAW,8BAA8B,WAAW,2CAA2C;6BAC9H,CAAC;wBACJ,CAAC;wBACD,0CAA0C;wBAC1C,IACE,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC;4BAClC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAC,EAC9C,CAAC;4BACD,OAAO;gCACL,OAAO,EAAE,KAAK;gCACd,KAAK,EAAE,+BAA+B;gCACtC,QAAQ,EAAE,KAAK,CAAC,OAAO;gCACvB,UAAU,EACR,6HAA6H;6BAChI,CAAC;wBACJ,CAAC;wBACD,mDAAmD;wBACnD,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC;4BAC7C,OAAO;gCACL,OAAO,EAAE,KAAK;gCACd,KAAK,EAAE,KAAK,CAAC,OAAO;gCACpB,UAAU,EACR,8EAA8E;6BACjF,CAAC;wBACJ,CAAC;oBACH,CAAC;oBACD,MAAM,KAAK,CAAC;gBACd,CAAC;YACH,CAAC;YAAC,OAAO,KAAc,EAAE,CAAC;gBACxB,OAAO;oBACL,OAAO,EAAE,KAAc;oBACvB,KAAK,EAAE,mBAAmB,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC;iBAChE,CAAC;YACJ,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC;AACD,MAAM,UAAU,2BAA2B,CACzC,OAAwB;IAExB,wDAAwD;IACxD,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC;QACrC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC;QACnD,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QAC5D,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC;QACvD,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,kBAAkB,CAAC;QACvD,OAAO,EAAE,CAAC;aACP,KAAK,CACJ,CAAC,CAAC,MAAM,CAAC;YACP,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;YAC3B,IAAI,EAAE,CAAC;iBACJ,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;iBAC/B,QAAQ,EAAE;iBACV,QAAQ,CAAC,0BAA0B,CAAC;SACxC,CAAC,CACH;aACA,QAAQ,CAAC,gDAAgD,CAAC;QAC7D,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,mCAAmC,CAAC;KAC5E,CAAC,CAAC;IAEH,uDAAuD;IACvD,MAAM,iBAAiB,GAAG,qBAAqB,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACnE,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,IAAI,EAAE;QACzC,MAAM,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,GAAG,IAAI,EAAE;QACrC,OAAO,EAAE,IAAI,CAAC,OAAO;QACrB,MAAM,EAAE,IAAI,CAAC,MAAM;KACpB,CAAC,CAAC,CAAC;IAEJ,OAAO;QACL,IAAI,EAAE,wBAAwB;QAC9B,WAAW,EACT,wLAAwL;QAC1L,KAAK,EAAE,QAAQ;QACf,qCAAqC;QACrC,WAAW,EAAE,qBAAqB;QAClC,WAAW,EAAE,KAAK,CAAC,sBAAsB,CAAC;QAC1C,KAAK,EAAE,YAAY,CAAC,QAAQ,EAAE,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC5D,OAAO,EAAE,KAAK,EAAE,MAAe,EAAE,QAAwB,EAAE,EAAE;YAC3D,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,iBAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBAE/C,wFAAwF;gBACxF,IAAI,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC;gBACjC,IAAI,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC;gBACnC,IAAI,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;oBAC/B,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBACtC,cAAc,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;oBACvD,aAAa,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC;gBAC3C,CAAC;gBAED,MAAM,SAAS,GAAG,iBAAiB,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC;gBACnE,MAAM,UAAU,GAAG,kBAAkB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBAErD,4CAA4C;gBAC5C,MAAM,cAAc,GAAG,MAAM,mBAAmB,CAC9C,OAAO,EACP,aAAa,EACb,MAAM,CAAC,MAAM,EACb,cAAc,IAAI,QAAQ,CAC3B,CAAC;gBACF,IAAI,cAAc,KAAK,IAAI,EAAE,CAAC;oBAC5B,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,cAAc,EAAE,CAAC;gBAC/C,CAAC;gBAED,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBAChC,OAAO;wBACL,OAAO,EAAE,IAAI;wBACb,YAAY,EAAE,CAAC;wBACf,OAAO,EAAE,sBAAsB;qBAChC,CAAC;gBACJ,CAAC;gBAED,wCAAwC;gBACxC,MAAM,WAAW,GAAG,IAAI,GAAG,EAAU,CAAC;gBACtC,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;oBAC/B,IAAI,CAAC,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;wBACzB,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;4BACpC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;wBACrB,CAAC;oBACH,CAAC;gBACH,CAAC;gBACD,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAE5C,MAAM,OAAO,GAAG;oBACd,UAAU;oBACV,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;iBACjD,CAAC;gBACF,MAAM,SAAS,GAAa,EAAE,CAAC;gBAC/B,MAAM,SAAS,GAAc,EAAE,CAAC;gBAChC,IAAI,UAAU,GAAG,CAAC,CAAC;gBAEnB,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;oBAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;oBACxD,MAAM,SAAS,GAAG,CAAC,SAAS,CAAC,CAAC;oBAE9B,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;wBAC9B,SAAS,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC,GAAG,CAAC,CAAC;wBAC5C,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC;oBACxC,CAAC;oBAED,SAAS,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC9C,CAAC;gBAED,MAAM,GAAG,GAAG,eAAe,SAAS,KAAK,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC/F,IAAI,CAAC;oBACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;oBAC1D,OAAO;wBACL,OAAO,EAAE,IAAI;wBACb,YAAY,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM;wBACnC,YAAY,EAAE,MAAM,CAAC,YAAY;qBAClC,CAAC;gBACJ,CAAC;gBAAC,OAAO,KAAc,EAAE,CAAC;oBACxB,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;wBAC3B,MAAM,QAAQ,GAAG,uCAAuC,CAAC,IAAI,CAC3D,KAAK,CAAC,OAAO,CACd,CAAC;wBACF,IAAI,QAAQ,EAAE,CAAC;4BACb,MAAM,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;4BACvC,MAAM,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;4BACvC,OAAO;gCACL,OAAO,EAAE,KAAK;gCACd,KAAK,EAAE,2BAA2B;gCAClC,kBAAkB,EAAE,QAAQ,CAAC,WAAW,EAAE,EAAE,CAAC;gCAC7C,kBAAkB,EAAE,QAAQ,CAAC,WAAW,EAAE,EAAE,CAAC;gCAC7C,UAAU,EAAE,kBAAkB,WAAW,gCAAgC,WAAW,4CAA4C;6BACjI,CAAC;wBACJ,CAAC;oBACH,CAAC;oBACD,MAAM,KAAK,CAAC;gBACd,CAAC;YACH,CAAC;YAAC,OAAO,KAAc,EAAE,CAAC;gBACxB,OAAO;oBACL,OAAO,EAAE,KAAc;oBACvB,KAAK,EAAE,mBAAmB,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,wBAAwB,EAAE,CAAC;iBACtE,CAAC;YACJ,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/vector/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/vector/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAiCjE;;GAEG;AACH,wBAAgB,cAAc,CAAC,OAAO,EAAE,eAAe,GAAG,cAAc,EAAE,CAmBzE"}
|
|
@@ -5,8 +5,12 @@
|
|
|
5
5
|
* 16 tools total.
|
|
6
6
|
*/
|
|
7
7
|
// Import from sub-modules
|
|
8
|
-
import { createVectorExtensionTool, createVectorAddColumnTool, createVectorInsertTool,
|
|
9
|
-
import {
|
|
8
|
+
import { createVectorExtensionTool, createVectorAddColumnTool, createVectorInsertTool, createVectorBatchInsertTool, } from "./data.js";
|
|
9
|
+
import { createVectorSearchTool, createVectorCreateIndexTool, createVectorDistanceTool, createVectorNormalizeTool, createVectorAggregateTool, createVectorValidateTool, } from "./query.js";
|
|
10
|
+
// Search & analysis operations
|
|
11
|
+
import { createVectorClusterTool, createHybridSearchTool, createVectorPerformanceTool, } from "./search-advanced.js";
|
|
12
|
+
// Index & utility management
|
|
13
|
+
import { createVectorIndexOptimizeTool, createVectorDimensionReduceTool, createVectorEmbedTool, } from "./management.js";
|
|
10
14
|
/**
|
|
11
15
|
* Get all pgvector tools
|
|
12
16
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/vector/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,0BAA0B;AAC1B,OAAO,EACL,yBAAyB,EACzB,yBAAyB,EACzB,sBAAsB,EACtB,sBAAsB,EACtB,2BAA2B,EAC3B,wBAAwB,EACxB,yBAAyB,EACzB,yBAAyB,EACzB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/vector/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,0BAA0B;AAC1B,OAAO,EACL,yBAAyB,EACzB,yBAAyB,EACzB,sBAAsB,EACtB,2BAA2B,GAC5B,MAAM,WAAW,CAAC;AAEnB,OAAO,EACL,sBAAsB,EACtB,2BAA2B,EAC3B,wBAAwB,EACxB,yBAAyB,EACzB,yBAAyB,EACzB,wBAAwB,GACzB,MAAM,YAAY,CAAC;AAEpB,+BAA+B;AAC/B,OAAO,EACL,uBAAuB,EACvB,sBAAsB,EACtB,2BAA2B,GAC5B,MAAM,sBAAsB,CAAC;AAE9B,6BAA6B;AAC7B,OAAO,EACL,6BAA6B,EAC7B,+BAA+B,EAC/B,qBAAqB,GACtB,MAAM,iBAAiB,CAAC;AAEzB;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,OAAwB;IACrD,OAAO;QACL,yBAAyB,CAAC,OAAO,CAAC;QAClC,yBAAyB,CAAC,OAAO,CAAC;QAClC,sBAAsB,CAAC,OAAO,CAAC;QAC/B,2BAA2B,CAAC,OAAO,CAAC;QACpC,sBAAsB,CAAC,OAAO,CAAC;QAC/B,2BAA2B,CAAC,OAAO,CAAC;QACpC,wBAAwB,CAAC,OAAO,CAAC;QACjC,yBAAyB,EAAE;QAC3B,yBAAyB,CAAC,OAAO,CAAC;QAClC,wBAAwB,CAAC,OAAO,CAAC;QACjC,uBAAuB,CAAC,OAAO,CAAC;QAChC,6BAA6B,CAAC,OAAO,CAAC;QACtC,sBAAsB,CAAC,OAAO,CAAC;QAC/B,2BAA2B,CAAC,OAAO,CAAC;QACpC,+BAA+B,CAAC,OAAO,CAAC;QACxC,qBAAqB,EAAE;KACxB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL pgvector - Index & Utility Management
|
|
3
|
+
*
|
|
4
|
+
* Management tools: indexOptimize, dimensionReduce, embed.
|
|
5
|
+
*/
|
|
6
|
+
import type { PostgresAdapter } from "../../PostgresAdapter.js";
|
|
7
|
+
import type { ToolDefinition } from "../../../../types/index.js";
|
|
8
|
+
export declare function createVectorIndexOptimizeTool(adapter: PostgresAdapter): ToolDefinition;
|
|
9
|
+
export declare function createVectorDimensionReduceTool(adapter: PostgresAdapter): ToolDefinition;
|
|
10
|
+
export declare function createVectorEmbedTool(): ToolDefinition;
|
|
11
|
+
//# sourceMappingURL=management.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"management.d.ts","sourceRoot":"","sources":["../../../../../src/adapters/postgresql/tools/vector/management.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,EACV,cAAc,EAEf,MAAM,4BAA4B,CAAC;AAgBpC,wBAAgB,6BAA6B,CAC3C,OAAO,EAAE,eAAe,GACvB,cAAc,CAwJhB;AAED,wBAAgB,+BAA+B,CAC7C,OAAO,EAAE,eAAe,GACvB,cAAc,CA0PhB;AAED,wBAAgB,qBAAqB,IAAI,cAAc,CAsFtD"}
|