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,52 @@
|
|
|
1
|
+
from typing import TYPE_CHECKING, Any
|
|
2
|
+
|
|
3
|
+
if TYPE_CHECKING:
|
|
4
|
+
from litestar.types import Scope
|
|
5
|
+
|
|
6
|
+
__all__ = ("delete_sqlspec_scope_state", "get_sqlspec_scope_state", "set_sqlspec_scope_state")
|
|
7
|
+
|
|
8
|
+
_SCOPE_NAMESPACE = "_sqlspec"
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
def get_sqlspec_scope_state(scope: "Scope", key: str, default: Any = None, pop: bool = False) -> Any:
|
|
12
|
+
"""Get an internal value from connection scope state.
|
|
13
|
+
|
|
14
|
+
Note:
|
|
15
|
+
If called with a default value, this method behaves like `dict.setdefault()`, both setting the key in the
|
|
16
|
+
namespace to the default value, and returning it.
|
|
17
|
+
|
|
18
|
+
If called without a default value, the method behaves like `dict.get()`, returning ``None`` if the key does not
|
|
19
|
+
exist.
|
|
20
|
+
|
|
21
|
+
Args:
|
|
22
|
+
scope: The connection scope.
|
|
23
|
+
key: Key to get from internal namespace in scope state.
|
|
24
|
+
default: Default value to return.
|
|
25
|
+
pop: Boolean flag dictating whether the value should be deleted from the state.
|
|
26
|
+
|
|
27
|
+
Returns:
|
|
28
|
+
Value mapped to ``key`` in internal connection scope namespace.
|
|
29
|
+
"""
|
|
30
|
+
namespace = scope.setdefault(_SCOPE_NAMESPACE, {}) # type: ignore[misc]
|
|
31
|
+
return namespace.pop(key, default) if pop else namespace.get(key, default) # pyright: ignore[reportUnknownVariableType,reportUnknownMemberType]
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
def set_sqlspec_scope_state(scope: "Scope", key: str, value: Any) -> None:
|
|
35
|
+
"""Set an internal value in connection scope state.
|
|
36
|
+
|
|
37
|
+
Args:
|
|
38
|
+
scope: The connection scope.
|
|
39
|
+
key: Key to set under internal namespace in scope state.
|
|
40
|
+
value: Value for key.
|
|
41
|
+
"""
|
|
42
|
+
scope.setdefault(_SCOPE_NAMESPACE, {})[key] = value # type: ignore[misc]
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
def delete_sqlspec_scope_state(scope: "Scope", key: str) -> None:
|
|
46
|
+
"""Remove an internal value from connection scope state.
|
|
47
|
+
|
|
48
|
+
Args:
|
|
49
|
+
scope: The connection scope.
|
|
50
|
+
key: Key to set under internal namespace in scope state.
|
|
51
|
+
"""
|
|
52
|
+
del scope.setdefault(_SCOPE_NAMESPACE, {})[key] # type: ignore[misc]
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
"""Litestar channels backend backed by SQLSpec's EventChannel."""
|
|
2
|
+
|
|
3
|
+
import asyncio
|
|
4
|
+
import base64
|
|
5
|
+
import hashlib
|
|
6
|
+
import re
|
|
7
|
+
from typing import TYPE_CHECKING, Any
|
|
8
|
+
|
|
9
|
+
from litestar.channels.backends.base import ChannelsBackend
|
|
10
|
+
|
|
11
|
+
from sqlspec.utils.logging import get_logger
|
|
12
|
+
|
|
13
|
+
if TYPE_CHECKING:
|
|
14
|
+
from collections.abc import AsyncGenerator, Iterable
|
|
15
|
+
|
|
16
|
+
from sqlspec.extensions.events import AsyncEventChannel
|
|
17
|
+
|
|
18
|
+
logger = get_logger("sqlspec.extensions.litestar.channels")
|
|
19
|
+
|
|
20
|
+
_IDENTIFIER_PATTERN = re.compile(r"^[A-Za-z_][A-Za-z0-9_]*$")
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
class SQLSpecChannelsBackend(ChannelsBackend):
|
|
24
|
+
"""A Litestar Channels backend implemented on top of SQLSpec's EventChannel.
|
|
25
|
+
|
|
26
|
+
This backend allows Litestar's ChannelsPlugin to use a SQLSpec database as the
|
|
27
|
+
broker. Under the hood it relies on SQLSpec's events extension, which can be
|
|
28
|
+
configured to use a durable table queue or native adapter backends.
|
|
29
|
+
|
|
30
|
+
Notes:
|
|
31
|
+
Litestar channels may use arbitrary string names. SQLSpec event channel
|
|
32
|
+
names must be valid identifiers. This backend maps Litestar channel names
|
|
33
|
+
to deterministic database channel identifiers via hashing.
|
|
34
|
+
"""
|
|
35
|
+
|
|
36
|
+
def __init__(
|
|
37
|
+
self, event_channel: "AsyncEventChannel", *, channel_prefix: str = "litestar", poll_interval: float = 0.2
|
|
38
|
+
) -> None:
|
|
39
|
+
if not _IDENTIFIER_PATTERN.match(channel_prefix):
|
|
40
|
+
msg = f"channel_prefix must be a valid identifier, got: {channel_prefix!r}"
|
|
41
|
+
raise ValueError(msg)
|
|
42
|
+
if poll_interval <= 0:
|
|
43
|
+
msg = "poll_interval must be greater than zero"
|
|
44
|
+
raise ValueError(msg)
|
|
45
|
+
self._event_channel = event_channel
|
|
46
|
+
self._channel_prefix = channel_prefix
|
|
47
|
+
self._poll_interval = poll_interval
|
|
48
|
+
self._output_queue: asyncio.Queue[tuple[str, bytes]] | None = None
|
|
49
|
+
self._shutdown = asyncio.Event()
|
|
50
|
+
self._tasks: dict[str, asyncio.Task[None]] = {}
|
|
51
|
+
self._to_db_channel: dict[str, str] = {}
|
|
52
|
+
self._to_litestar_channel: dict[str, str] = {}
|
|
53
|
+
|
|
54
|
+
async def on_startup(self) -> None:
|
|
55
|
+
self._shutdown.clear()
|
|
56
|
+
if self._output_queue is None:
|
|
57
|
+
self._output_queue = asyncio.Queue()
|
|
58
|
+
|
|
59
|
+
async def on_shutdown(self) -> None:
|
|
60
|
+
self._shutdown.set()
|
|
61
|
+
tasks = list(self._tasks.values())
|
|
62
|
+
self._tasks.clear()
|
|
63
|
+
for task in tasks:
|
|
64
|
+
task.cancel()
|
|
65
|
+
if tasks:
|
|
66
|
+
await asyncio.gather(*tasks, return_exceptions=True)
|
|
67
|
+
self._to_db_channel.clear()
|
|
68
|
+
self._to_litestar_channel.clear()
|
|
69
|
+
await self._event_channel.shutdown()
|
|
70
|
+
|
|
71
|
+
async def publish(self, data: bytes, channels: "Iterable[str]") -> None:
|
|
72
|
+
payload = {"data_b64": base64.b64encode(data).decode("ascii")}
|
|
73
|
+
for channel in channels:
|
|
74
|
+
db_channel = self._db_channel_name(channel)
|
|
75
|
+
await self._event_channel.publish(db_channel, payload)
|
|
76
|
+
|
|
77
|
+
async def subscribe(self, channels: "Iterable[str]") -> None:
|
|
78
|
+
for channel in channels:
|
|
79
|
+
if channel in self._tasks:
|
|
80
|
+
continue
|
|
81
|
+
db_channel = self._db_channel_name(channel)
|
|
82
|
+
task = asyncio.create_task(self._stream_channel(channel, db_channel))
|
|
83
|
+
self._tasks[channel] = task
|
|
84
|
+
|
|
85
|
+
async def unsubscribe(self, channels: "Iterable[str]") -> None:
|
|
86
|
+
cancelled: list[asyncio.Task[None]] = []
|
|
87
|
+
for channel in channels:
|
|
88
|
+
task = self._tasks.pop(channel, None)
|
|
89
|
+
if task is None:
|
|
90
|
+
continue
|
|
91
|
+
task.cancel()
|
|
92
|
+
cancelled.append(task)
|
|
93
|
+
if cancelled:
|
|
94
|
+
await asyncio.gather(*cancelled, return_exceptions=True)
|
|
95
|
+
self._cleanup_channel_mappings()
|
|
96
|
+
|
|
97
|
+
def stream_events(self) -> "AsyncGenerator[tuple[str, bytes], None]":
|
|
98
|
+
return self._event_generator()
|
|
99
|
+
|
|
100
|
+
async def get_history(self, channel: str, limit: int | None = None) -> list[bytes]:
|
|
101
|
+
"""Return history entries for a channel.
|
|
102
|
+
|
|
103
|
+
SQLSpec's event queue is primarily designed for durable delivery, not
|
|
104
|
+
for history replay. For now, this backend does not expose history.
|
|
105
|
+
"""
|
|
106
|
+
|
|
107
|
+
return []
|
|
108
|
+
|
|
109
|
+
def _cleanup_channel_mappings(self) -> None:
|
|
110
|
+
active = set(self._tasks)
|
|
111
|
+
removed = [name for name in self._to_db_channel if name not in active]
|
|
112
|
+
for name in removed:
|
|
113
|
+
db_name = self._to_db_channel.pop(name, None)
|
|
114
|
+
if db_name:
|
|
115
|
+
self._to_litestar_channel.pop(db_name, None)
|
|
116
|
+
|
|
117
|
+
async def _event_generator(self) -> "AsyncGenerator[tuple[str, bytes], None]":
|
|
118
|
+
if self._output_queue is None:
|
|
119
|
+
msg = "SQLSpecChannelsBackend not started - call ChannelsPlugin.on_startup() first"
|
|
120
|
+
raise RuntimeError(msg)
|
|
121
|
+
queue = self._output_queue
|
|
122
|
+
while True:
|
|
123
|
+
item = await queue.get()
|
|
124
|
+
yield item
|
|
125
|
+
|
|
126
|
+
def _db_channel_name(self, channel: str) -> str:
|
|
127
|
+
existing = self._to_db_channel.get(channel)
|
|
128
|
+
if existing:
|
|
129
|
+
return existing
|
|
130
|
+
digest = hashlib.sha256(channel.encode("utf-8")).hexdigest()[:24]
|
|
131
|
+
db_channel = f"{self._channel_prefix}_{digest}"
|
|
132
|
+
self._to_db_channel[channel] = db_channel
|
|
133
|
+
self._to_litestar_channel[db_channel] = channel
|
|
134
|
+
return db_channel
|
|
135
|
+
|
|
136
|
+
async def _stream_channel(self, channel: str, db_channel: str) -> None:
|
|
137
|
+
try:
|
|
138
|
+
async for message in self._event_channel.iter_events(db_channel, poll_interval=self._poll_interval):
|
|
139
|
+
if self._shutdown.is_set():
|
|
140
|
+
return
|
|
141
|
+
payload = message.payload
|
|
142
|
+
decoded = self._decode_payload(payload)
|
|
143
|
+
if decoded is None:
|
|
144
|
+
logger.warning("litestar channel %s dropped malformed payload: %r", channel, payload)
|
|
145
|
+
await self._event_channel.ack(message.event_id)
|
|
146
|
+
continue
|
|
147
|
+
assert self._output_queue is not None
|
|
148
|
+
await self._output_queue.put((channel, decoded))
|
|
149
|
+
await self._event_channel.ack(message.event_id)
|
|
150
|
+
except asyncio.CancelledError:
|
|
151
|
+
raise
|
|
152
|
+
except Exception as error: # pragma: no cover - defensive
|
|
153
|
+
logger.warning("litestar channel %s stream worker error: %s", channel, error)
|
|
154
|
+
|
|
155
|
+
@staticmethod
|
|
156
|
+
def _decode_payload(payload: Any) -> bytes | None:
|
|
157
|
+
if not isinstance(payload, dict):
|
|
158
|
+
return None
|
|
159
|
+
encoded = payload.get("data_b64")
|
|
160
|
+
if not isinstance(encoded, str) or not encoded:
|
|
161
|
+
return None
|
|
162
|
+
try:
|
|
163
|
+
return base64.b64decode(encoded.encode("ascii"))
|
|
164
|
+
except (ValueError, UnicodeEncodeError):
|
|
165
|
+
return None
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
"""Litestar CLI integration for SQLSpec migrations."""
|
|
2
|
+
|
|
3
|
+
from collections.abc import Callable
|
|
4
|
+
from contextlib import suppress
|
|
5
|
+
from typing import TYPE_CHECKING, Any, cast
|
|
6
|
+
|
|
7
|
+
import anyio
|
|
8
|
+
import rich_click as click
|
|
9
|
+
from litestar.cli._utils import LitestarGroup
|
|
10
|
+
|
|
11
|
+
from sqlspec.cli import add_migration_commands
|
|
12
|
+
from sqlspec.exceptions import ImproperConfigurationError
|
|
13
|
+
from sqlspec.extensions.litestar.store import BaseSQLSpecStore
|
|
14
|
+
|
|
15
|
+
if TYPE_CHECKING:
|
|
16
|
+
from litestar import Litestar
|
|
17
|
+
|
|
18
|
+
from sqlspec.extensions.litestar.plugin import SQLSpecPlugin
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
def _safe_group(*, aliases: "list[str] | None" = None, **kwargs: Any) -> Callable[[Callable[..., Any]], Any]:
|
|
22
|
+
if aliases is None:
|
|
23
|
+
return cast("Callable[[Callable[..., Any]], Any]", click.group(**kwargs))
|
|
24
|
+
try:
|
|
25
|
+
return cast("Callable[[Callable[..., Any]], Any]", click.group(aliases=aliases, **kwargs))
|
|
26
|
+
except TypeError:
|
|
27
|
+
return cast("Callable[[Callable[..., Any]], Any]", click.group(**kwargs))
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
def get_database_migration_plugin(app: "Litestar") -> "SQLSpecPlugin":
|
|
31
|
+
"""Retrieve the SQLSpec plugin from the Litestar application's plugins.
|
|
32
|
+
|
|
33
|
+
Args:
|
|
34
|
+
app: The Litestar application
|
|
35
|
+
|
|
36
|
+
Returns:
|
|
37
|
+
The SQLSpec plugin
|
|
38
|
+
|
|
39
|
+
Raises:
|
|
40
|
+
ImproperConfigurationError: If the SQLSpec plugin is not found
|
|
41
|
+
"""
|
|
42
|
+
from sqlspec.extensions.litestar.plugin import SQLSpecPlugin
|
|
43
|
+
|
|
44
|
+
with suppress(KeyError):
|
|
45
|
+
return app.plugins.get(SQLSpecPlugin)
|
|
46
|
+
msg = "Failed to initialize database migrations. The required SQLSpec plugin is missing."
|
|
47
|
+
raise ImproperConfigurationError(msg)
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
@_safe_group(cls=LitestarGroup, name="db", aliases=["database"])
|
|
51
|
+
def database_group(ctx: "click.Context") -> None:
|
|
52
|
+
"""Manage SQLSpec database components."""
|
|
53
|
+
ctx.obj = {"app": ctx.obj, "configs": get_database_migration_plugin(ctx.obj.app).config}
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
add_migration_commands(database_group)
|
|
57
|
+
|
|
58
|
+
|
|
59
|
+
def add_sessions_delete_expired_command() -> None:
|
|
60
|
+
"""Add delete-expired command to Litestar's sessions CLI group."""
|
|
61
|
+
try:
|
|
62
|
+
from litestar.cli._utils import console
|
|
63
|
+
from litestar.cli.commands.sessions import get_session_backend, sessions_group
|
|
64
|
+
except ImportError:
|
|
65
|
+
return
|
|
66
|
+
|
|
67
|
+
@sessions_group.command("delete-expired") # type: ignore[untyped-decorator]
|
|
68
|
+
@click.option(
|
|
69
|
+
"--verbose", is_flag=True, default=False, help="Show detailed information about the cleanup operation"
|
|
70
|
+
)
|
|
71
|
+
def delete_expired_sessions_command(app: "Litestar", verbose: bool) -> None:
|
|
72
|
+
"""Delete expired sessions from the session store.
|
|
73
|
+
|
|
74
|
+
This command removes all sessions that have passed their expiration time.
|
|
75
|
+
It can be scheduled via cron or systemd timers for automatic maintenance.
|
|
76
|
+
|
|
77
|
+
Examples:
|
|
78
|
+
litestar sessions delete-expired
|
|
79
|
+
litestar sessions delete-expired --verbose
|
|
80
|
+
"""
|
|
81
|
+
backend = get_session_backend(app)
|
|
82
|
+
store = backend.config.get_store_from_app(app)
|
|
83
|
+
|
|
84
|
+
if not isinstance(store, BaseSQLSpecStore):
|
|
85
|
+
console.print(f"[red]{type(store).__name__} does not support deleting expired sessions")
|
|
86
|
+
return
|
|
87
|
+
|
|
88
|
+
async def _delete_expired() -> int:
|
|
89
|
+
return await store.delete_expired()
|
|
90
|
+
|
|
91
|
+
count = anyio.run(_delete_expired)
|
|
92
|
+
|
|
93
|
+
if count > 0:
|
|
94
|
+
if verbose:
|
|
95
|
+
console.print(f"[green]Successfully deleted {count} expired session(s)")
|
|
96
|
+
else:
|
|
97
|
+
console.print(f"[green]Deleted {count} expired session(s)")
|
|
98
|
+
else:
|
|
99
|
+
console.print("[yellow]No expired sessions found")
|
|
100
|
+
|
|
101
|
+
|
|
102
|
+
add_sessions_delete_expired_command()
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"""Configuration types for Litestar session store extension."""
|
|
2
|
+
|
|
3
|
+
from typing_extensions import NotRequired, TypedDict
|
|
4
|
+
|
|
5
|
+
__all__ = ("LitestarConfig",)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class LitestarConfig(TypedDict):
|
|
9
|
+
"""Configuration options for Litestar session store extension.
|
|
10
|
+
|
|
11
|
+
All fields are optional with sensible defaults. Use in extension_config["litestar"]:
|
|
12
|
+
|
|
13
|
+
Example:
|
|
14
|
+
from sqlspec.adapters.oracledb import OracleAsyncConfig
|
|
15
|
+
|
|
16
|
+
config = OracleAsyncConfig(
|
|
17
|
+
connection_config={"dsn": "oracle://localhost/XEPDB1"},
|
|
18
|
+
extension_config={
|
|
19
|
+
"litestar": {
|
|
20
|
+
"session_table": "my_sessions",
|
|
21
|
+
"in_memory": True
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
)
|
|
25
|
+
|
|
26
|
+
Notes:
|
|
27
|
+
This TypedDict provides type safety for extension config but is not required.
|
|
28
|
+
You can use plain dicts as well.
|
|
29
|
+
"""
|
|
30
|
+
|
|
31
|
+
session_table: NotRequired[str]
|
|
32
|
+
"""Name of the sessions table. Default: 'litestar_session'
|
|
33
|
+
|
|
34
|
+
Examples:
|
|
35
|
+
"app_sessions"
|
|
36
|
+
"user_sessions"
|
|
37
|
+
"tenant_acme_sessions"
|
|
38
|
+
"""
|
|
39
|
+
|
|
40
|
+
in_memory: NotRequired[bool]
|
|
41
|
+
"""Enable in-memory table storage (Oracle-specific). Default: False.
|
|
42
|
+
|
|
43
|
+
When enabled, tables are created with the in-memory attribute for databases that support it.
|
|
44
|
+
|
|
45
|
+
This is an Oracle-specific feature that requires:
|
|
46
|
+
- Oracle Database 12.1.0.2 or higher
|
|
47
|
+
- Database In-Memory option license (Enterprise Edition)
|
|
48
|
+
- Sufficient INMEMORY_SIZE configured in the database instance
|
|
49
|
+
|
|
50
|
+
Other database adapters ignore this setting.
|
|
51
|
+
|
|
52
|
+
Examples:
|
|
53
|
+
Oracle with in-memory enabled:
|
|
54
|
+
config = OracleAsyncConfig(
|
|
55
|
+
connection_config={"dsn": "oracle://..."},
|
|
56
|
+
extension_config={
|
|
57
|
+
"litestar": {
|
|
58
|
+
"in_memory": True
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
)
|
|
62
|
+
|
|
63
|
+
Notes:
|
|
64
|
+
- Tables created with INMEMORY PRIORITY HIGH clause
|
|
65
|
+
- Ignored by unsupported adapters
|
|
66
|
+
"""
|
|
67
|
+
|
|
68
|
+
shard_count: NotRequired[int]
|
|
69
|
+
"""Optional hash shard count for session table primary key.
|
|
70
|
+
|
|
71
|
+
When set (>1), adapters that support computed shard columns (e.g., Spanner)
|
|
72
|
+
will create a generated shard_id using MOD(FARM_FINGERPRINT(session_id), shard_count)
|
|
73
|
+
and include it in the primary key to reduce hotspotting. Ignored by adapters
|
|
74
|
+
that do not support computed shards.
|
|
75
|
+
"""
|
|
76
|
+
|
|
77
|
+
table_options: NotRequired[str]
|
|
78
|
+
"""Optional raw OPTIONS/engine-specific table options string.
|
|
79
|
+
|
|
80
|
+
Passed verbatim when the adapter supports table-level OPTIONS/clauses
|
|
81
|
+
(e.g., Spanner columnar/tiered storage). Ignored by adapters that do not
|
|
82
|
+
support table options.
|
|
83
|
+
"""
|
|
84
|
+
|
|
85
|
+
index_options: NotRequired[str]
|
|
86
|
+
"""Optional raw OPTIONS/engine-specific options for the expires_at index.
|
|
87
|
+
|
|
88
|
+
Passed verbatim to the index definition for adapters that support index
|
|
89
|
+
OPTIONS/clauses. Ignored by adapters that do not support index options.
|
|
90
|
+
"""
|