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.
Files changed (531) hide show
  1. ac8f31065839703b4e70__mypyc.cpython-310-aarch64-linux-gnu.so +0 -0
  2. sqlspec/__init__.py +140 -0
  3. sqlspec/__main__.py +12 -0
  4. sqlspec/__metadata__.py +14 -0
  5. sqlspec/_serialization.py +315 -0
  6. sqlspec/_typing.py +700 -0
  7. sqlspec/adapters/__init__.py +0 -0
  8. sqlspec/adapters/adbc/__init__.py +5 -0
  9. sqlspec/adapters/adbc/_typing.py +82 -0
  10. sqlspec/adapters/adbc/adk/__init__.py +5 -0
  11. sqlspec/adapters/adbc/adk/store.py +1273 -0
  12. sqlspec/adapters/adbc/config.py +295 -0
  13. sqlspec/adapters/adbc/core.cpython-310-aarch64-linux-gnu.so +0 -0
  14. sqlspec/adapters/adbc/core.py +735 -0
  15. sqlspec/adapters/adbc/data_dictionary.py +334 -0
  16. sqlspec/adapters/adbc/driver.py +529 -0
  17. sqlspec/adapters/adbc/events/__init__.py +5 -0
  18. sqlspec/adapters/adbc/events/store.py +285 -0
  19. sqlspec/adapters/adbc/litestar/__init__.py +5 -0
  20. sqlspec/adapters/adbc/litestar/store.py +502 -0
  21. sqlspec/adapters/adbc/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  22. sqlspec/adapters/adbc/type_converter.py +140 -0
  23. sqlspec/adapters/aiosqlite/__init__.py +25 -0
  24. sqlspec/adapters/aiosqlite/_typing.py +82 -0
  25. sqlspec/adapters/aiosqlite/adk/__init__.py +5 -0
  26. sqlspec/adapters/aiosqlite/adk/store.py +818 -0
  27. sqlspec/adapters/aiosqlite/config.py +334 -0
  28. sqlspec/adapters/aiosqlite/core.cpython-310-aarch64-linux-gnu.so +0 -0
  29. sqlspec/adapters/aiosqlite/core.py +315 -0
  30. sqlspec/adapters/aiosqlite/data_dictionary.py +208 -0
  31. sqlspec/adapters/aiosqlite/driver.py +313 -0
  32. sqlspec/adapters/aiosqlite/events/__init__.py +5 -0
  33. sqlspec/adapters/aiosqlite/events/store.py +20 -0
  34. sqlspec/adapters/aiosqlite/litestar/__init__.py +5 -0
  35. sqlspec/adapters/aiosqlite/litestar/store.py +279 -0
  36. sqlspec/adapters/aiosqlite/pool.py +533 -0
  37. sqlspec/adapters/asyncmy/__init__.py +21 -0
  38. sqlspec/adapters/asyncmy/_typing.py +87 -0
  39. sqlspec/adapters/asyncmy/adk/__init__.py +5 -0
  40. sqlspec/adapters/asyncmy/adk/store.py +703 -0
  41. sqlspec/adapters/asyncmy/config.py +302 -0
  42. sqlspec/adapters/asyncmy/core.cpython-310-aarch64-linux-gnu.so +0 -0
  43. sqlspec/adapters/asyncmy/core.py +360 -0
  44. sqlspec/adapters/asyncmy/data_dictionary.py +124 -0
  45. sqlspec/adapters/asyncmy/driver.py +383 -0
  46. sqlspec/adapters/asyncmy/events/__init__.py +5 -0
  47. sqlspec/adapters/asyncmy/events/store.py +104 -0
  48. sqlspec/adapters/asyncmy/litestar/__init__.py +5 -0
  49. sqlspec/adapters/asyncmy/litestar/store.py +296 -0
  50. sqlspec/adapters/asyncpg/__init__.py +19 -0
  51. sqlspec/adapters/asyncpg/_typing.py +88 -0
  52. sqlspec/adapters/asyncpg/adk/__init__.py +5 -0
  53. sqlspec/adapters/asyncpg/adk/store.py +748 -0
  54. sqlspec/adapters/asyncpg/config.py +569 -0
  55. sqlspec/adapters/asyncpg/core.cpython-310-aarch64-linux-gnu.so +0 -0
  56. sqlspec/adapters/asyncpg/core.py +367 -0
  57. sqlspec/adapters/asyncpg/data_dictionary.py +162 -0
  58. sqlspec/adapters/asyncpg/driver.py +487 -0
  59. sqlspec/adapters/asyncpg/events/__init__.py +6 -0
  60. sqlspec/adapters/asyncpg/events/backend.py +286 -0
  61. sqlspec/adapters/asyncpg/events/store.py +40 -0
  62. sqlspec/adapters/asyncpg/litestar/__init__.py +5 -0
  63. sqlspec/adapters/asyncpg/litestar/store.py +251 -0
  64. sqlspec/adapters/bigquery/__init__.py +14 -0
  65. sqlspec/adapters/bigquery/_typing.py +86 -0
  66. sqlspec/adapters/bigquery/adk/__init__.py +5 -0
  67. sqlspec/adapters/bigquery/adk/store.py +827 -0
  68. sqlspec/adapters/bigquery/config.py +353 -0
  69. sqlspec/adapters/bigquery/core.cpython-310-aarch64-linux-gnu.so +0 -0
  70. sqlspec/adapters/bigquery/core.py +715 -0
  71. sqlspec/adapters/bigquery/data_dictionary.py +128 -0
  72. sqlspec/adapters/bigquery/driver.py +548 -0
  73. sqlspec/adapters/bigquery/events/__init__.py +5 -0
  74. sqlspec/adapters/bigquery/events/store.py +139 -0
  75. sqlspec/adapters/bigquery/litestar/__init__.py +5 -0
  76. sqlspec/adapters/bigquery/litestar/store.py +325 -0
  77. sqlspec/adapters/bigquery/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  78. sqlspec/adapters/bigquery/type_converter.py +107 -0
  79. sqlspec/adapters/cockroach_asyncpg/__init__.py +24 -0
  80. sqlspec/adapters/cockroach_asyncpg/_typing.py +72 -0
  81. sqlspec/adapters/cockroach_asyncpg/adk/__init__.py +3 -0
  82. sqlspec/adapters/cockroach_asyncpg/adk/store.py +410 -0
  83. sqlspec/adapters/cockroach_asyncpg/config.py +238 -0
  84. sqlspec/adapters/cockroach_asyncpg/core.cpython-310-aarch64-linux-gnu.so +0 -0
  85. sqlspec/adapters/cockroach_asyncpg/core.py +55 -0
  86. sqlspec/adapters/cockroach_asyncpg/data_dictionary.py +107 -0
  87. sqlspec/adapters/cockroach_asyncpg/driver.py +144 -0
  88. sqlspec/adapters/cockroach_asyncpg/events/__init__.py +3 -0
  89. sqlspec/adapters/cockroach_asyncpg/events/store.py +20 -0
  90. sqlspec/adapters/cockroach_asyncpg/litestar/__init__.py +3 -0
  91. sqlspec/adapters/cockroach_asyncpg/litestar/store.py +142 -0
  92. sqlspec/adapters/cockroach_psycopg/__init__.py +38 -0
  93. sqlspec/adapters/cockroach_psycopg/_typing.py +129 -0
  94. sqlspec/adapters/cockroach_psycopg/adk/__init__.py +13 -0
  95. sqlspec/adapters/cockroach_psycopg/adk/store.py +868 -0
  96. sqlspec/adapters/cockroach_psycopg/config.py +484 -0
  97. sqlspec/adapters/cockroach_psycopg/core.cpython-310-aarch64-linux-gnu.so +0 -0
  98. sqlspec/adapters/cockroach_psycopg/core.py +63 -0
  99. sqlspec/adapters/cockroach_psycopg/data_dictionary.py +215 -0
  100. sqlspec/adapters/cockroach_psycopg/driver.py +284 -0
  101. sqlspec/adapters/cockroach_psycopg/events/__init__.py +6 -0
  102. sqlspec/adapters/cockroach_psycopg/events/store.py +34 -0
  103. sqlspec/adapters/cockroach_psycopg/litestar/__init__.py +3 -0
  104. sqlspec/adapters/cockroach_psycopg/litestar/store.py +325 -0
  105. sqlspec/adapters/duckdb/__init__.py +25 -0
  106. sqlspec/adapters/duckdb/_typing.py +81 -0
  107. sqlspec/adapters/duckdb/adk/__init__.py +14 -0
  108. sqlspec/adapters/duckdb/adk/store.py +850 -0
  109. sqlspec/adapters/duckdb/config.py +463 -0
  110. sqlspec/adapters/duckdb/core.cpython-310-aarch64-linux-gnu.so +0 -0
  111. sqlspec/adapters/duckdb/core.py +257 -0
  112. sqlspec/adapters/duckdb/data_dictionary.py +140 -0
  113. sqlspec/adapters/duckdb/driver.py +430 -0
  114. sqlspec/adapters/duckdb/events/__init__.py +5 -0
  115. sqlspec/adapters/duckdb/events/store.py +57 -0
  116. sqlspec/adapters/duckdb/litestar/__init__.py +5 -0
  117. sqlspec/adapters/duckdb/litestar/store.py +330 -0
  118. sqlspec/adapters/duckdb/pool.py +293 -0
  119. sqlspec/adapters/duckdb/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  120. sqlspec/adapters/duckdb/type_converter.py +118 -0
  121. sqlspec/adapters/mock/__init__.py +72 -0
  122. sqlspec/adapters/mock/_typing.py +147 -0
  123. sqlspec/adapters/mock/config.py +483 -0
  124. sqlspec/adapters/mock/core.py +319 -0
  125. sqlspec/adapters/mock/data_dictionary.py +366 -0
  126. sqlspec/adapters/mock/driver.py +721 -0
  127. sqlspec/adapters/mysqlconnector/__init__.py +36 -0
  128. sqlspec/adapters/mysqlconnector/_typing.py +141 -0
  129. sqlspec/adapters/mysqlconnector/adk/__init__.py +15 -0
  130. sqlspec/adapters/mysqlconnector/adk/store.py +1060 -0
  131. sqlspec/adapters/mysqlconnector/config.py +394 -0
  132. sqlspec/adapters/mysqlconnector/core.cpython-310-aarch64-linux-gnu.so +0 -0
  133. sqlspec/adapters/mysqlconnector/core.py +303 -0
  134. sqlspec/adapters/mysqlconnector/data_dictionary.py +235 -0
  135. sqlspec/adapters/mysqlconnector/driver.py +483 -0
  136. sqlspec/adapters/mysqlconnector/events/__init__.py +8 -0
  137. sqlspec/adapters/mysqlconnector/events/store.py +98 -0
  138. sqlspec/adapters/mysqlconnector/litestar/__init__.py +5 -0
  139. sqlspec/adapters/mysqlconnector/litestar/store.py +426 -0
  140. sqlspec/adapters/oracledb/__init__.py +60 -0
  141. sqlspec/adapters/oracledb/_numpy_handlers.py +141 -0
  142. sqlspec/adapters/oracledb/_typing.py +182 -0
  143. sqlspec/adapters/oracledb/_uuid_handlers.py +166 -0
  144. sqlspec/adapters/oracledb/adk/__init__.py +10 -0
  145. sqlspec/adapters/oracledb/adk/store.py +2369 -0
  146. sqlspec/adapters/oracledb/config.py +550 -0
  147. sqlspec/adapters/oracledb/core.cpython-310-aarch64-linux-gnu.so +0 -0
  148. sqlspec/adapters/oracledb/core.py +543 -0
  149. sqlspec/adapters/oracledb/data_dictionary.py +536 -0
  150. sqlspec/adapters/oracledb/driver.py +1229 -0
  151. sqlspec/adapters/oracledb/events/__init__.py +16 -0
  152. sqlspec/adapters/oracledb/events/backend.py +347 -0
  153. sqlspec/adapters/oracledb/events/store.py +420 -0
  154. sqlspec/adapters/oracledb/litestar/__init__.py +5 -0
  155. sqlspec/adapters/oracledb/litestar/store.py +781 -0
  156. sqlspec/adapters/oracledb/migrations.py +535 -0
  157. sqlspec/adapters/oracledb/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  158. sqlspec/adapters/oracledb/type_converter.py +211 -0
  159. sqlspec/adapters/psqlpy/__init__.py +17 -0
  160. sqlspec/adapters/psqlpy/_typing.py +79 -0
  161. sqlspec/adapters/psqlpy/adk/__init__.py +5 -0
  162. sqlspec/adapters/psqlpy/adk/store.py +766 -0
  163. sqlspec/adapters/psqlpy/config.py +304 -0
  164. sqlspec/adapters/psqlpy/core.cpython-310-aarch64-linux-gnu.so +0 -0
  165. sqlspec/adapters/psqlpy/core.py +480 -0
  166. sqlspec/adapters/psqlpy/data_dictionary.py +126 -0
  167. sqlspec/adapters/psqlpy/driver.py +438 -0
  168. sqlspec/adapters/psqlpy/events/__init__.py +6 -0
  169. sqlspec/adapters/psqlpy/events/backend.py +310 -0
  170. sqlspec/adapters/psqlpy/events/store.py +20 -0
  171. sqlspec/adapters/psqlpy/litestar/__init__.py +5 -0
  172. sqlspec/adapters/psqlpy/litestar/store.py +270 -0
  173. sqlspec/adapters/psqlpy/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  174. sqlspec/adapters/psqlpy/type_converter.py +113 -0
  175. sqlspec/adapters/psycopg/__init__.py +32 -0
  176. sqlspec/adapters/psycopg/_typing.py +164 -0
  177. sqlspec/adapters/psycopg/adk/__init__.py +10 -0
  178. sqlspec/adapters/psycopg/adk/store.py +1387 -0
  179. sqlspec/adapters/psycopg/config.py +576 -0
  180. sqlspec/adapters/psycopg/core.cpython-310-aarch64-linux-gnu.so +0 -0
  181. sqlspec/adapters/psycopg/core.py +450 -0
  182. sqlspec/adapters/psycopg/data_dictionary.py +289 -0
  183. sqlspec/adapters/psycopg/driver.py +975 -0
  184. sqlspec/adapters/psycopg/events/__init__.py +20 -0
  185. sqlspec/adapters/psycopg/events/backend.py +458 -0
  186. sqlspec/adapters/psycopg/events/store.py +42 -0
  187. sqlspec/adapters/psycopg/litestar/__init__.py +5 -0
  188. sqlspec/adapters/psycopg/litestar/store.py +552 -0
  189. sqlspec/adapters/psycopg/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  190. sqlspec/adapters/psycopg/type_converter.py +93 -0
  191. sqlspec/adapters/pymysql/__init__.py +21 -0
  192. sqlspec/adapters/pymysql/_typing.py +71 -0
  193. sqlspec/adapters/pymysql/adk/__init__.py +5 -0
  194. sqlspec/adapters/pymysql/adk/store.py +540 -0
  195. sqlspec/adapters/pymysql/config.py +195 -0
  196. sqlspec/adapters/pymysql/core.cpython-310-aarch64-linux-gnu.so +0 -0
  197. sqlspec/adapters/pymysql/core.py +299 -0
  198. sqlspec/adapters/pymysql/data_dictionary.py +122 -0
  199. sqlspec/adapters/pymysql/driver.py +259 -0
  200. sqlspec/adapters/pymysql/events/__init__.py +5 -0
  201. sqlspec/adapters/pymysql/events/store.py +50 -0
  202. sqlspec/adapters/pymysql/litestar/__init__.py +5 -0
  203. sqlspec/adapters/pymysql/litestar/store.py +232 -0
  204. sqlspec/adapters/pymysql/pool.py +137 -0
  205. sqlspec/adapters/spanner/__init__.py +40 -0
  206. sqlspec/adapters/spanner/_typing.py +86 -0
  207. sqlspec/adapters/spanner/adk/__init__.py +5 -0
  208. sqlspec/adapters/spanner/adk/store.py +732 -0
  209. sqlspec/adapters/spanner/config.py +352 -0
  210. sqlspec/adapters/spanner/core.cpython-310-aarch64-linux-gnu.so +0 -0
  211. sqlspec/adapters/spanner/core.py +188 -0
  212. sqlspec/adapters/spanner/data_dictionary.py +120 -0
  213. sqlspec/adapters/spanner/dialect/__init__.py +6 -0
  214. sqlspec/adapters/spanner/dialect/_spangres.py +57 -0
  215. sqlspec/adapters/spanner/dialect/_spanner.py +130 -0
  216. sqlspec/adapters/spanner/driver.py +373 -0
  217. sqlspec/adapters/spanner/events/__init__.py +5 -0
  218. sqlspec/adapters/spanner/events/store.py +187 -0
  219. sqlspec/adapters/spanner/litestar/__init__.py +5 -0
  220. sqlspec/adapters/spanner/litestar/store.py +291 -0
  221. sqlspec/adapters/spanner/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  222. sqlspec/adapters/spanner/type_converter.py +331 -0
  223. sqlspec/adapters/sqlite/__init__.py +19 -0
  224. sqlspec/adapters/sqlite/_typing.py +80 -0
  225. sqlspec/adapters/sqlite/adk/__init__.py +5 -0
  226. sqlspec/adapters/sqlite/adk/store.py +958 -0
  227. sqlspec/adapters/sqlite/config.py +280 -0
  228. sqlspec/adapters/sqlite/core.cpython-310-aarch64-linux-gnu.so +0 -0
  229. sqlspec/adapters/sqlite/core.py +312 -0
  230. sqlspec/adapters/sqlite/data_dictionary.py +202 -0
  231. sqlspec/adapters/sqlite/driver.py +359 -0
  232. sqlspec/adapters/sqlite/events/__init__.py +5 -0
  233. sqlspec/adapters/sqlite/events/store.py +20 -0
  234. sqlspec/adapters/sqlite/litestar/__init__.py +5 -0
  235. sqlspec/adapters/sqlite/litestar/store.py +316 -0
  236. sqlspec/adapters/sqlite/pool.py +198 -0
  237. sqlspec/adapters/sqlite/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  238. sqlspec/adapters/sqlite/type_converter.py +114 -0
  239. sqlspec/base.py +747 -0
  240. sqlspec/builder/__init__.py +179 -0
  241. sqlspec/builder/_base.cpython-310-aarch64-linux-gnu.so +0 -0
  242. sqlspec/builder/_base.py +1022 -0
  243. sqlspec/builder/_column.cpython-310-aarch64-linux-gnu.so +0 -0
  244. sqlspec/builder/_column.py +521 -0
  245. sqlspec/builder/_ddl.cpython-310-aarch64-linux-gnu.so +0 -0
  246. sqlspec/builder/_ddl.py +1642 -0
  247. sqlspec/builder/_delete.cpython-310-aarch64-linux-gnu.so +0 -0
  248. sqlspec/builder/_delete.py +95 -0
  249. sqlspec/builder/_dml.cpython-310-aarch64-linux-gnu.so +0 -0
  250. sqlspec/builder/_dml.py +365 -0
  251. sqlspec/builder/_explain.cpython-310-aarch64-linux-gnu.so +0 -0
  252. sqlspec/builder/_explain.py +579 -0
  253. sqlspec/builder/_expression_wrappers.cpython-310-aarch64-linux-gnu.so +0 -0
  254. sqlspec/builder/_expression_wrappers.py +46 -0
  255. sqlspec/builder/_factory.cpython-310-aarch64-linux-gnu.so +0 -0
  256. sqlspec/builder/_factory.py +1697 -0
  257. sqlspec/builder/_insert.cpython-310-aarch64-linux-gnu.so +0 -0
  258. sqlspec/builder/_insert.py +328 -0
  259. sqlspec/builder/_join.cpython-310-aarch64-linux-gnu.so +0 -0
  260. sqlspec/builder/_join.py +499 -0
  261. sqlspec/builder/_merge.cpython-310-aarch64-linux-gnu.so +0 -0
  262. sqlspec/builder/_merge.py +821 -0
  263. sqlspec/builder/_parsing_utils.cpython-310-aarch64-linux-gnu.so +0 -0
  264. sqlspec/builder/_parsing_utils.py +297 -0
  265. sqlspec/builder/_select.cpython-310-aarch64-linux-gnu.so +0 -0
  266. sqlspec/builder/_select.py +1660 -0
  267. sqlspec/builder/_temporal.cpython-310-aarch64-linux-gnu.so +0 -0
  268. sqlspec/builder/_temporal.py +139 -0
  269. sqlspec/builder/_update.cpython-310-aarch64-linux-gnu.so +0 -0
  270. sqlspec/builder/_update.py +173 -0
  271. sqlspec/builder/_vector_expressions.py +267 -0
  272. sqlspec/cli.py +911 -0
  273. sqlspec/config.py +1755 -0
  274. sqlspec/core/__init__.py +374 -0
  275. sqlspec/core/_correlation.cpython-310-aarch64-linux-gnu.so +0 -0
  276. sqlspec/core/_correlation.py +176 -0
  277. sqlspec/core/cache.cpython-310-aarch64-linux-gnu.so +0 -0
  278. sqlspec/core/cache.py +1069 -0
  279. sqlspec/core/compiler.cpython-310-aarch64-linux-gnu.so +0 -0
  280. sqlspec/core/compiler.py +954 -0
  281. sqlspec/core/explain.cpython-310-aarch64-linux-gnu.so +0 -0
  282. sqlspec/core/explain.py +275 -0
  283. sqlspec/core/filters.cpython-310-aarch64-linux-gnu.so +0 -0
  284. sqlspec/core/filters.py +952 -0
  285. sqlspec/core/hashing.cpython-310-aarch64-linux-gnu.so +0 -0
  286. sqlspec/core/hashing.py +262 -0
  287. sqlspec/core/metrics.cpython-310-aarch64-linux-gnu.so +0 -0
  288. sqlspec/core/metrics.py +83 -0
  289. sqlspec/core/parameters/__init__.py +71 -0
  290. sqlspec/core/parameters/_alignment.cpython-310-aarch64-linux-gnu.so +0 -0
  291. sqlspec/core/parameters/_alignment.py +270 -0
  292. sqlspec/core/parameters/_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  293. sqlspec/core/parameters/_converter.py +543 -0
  294. sqlspec/core/parameters/_processor.cpython-310-aarch64-linux-gnu.so +0 -0
  295. sqlspec/core/parameters/_processor.py +505 -0
  296. sqlspec/core/parameters/_registry.cpython-310-aarch64-linux-gnu.so +0 -0
  297. sqlspec/core/parameters/_registry.py +206 -0
  298. sqlspec/core/parameters/_transformers.cpython-310-aarch64-linux-gnu.so +0 -0
  299. sqlspec/core/parameters/_transformers.py +292 -0
  300. sqlspec/core/parameters/_types.cpython-310-aarch64-linux-gnu.so +0 -0
  301. sqlspec/core/parameters/_types.py +499 -0
  302. sqlspec/core/parameters/_validator.cpython-310-aarch64-linux-gnu.so +0 -0
  303. sqlspec/core/parameters/_validator.py +180 -0
  304. sqlspec/core/pipeline.cpython-310-aarch64-linux-gnu.so +0 -0
  305. sqlspec/core/pipeline.py +319 -0
  306. sqlspec/core/query_modifiers.cpython-310-aarch64-linux-gnu.so +0 -0
  307. sqlspec/core/query_modifiers.py +437 -0
  308. sqlspec/core/result/__init__.py +23 -0
  309. sqlspec/core/result/_base.cpython-310-aarch64-linux-gnu.so +0 -0
  310. sqlspec/core/result/_base.py +1121 -0
  311. sqlspec/core/result/_io.cpython-310-aarch64-linux-gnu.so +0 -0
  312. sqlspec/core/result/_io.py +28 -0
  313. sqlspec/core/splitter.cpython-310-aarch64-linux-gnu.so +0 -0
  314. sqlspec/core/splitter.py +966 -0
  315. sqlspec/core/stack.cpython-310-aarch64-linux-gnu.so +0 -0
  316. sqlspec/core/stack.py +163 -0
  317. sqlspec/core/statement.cpython-310-aarch64-linux-gnu.so +0 -0
  318. sqlspec/core/statement.py +1503 -0
  319. sqlspec/core/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  320. sqlspec/core/type_converter.py +339 -0
  321. sqlspec/data_dictionary/__init__.py +22 -0
  322. sqlspec/data_dictionary/_loader.py +123 -0
  323. sqlspec/data_dictionary/_registry.cpython-310-aarch64-linux-gnu.so +0 -0
  324. sqlspec/data_dictionary/_registry.py +74 -0
  325. sqlspec/data_dictionary/_types.cpython-310-aarch64-linux-gnu.so +0 -0
  326. sqlspec/data_dictionary/_types.py +121 -0
  327. sqlspec/data_dictionary/dialects/__init__.py +21 -0
  328. sqlspec/data_dictionary/dialects/bigquery.cpython-310-aarch64-linux-gnu.so +0 -0
  329. sqlspec/data_dictionary/dialects/bigquery.py +49 -0
  330. sqlspec/data_dictionary/dialects/cockroachdb.cpython-310-aarch64-linux-gnu.so +0 -0
  331. sqlspec/data_dictionary/dialects/cockroachdb.py +43 -0
  332. sqlspec/data_dictionary/dialects/duckdb.cpython-310-aarch64-linux-gnu.so +0 -0
  333. sqlspec/data_dictionary/dialects/duckdb.py +47 -0
  334. sqlspec/data_dictionary/dialects/mysql.cpython-310-aarch64-linux-gnu.so +0 -0
  335. sqlspec/data_dictionary/dialects/mysql.py +42 -0
  336. sqlspec/data_dictionary/dialects/oracle.cpython-310-aarch64-linux-gnu.so +0 -0
  337. sqlspec/data_dictionary/dialects/oracle.py +34 -0
  338. sqlspec/data_dictionary/dialects/postgres.cpython-310-aarch64-linux-gnu.so +0 -0
  339. sqlspec/data_dictionary/dialects/postgres.py +46 -0
  340. sqlspec/data_dictionary/dialects/spanner.cpython-310-aarch64-linux-gnu.so +0 -0
  341. sqlspec/data_dictionary/dialects/spanner.py +37 -0
  342. sqlspec/data_dictionary/dialects/sqlite.cpython-310-aarch64-linux-gnu.so +0 -0
  343. sqlspec/data_dictionary/dialects/sqlite.py +42 -0
  344. sqlspec/data_dictionary/sql/.gitkeep +0 -0
  345. sqlspec/data_dictionary/sql/bigquery/columns.sql +23 -0
  346. sqlspec/data_dictionary/sql/bigquery/foreign_keys.sql +34 -0
  347. sqlspec/data_dictionary/sql/bigquery/indexes.sql +19 -0
  348. sqlspec/data_dictionary/sql/bigquery/tables.sql +33 -0
  349. sqlspec/data_dictionary/sql/bigquery/version.sql +3 -0
  350. sqlspec/data_dictionary/sql/cockroachdb/columns.sql +34 -0
  351. sqlspec/data_dictionary/sql/cockroachdb/foreign_keys.sql +40 -0
  352. sqlspec/data_dictionary/sql/cockroachdb/indexes.sql +32 -0
  353. sqlspec/data_dictionary/sql/cockroachdb/tables.sql +44 -0
  354. sqlspec/data_dictionary/sql/cockroachdb/version.sql +3 -0
  355. sqlspec/data_dictionary/sql/duckdb/columns.sql +23 -0
  356. sqlspec/data_dictionary/sql/duckdb/foreign_keys.sql +36 -0
  357. sqlspec/data_dictionary/sql/duckdb/indexes.sql +19 -0
  358. sqlspec/data_dictionary/sql/duckdb/tables.sql +38 -0
  359. sqlspec/data_dictionary/sql/duckdb/version.sql +3 -0
  360. sqlspec/data_dictionary/sql/mysql/columns.sql +23 -0
  361. sqlspec/data_dictionary/sql/mysql/foreign_keys.sql +28 -0
  362. sqlspec/data_dictionary/sql/mysql/indexes.sql +26 -0
  363. sqlspec/data_dictionary/sql/mysql/tables.sql +33 -0
  364. sqlspec/data_dictionary/sql/mysql/version.sql +3 -0
  365. sqlspec/data_dictionary/sql/oracle/columns.sql +23 -0
  366. sqlspec/data_dictionary/sql/oracle/foreign_keys.sql +48 -0
  367. sqlspec/data_dictionary/sql/oracle/indexes.sql +44 -0
  368. sqlspec/data_dictionary/sql/oracle/tables.sql +25 -0
  369. sqlspec/data_dictionary/sql/oracle/version.sql +20 -0
  370. sqlspec/data_dictionary/sql/postgres/columns.sql +34 -0
  371. sqlspec/data_dictionary/sql/postgres/foreign_keys.sql +40 -0
  372. sqlspec/data_dictionary/sql/postgres/indexes.sql +56 -0
  373. sqlspec/data_dictionary/sql/postgres/tables.sql +44 -0
  374. sqlspec/data_dictionary/sql/postgres/version.sql +3 -0
  375. sqlspec/data_dictionary/sql/spanner/columns.sql +23 -0
  376. sqlspec/data_dictionary/sql/spanner/foreign_keys.sql +70 -0
  377. sqlspec/data_dictionary/sql/spanner/indexes.sql +30 -0
  378. sqlspec/data_dictionary/sql/spanner/tables.sql +9 -0
  379. sqlspec/data_dictionary/sql/spanner/version.sql +3 -0
  380. sqlspec/data_dictionary/sql/sqlite/columns.sql +23 -0
  381. sqlspec/data_dictionary/sql/sqlite/foreign_keys.sql +22 -0
  382. sqlspec/data_dictionary/sql/sqlite/indexes.sql +7 -0
  383. sqlspec/data_dictionary/sql/sqlite/tables.sql +28 -0
  384. sqlspec/data_dictionary/sql/sqlite/version.sql +3 -0
  385. sqlspec/driver/__init__.py +32 -0
  386. sqlspec/driver/_async.cpython-310-aarch64-linux-gnu.so +0 -0
  387. sqlspec/driver/_async.py +1737 -0
  388. sqlspec/driver/_common.cpython-310-aarch64-linux-gnu.so +0 -0
  389. sqlspec/driver/_common.py +1478 -0
  390. sqlspec/driver/_sql_helpers.cpython-310-aarch64-linux-gnu.so +0 -0
  391. sqlspec/driver/_sql_helpers.py +148 -0
  392. sqlspec/driver/_storage_helpers.cpython-310-aarch64-linux-gnu.so +0 -0
  393. sqlspec/driver/_storage_helpers.py +144 -0
  394. sqlspec/driver/_sync.cpython-310-aarch64-linux-gnu.so +0 -0
  395. sqlspec/driver/_sync.py +1710 -0
  396. sqlspec/exceptions.py +338 -0
  397. sqlspec/extensions/__init__.py +0 -0
  398. sqlspec/extensions/adk/__init__.py +70 -0
  399. sqlspec/extensions/adk/_types.py +51 -0
  400. sqlspec/extensions/adk/converters.py +172 -0
  401. sqlspec/extensions/adk/memory/__init__.py +69 -0
  402. sqlspec/extensions/adk/memory/_types.py +30 -0
  403. sqlspec/extensions/adk/memory/converters.py +149 -0
  404. sqlspec/extensions/adk/memory/service.py +217 -0
  405. sqlspec/extensions/adk/memory/store.py +569 -0
  406. sqlspec/extensions/adk/migrations/0001_create_adk_tables.py +246 -0
  407. sqlspec/extensions/adk/migrations/__init__.py +0 -0
  408. sqlspec/extensions/adk/service.py +225 -0
  409. sqlspec/extensions/adk/store.py +567 -0
  410. sqlspec/extensions/events/__init__.py +51 -0
  411. sqlspec/extensions/events/_channel.py +703 -0
  412. sqlspec/extensions/events/_hints.py +45 -0
  413. sqlspec/extensions/events/_models.py +23 -0
  414. sqlspec/extensions/events/_payload.py +69 -0
  415. sqlspec/extensions/events/_protocols.py +134 -0
  416. sqlspec/extensions/events/_queue.py +461 -0
  417. sqlspec/extensions/events/_store.py +209 -0
  418. sqlspec/extensions/events/migrations/0001_create_event_queue.py +59 -0
  419. sqlspec/extensions/events/migrations/__init__.py +3 -0
  420. sqlspec/extensions/fastapi/__init__.py +19 -0
  421. sqlspec/extensions/fastapi/extension.py +351 -0
  422. sqlspec/extensions/fastapi/providers.py +607 -0
  423. sqlspec/extensions/flask/__init__.py +37 -0
  424. sqlspec/extensions/flask/_state.py +76 -0
  425. sqlspec/extensions/flask/_utils.py +71 -0
  426. sqlspec/extensions/flask/extension.py +519 -0
  427. sqlspec/extensions/litestar/__init__.py +28 -0
  428. sqlspec/extensions/litestar/_utils.py +52 -0
  429. sqlspec/extensions/litestar/channels.py +165 -0
  430. sqlspec/extensions/litestar/cli.py +102 -0
  431. sqlspec/extensions/litestar/config.py +90 -0
  432. sqlspec/extensions/litestar/handlers.py +316 -0
  433. sqlspec/extensions/litestar/migrations/0001_create_session_table.py +137 -0
  434. sqlspec/extensions/litestar/migrations/__init__.py +3 -0
  435. sqlspec/extensions/litestar/plugin.py +671 -0
  436. sqlspec/extensions/litestar/providers.py +526 -0
  437. sqlspec/extensions/litestar/store.py +296 -0
  438. sqlspec/extensions/otel/__init__.py +58 -0
  439. sqlspec/extensions/prometheus/__init__.py +113 -0
  440. sqlspec/extensions/starlette/__init__.py +19 -0
  441. sqlspec/extensions/starlette/_state.py +30 -0
  442. sqlspec/extensions/starlette/_utils.py +96 -0
  443. sqlspec/extensions/starlette/extension.py +346 -0
  444. sqlspec/extensions/starlette/middleware.py +235 -0
  445. sqlspec/loader.cpython-310-aarch64-linux-gnu.so +0 -0
  446. sqlspec/loader.py +702 -0
  447. sqlspec/migrations/__init__.py +36 -0
  448. sqlspec/migrations/base.py +731 -0
  449. sqlspec/migrations/commands.py +1232 -0
  450. sqlspec/migrations/context.py +157 -0
  451. sqlspec/migrations/fix.py +204 -0
  452. sqlspec/migrations/loaders.py +443 -0
  453. sqlspec/migrations/runner.py +1172 -0
  454. sqlspec/migrations/templates.py +234 -0
  455. sqlspec/migrations/tracker.py +611 -0
  456. sqlspec/migrations/utils.py +256 -0
  457. sqlspec/migrations/validation.py +207 -0
  458. sqlspec/migrations/version.py +446 -0
  459. sqlspec/observability/__init__.py +55 -0
  460. sqlspec/observability/_common.cpython-310-aarch64-linux-gnu.so +0 -0
  461. sqlspec/observability/_common.py +77 -0
  462. sqlspec/observability/_config.cpython-310-aarch64-linux-gnu.so +0 -0
  463. sqlspec/observability/_config.py +348 -0
  464. sqlspec/observability/_diagnostics.cpython-310-aarch64-linux-gnu.so +0 -0
  465. sqlspec/observability/_diagnostics.py +74 -0
  466. sqlspec/observability/_dispatcher.cpython-310-aarch64-linux-gnu.so +0 -0
  467. sqlspec/observability/_dispatcher.py +152 -0
  468. sqlspec/observability/_formatters/__init__.py +13 -0
  469. sqlspec/observability/_formatters/_aws.cpython-310-aarch64-linux-gnu.so +0 -0
  470. sqlspec/observability/_formatters/_aws.py +102 -0
  471. sqlspec/observability/_formatters/_azure.cpython-310-aarch64-linux-gnu.so +0 -0
  472. sqlspec/observability/_formatters/_azure.py +96 -0
  473. sqlspec/observability/_formatters/_base.cpython-310-aarch64-linux-gnu.so +0 -0
  474. sqlspec/observability/_formatters/_base.py +57 -0
  475. sqlspec/observability/_formatters/_gcp.cpython-310-aarch64-linux-gnu.so +0 -0
  476. sqlspec/observability/_formatters/_gcp.py +131 -0
  477. sqlspec/observability/_formatting.py +58 -0
  478. sqlspec/observability/_observer.cpython-310-aarch64-linux-gnu.so +0 -0
  479. sqlspec/observability/_observer.py +357 -0
  480. sqlspec/observability/_runtime.cpython-310-aarch64-linux-gnu.so +0 -0
  481. sqlspec/observability/_runtime.py +420 -0
  482. sqlspec/observability/_sampling.cpython-310-aarch64-linux-gnu.so +0 -0
  483. sqlspec/observability/_sampling.py +188 -0
  484. sqlspec/observability/_spans.cpython-310-aarch64-linux-gnu.so +0 -0
  485. sqlspec/observability/_spans.py +161 -0
  486. sqlspec/protocols.py +916 -0
  487. sqlspec/py.typed +0 -0
  488. sqlspec/storage/__init__.py +48 -0
  489. sqlspec/storage/_utils.py +104 -0
  490. sqlspec/storage/backends/__init__.py +1 -0
  491. sqlspec/storage/backends/base.py +253 -0
  492. sqlspec/storage/backends/fsspec.py +529 -0
  493. sqlspec/storage/backends/local.py +441 -0
  494. sqlspec/storage/backends/obstore.py +916 -0
  495. sqlspec/storage/errors.py +104 -0
  496. sqlspec/storage/pipeline.py +582 -0
  497. sqlspec/storage/registry.py +301 -0
  498. sqlspec/typing.py +395 -0
  499. sqlspec/utils/__init__.py +7 -0
  500. sqlspec/utils/arrow_helpers.py +318 -0
  501. sqlspec/utils/config_tools.py +332 -0
  502. sqlspec/utils/correlation.cpython-310-aarch64-linux-gnu.so +0 -0
  503. sqlspec/utils/correlation.py +134 -0
  504. sqlspec/utils/deprecation.py +190 -0
  505. sqlspec/utils/fixtures.cpython-310-aarch64-linux-gnu.so +0 -0
  506. sqlspec/utils/fixtures.py +258 -0
  507. sqlspec/utils/logging.py +222 -0
  508. sqlspec/utils/module_loader.py +306 -0
  509. sqlspec/utils/portal.cpython-310-aarch64-linux-gnu.so +0 -0
  510. sqlspec/utils/portal.py +375 -0
  511. sqlspec/utils/schema.cpython-310-aarch64-linux-gnu.so +0 -0
  512. sqlspec/utils/schema.py +485 -0
  513. sqlspec/utils/serializers.cpython-310-aarch64-linux-gnu.so +0 -0
  514. sqlspec/utils/serializers.py +408 -0
  515. sqlspec/utils/singleton.cpython-310-aarch64-linux-gnu.so +0 -0
  516. sqlspec/utils/singleton.py +41 -0
  517. sqlspec/utils/sync_tools.cpython-310-aarch64-linux-gnu.so +0 -0
  518. sqlspec/utils/sync_tools.py +311 -0
  519. sqlspec/utils/text.cpython-310-aarch64-linux-gnu.so +0 -0
  520. sqlspec/utils/text.py +108 -0
  521. sqlspec/utils/type_converters.cpython-310-aarch64-linux-gnu.so +0 -0
  522. sqlspec/utils/type_converters.py +128 -0
  523. sqlspec/utils/type_guards.cpython-310-aarch64-linux-gnu.so +0 -0
  524. sqlspec/utils/type_guards.py +1360 -0
  525. sqlspec/utils/uuids.cpython-310-aarch64-linux-gnu.so +0 -0
  526. sqlspec/utils/uuids.py +225 -0
  527. sqlspec-0.36.0.dist-info/METADATA +205 -0
  528. sqlspec-0.36.0.dist-info/RECORD +531 -0
  529. sqlspec-0.36.0.dist-info/WHEEL +7 -0
  530. sqlspec-0.36.0.dist-info/entry_points.txt +2 -0
  531. 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
+ )