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,567 @@
|
|
|
1
|
+
"""Base store classes for ADK session backend (sync and async)."""
|
|
2
|
+
|
|
3
|
+
import logging
|
|
4
|
+
import re
|
|
5
|
+
from abc import ABC, abstractmethod
|
|
6
|
+
from typing import TYPE_CHECKING, Any, Final, Generic, TypeVar, cast
|
|
7
|
+
|
|
8
|
+
from sqlspec.observability import resolve_db_system
|
|
9
|
+
from sqlspec.utils.logging import get_logger, log_with_context
|
|
10
|
+
|
|
11
|
+
if TYPE_CHECKING:
|
|
12
|
+
from datetime import datetime
|
|
13
|
+
|
|
14
|
+
from sqlspec.config import ADKConfig, DatabaseConfigProtocol
|
|
15
|
+
from sqlspec.extensions.adk._types import EventRecord, SessionRecord
|
|
16
|
+
|
|
17
|
+
ConfigT = TypeVar("ConfigT", bound="DatabaseConfigProtocol[Any, Any, Any]")
|
|
18
|
+
|
|
19
|
+
logger = get_logger("sqlspec.extensions.adk.store")
|
|
20
|
+
|
|
21
|
+
__all__ = ("BaseAsyncADKStore", "BaseSyncADKStore")
|
|
22
|
+
|
|
23
|
+
VALID_TABLE_NAME_PATTERN: Final = re.compile(r"^[a-zA-Z_][a-zA-Z0-9_]*$")
|
|
24
|
+
COLUMN_NAME_PATTERN: Final = re.compile(r"^(\w+)")
|
|
25
|
+
MAX_TABLE_NAME_LENGTH: Final = 63
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
def _parse_owner_id_column(owner_id_column_ddl: str) -> str:
|
|
29
|
+
"""Extract column name from owner ID column DDL definition.
|
|
30
|
+
|
|
31
|
+
Args:
|
|
32
|
+
owner_id_column_ddl: Full column DDL string (e.g., "user_id INTEGER REFERENCES users(id)").
|
|
33
|
+
|
|
34
|
+
Returns:
|
|
35
|
+
Column name only (first word).
|
|
36
|
+
|
|
37
|
+
Raises:
|
|
38
|
+
ValueError: If DDL format is invalid.
|
|
39
|
+
|
|
40
|
+
Examples:
|
|
41
|
+
"account_id INTEGER NOT NULL" -> "account_id"
|
|
42
|
+
"user_id UUID REFERENCES users(id)" -> "user_id"
|
|
43
|
+
"tenant VARCHAR(64) DEFAULT 'public'" -> "tenant"
|
|
44
|
+
|
|
45
|
+
Notes:
|
|
46
|
+
Only the column name is parsed. The rest of the DDL is passed through
|
|
47
|
+
verbatim to CREATE TABLE statements.
|
|
48
|
+
"""
|
|
49
|
+
match = COLUMN_NAME_PATTERN.match(owner_id_column_ddl.strip())
|
|
50
|
+
if not match:
|
|
51
|
+
msg = f"Invalid owner_id_column DDL: {owner_id_column_ddl!r}. Must start with column name."
|
|
52
|
+
raise ValueError(msg)
|
|
53
|
+
|
|
54
|
+
return match.group(1)
|
|
55
|
+
|
|
56
|
+
|
|
57
|
+
def _validate_table_name(table_name: str) -> None:
|
|
58
|
+
"""Validate table name for SQL safety.
|
|
59
|
+
|
|
60
|
+
Args:
|
|
61
|
+
table_name: Table name to validate.
|
|
62
|
+
|
|
63
|
+
Raises:
|
|
64
|
+
ValueError: If table name is invalid.
|
|
65
|
+
|
|
66
|
+
Notes:
|
|
67
|
+
- Must start with letter or underscore
|
|
68
|
+
- Can only contain letters, numbers, and underscores
|
|
69
|
+
- Maximum length is 63 characters (PostgreSQL limit)
|
|
70
|
+
- Prevents SQL injection in table names
|
|
71
|
+
"""
|
|
72
|
+
if not table_name:
|
|
73
|
+
msg = "Table name cannot be empty"
|
|
74
|
+
raise ValueError(msg)
|
|
75
|
+
|
|
76
|
+
if len(table_name) > MAX_TABLE_NAME_LENGTH:
|
|
77
|
+
msg = f"Table name too long: {len(table_name)} chars (max {MAX_TABLE_NAME_LENGTH})"
|
|
78
|
+
raise ValueError(msg)
|
|
79
|
+
|
|
80
|
+
if not VALID_TABLE_NAME_PATTERN.match(table_name):
|
|
81
|
+
msg = (
|
|
82
|
+
f"Invalid table name: {table_name!r}. "
|
|
83
|
+
"Must start with letter/underscore and contain only alphanumeric characters and underscores"
|
|
84
|
+
)
|
|
85
|
+
raise ValueError(msg)
|
|
86
|
+
|
|
87
|
+
|
|
88
|
+
class BaseAsyncADKStore(ABC, Generic[ConfigT]):
|
|
89
|
+
"""Base class for async SQLSpec-backed ADK session stores.
|
|
90
|
+
|
|
91
|
+
Implements storage operations for Google ADK sessions and events using
|
|
92
|
+
SQLSpec database adapters with async/await.
|
|
93
|
+
|
|
94
|
+
This abstract base class provides common functionality for all database-specific
|
|
95
|
+
store implementations including:
|
|
96
|
+
- Connection management via SQLSpec configs
|
|
97
|
+
- Table name validation
|
|
98
|
+
- Session and event CRUD operations
|
|
99
|
+
|
|
100
|
+
Subclasses must implement dialect-specific SQL queries and will be created
|
|
101
|
+
in each adapter directory (e.g., sqlspec/adapters/asyncpg/adk/store.py).
|
|
102
|
+
|
|
103
|
+
Args:
|
|
104
|
+
config: SQLSpec database configuration with extension_config["adk"] settings.
|
|
105
|
+
|
|
106
|
+
Notes:
|
|
107
|
+
Configuration is read from config.extension_config["adk"]:
|
|
108
|
+
- session_table: Sessions table name (default: "adk_sessions")
|
|
109
|
+
- events_table: Events table name (default: "adk_events")
|
|
110
|
+
- owner_id_column: Optional owner FK column DDL (default: None)
|
|
111
|
+
"""
|
|
112
|
+
|
|
113
|
+
__slots__ = ("_config", "_events_table", "_owner_id_column_ddl", "_owner_id_column_name", "_session_table")
|
|
114
|
+
|
|
115
|
+
def __init__(self, config: ConfigT) -> None:
|
|
116
|
+
"""Initialize the ADK store.
|
|
117
|
+
|
|
118
|
+
Args:
|
|
119
|
+
config: SQLSpec database configuration.
|
|
120
|
+
|
|
121
|
+
Notes:
|
|
122
|
+
Reads configuration from config.extension_config["adk"]:
|
|
123
|
+
- session_table: Sessions table name (default: "adk_sessions")
|
|
124
|
+
- events_table: Events table name (default: "adk_events")
|
|
125
|
+
- owner_id_column: Optional owner FK column DDL (default: None)
|
|
126
|
+
"""
|
|
127
|
+
self._config = config
|
|
128
|
+
store_config = self._get_store_config_from_extension()
|
|
129
|
+
self._session_table: str = str(store_config["session_table"])
|
|
130
|
+
self._events_table: str = str(store_config["events_table"])
|
|
131
|
+
self._owner_id_column_ddl: str | None = store_config.get("owner_id_column")
|
|
132
|
+
self._owner_id_column_name: str | None = (
|
|
133
|
+
_parse_owner_id_column(self._owner_id_column_ddl) if self._owner_id_column_ddl else None
|
|
134
|
+
)
|
|
135
|
+
_validate_table_name(self._session_table)
|
|
136
|
+
_validate_table_name(self._events_table)
|
|
137
|
+
|
|
138
|
+
def _get_store_config_from_extension(self) -> "dict[str, Any]":
|
|
139
|
+
"""Extract ADK store configuration from config.extension_config.
|
|
140
|
+
|
|
141
|
+
Returns:
|
|
142
|
+
Dict with session_table, events_table, and optionally owner_id_column.
|
|
143
|
+
"""
|
|
144
|
+
extension_config = self._config.extension_config
|
|
145
|
+
adk_config = cast("ADKConfig", extension_config.get("adk", {}))
|
|
146
|
+
session_table = adk_config.get("session_table")
|
|
147
|
+
events_table = adk_config.get("events_table")
|
|
148
|
+
result: dict[str, Any] = {
|
|
149
|
+
"session_table": session_table if session_table is not None else "adk_sessions",
|
|
150
|
+
"events_table": events_table if events_table is not None else "adk_events",
|
|
151
|
+
}
|
|
152
|
+
owner_id = adk_config.get("owner_id_column")
|
|
153
|
+
if owner_id is not None:
|
|
154
|
+
result["owner_id_column"] = owner_id
|
|
155
|
+
return result
|
|
156
|
+
|
|
157
|
+
@property
|
|
158
|
+
def config(self) -> ConfigT:
|
|
159
|
+
"""Return the database configuration."""
|
|
160
|
+
return self._config
|
|
161
|
+
|
|
162
|
+
@property
|
|
163
|
+
def session_table(self) -> str:
|
|
164
|
+
"""Return the sessions table name."""
|
|
165
|
+
return self._session_table
|
|
166
|
+
|
|
167
|
+
@property
|
|
168
|
+
def events_table(self) -> str:
|
|
169
|
+
"""Return the events table name."""
|
|
170
|
+
return self._events_table
|
|
171
|
+
|
|
172
|
+
@property
|
|
173
|
+
def owner_id_column_ddl(self) -> "str | None":
|
|
174
|
+
"""Return the full owner ID column DDL (or None if not configured)."""
|
|
175
|
+
return self._owner_id_column_ddl
|
|
176
|
+
|
|
177
|
+
@property
|
|
178
|
+
def owner_id_column_name(self) -> "str | None":
|
|
179
|
+
"""Return the owner ID column name only (or None if not configured)."""
|
|
180
|
+
return self._owner_id_column_name
|
|
181
|
+
|
|
182
|
+
@abstractmethod
|
|
183
|
+
async def create_session(
|
|
184
|
+
self, session_id: str, app_name: str, user_id: str, state: "dict[str, Any]", owner_id: "Any | None" = None
|
|
185
|
+
) -> "SessionRecord":
|
|
186
|
+
"""Create a new session.
|
|
187
|
+
|
|
188
|
+
Args:
|
|
189
|
+
session_id: Unique identifier for the session.
|
|
190
|
+
app_name: Name of the application.
|
|
191
|
+
user_id: ID of the user.
|
|
192
|
+
state: Session state dictionary.
|
|
193
|
+
owner_id: Optional owner ID value for owner_id_column (if configured).
|
|
194
|
+
|
|
195
|
+
Returns:
|
|
196
|
+
The created session record.
|
|
197
|
+
"""
|
|
198
|
+
raise NotImplementedError
|
|
199
|
+
|
|
200
|
+
@abstractmethod
|
|
201
|
+
async def get_session(self, session_id: str) -> "SessionRecord | None":
|
|
202
|
+
"""Get a session by ID.
|
|
203
|
+
|
|
204
|
+
Args:
|
|
205
|
+
session_id: Session identifier.
|
|
206
|
+
|
|
207
|
+
Returns:
|
|
208
|
+
Session record if found, None otherwise.
|
|
209
|
+
"""
|
|
210
|
+
raise NotImplementedError
|
|
211
|
+
|
|
212
|
+
@abstractmethod
|
|
213
|
+
async def update_session_state(self, session_id: str, state: "dict[str, Any]") -> None:
|
|
214
|
+
"""Update session state.
|
|
215
|
+
|
|
216
|
+
Args:
|
|
217
|
+
session_id: Session identifier.
|
|
218
|
+
state: New state dictionary.
|
|
219
|
+
"""
|
|
220
|
+
raise NotImplementedError
|
|
221
|
+
|
|
222
|
+
@abstractmethod
|
|
223
|
+
async def list_sessions(self, app_name: str, user_id: "str | None" = None) -> "list[SessionRecord]":
|
|
224
|
+
"""List all sessions for an app, optionally filtered by user.
|
|
225
|
+
|
|
226
|
+
Args:
|
|
227
|
+
app_name: Name of the application.
|
|
228
|
+
user_id: ID of the user. If None, returns all sessions for the app.
|
|
229
|
+
|
|
230
|
+
Returns:
|
|
231
|
+
List of session records.
|
|
232
|
+
"""
|
|
233
|
+
raise NotImplementedError
|
|
234
|
+
|
|
235
|
+
@abstractmethod
|
|
236
|
+
async def delete_session(self, session_id: str) -> None:
|
|
237
|
+
"""Delete a session and its events.
|
|
238
|
+
|
|
239
|
+
Args:
|
|
240
|
+
session_id: Session identifier.
|
|
241
|
+
"""
|
|
242
|
+
raise NotImplementedError
|
|
243
|
+
|
|
244
|
+
@abstractmethod
|
|
245
|
+
async def append_event(self, event_record: "EventRecord") -> None:
|
|
246
|
+
"""Append an event to a session.
|
|
247
|
+
|
|
248
|
+
Args:
|
|
249
|
+
event_record: Event record to store.
|
|
250
|
+
"""
|
|
251
|
+
raise NotImplementedError
|
|
252
|
+
|
|
253
|
+
@abstractmethod
|
|
254
|
+
async def get_events(
|
|
255
|
+
self, session_id: str, after_timestamp: "datetime | None" = None, limit: "int | None" = None
|
|
256
|
+
) -> "list[EventRecord]":
|
|
257
|
+
"""Get events for a session.
|
|
258
|
+
|
|
259
|
+
Args:
|
|
260
|
+
session_id: Session identifier.
|
|
261
|
+
after_timestamp: Only return events after this time.
|
|
262
|
+
limit: Maximum number of events to return.
|
|
263
|
+
|
|
264
|
+
Returns:
|
|
265
|
+
List of event records ordered by timestamp ascending.
|
|
266
|
+
"""
|
|
267
|
+
raise NotImplementedError
|
|
268
|
+
|
|
269
|
+
@abstractmethod
|
|
270
|
+
async def create_tables(self) -> None:
|
|
271
|
+
"""Create the sessions and events tables if they don't exist."""
|
|
272
|
+
raise NotImplementedError
|
|
273
|
+
|
|
274
|
+
async def ensure_tables(self) -> None:
|
|
275
|
+
"""Create tables and emit a standardized log entry."""
|
|
276
|
+
|
|
277
|
+
await self.create_tables()
|
|
278
|
+
self._log_tables_created()
|
|
279
|
+
|
|
280
|
+
@abstractmethod
|
|
281
|
+
async def _get_create_sessions_table_sql(self) -> str:
|
|
282
|
+
"""Get the CREATE TABLE SQL for the sessions table.
|
|
283
|
+
|
|
284
|
+
Returns:
|
|
285
|
+
SQL statement to create the sessions table.
|
|
286
|
+
"""
|
|
287
|
+
raise NotImplementedError
|
|
288
|
+
|
|
289
|
+
@abstractmethod
|
|
290
|
+
async def _get_create_events_table_sql(self) -> str:
|
|
291
|
+
"""Get the CREATE TABLE SQL for the events table.
|
|
292
|
+
|
|
293
|
+
Returns:
|
|
294
|
+
SQL statement to create the events table.
|
|
295
|
+
"""
|
|
296
|
+
raise NotImplementedError
|
|
297
|
+
|
|
298
|
+
@abstractmethod
|
|
299
|
+
def _get_drop_tables_sql(self) -> "list[str]":
|
|
300
|
+
"""Get the DROP TABLE SQL statements for this database dialect.
|
|
301
|
+
|
|
302
|
+
Returns:
|
|
303
|
+
List of SQL statements to drop the tables and all indexes.
|
|
304
|
+
Order matters: drop events table before sessions table due to FK.
|
|
305
|
+
|
|
306
|
+
Notes:
|
|
307
|
+
Should use IF EXISTS or dialect-specific error handling
|
|
308
|
+
to allow idempotent migrations.
|
|
309
|
+
"""
|
|
310
|
+
raise NotImplementedError
|
|
311
|
+
|
|
312
|
+
def _log_tables_created(self) -> None:
|
|
313
|
+
log_with_context(
|
|
314
|
+
logger,
|
|
315
|
+
logging.DEBUG,
|
|
316
|
+
"adk.tables.ready",
|
|
317
|
+
db_system=resolve_db_system(type(self).__name__),
|
|
318
|
+
session_table=self._session_table,
|
|
319
|
+
events_table=self._events_table,
|
|
320
|
+
)
|
|
321
|
+
|
|
322
|
+
|
|
323
|
+
class BaseSyncADKStore(ABC, Generic[ConfigT]):
|
|
324
|
+
"""Base class for sync SQLSpec-backed ADK session stores.
|
|
325
|
+
|
|
326
|
+
Implements storage operations for Google ADK sessions and events using
|
|
327
|
+
SQLSpec database adapters with synchronous execution.
|
|
328
|
+
|
|
329
|
+
This abstract base class provides common functionality for sync database-specific
|
|
330
|
+
store implementations including:
|
|
331
|
+
- Connection management via SQLSpec configs
|
|
332
|
+
- Table name validation
|
|
333
|
+
- Session and event CRUD operations
|
|
334
|
+
|
|
335
|
+
Subclasses must implement dialect-specific SQL queries and will be created
|
|
336
|
+
in each adapter directory (e.g., sqlspec/adapters/sqlite/adk/store.py).
|
|
337
|
+
|
|
338
|
+
Args:
|
|
339
|
+
config: SQLSpec database configuration with extension_config["adk"] settings.
|
|
340
|
+
|
|
341
|
+
Notes:
|
|
342
|
+
Configuration is read from config.extension_config["adk"]:
|
|
343
|
+
- session_table: Sessions table name (default: "adk_sessions")
|
|
344
|
+
- events_table: Events table name (default: "adk_events")
|
|
345
|
+
- owner_id_column: Optional owner FK column DDL (default: None)
|
|
346
|
+
"""
|
|
347
|
+
|
|
348
|
+
__slots__ = ("_config", "_events_table", "_owner_id_column_ddl", "_owner_id_column_name", "_session_table")
|
|
349
|
+
|
|
350
|
+
def __init__(self, config: ConfigT) -> None:
|
|
351
|
+
"""Initialize the sync ADK store.
|
|
352
|
+
|
|
353
|
+
Args:
|
|
354
|
+
config: SQLSpec database configuration.
|
|
355
|
+
|
|
356
|
+
Notes:
|
|
357
|
+
Reads configuration from config.extension_config["adk"]:
|
|
358
|
+
- session_table: Sessions table name (default: "adk_sessions")
|
|
359
|
+
- events_table: Events table name (default: "adk_events")
|
|
360
|
+
- owner_id_column: Optional owner FK column DDL (default: None)
|
|
361
|
+
"""
|
|
362
|
+
self._config = config
|
|
363
|
+
store_config = self._get_store_config_from_extension()
|
|
364
|
+
self._session_table: str = str(store_config["session_table"])
|
|
365
|
+
self._events_table: str = str(store_config["events_table"])
|
|
366
|
+
self._owner_id_column_ddl: str | None = store_config.get("owner_id_column")
|
|
367
|
+
self._owner_id_column_name: str | None = (
|
|
368
|
+
_parse_owner_id_column(self._owner_id_column_ddl) if self._owner_id_column_ddl else None
|
|
369
|
+
)
|
|
370
|
+
_validate_table_name(self._session_table)
|
|
371
|
+
_validate_table_name(self._events_table)
|
|
372
|
+
|
|
373
|
+
def _get_store_config_from_extension(self) -> "dict[str, Any]":
|
|
374
|
+
"""Extract ADK store configuration from config.extension_config.
|
|
375
|
+
|
|
376
|
+
Returns:
|
|
377
|
+
Dict with session_table, events_table, and optionally owner_id_column.
|
|
378
|
+
"""
|
|
379
|
+
extension_config = self._config.extension_config
|
|
380
|
+
adk_config = cast("ADKConfig", extension_config.get("adk", {}))
|
|
381
|
+
session_table = adk_config.get("session_table")
|
|
382
|
+
events_table = adk_config.get("events_table")
|
|
383
|
+
result: dict[str, Any] = {
|
|
384
|
+
"session_table": session_table if session_table is not None else "adk_sessions",
|
|
385
|
+
"events_table": events_table if events_table is not None else "adk_events",
|
|
386
|
+
}
|
|
387
|
+
owner_id = adk_config.get("owner_id_column")
|
|
388
|
+
if owner_id is not None:
|
|
389
|
+
result["owner_id_column"] = owner_id
|
|
390
|
+
return result
|
|
391
|
+
|
|
392
|
+
@property
|
|
393
|
+
def config(self) -> ConfigT:
|
|
394
|
+
"""Return the database configuration."""
|
|
395
|
+
return self._config
|
|
396
|
+
|
|
397
|
+
@property
|
|
398
|
+
def session_table(self) -> str:
|
|
399
|
+
"""Return the sessions table name."""
|
|
400
|
+
return self._session_table
|
|
401
|
+
|
|
402
|
+
@property
|
|
403
|
+
def events_table(self) -> str:
|
|
404
|
+
"""Return the events table name."""
|
|
405
|
+
return self._events_table
|
|
406
|
+
|
|
407
|
+
@property
|
|
408
|
+
def owner_id_column_ddl(self) -> "str | None":
|
|
409
|
+
"""Return the full owner ID column DDL (or None if not configured)."""
|
|
410
|
+
return self._owner_id_column_ddl
|
|
411
|
+
|
|
412
|
+
@property
|
|
413
|
+
def owner_id_column_name(self) -> "str | None":
|
|
414
|
+
"""Return the owner ID column name only (or None if not configured)."""
|
|
415
|
+
return self._owner_id_column_name
|
|
416
|
+
|
|
417
|
+
@abstractmethod
|
|
418
|
+
def create_session(
|
|
419
|
+
self, session_id: str, app_name: str, user_id: str, state: "dict[str, Any]", owner_id: "Any | None" = None
|
|
420
|
+
) -> "SessionRecord":
|
|
421
|
+
"""Create a new session.
|
|
422
|
+
|
|
423
|
+
Args:
|
|
424
|
+
session_id: Unique identifier for the session.
|
|
425
|
+
app_name: Name of the application.
|
|
426
|
+
user_id: ID of the user.
|
|
427
|
+
state: Session state dictionary.
|
|
428
|
+
owner_id: Optional owner ID value for owner_id_column (if configured).
|
|
429
|
+
|
|
430
|
+
Returns:
|
|
431
|
+
The created session record.
|
|
432
|
+
"""
|
|
433
|
+
raise NotImplementedError
|
|
434
|
+
|
|
435
|
+
@abstractmethod
|
|
436
|
+
def get_session(self, session_id: str) -> "SessionRecord | None":
|
|
437
|
+
"""Get a session by ID.
|
|
438
|
+
|
|
439
|
+
Args:
|
|
440
|
+
session_id: Session identifier.
|
|
441
|
+
|
|
442
|
+
Returns:
|
|
443
|
+
Session record if found, None otherwise.
|
|
444
|
+
"""
|
|
445
|
+
raise NotImplementedError
|
|
446
|
+
|
|
447
|
+
@abstractmethod
|
|
448
|
+
def update_session_state(self, session_id: str, state: "dict[str, Any]") -> None:
|
|
449
|
+
"""Update session state.
|
|
450
|
+
|
|
451
|
+
Args:
|
|
452
|
+
session_id: Session identifier.
|
|
453
|
+
state: New state dictionary.
|
|
454
|
+
"""
|
|
455
|
+
raise NotImplementedError
|
|
456
|
+
|
|
457
|
+
@abstractmethod
|
|
458
|
+
def list_sessions(self, app_name: str, user_id: "str | None" = None) -> "list[SessionRecord]":
|
|
459
|
+
"""List all sessions for an app, optionally filtered by user.
|
|
460
|
+
|
|
461
|
+
Args:
|
|
462
|
+
app_name: Name of the application.
|
|
463
|
+
user_id: ID of the user. If None, returns all sessions for the app.
|
|
464
|
+
|
|
465
|
+
Returns:
|
|
466
|
+
List of session records.
|
|
467
|
+
"""
|
|
468
|
+
raise NotImplementedError
|
|
469
|
+
|
|
470
|
+
@abstractmethod
|
|
471
|
+
def delete_session(self, session_id: str) -> None:
|
|
472
|
+
"""Delete a session and its events.
|
|
473
|
+
|
|
474
|
+
Args:
|
|
475
|
+
session_id: Session identifier.
|
|
476
|
+
"""
|
|
477
|
+
raise NotImplementedError
|
|
478
|
+
|
|
479
|
+
@abstractmethod
|
|
480
|
+
def create_event(
|
|
481
|
+
self,
|
|
482
|
+
event_id: str,
|
|
483
|
+
session_id: str,
|
|
484
|
+
app_name: str,
|
|
485
|
+
user_id: str,
|
|
486
|
+
author: "str | None" = None,
|
|
487
|
+
actions: "bytes | None" = None,
|
|
488
|
+
content: "dict[str, Any] | None" = None,
|
|
489
|
+
**kwargs: Any,
|
|
490
|
+
) -> "EventRecord":
|
|
491
|
+
"""Create a new event.
|
|
492
|
+
|
|
493
|
+
Args:
|
|
494
|
+
event_id: Unique event identifier.
|
|
495
|
+
session_id: Session identifier.
|
|
496
|
+
app_name: Application name.
|
|
497
|
+
user_id: User identifier.
|
|
498
|
+
author: Event author (user/assistant/system).
|
|
499
|
+
actions: Pickled actions object.
|
|
500
|
+
content: Event content (JSONB/JSON).
|
|
501
|
+
**kwargs: Additional optional fields.
|
|
502
|
+
|
|
503
|
+
Returns:
|
|
504
|
+
Created event record.
|
|
505
|
+
"""
|
|
506
|
+
raise NotImplementedError
|
|
507
|
+
|
|
508
|
+
@abstractmethod
|
|
509
|
+
def list_events(self, session_id: str) -> "list[EventRecord]":
|
|
510
|
+
"""List events for a session ordered by timestamp.
|
|
511
|
+
|
|
512
|
+
Args:
|
|
513
|
+
session_id: Session identifier.
|
|
514
|
+
|
|
515
|
+
Returns:
|
|
516
|
+
List of event records ordered by timestamp ASC.
|
|
517
|
+
"""
|
|
518
|
+
raise NotImplementedError
|
|
519
|
+
|
|
520
|
+
@abstractmethod
|
|
521
|
+
def create_tables(self) -> None:
|
|
522
|
+
"""Create both sessions and events tables if they don't exist."""
|
|
523
|
+
raise NotImplementedError
|
|
524
|
+
|
|
525
|
+
def ensure_tables(self) -> None:
|
|
526
|
+
"""Create tables and emit a standardized log entry."""
|
|
527
|
+
|
|
528
|
+
self.create_tables()
|
|
529
|
+
self._log_tables_created()
|
|
530
|
+
|
|
531
|
+
@abstractmethod
|
|
532
|
+
def _get_create_sessions_table_sql(self) -> str:
|
|
533
|
+
"""Get SQL to create sessions table.
|
|
534
|
+
|
|
535
|
+
Returns:
|
|
536
|
+
SQL statement to create adk_sessions table with indexes.
|
|
537
|
+
"""
|
|
538
|
+
raise NotImplementedError
|
|
539
|
+
|
|
540
|
+
@abstractmethod
|
|
541
|
+
def _get_create_events_table_sql(self) -> str:
|
|
542
|
+
"""Get SQL to create events table.
|
|
543
|
+
|
|
544
|
+
Returns:
|
|
545
|
+
SQL statement to create adk_events table with indexes.
|
|
546
|
+
"""
|
|
547
|
+
raise NotImplementedError
|
|
548
|
+
|
|
549
|
+
def _log_tables_created(self) -> None:
|
|
550
|
+
log_with_context(
|
|
551
|
+
logger,
|
|
552
|
+
logging.DEBUG,
|
|
553
|
+
"adk.tables.ready",
|
|
554
|
+
db_system=resolve_db_system(type(self).__name__),
|
|
555
|
+
session_table=self._session_table,
|
|
556
|
+
events_table=self._events_table,
|
|
557
|
+
)
|
|
558
|
+
|
|
559
|
+
@abstractmethod
|
|
560
|
+
def _get_drop_tables_sql(self) -> "list[str]":
|
|
561
|
+
"""Get SQL to drop tables.
|
|
562
|
+
|
|
563
|
+
Returns:
|
|
564
|
+
List of SQL statements to drop tables and indexes.
|
|
565
|
+
Order matters: drop events before sessions due to FK.
|
|
566
|
+
"""
|
|
567
|
+
raise NotImplementedError
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"""Event channel package exports."""
|
|
2
|
+
|
|
3
|
+
from sqlspec.extensions.events._channel import (
|
|
4
|
+
AsyncEventChannel,
|
|
5
|
+
AsyncEventListener,
|
|
6
|
+
SyncEventChannel,
|
|
7
|
+
SyncEventListener,
|
|
8
|
+
load_native_backend,
|
|
9
|
+
resolve_poll_interval,
|
|
10
|
+
)
|
|
11
|
+
from sqlspec.extensions.events._hints import EventRuntimeHints, get_runtime_hints, resolve_adapter_name
|
|
12
|
+
from sqlspec.extensions.events._models import EventMessage
|
|
13
|
+
from sqlspec.extensions.events._payload import decode_notify_payload, encode_notify_payload, parse_event_timestamp
|
|
14
|
+
from sqlspec.extensions.events._protocols import (
|
|
15
|
+
AsyncEventBackendProtocol,
|
|
16
|
+
AsyncEventHandler,
|
|
17
|
+
SyncEventBackendProtocol,
|
|
18
|
+
SyncEventHandler,
|
|
19
|
+
)
|
|
20
|
+
from sqlspec.extensions.events._queue import AsyncTableEventQueue, SyncTableEventQueue, build_queue_backend
|
|
21
|
+
from sqlspec.extensions.events._store import (
|
|
22
|
+
BaseEventQueueStore,
|
|
23
|
+
normalize_event_channel_name,
|
|
24
|
+
normalize_queue_table_name,
|
|
25
|
+
)
|
|
26
|
+
|
|
27
|
+
__all__ = (
|
|
28
|
+
"AsyncEventBackendProtocol",
|
|
29
|
+
"AsyncEventChannel",
|
|
30
|
+
"AsyncEventHandler",
|
|
31
|
+
"AsyncEventListener",
|
|
32
|
+
"AsyncTableEventQueue",
|
|
33
|
+
"BaseEventQueueStore",
|
|
34
|
+
"EventMessage",
|
|
35
|
+
"EventRuntimeHints",
|
|
36
|
+
"SyncEventBackendProtocol",
|
|
37
|
+
"SyncEventChannel",
|
|
38
|
+
"SyncEventHandler",
|
|
39
|
+
"SyncEventListener",
|
|
40
|
+
"SyncTableEventQueue",
|
|
41
|
+
"build_queue_backend",
|
|
42
|
+
"decode_notify_payload",
|
|
43
|
+
"encode_notify_payload",
|
|
44
|
+
"get_runtime_hints",
|
|
45
|
+
"load_native_backend",
|
|
46
|
+
"normalize_event_channel_name",
|
|
47
|
+
"normalize_queue_table_name",
|
|
48
|
+
"parse_event_timestamp",
|
|
49
|
+
"resolve_adapter_name",
|
|
50
|
+
"resolve_poll_interval",
|
|
51
|
+
)
|