sqlspec 0.36.0__cp310-cp310-manylinux2014_aarch64.manylinux_2_17_aarch64.manylinux_2_28_aarch64.whl
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.
- ac8f31065839703b4e70__mypyc.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/__init__.py +140 -0
- sqlspec/__main__.py +12 -0
- sqlspec/__metadata__.py +14 -0
- sqlspec/_serialization.py +315 -0
- sqlspec/_typing.py +700 -0
- sqlspec/adapters/__init__.py +0 -0
- sqlspec/adapters/adbc/__init__.py +5 -0
- sqlspec/adapters/adbc/_typing.py +82 -0
- sqlspec/adapters/adbc/adk/__init__.py +5 -0
- sqlspec/adapters/adbc/adk/store.py +1273 -0
- sqlspec/adapters/adbc/config.py +295 -0
- sqlspec/adapters/adbc/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/adbc/core.py +735 -0
- sqlspec/adapters/adbc/data_dictionary.py +334 -0
- sqlspec/adapters/adbc/driver.py +529 -0
- sqlspec/adapters/adbc/events/__init__.py +5 -0
- sqlspec/adapters/adbc/events/store.py +285 -0
- sqlspec/adapters/adbc/litestar/__init__.py +5 -0
- sqlspec/adapters/adbc/litestar/store.py +502 -0
- sqlspec/adapters/adbc/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/adbc/type_converter.py +140 -0
- sqlspec/adapters/aiosqlite/__init__.py +25 -0
- sqlspec/adapters/aiosqlite/_typing.py +82 -0
- sqlspec/adapters/aiosqlite/adk/__init__.py +5 -0
- sqlspec/adapters/aiosqlite/adk/store.py +818 -0
- sqlspec/adapters/aiosqlite/config.py +334 -0
- sqlspec/adapters/aiosqlite/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/aiosqlite/core.py +315 -0
- sqlspec/adapters/aiosqlite/data_dictionary.py +208 -0
- sqlspec/adapters/aiosqlite/driver.py +313 -0
- sqlspec/adapters/aiosqlite/events/__init__.py +5 -0
- sqlspec/adapters/aiosqlite/events/store.py +20 -0
- sqlspec/adapters/aiosqlite/litestar/__init__.py +5 -0
- sqlspec/adapters/aiosqlite/litestar/store.py +279 -0
- sqlspec/adapters/aiosqlite/pool.py +533 -0
- sqlspec/adapters/asyncmy/__init__.py +21 -0
- sqlspec/adapters/asyncmy/_typing.py +87 -0
- sqlspec/adapters/asyncmy/adk/__init__.py +5 -0
- sqlspec/adapters/asyncmy/adk/store.py +703 -0
- sqlspec/adapters/asyncmy/config.py +302 -0
- sqlspec/adapters/asyncmy/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/asyncmy/core.py +360 -0
- sqlspec/adapters/asyncmy/data_dictionary.py +124 -0
- sqlspec/adapters/asyncmy/driver.py +383 -0
- sqlspec/adapters/asyncmy/events/__init__.py +5 -0
- sqlspec/adapters/asyncmy/events/store.py +104 -0
- sqlspec/adapters/asyncmy/litestar/__init__.py +5 -0
- sqlspec/adapters/asyncmy/litestar/store.py +296 -0
- sqlspec/adapters/asyncpg/__init__.py +19 -0
- sqlspec/adapters/asyncpg/_typing.py +88 -0
- sqlspec/adapters/asyncpg/adk/__init__.py +5 -0
- sqlspec/adapters/asyncpg/adk/store.py +748 -0
- sqlspec/adapters/asyncpg/config.py +569 -0
- sqlspec/adapters/asyncpg/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/asyncpg/core.py +367 -0
- sqlspec/adapters/asyncpg/data_dictionary.py +162 -0
- sqlspec/adapters/asyncpg/driver.py +487 -0
- sqlspec/adapters/asyncpg/events/__init__.py +6 -0
- sqlspec/adapters/asyncpg/events/backend.py +286 -0
- sqlspec/adapters/asyncpg/events/store.py +40 -0
- sqlspec/adapters/asyncpg/litestar/__init__.py +5 -0
- sqlspec/adapters/asyncpg/litestar/store.py +251 -0
- sqlspec/adapters/bigquery/__init__.py +14 -0
- sqlspec/adapters/bigquery/_typing.py +86 -0
- sqlspec/adapters/bigquery/adk/__init__.py +5 -0
- sqlspec/adapters/bigquery/adk/store.py +827 -0
- sqlspec/adapters/bigquery/config.py +353 -0
- sqlspec/adapters/bigquery/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/bigquery/core.py +715 -0
- sqlspec/adapters/bigquery/data_dictionary.py +128 -0
- sqlspec/adapters/bigquery/driver.py +548 -0
- sqlspec/adapters/bigquery/events/__init__.py +5 -0
- sqlspec/adapters/bigquery/events/store.py +139 -0
- sqlspec/adapters/bigquery/litestar/__init__.py +5 -0
- sqlspec/adapters/bigquery/litestar/store.py +325 -0
- sqlspec/adapters/bigquery/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/bigquery/type_converter.py +107 -0
- sqlspec/adapters/cockroach_asyncpg/__init__.py +24 -0
- sqlspec/adapters/cockroach_asyncpg/_typing.py +72 -0
- sqlspec/adapters/cockroach_asyncpg/adk/__init__.py +3 -0
- sqlspec/adapters/cockroach_asyncpg/adk/store.py +410 -0
- sqlspec/adapters/cockroach_asyncpg/config.py +238 -0
- sqlspec/adapters/cockroach_asyncpg/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/cockroach_asyncpg/core.py +55 -0
- sqlspec/adapters/cockroach_asyncpg/data_dictionary.py +107 -0
- sqlspec/adapters/cockroach_asyncpg/driver.py +144 -0
- sqlspec/adapters/cockroach_asyncpg/events/__init__.py +3 -0
- sqlspec/adapters/cockroach_asyncpg/events/store.py +20 -0
- sqlspec/adapters/cockroach_asyncpg/litestar/__init__.py +3 -0
- sqlspec/adapters/cockroach_asyncpg/litestar/store.py +142 -0
- sqlspec/adapters/cockroach_psycopg/__init__.py +38 -0
- sqlspec/adapters/cockroach_psycopg/_typing.py +129 -0
- sqlspec/adapters/cockroach_psycopg/adk/__init__.py +13 -0
- sqlspec/adapters/cockroach_psycopg/adk/store.py +868 -0
- sqlspec/adapters/cockroach_psycopg/config.py +484 -0
- sqlspec/adapters/cockroach_psycopg/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/cockroach_psycopg/core.py +63 -0
- sqlspec/adapters/cockroach_psycopg/data_dictionary.py +215 -0
- sqlspec/adapters/cockroach_psycopg/driver.py +284 -0
- sqlspec/adapters/cockroach_psycopg/events/__init__.py +6 -0
- sqlspec/adapters/cockroach_psycopg/events/store.py +34 -0
- sqlspec/adapters/cockroach_psycopg/litestar/__init__.py +3 -0
- sqlspec/adapters/cockroach_psycopg/litestar/store.py +325 -0
- sqlspec/adapters/duckdb/__init__.py +25 -0
- sqlspec/adapters/duckdb/_typing.py +81 -0
- sqlspec/adapters/duckdb/adk/__init__.py +14 -0
- sqlspec/adapters/duckdb/adk/store.py +850 -0
- sqlspec/adapters/duckdb/config.py +463 -0
- sqlspec/adapters/duckdb/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/duckdb/core.py +257 -0
- sqlspec/adapters/duckdb/data_dictionary.py +140 -0
- sqlspec/adapters/duckdb/driver.py +430 -0
- sqlspec/adapters/duckdb/events/__init__.py +5 -0
- sqlspec/adapters/duckdb/events/store.py +57 -0
- sqlspec/adapters/duckdb/litestar/__init__.py +5 -0
- sqlspec/adapters/duckdb/litestar/store.py +330 -0
- sqlspec/adapters/duckdb/pool.py +293 -0
- sqlspec/adapters/duckdb/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/duckdb/type_converter.py +118 -0
- sqlspec/adapters/mock/__init__.py +72 -0
- sqlspec/adapters/mock/_typing.py +147 -0
- sqlspec/adapters/mock/config.py +483 -0
- sqlspec/adapters/mock/core.py +319 -0
- sqlspec/adapters/mock/data_dictionary.py +366 -0
- sqlspec/adapters/mock/driver.py +721 -0
- sqlspec/adapters/mysqlconnector/__init__.py +36 -0
- sqlspec/adapters/mysqlconnector/_typing.py +141 -0
- sqlspec/adapters/mysqlconnector/adk/__init__.py +15 -0
- sqlspec/adapters/mysqlconnector/adk/store.py +1060 -0
- sqlspec/adapters/mysqlconnector/config.py +394 -0
- sqlspec/adapters/mysqlconnector/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/mysqlconnector/core.py +303 -0
- sqlspec/adapters/mysqlconnector/data_dictionary.py +235 -0
- sqlspec/adapters/mysqlconnector/driver.py +483 -0
- sqlspec/adapters/mysqlconnector/events/__init__.py +8 -0
- sqlspec/adapters/mysqlconnector/events/store.py +98 -0
- sqlspec/adapters/mysqlconnector/litestar/__init__.py +5 -0
- sqlspec/adapters/mysqlconnector/litestar/store.py +426 -0
- sqlspec/adapters/oracledb/__init__.py +60 -0
- sqlspec/adapters/oracledb/_numpy_handlers.py +141 -0
- sqlspec/adapters/oracledb/_typing.py +182 -0
- sqlspec/adapters/oracledb/_uuid_handlers.py +166 -0
- sqlspec/adapters/oracledb/adk/__init__.py +10 -0
- sqlspec/adapters/oracledb/adk/store.py +2369 -0
- sqlspec/adapters/oracledb/config.py +550 -0
- sqlspec/adapters/oracledb/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/oracledb/core.py +543 -0
- sqlspec/adapters/oracledb/data_dictionary.py +536 -0
- sqlspec/adapters/oracledb/driver.py +1229 -0
- sqlspec/adapters/oracledb/events/__init__.py +16 -0
- sqlspec/adapters/oracledb/events/backend.py +347 -0
- sqlspec/adapters/oracledb/events/store.py +420 -0
- sqlspec/adapters/oracledb/litestar/__init__.py +5 -0
- sqlspec/adapters/oracledb/litestar/store.py +781 -0
- sqlspec/adapters/oracledb/migrations.py +535 -0
- sqlspec/adapters/oracledb/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/oracledb/type_converter.py +211 -0
- sqlspec/adapters/psqlpy/__init__.py +17 -0
- sqlspec/adapters/psqlpy/_typing.py +79 -0
- sqlspec/adapters/psqlpy/adk/__init__.py +5 -0
- sqlspec/adapters/psqlpy/adk/store.py +766 -0
- sqlspec/adapters/psqlpy/config.py +304 -0
- sqlspec/adapters/psqlpy/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/psqlpy/core.py +480 -0
- sqlspec/adapters/psqlpy/data_dictionary.py +126 -0
- sqlspec/adapters/psqlpy/driver.py +438 -0
- sqlspec/adapters/psqlpy/events/__init__.py +6 -0
- sqlspec/adapters/psqlpy/events/backend.py +310 -0
- sqlspec/adapters/psqlpy/events/store.py +20 -0
- sqlspec/adapters/psqlpy/litestar/__init__.py +5 -0
- sqlspec/adapters/psqlpy/litestar/store.py +270 -0
- sqlspec/adapters/psqlpy/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/psqlpy/type_converter.py +113 -0
- sqlspec/adapters/psycopg/__init__.py +32 -0
- sqlspec/adapters/psycopg/_typing.py +164 -0
- sqlspec/adapters/psycopg/adk/__init__.py +10 -0
- sqlspec/adapters/psycopg/adk/store.py +1387 -0
- sqlspec/adapters/psycopg/config.py +576 -0
- sqlspec/adapters/psycopg/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/psycopg/core.py +450 -0
- sqlspec/adapters/psycopg/data_dictionary.py +289 -0
- sqlspec/adapters/psycopg/driver.py +975 -0
- sqlspec/adapters/psycopg/events/__init__.py +20 -0
- sqlspec/adapters/psycopg/events/backend.py +458 -0
- sqlspec/adapters/psycopg/events/store.py +42 -0
- sqlspec/adapters/psycopg/litestar/__init__.py +5 -0
- sqlspec/adapters/psycopg/litestar/store.py +552 -0
- sqlspec/adapters/psycopg/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/psycopg/type_converter.py +93 -0
- sqlspec/adapters/pymysql/__init__.py +21 -0
- sqlspec/adapters/pymysql/_typing.py +71 -0
- sqlspec/adapters/pymysql/adk/__init__.py +5 -0
- sqlspec/adapters/pymysql/adk/store.py +540 -0
- sqlspec/adapters/pymysql/config.py +195 -0
- sqlspec/adapters/pymysql/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/pymysql/core.py +299 -0
- sqlspec/adapters/pymysql/data_dictionary.py +122 -0
- sqlspec/adapters/pymysql/driver.py +259 -0
- sqlspec/adapters/pymysql/events/__init__.py +5 -0
- sqlspec/adapters/pymysql/events/store.py +50 -0
- sqlspec/adapters/pymysql/litestar/__init__.py +5 -0
- sqlspec/adapters/pymysql/litestar/store.py +232 -0
- sqlspec/adapters/pymysql/pool.py +137 -0
- sqlspec/adapters/spanner/__init__.py +40 -0
- sqlspec/adapters/spanner/_typing.py +86 -0
- sqlspec/adapters/spanner/adk/__init__.py +5 -0
- sqlspec/adapters/spanner/adk/store.py +732 -0
- sqlspec/adapters/spanner/config.py +352 -0
- sqlspec/adapters/spanner/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/spanner/core.py +188 -0
- sqlspec/adapters/spanner/data_dictionary.py +120 -0
- sqlspec/adapters/spanner/dialect/__init__.py +6 -0
- sqlspec/adapters/spanner/dialect/_spangres.py +57 -0
- sqlspec/adapters/spanner/dialect/_spanner.py +130 -0
- sqlspec/adapters/spanner/driver.py +373 -0
- sqlspec/adapters/spanner/events/__init__.py +5 -0
- sqlspec/adapters/spanner/events/store.py +187 -0
- sqlspec/adapters/spanner/litestar/__init__.py +5 -0
- sqlspec/adapters/spanner/litestar/store.py +291 -0
- sqlspec/adapters/spanner/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/spanner/type_converter.py +331 -0
- sqlspec/adapters/sqlite/__init__.py +19 -0
- sqlspec/adapters/sqlite/_typing.py +80 -0
- sqlspec/adapters/sqlite/adk/__init__.py +5 -0
- sqlspec/adapters/sqlite/adk/store.py +958 -0
- sqlspec/adapters/sqlite/config.py +280 -0
- sqlspec/adapters/sqlite/core.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/sqlite/core.py +312 -0
- sqlspec/adapters/sqlite/data_dictionary.py +202 -0
- sqlspec/adapters/sqlite/driver.py +359 -0
- sqlspec/adapters/sqlite/events/__init__.py +5 -0
- sqlspec/adapters/sqlite/events/store.py +20 -0
- sqlspec/adapters/sqlite/litestar/__init__.py +5 -0
- sqlspec/adapters/sqlite/litestar/store.py +316 -0
- sqlspec/adapters/sqlite/pool.py +198 -0
- sqlspec/adapters/sqlite/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/adapters/sqlite/type_converter.py +114 -0
- sqlspec/base.py +747 -0
- sqlspec/builder/__init__.py +179 -0
- sqlspec/builder/_base.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_base.py +1022 -0
- sqlspec/builder/_column.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_column.py +521 -0
- sqlspec/builder/_ddl.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_ddl.py +1642 -0
- sqlspec/builder/_delete.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_delete.py +95 -0
- sqlspec/builder/_dml.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_dml.py +365 -0
- sqlspec/builder/_explain.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_explain.py +579 -0
- sqlspec/builder/_expression_wrappers.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_expression_wrappers.py +46 -0
- sqlspec/builder/_factory.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_factory.py +1697 -0
- sqlspec/builder/_insert.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_insert.py +328 -0
- sqlspec/builder/_join.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_join.py +499 -0
- sqlspec/builder/_merge.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_merge.py +821 -0
- sqlspec/builder/_parsing_utils.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_parsing_utils.py +297 -0
- sqlspec/builder/_select.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_select.py +1660 -0
- sqlspec/builder/_temporal.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_temporal.py +139 -0
- sqlspec/builder/_update.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/builder/_update.py +173 -0
- sqlspec/builder/_vector_expressions.py +267 -0
- sqlspec/cli.py +911 -0
- sqlspec/config.py +1755 -0
- sqlspec/core/__init__.py +374 -0
- sqlspec/core/_correlation.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/_correlation.py +176 -0
- sqlspec/core/cache.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/cache.py +1069 -0
- sqlspec/core/compiler.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/compiler.py +954 -0
- sqlspec/core/explain.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/explain.py +275 -0
- sqlspec/core/filters.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/filters.py +952 -0
- sqlspec/core/hashing.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/hashing.py +262 -0
- sqlspec/core/metrics.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/metrics.py +83 -0
- sqlspec/core/parameters/__init__.py +71 -0
- sqlspec/core/parameters/_alignment.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/parameters/_alignment.py +270 -0
- sqlspec/core/parameters/_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/parameters/_converter.py +543 -0
- sqlspec/core/parameters/_processor.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/parameters/_processor.py +505 -0
- sqlspec/core/parameters/_registry.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/parameters/_registry.py +206 -0
- sqlspec/core/parameters/_transformers.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/parameters/_transformers.py +292 -0
- sqlspec/core/parameters/_types.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/parameters/_types.py +499 -0
- sqlspec/core/parameters/_validator.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/parameters/_validator.py +180 -0
- sqlspec/core/pipeline.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/pipeline.py +319 -0
- sqlspec/core/query_modifiers.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/query_modifiers.py +437 -0
- sqlspec/core/result/__init__.py +23 -0
- sqlspec/core/result/_base.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/result/_base.py +1121 -0
- sqlspec/core/result/_io.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/result/_io.py +28 -0
- sqlspec/core/splitter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/splitter.py +966 -0
- sqlspec/core/stack.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/stack.py +163 -0
- sqlspec/core/statement.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/statement.py +1503 -0
- sqlspec/core/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/core/type_converter.py +339 -0
- sqlspec/data_dictionary/__init__.py +22 -0
- sqlspec/data_dictionary/_loader.py +123 -0
- sqlspec/data_dictionary/_registry.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/_registry.py +74 -0
- sqlspec/data_dictionary/_types.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/_types.py +121 -0
- sqlspec/data_dictionary/dialects/__init__.py +21 -0
- sqlspec/data_dictionary/dialects/bigquery.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/dialects/bigquery.py +49 -0
- sqlspec/data_dictionary/dialects/cockroachdb.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/dialects/cockroachdb.py +43 -0
- sqlspec/data_dictionary/dialects/duckdb.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/dialects/duckdb.py +47 -0
- sqlspec/data_dictionary/dialects/mysql.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/dialects/mysql.py +42 -0
- sqlspec/data_dictionary/dialects/oracle.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/dialects/oracle.py +34 -0
- sqlspec/data_dictionary/dialects/postgres.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/dialects/postgres.py +46 -0
- sqlspec/data_dictionary/dialects/spanner.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/dialects/spanner.py +37 -0
- sqlspec/data_dictionary/dialects/sqlite.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/data_dictionary/dialects/sqlite.py +42 -0
- sqlspec/data_dictionary/sql/.gitkeep +0 -0
- sqlspec/data_dictionary/sql/bigquery/columns.sql +23 -0
- sqlspec/data_dictionary/sql/bigquery/foreign_keys.sql +34 -0
- sqlspec/data_dictionary/sql/bigquery/indexes.sql +19 -0
- sqlspec/data_dictionary/sql/bigquery/tables.sql +33 -0
- sqlspec/data_dictionary/sql/bigquery/version.sql +3 -0
- sqlspec/data_dictionary/sql/cockroachdb/columns.sql +34 -0
- sqlspec/data_dictionary/sql/cockroachdb/foreign_keys.sql +40 -0
- sqlspec/data_dictionary/sql/cockroachdb/indexes.sql +32 -0
- sqlspec/data_dictionary/sql/cockroachdb/tables.sql +44 -0
- sqlspec/data_dictionary/sql/cockroachdb/version.sql +3 -0
- sqlspec/data_dictionary/sql/duckdb/columns.sql +23 -0
- sqlspec/data_dictionary/sql/duckdb/foreign_keys.sql +36 -0
- sqlspec/data_dictionary/sql/duckdb/indexes.sql +19 -0
- sqlspec/data_dictionary/sql/duckdb/tables.sql +38 -0
- sqlspec/data_dictionary/sql/duckdb/version.sql +3 -0
- sqlspec/data_dictionary/sql/mysql/columns.sql +23 -0
- sqlspec/data_dictionary/sql/mysql/foreign_keys.sql +28 -0
- sqlspec/data_dictionary/sql/mysql/indexes.sql +26 -0
- sqlspec/data_dictionary/sql/mysql/tables.sql +33 -0
- sqlspec/data_dictionary/sql/mysql/version.sql +3 -0
- sqlspec/data_dictionary/sql/oracle/columns.sql +23 -0
- sqlspec/data_dictionary/sql/oracle/foreign_keys.sql +48 -0
- sqlspec/data_dictionary/sql/oracle/indexes.sql +44 -0
- sqlspec/data_dictionary/sql/oracle/tables.sql +25 -0
- sqlspec/data_dictionary/sql/oracle/version.sql +20 -0
- sqlspec/data_dictionary/sql/postgres/columns.sql +34 -0
- sqlspec/data_dictionary/sql/postgres/foreign_keys.sql +40 -0
- sqlspec/data_dictionary/sql/postgres/indexes.sql +56 -0
- sqlspec/data_dictionary/sql/postgres/tables.sql +44 -0
- sqlspec/data_dictionary/sql/postgres/version.sql +3 -0
- sqlspec/data_dictionary/sql/spanner/columns.sql +23 -0
- sqlspec/data_dictionary/sql/spanner/foreign_keys.sql +70 -0
- sqlspec/data_dictionary/sql/spanner/indexes.sql +30 -0
- sqlspec/data_dictionary/sql/spanner/tables.sql +9 -0
- sqlspec/data_dictionary/sql/spanner/version.sql +3 -0
- sqlspec/data_dictionary/sql/sqlite/columns.sql +23 -0
- sqlspec/data_dictionary/sql/sqlite/foreign_keys.sql +22 -0
- sqlspec/data_dictionary/sql/sqlite/indexes.sql +7 -0
- sqlspec/data_dictionary/sql/sqlite/tables.sql +28 -0
- sqlspec/data_dictionary/sql/sqlite/version.sql +3 -0
- sqlspec/driver/__init__.py +32 -0
- sqlspec/driver/_async.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/driver/_async.py +1737 -0
- sqlspec/driver/_common.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/driver/_common.py +1478 -0
- sqlspec/driver/_sql_helpers.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/driver/_sql_helpers.py +148 -0
- sqlspec/driver/_storage_helpers.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/driver/_storage_helpers.py +144 -0
- sqlspec/driver/_sync.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/driver/_sync.py +1710 -0
- sqlspec/exceptions.py +338 -0
- sqlspec/extensions/__init__.py +0 -0
- sqlspec/extensions/adk/__init__.py +70 -0
- sqlspec/extensions/adk/_types.py +51 -0
- sqlspec/extensions/adk/converters.py +172 -0
- sqlspec/extensions/adk/memory/__init__.py +69 -0
- sqlspec/extensions/adk/memory/_types.py +30 -0
- sqlspec/extensions/adk/memory/converters.py +149 -0
- sqlspec/extensions/adk/memory/service.py +217 -0
- sqlspec/extensions/adk/memory/store.py +569 -0
- sqlspec/extensions/adk/migrations/0001_create_adk_tables.py +246 -0
- sqlspec/extensions/adk/migrations/__init__.py +0 -0
- sqlspec/extensions/adk/service.py +225 -0
- sqlspec/extensions/adk/store.py +567 -0
- sqlspec/extensions/events/__init__.py +51 -0
- sqlspec/extensions/events/_channel.py +703 -0
- sqlspec/extensions/events/_hints.py +45 -0
- sqlspec/extensions/events/_models.py +23 -0
- sqlspec/extensions/events/_payload.py +69 -0
- sqlspec/extensions/events/_protocols.py +134 -0
- sqlspec/extensions/events/_queue.py +461 -0
- sqlspec/extensions/events/_store.py +209 -0
- sqlspec/extensions/events/migrations/0001_create_event_queue.py +59 -0
- sqlspec/extensions/events/migrations/__init__.py +3 -0
- sqlspec/extensions/fastapi/__init__.py +19 -0
- sqlspec/extensions/fastapi/extension.py +351 -0
- sqlspec/extensions/fastapi/providers.py +607 -0
- sqlspec/extensions/flask/__init__.py +37 -0
- sqlspec/extensions/flask/_state.py +76 -0
- sqlspec/extensions/flask/_utils.py +71 -0
- sqlspec/extensions/flask/extension.py +519 -0
- sqlspec/extensions/litestar/__init__.py +28 -0
- sqlspec/extensions/litestar/_utils.py +52 -0
- sqlspec/extensions/litestar/channels.py +165 -0
- sqlspec/extensions/litestar/cli.py +102 -0
- sqlspec/extensions/litestar/config.py +90 -0
- sqlspec/extensions/litestar/handlers.py +316 -0
- sqlspec/extensions/litestar/migrations/0001_create_session_table.py +137 -0
- sqlspec/extensions/litestar/migrations/__init__.py +3 -0
- sqlspec/extensions/litestar/plugin.py +671 -0
- sqlspec/extensions/litestar/providers.py +526 -0
- sqlspec/extensions/litestar/store.py +296 -0
- sqlspec/extensions/otel/__init__.py +58 -0
- sqlspec/extensions/prometheus/__init__.py +113 -0
- sqlspec/extensions/starlette/__init__.py +19 -0
- sqlspec/extensions/starlette/_state.py +30 -0
- sqlspec/extensions/starlette/_utils.py +96 -0
- sqlspec/extensions/starlette/extension.py +346 -0
- sqlspec/extensions/starlette/middleware.py +235 -0
- sqlspec/loader.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/loader.py +702 -0
- sqlspec/migrations/__init__.py +36 -0
- sqlspec/migrations/base.py +731 -0
- sqlspec/migrations/commands.py +1232 -0
- sqlspec/migrations/context.py +157 -0
- sqlspec/migrations/fix.py +204 -0
- sqlspec/migrations/loaders.py +443 -0
- sqlspec/migrations/runner.py +1172 -0
- sqlspec/migrations/templates.py +234 -0
- sqlspec/migrations/tracker.py +611 -0
- sqlspec/migrations/utils.py +256 -0
- sqlspec/migrations/validation.py +207 -0
- sqlspec/migrations/version.py +446 -0
- sqlspec/observability/__init__.py +55 -0
- sqlspec/observability/_common.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_common.py +77 -0
- sqlspec/observability/_config.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_config.py +348 -0
- sqlspec/observability/_diagnostics.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_diagnostics.py +74 -0
- sqlspec/observability/_dispatcher.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_dispatcher.py +152 -0
- sqlspec/observability/_formatters/__init__.py +13 -0
- sqlspec/observability/_formatters/_aws.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_formatters/_aws.py +102 -0
- sqlspec/observability/_formatters/_azure.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_formatters/_azure.py +96 -0
- sqlspec/observability/_formatters/_base.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_formatters/_base.py +57 -0
- sqlspec/observability/_formatters/_gcp.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_formatters/_gcp.py +131 -0
- sqlspec/observability/_formatting.py +58 -0
- sqlspec/observability/_observer.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_observer.py +357 -0
- sqlspec/observability/_runtime.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_runtime.py +420 -0
- sqlspec/observability/_sampling.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_sampling.py +188 -0
- sqlspec/observability/_spans.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/observability/_spans.py +161 -0
- sqlspec/protocols.py +916 -0
- sqlspec/py.typed +0 -0
- sqlspec/storage/__init__.py +48 -0
- sqlspec/storage/_utils.py +104 -0
- sqlspec/storage/backends/__init__.py +1 -0
- sqlspec/storage/backends/base.py +253 -0
- sqlspec/storage/backends/fsspec.py +529 -0
- sqlspec/storage/backends/local.py +441 -0
- sqlspec/storage/backends/obstore.py +916 -0
- sqlspec/storage/errors.py +104 -0
- sqlspec/storage/pipeline.py +582 -0
- sqlspec/storage/registry.py +301 -0
- sqlspec/typing.py +395 -0
- sqlspec/utils/__init__.py +7 -0
- sqlspec/utils/arrow_helpers.py +318 -0
- sqlspec/utils/config_tools.py +332 -0
- sqlspec/utils/correlation.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/correlation.py +134 -0
- sqlspec/utils/deprecation.py +190 -0
- sqlspec/utils/fixtures.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/fixtures.py +258 -0
- sqlspec/utils/logging.py +222 -0
- sqlspec/utils/module_loader.py +306 -0
- sqlspec/utils/portal.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/portal.py +375 -0
- sqlspec/utils/schema.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/schema.py +485 -0
- sqlspec/utils/serializers.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/serializers.py +408 -0
- sqlspec/utils/singleton.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/singleton.py +41 -0
- sqlspec/utils/sync_tools.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/sync_tools.py +311 -0
- sqlspec/utils/text.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/text.py +108 -0
- sqlspec/utils/type_converters.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/type_converters.py +128 -0
- sqlspec/utils/type_guards.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/type_guards.py +1360 -0
- sqlspec/utils/uuids.cpython-310-aarch64-linux-gnu.so +0 -0
- sqlspec/utils/uuids.py +225 -0
- sqlspec-0.36.0.dist-info/METADATA +205 -0
- sqlspec-0.36.0.dist-info/RECORD +531 -0
- sqlspec-0.36.0.dist-info/WHEEL +7 -0
- sqlspec-0.36.0.dist-info/entry_points.txt +2 -0
- sqlspec-0.36.0.dist-info/licenses/LICENSE +21 -0
|
@@ -0,0 +1,569 @@
|
|
|
1
|
+
"""AsyncPG database configuration with direct field-based configuration."""
|
|
2
|
+
|
|
3
|
+
from typing import TYPE_CHECKING, Any, ClassVar, TypedDict, cast
|
|
4
|
+
|
|
5
|
+
from asyncpg import Connection, Record
|
|
6
|
+
from asyncpg import create_pool as asyncpg_create_pool
|
|
7
|
+
from asyncpg.connection import ConnectionMeta
|
|
8
|
+
from asyncpg.pool import Pool, PoolConnectionProxy, PoolConnectionProxyMeta
|
|
9
|
+
from mypy_extensions import mypyc_attr
|
|
10
|
+
from typing_extensions import NotRequired
|
|
11
|
+
|
|
12
|
+
from sqlspec.adapters.asyncpg._typing import AsyncpgConnection, AsyncpgPool, AsyncpgPreparedStatement
|
|
13
|
+
from sqlspec.adapters.asyncpg.core import (
|
|
14
|
+
apply_driver_features,
|
|
15
|
+
build_connection_config,
|
|
16
|
+
default_statement_config,
|
|
17
|
+
register_json_codecs,
|
|
18
|
+
register_pgvector_support,
|
|
19
|
+
)
|
|
20
|
+
from sqlspec.adapters.asyncpg.driver import AsyncpgCursor, AsyncpgDriver, AsyncpgExceptionHandler, AsyncpgSessionContext
|
|
21
|
+
from sqlspec.config import AsyncDatabaseConfig, ExtensionConfigs
|
|
22
|
+
from sqlspec.exceptions import ImproperConfigurationError, MissingDependencyError
|
|
23
|
+
from sqlspec.extensions.events import EventRuntimeHints
|
|
24
|
+
from sqlspec.typing import ALLOYDB_CONNECTOR_INSTALLED, CLOUD_SQL_CONNECTOR_INSTALLED, PGVECTOR_INSTALLED
|
|
25
|
+
from sqlspec.utils.config_tools import normalize_connection_config, reject_pool_aliases
|
|
26
|
+
from sqlspec.utils.logging import get_logger
|
|
27
|
+
from sqlspec.utils.serializers import from_json, to_json
|
|
28
|
+
|
|
29
|
+
if TYPE_CHECKING:
|
|
30
|
+
from asyncio.events import AbstractEventLoop
|
|
31
|
+
from collections.abc import Awaitable, Callable
|
|
32
|
+
|
|
33
|
+
from sqlspec.core import StatementConfig
|
|
34
|
+
from sqlspec.observability import ObservabilityConfig
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
__all__ = (
|
|
38
|
+
"PGVECTOR_INSTALLED",
|
|
39
|
+
"AsyncpgConfig",
|
|
40
|
+
"AsyncpgConnectionConfig",
|
|
41
|
+
"AsyncpgDriverFeatures",
|
|
42
|
+
"AsyncpgPoolConfig",
|
|
43
|
+
"register_json_codecs",
|
|
44
|
+
"register_pgvector_support",
|
|
45
|
+
)
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
logger = get_logger(__name__)
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
class AsyncpgConnectionConfig(TypedDict):
|
|
52
|
+
"""TypedDict for AsyncPG connection parameters."""
|
|
53
|
+
|
|
54
|
+
dsn: NotRequired[str]
|
|
55
|
+
host: NotRequired[str]
|
|
56
|
+
port: NotRequired[int]
|
|
57
|
+
user: NotRequired[str]
|
|
58
|
+
password: NotRequired[str]
|
|
59
|
+
database: NotRequired[str]
|
|
60
|
+
ssl: NotRequired[Any]
|
|
61
|
+
passfile: NotRequired[str]
|
|
62
|
+
direct_tls: NotRequired[bool]
|
|
63
|
+
connect_timeout: NotRequired[float]
|
|
64
|
+
command_timeout: NotRequired[float]
|
|
65
|
+
statement_cache_size: NotRequired[int]
|
|
66
|
+
max_cached_statement_lifetime: NotRequired[int]
|
|
67
|
+
max_cacheable_statement_size: NotRequired[int]
|
|
68
|
+
server_settings: NotRequired["dict[str, str]"]
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
class AsyncpgPoolConfig(AsyncpgConnectionConfig):
|
|
72
|
+
"""TypedDict for AsyncPG pool parameters, inheriting connection parameters."""
|
|
73
|
+
|
|
74
|
+
min_size: NotRequired[int]
|
|
75
|
+
max_size: NotRequired[int]
|
|
76
|
+
max_queries: NotRequired[int]
|
|
77
|
+
max_inactive_connection_lifetime: NotRequired[float]
|
|
78
|
+
setup: NotRequired["Callable[[AsyncpgConnection], Awaitable[None]]"]
|
|
79
|
+
init: NotRequired["Callable[[AsyncpgConnection], Awaitable[None]]"]
|
|
80
|
+
loop: NotRequired["AbstractEventLoop"]
|
|
81
|
+
connection_class: NotRequired[type["AsyncpgConnection"]]
|
|
82
|
+
record_class: NotRequired[type[Record]]
|
|
83
|
+
extra: NotRequired["dict[str, Any]"]
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
class AsyncpgDriverFeatures(TypedDict):
|
|
87
|
+
"""AsyncPG driver feature flags.
|
|
88
|
+
|
|
89
|
+
json_serializer: Custom JSON serializer function for PostgreSQL JSON/JSONB types.
|
|
90
|
+
Defaults to sqlspec.utils.serializers.to_json.
|
|
91
|
+
Use for performance optimization (e.g., orjson) or custom encoding behavior.
|
|
92
|
+
Applied when enable_json_codecs is True.
|
|
93
|
+
json_deserializer: Custom JSON deserializer function for PostgreSQL JSON/JSONB types.
|
|
94
|
+
Defaults to sqlspec.utils.serializers.from_json.
|
|
95
|
+
Use for performance optimization (e.g., orjson) or custom decoding behavior.
|
|
96
|
+
Applied when enable_json_codecs is True.
|
|
97
|
+
enable_json_codecs: Enable automatic JSON/JSONB codec registration on connections.
|
|
98
|
+
Defaults to True for seamless Python dict/list to PostgreSQL JSON/JSONB conversion.
|
|
99
|
+
Set to False to disable automatic codec registration (manual handling required).
|
|
100
|
+
enable_pgvector: Enable pgvector extension support for vector similarity search.
|
|
101
|
+
Requires pgvector-python package (pip install pgvector) and PostgreSQL with pgvector extension.
|
|
102
|
+
Defaults to True when pgvector-python is installed.
|
|
103
|
+
Provides automatic conversion between Python objects and PostgreSQL vector types.
|
|
104
|
+
Enables vector similarity operations and index support.
|
|
105
|
+
enable_cloud_sql: Enable Google Cloud SQL connector integration.
|
|
106
|
+
Requires cloud-sql-python-connector package.
|
|
107
|
+
Defaults to False (explicit opt-in required).
|
|
108
|
+
Auto-configures IAM authentication, SSL, and IP routing.
|
|
109
|
+
Mutually exclusive with enable_alloydb.
|
|
110
|
+
cloud_sql_instance: Cloud SQL instance connection name.
|
|
111
|
+
Format: "project:region:instance"
|
|
112
|
+
Required when enable_cloud_sql is True.
|
|
113
|
+
cloud_sql_enable_iam_auth: Enable IAM database authentication.
|
|
114
|
+
Defaults to False for passwordless authentication.
|
|
115
|
+
When False, requires user/password in connection_config.
|
|
116
|
+
cloud_sql_ip_type: IP address type for connection.
|
|
117
|
+
Options: "PUBLIC", "PRIVATE", "PSC"
|
|
118
|
+
Defaults to "PRIVATE".
|
|
119
|
+
enable_alloydb: Enable Google AlloyDB connector integration.
|
|
120
|
+
Requires cloud-alloydb-python-connector package.
|
|
121
|
+
Defaults to False (explicit opt-in required).
|
|
122
|
+
Auto-configures IAM authentication and private networking.
|
|
123
|
+
Mutually exclusive with enable_cloud_sql.
|
|
124
|
+
alloydb_instance_uri: AlloyDB instance URI.
|
|
125
|
+
Format: "projects/PROJECT/locations/REGION/clusters/CLUSTER/instances/INSTANCE"
|
|
126
|
+
Required when enable_alloydb is True.
|
|
127
|
+
alloydb_enable_iam_auth: Enable IAM database authentication.
|
|
128
|
+
Defaults to False for passwordless authentication.
|
|
129
|
+
alloydb_ip_type: IP address type for connection.
|
|
130
|
+
Options: "PUBLIC", "PRIVATE", "PSC"
|
|
131
|
+
Defaults to "PRIVATE".
|
|
132
|
+
enable_events: Enable database event channel support.
|
|
133
|
+
Defaults to True when extension_config["events"] is configured.
|
|
134
|
+
Provides pub/sub capabilities via LISTEN/NOTIFY or table-backed fallback.
|
|
135
|
+
Requires extension_config["events"] for migration setup when using table_queue backend.
|
|
136
|
+
events_backend: Event channel backend selection.
|
|
137
|
+
Options: "listen_notify", "table_queue", "listen_notify_durable"
|
|
138
|
+
- "listen_notify": Zero-copy PostgreSQL LISTEN/NOTIFY (ephemeral, real-time)
|
|
139
|
+
- "table_queue": Durable table-backed queue with retries and exactly-once delivery
|
|
140
|
+
- "listen_notify_durable": Hybrid - combines real-time LISTEN/NOTIFY with table durability (recommended for production)
|
|
141
|
+
Defaults to "listen_notify" for backward compatibility.
|
|
142
|
+
Note: "listen_notify_durable" provides best of both worlds - <100ms latency with full durability.
|
|
143
|
+
"""
|
|
144
|
+
|
|
145
|
+
json_serializer: NotRequired["Callable[[Any], str]"]
|
|
146
|
+
json_deserializer: NotRequired["Callable[[str], Any]"]
|
|
147
|
+
enable_json_codecs: NotRequired[bool]
|
|
148
|
+
enable_pgvector: NotRequired[bool]
|
|
149
|
+
enable_cloud_sql: NotRequired[bool]
|
|
150
|
+
cloud_sql_instance: NotRequired[str]
|
|
151
|
+
cloud_sql_enable_iam_auth: NotRequired[bool]
|
|
152
|
+
cloud_sql_ip_type: NotRequired[str]
|
|
153
|
+
enable_alloydb: NotRequired[bool]
|
|
154
|
+
alloydb_instance_uri: NotRequired[str]
|
|
155
|
+
alloydb_enable_iam_auth: NotRequired[bool]
|
|
156
|
+
alloydb_ip_type: NotRequired[str]
|
|
157
|
+
enable_events: NotRequired[bool]
|
|
158
|
+
events_backend: NotRequired[str]
|
|
159
|
+
connection_instance: NotRequired["AsyncpgPool"]
|
|
160
|
+
on_connection_create: NotRequired["Callable[[AsyncpgConnection], Awaitable[None]]"]
|
|
161
|
+
|
|
162
|
+
|
|
163
|
+
class _AsyncpgCloudSqlConnector:
|
|
164
|
+
__slots__ = ("_config", "_database", "_password", "_user")
|
|
165
|
+
|
|
166
|
+
def __init__(self, config: "AsyncpgConfig", user: str | None, password: str | None, database: str | None) -> None:
|
|
167
|
+
self._config = config
|
|
168
|
+
self._user = user
|
|
169
|
+
self._password = password
|
|
170
|
+
self._database = database
|
|
171
|
+
|
|
172
|
+
async def __call__(self) -> "AsyncpgConnection":
|
|
173
|
+
connector = self._config.get_cloud_sql_connector()
|
|
174
|
+
if connector is None:
|
|
175
|
+
msg = "Cloud SQL connector is not initialized"
|
|
176
|
+
raise ImproperConfigurationError(msg)
|
|
177
|
+
conn_kwargs: dict[str, Any] = {
|
|
178
|
+
"instance_connection_string": self._config.driver_features["cloud_sql_instance"],
|
|
179
|
+
"driver": "asyncpg",
|
|
180
|
+
"enable_iam_auth": self._config.driver_features.get("cloud_sql_enable_iam_auth", False),
|
|
181
|
+
"ip_type": self._config.driver_features.get("cloud_sql_ip_type", "PRIVATE"),
|
|
182
|
+
}
|
|
183
|
+
if self._user:
|
|
184
|
+
conn_kwargs["user"] = self._user
|
|
185
|
+
if self._password:
|
|
186
|
+
conn_kwargs["password"] = self._password
|
|
187
|
+
if self._database:
|
|
188
|
+
conn_kwargs["db"] = self._database
|
|
189
|
+
return cast("AsyncpgConnection", await connector.connect_async(**conn_kwargs))
|
|
190
|
+
|
|
191
|
+
|
|
192
|
+
class _AsyncpgAlloydbConnector:
|
|
193
|
+
__slots__ = ("_config", "_database", "_password", "_user")
|
|
194
|
+
|
|
195
|
+
def __init__(self, config: "AsyncpgConfig", user: str | None, password: str | None, database: str | None) -> None:
|
|
196
|
+
self._config = config
|
|
197
|
+
self._user = user
|
|
198
|
+
self._password = password
|
|
199
|
+
self._database = database
|
|
200
|
+
|
|
201
|
+
async def __call__(self) -> "AsyncpgConnection":
|
|
202
|
+
connector = self._config.get_alloydb_connector()
|
|
203
|
+
if connector is None:
|
|
204
|
+
msg = "AlloyDB connector is not initialized"
|
|
205
|
+
raise ImproperConfigurationError(msg)
|
|
206
|
+
conn_kwargs: dict[str, Any] = {
|
|
207
|
+
"instance_uri": self._config.driver_features["alloydb_instance_uri"],
|
|
208
|
+
"driver": "asyncpg",
|
|
209
|
+
"enable_iam_auth": self._config.driver_features.get("alloydb_enable_iam_auth", False),
|
|
210
|
+
"ip_type": self._config.driver_features.get("alloydb_ip_type", "PRIVATE"),
|
|
211
|
+
}
|
|
212
|
+
if self._user:
|
|
213
|
+
conn_kwargs["user"] = self._user
|
|
214
|
+
if self._password:
|
|
215
|
+
conn_kwargs["password"] = self._password
|
|
216
|
+
if self._database:
|
|
217
|
+
conn_kwargs["db"] = self._database
|
|
218
|
+
return cast("AsyncpgConnection", await connector.connect(**conn_kwargs))
|
|
219
|
+
|
|
220
|
+
|
|
221
|
+
class _AsyncpgSessionFactory:
|
|
222
|
+
__slots__ = ("_config", "_connection")
|
|
223
|
+
|
|
224
|
+
def __init__(self, config: "AsyncpgConfig") -> None:
|
|
225
|
+
self._config = config
|
|
226
|
+
self._connection: AsyncpgConnection | None = None
|
|
227
|
+
|
|
228
|
+
async def acquire_connection(self) -> "AsyncpgConnection":
|
|
229
|
+
pool = self._config.connection_instance
|
|
230
|
+
if pool is None:
|
|
231
|
+
pool = await self._config.create_pool()
|
|
232
|
+
self._config.connection_instance = pool
|
|
233
|
+
self._connection = await pool.acquire()
|
|
234
|
+
return self._connection
|
|
235
|
+
|
|
236
|
+
async def release_connection(self, _conn: "AsyncpgConnection") -> None:
|
|
237
|
+
if self._connection is not None and self._config.connection_instance is not None:
|
|
238
|
+
await self._config.connection_instance.release(self._connection) # type: ignore[arg-type]
|
|
239
|
+
self._connection = None
|
|
240
|
+
|
|
241
|
+
|
|
242
|
+
class AsyncpgConnectionContext:
|
|
243
|
+
"""Async context manager for AsyncPG connections."""
|
|
244
|
+
|
|
245
|
+
__slots__ = ("_config", "_connection")
|
|
246
|
+
|
|
247
|
+
def __init__(self, config: "AsyncpgConfig") -> None:
|
|
248
|
+
self._config = config
|
|
249
|
+
self._connection: AsyncpgConnection | None = None
|
|
250
|
+
|
|
251
|
+
async def __aenter__(self) -> "AsyncpgConnection":
|
|
252
|
+
pool = self._config.connection_instance
|
|
253
|
+
if pool is None:
|
|
254
|
+
pool = await self._config.create_pool()
|
|
255
|
+
self._config.connection_instance = pool
|
|
256
|
+
self._connection = await pool.acquire()
|
|
257
|
+
return self._connection
|
|
258
|
+
|
|
259
|
+
async def __aexit__(
|
|
260
|
+
self, exc_type: "type[BaseException] | None", exc_val: "BaseException | None", exc_tb: Any
|
|
261
|
+
) -> bool | None:
|
|
262
|
+
if self._connection is not None:
|
|
263
|
+
if self._config.connection_instance:
|
|
264
|
+
await self._config.connection_instance.release(self._connection) # type: ignore[arg-type]
|
|
265
|
+
self._connection = None
|
|
266
|
+
return None
|
|
267
|
+
|
|
268
|
+
|
|
269
|
+
@mypyc_attr(native_class=False)
|
|
270
|
+
class AsyncpgConfig(AsyncDatabaseConfig[AsyncpgConnection, "Pool[Record]", AsyncpgDriver]):
|
|
271
|
+
"""Configuration for AsyncPG database connections using TypedDict."""
|
|
272
|
+
|
|
273
|
+
driver_type: "ClassVar[type[AsyncpgDriver]]" = AsyncpgDriver
|
|
274
|
+
connection_type: "ClassVar[type[AsyncpgConnection]]" = type(AsyncpgConnection) # type: ignore[assignment]
|
|
275
|
+
supports_transactional_ddl: "ClassVar[bool]" = True
|
|
276
|
+
supports_native_arrow_export: "ClassVar[bool]" = True
|
|
277
|
+
supports_native_arrow_import: "ClassVar[bool]" = True
|
|
278
|
+
supports_native_parquet_export: "ClassVar[bool]" = True
|
|
279
|
+
supports_native_parquet_import: "ClassVar[bool]" = True
|
|
280
|
+
|
|
281
|
+
def __init__(
|
|
282
|
+
self,
|
|
283
|
+
*,
|
|
284
|
+
connection_config: "AsyncpgPoolConfig | dict[str, Any] | None" = None,
|
|
285
|
+
connection_instance: "Pool[Record] | None" = None,
|
|
286
|
+
migration_config: "dict[str, Any] | None" = None,
|
|
287
|
+
statement_config: "StatementConfig | None" = None,
|
|
288
|
+
driver_features: "AsyncpgDriverFeatures | dict[str, Any] | None" = None,
|
|
289
|
+
bind_key: "str | None" = None,
|
|
290
|
+
extension_config: "ExtensionConfigs | None" = None,
|
|
291
|
+
observability_config: "ObservabilityConfig | None" = None,
|
|
292
|
+
**kwargs: Any,
|
|
293
|
+
) -> None:
|
|
294
|
+
"""Initialize AsyncPG configuration.
|
|
295
|
+
|
|
296
|
+
Args:
|
|
297
|
+
connection_config: Connection and pool configuration parameters (TypedDict or dict)
|
|
298
|
+
connection_instance: Existing pool instance to use
|
|
299
|
+
migration_config: Migration configuration
|
|
300
|
+
statement_config: Statement configuration override
|
|
301
|
+
driver_features: Driver features configuration (TypedDict or dict)
|
|
302
|
+
bind_key: Optional unique identifier for this configuration
|
|
303
|
+
extension_config: Extension-specific configuration (e.g., Litestar plugin settings)
|
|
304
|
+
observability_config: Adapter-level observability overrides for lifecycle hooks and observers
|
|
305
|
+
**kwargs: Additional keyword arguments
|
|
306
|
+
"""
|
|
307
|
+
reject_pool_aliases(kwargs)
|
|
308
|
+
|
|
309
|
+
statement_config = statement_config or default_statement_config
|
|
310
|
+
statement_config, driver_features = apply_driver_features(statement_config, driver_features)
|
|
311
|
+
|
|
312
|
+
super().__init__(
|
|
313
|
+
connection_config=normalize_connection_config(connection_config),
|
|
314
|
+
connection_instance=connection_instance,
|
|
315
|
+
migration_config=migration_config,
|
|
316
|
+
statement_config=statement_config,
|
|
317
|
+
driver_features=driver_features,
|
|
318
|
+
bind_key=bind_key,
|
|
319
|
+
extension_config=extension_config,
|
|
320
|
+
observability_config=observability_config,
|
|
321
|
+
**kwargs,
|
|
322
|
+
)
|
|
323
|
+
|
|
324
|
+
self._cloud_sql_connector: Any | None = None
|
|
325
|
+
self._alloydb_connector: Any | None = None
|
|
326
|
+
self._pgvector_available: bool | None = None
|
|
327
|
+
|
|
328
|
+
self._validate_connector_config()
|
|
329
|
+
|
|
330
|
+
def get_cloud_sql_connector(self) -> Any | None:
|
|
331
|
+
"""Return the configured Cloud SQL connector instance."""
|
|
332
|
+
return self._cloud_sql_connector
|
|
333
|
+
|
|
334
|
+
def get_alloydb_connector(self) -> Any | None:
|
|
335
|
+
"""Return the configured AlloyDB connector instance."""
|
|
336
|
+
return self._alloydb_connector
|
|
337
|
+
|
|
338
|
+
def _validate_connector_config(self) -> None:
|
|
339
|
+
"""Validate Google Cloud connector configuration.
|
|
340
|
+
|
|
341
|
+
Raises:
|
|
342
|
+
ImproperConfigurationError: If configuration is invalid.
|
|
343
|
+
MissingDependencyError: If required connector packages are not installed.
|
|
344
|
+
"""
|
|
345
|
+
enable_cloud_sql = self.driver_features.get("enable_cloud_sql", False)
|
|
346
|
+
enable_alloydb = self.driver_features.get("enable_alloydb", False)
|
|
347
|
+
|
|
348
|
+
match (enable_cloud_sql, enable_alloydb):
|
|
349
|
+
case (True, True):
|
|
350
|
+
msg = (
|
|
351
|
+
"Cannot enable both Cloud SQL and AlloyDB connectors simultaneously. "
|
|
352
|
+
"Use separate configs for each database."
|
|
353
|
+
)
|
|
354
|
+
raise ImproperConfigurationError(msg)
|
|
355
|
+
case (False, False):
|
|
356
|
+
return
|
|
357
|
+
case (True, False):
|
|
358
|
+
if not CLOUD_SQL_CONNECTOR_INSTALLED:
|
|
359
|
+
raise MissingDependencyError(package="cloud-sql-python-connector", install_package="cloud-sql")
|
|
360
|
+
|
|
361
|
+
instance = self.driver_features.get("cloud_sql_instance")
|
|
362
|
+
if not instance:
|
|
363
|
+
msg = "cloud_sql_instance required when enable_cloud_sql is True. Format: 'project:region:instance'"
|
|
364
|
+
raise ImproperConfigurationError(msg)
|
|
365
|
+
|
|
366
|
+
cloud_sql_instance_parts_expected = 2
|
|
367
|
+
if instance.count(":") != cloud_sql_instance_parts_expected:
|
|
368
|
+
msg = f"Invalid Cloud SQL instance format: {instance}. Expected format: 'project:region:instance'"
|
|
369
|
+
raise ImproperConfigurationError(msg)
|
|
370
|
+
case (False, True):
|
|
371
|
+
if not ALLOYDB_CONNECTOR_INSTALLED:
|
|
372
|
+
raise MissingDependencyError(
|
|
373
|
+
package="google-cloud-alloydb-connector", install_package="google-cloud-alloydb-connector"
|
|
374
|
+
)
|
|
375
|
+
|
|
376
|
+
instance_uri = self.driver_features.get("alloydb_instance_uri")
|
|
377
|
+
if not instance_uri:
|
|
378
|
+
msg = "alloydb_instance_uri required when enable_alloydb is True. Format: 'projects/PROJECT/locations/REGION/clusters/CLUSTER/instances/INSTANCE'"
|
|
379
|
+
raise ImproperConfigurationError(msg)
|
|
380
|
+
|
|
381
|
+
if not instance_uri.startswith("projects/"):
|
|
382
|
+
msg = f"Invalid AlloyDB instance URI format: {instance_uri}. Expected format: 'projects/PROJECT/locations/REGION/clusters/CLUSTER/instances/INSTANCE'"
|
|
383
|
+
raise ImproperConfigurationError(msg)
|
|
384
|
+
|
|
385
|
+
def _setup_cloud_sql_connector(self, config: "dict[str, Any]") -> None:
|
|
386
|
+
"""Setup Cloud SQL connector and configure pool for connection factory pattern.
|
|
387
|
+
|
|
388
|
+
Args:
|
|
389
|
+
config: Pool configuration dictionary to modify in-place.
|
|
390
|
+
"""
|
|
391
|
+
from google.cloud.sql.connector import Connector # type: ignore[import-untyped,unused-ignore]
|
|
392
|
+
|
|
393
|
+
self._cloud_sql_connector = Connector()
|
|
394
|
+
|
|
395
|
+
user = config.get("user")
|
|
396
|
+
password = config.get("password")
|
|
397
|
+
database = config.get("database")
|
|
398
|
+
|
|
399
|
+
for key in ("dsn", "host", "port", "user", "password", "database"):
|
|
400
|
+
config.pop(key, None)
|
|
401
|
+
|
|
402
|
+
config["connect"] = _AsyncpgCloudSqlConnector(self, user, password, database)
|
|
403
|
+
|
|
404
|
+
def _setup_alloydb_connector(self, config: "dict[str, Any]") -> None:
|
|
405
|
+
"""Setup AlloyDB connector and configure pool for connection factory pattern.
|
|
406
|
+
|
|
407
|
+
Args:
|
|
408
|
+
config: Pool configuration dictionary to modify in-place.
|
|
409
|
+
"""
|
|
410
|
+
from google.cloud.alloydb.connector import AsyncConnector # type: ignore[import-untyped,unused-ignore]
|
|
411
|
+
|
|
412
|
+
self._alloydb_connector = AsyncConnector()
|
|
413
|
+
|
|
414
|
+
user = config.get("user")
|
|
415
|
+
password = config.get("password")
|
|
416
|
+
database = config.get("database")
|
|
417
|
+
|
|
418
|
+
for key in ("dsn", "host", "port", "user", "password", "database"):
|
|
419
|
+
config.pop(key, None)
|
|
420
|
+
|
|
421
|
+
config["connect"] = _AsyncpgAlloydbConnector(self, user, password, database)
|
|
422
|
+
|
|
423
|
+
async def _create_pool(self) -> "Pool[Record]":
|
|
424
|
+
"""Create the actual async connection pool."""
|
|
425
|
+
config = build_connection_config(self.connection_config)
|
|
426
|
+
|
|
427
|
+
if self.driver_features.get("enable_cloud_sql", False):
|
|
428
|
+
self._setup_cloud_sql_connector(config)
|
|
429
|
+
elif self.driver_features.get("enable_alloydb", False):
|
|
430
|
+
self._setup_alloydb_connector(config)
|
|
431
|
+
|
|
432
|
+
config.setdefault("init", self._init_connection)
|
|
433
|
+
|
|
434
|
+
return await asyncpg_create_pool(**config)
|
|
435
|
+
|
|
436
|
+
async def _init_connection(self, connection: "AsyncpgConnection") -> None:
|
|
437
|
+
"""Initialize connection with JSON codecs and pgvector support.
|
|
438
|
+
|
|
439
|
+
Args:
|
|
440
|
+
connection: AsyncPG connection to initialize.
|
|
441
|
+
"""
|
|
442
|
+
if self.driver_features.get("enable_json_codecs", True):
|
|
443
|
+
await register_json_codecs(
|
|
444
|
+
connection,
|
|
445
|
+
encoder=self.driver_features.get("json_serializer", to_json),
|
|
446
|
+
decoder=self.driver_features.get("json_deserializer", from_json),
|
|
447
|
+
)
|
|
448
|
+
|
|
449
|
+
if self.driver_features.get("enable_pgvector", False):
|
|
450
|
+
if self._pgvector_available is None:
|
|
451
|
+
try:
|
|
452
|
+
result = await connection.fetchval("SELECT 1 FROM pg_extension WHERE extname = 'vector'")
|
|
453
|
+
self._pgvector_available = bool(result)
|
|
454
|
+
except Exception:
|
|
455
|
+
# If we can't query extensions, assume false to be safe and avoid errors
|
|
456
|
+
self._pgvector_available = False
|
|
457
|
+
|
|
458
|
+
if self._pgvector_available:
|
|
459
|
+
await register_pgvector_support(connection)
|
|
460
|
+
|
|
461
|
+
async def _close_pool(self) -> None:
|
|
462
|
+
"""Close the actual async connection pool and cleanup connectors."""
|
|
463
|
+
if self.connection_instance:
|
|
464
|
+
await self.connection_instance.close()
|
|
465
|
+
self.connection_instance = None
|
|
466
|
+
|
|
467
|
+
if self._cloud_sql_connector is not None:
|
|
468
|
+
await self._cloud_sql_connector.close_async()
|
|
469
|
+
self._cloud_sql_connector = None
|
|
470
|
+
|
|
471
|
+
if self._alloydb_connector is not None:
|
|
472
|
+
await self._alloydb_connector.close()
|
|
473
|
+
self._alloydb_connector = None
|
|
474
|
+
|
|
475
|
+
async def close_pool(self) -> None:
|
|
476
|
+
"""Close the connection pool."""
|
|
477
|
+
await self._close_pool()
|
|
478
|
+
|
|
479
|
+
async def create_connection(self) -> "AsyncpgConnection":
|
|
480
|
+
"""Create a single async connection from the pool.
|
|
481
|
+
|
|
482
|
+
Returns:
|
|
483
|
+
An AsyncPG connection instance.
|
|
484
|
+
"""
|
|
485
|
+
pool = self.connection_instance
|
|
486
|
+
if pool is None:
|
|
487
|
+
pool = await self.create_pool()
|
|
488
|
+
self.connection_instance = pool
|
|
489
|
+
return await pool.acquire()
|
|
490
|
+
|
|
491
|
+
def provide_connection(self, *args: Any, **kwargs: Any) -> "AsyncpgConnectionContext":
|
|
492
|
+
"""Provide an async connection context manager.
|
|
493
|
+
|
|
494
|
+
Args:
|
|
495
|
+
*args: Additional arguments.
|
|
496
|
+
**kwargs: Additional keyword arguments.
|
|
497
|
+
|
|
498
|
+
Returns:
|
|
499
|
+
An AsyncPG connection context manager.
|
|
500
|
+
"""
|
|
501
|
+
return AsyncpgConnectionContext(self)
|
|
502
|
+
|
|
503
|
+
def provide_session(
|
|
504
|
+
self, *_args: Any, statement_config: "StatementConfig | None" = None, **_kwargs: Any
|
|
505
|
+
) -> "AsyncpgSessionContext":
|
|
506
|
+
"""Provide an async driver session context manager.
|
|
507
|
+
|
|
508
|
+
Args:
|
|
509
|
+
*_args: Additional arguments.
|
|
510
|
+
statement_config: Optional statement configuration override.
|
|
511
|
+
**_kwargs: Additional keyword arguments.
|
|
512
|
+
|
|
513
|
+
Returns:
|
|
514
|
+
An AsyncPG driver session context manager.
|
|
515
|
+
"""
|
|
516
|
+
factory = _AsyncpgSessionFactory(self)
|
|
517
|
+
return AsyncpgSessionContext(
|
|
518
|
+
acquire_connection=factory.acquire_connection,
|
|
519
|
+
release_connection=factory.release_connection,
|
|
520
|
+
statement_config=statement_config or self.statement_config or default_statement_config,
|
|
521
|
+
driver_features=self.driver_features,
|
|
522
|
+
prepare_driver=self._prepare_driver,
|
|
523
|
+
)
|
|
524
|
+
|
|
525
|
+
async def provide_pool(self, *args: Any, **kwargs: Any) -> "Pool[Record]":
|
|
526
|
+
"""Provide async pool instance.
|
|
527
|
+
|
|
528
|
+
Returns:
|
|
529
|
+
The async connection pool.
|
|
530
|
+
"""
|
|
531
|
+
if not self.connection_instance:
|
|
532
|
+
self.connection_instance = await self.create_pool()
|
|
533
|
+
return self.connection_instance
|
|
534
|
+
|
|
535
|
+
def get_signature_namespace(self) -> "dict[str, Any]":
|
|
536
|
+
"""Get the signature namespace for AsyncPG types.
|
|
537
|
+
|
|
538
|
+
This provides all AsyncPG-specific types that Litestar needs to recognize
|
|
539
|
+
to avoid serialization attempts.
|
|
540
|
+
|
|
541
|
+
Returns:
|
|
542
|
+
Dictionary mapping type names to types.
|
|
543
|
+
"""
|
|
544
|
+
|
|
545
|
+
namespace = super().get_signature_namespace()
|
|
546
|
+
namespace.update({
|
|
547
|
+
"Connection": Connection,
|
|
548
|
+
"Pool": Pool,
|
|
549
|
+
"PoolConnectionProxy": PoolConnectionProxy,
|
|
550
|
+
"PoolConnectionProxyMeta": PoolConnectionProxyMeta,
|
|
551
|
+
"ConnectionMeta": ConnectionMeta,
|
|
552
|
+
"Record": Record,
|
|
553
|
+
"AsyncpgConnection": AsyncpgConnection,
|
|
554
|
+
"AsyncpgConnectionConfig": AsyncpgConnectionConfig,
|
|
555
|
+
"AsyncpgConnectionContext": AsyncpgConnectionContext,
|
|
556
|
+
"AsyncpgCursor": AsyncpgCursor,
|
|
557
|
+
"AsyncpgDriver": AsyncpgDriver,
|
|
558
|
+
"AsyncpgExceptionHandler": AsyncpgExceptionHandler,
|
|
559
|
+
"AsyncpgPool": AsyncpgPool,
|
|
560
|
+
"AsyncpgPoolConfig": AsyncpgPoolConfig,
|
|
561
|
+
"AsyncpgPreparedStatement": AsyncpgPreparedStatement,
|
|
562
|
+
"AsyncpgSessionContext": AsyncpgSessionContext,
|
|
563
|
+
})
|
|
564
|
+
return namespace
|
|
565
|
+
|
|
566
|
+
def get_event_runtime_hints(self) -> "EventRuntimeHints":
|
|
567
|
+
"""Return polling defaults for PostgreSQL queue fallback."""
|
|
568
|
+
|
|
569
|
+
return EventRuntimeHints(poll_interval=0.5, select_for_update=True, skip_locked=True)
|
|
Binary file
|