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,818 @@
1
+ """Aiosqlite async ADK store for Google Agent Development Kit session/event storage."""
2
+
3
+ from datetime import datetime, timezone
4
+ from typing import TYPE_CHECKING, Any, cast
5
+
6
+ from sqlspec.extensions.adk import BaseAsyncADKStore, EventRecord, SessionRecord
7
+ from sqlspec.extensions.adk.memory.store import BaseAsyncADKMemoryStore
8
+ from sqlspec.utils.serializers import from_json, to_json
9
+
10
+ if TYPE_CHECKING:
11
+ from sqlspec.adapters.aiosqlite.config import AiosqliteConfig
12
+ from sqlspec.extensions.adk import MemoryRecord
13
+
14
+
15
+ SECONDS_PER_DAY = 86400.0
16
+ JULIAN_EPOCH = 2440587.5
17
+
18
+ __all__ = ("AiosqliteADKMemoryStore", "AiosqliteADKStore")
19
+
20
+
21
+ def _datetime_to_julian(dt: datetime) -> float:
22
+ """Convert datetime to Julian Day number for SQLite storage.
23
+
24
+ Args:
25
+ dt: Datetime to convert (must be UTC-aware).
26
+
27
+ Returns:
28
+ Julian Day number as REAL.
29
+
30
+ Notes:
31
+ Julian Day number is days since November 24, 4714 BCE (proleptic Gregorian).
32
+ This enables direct comparison with julianday('now') in SQL queries.
33
+ """
34
+ if dt.tzinfo is None:
35
+ dt = dt.replace(tzinfo=timezone.utc)
36
+ epoch = datetime(1970, 1, 1, tzinfo=timezone.utc)
37
+ delta_days = (dt - epoch).total_seconds() / SECONDS_PER_DAY
38
+ return JULIAN_EPOCH + delta_days
39
+
40
+
41
+ def _julian_to_datetime(julian: float) -> datetime:
42
+ """Convert Julian Day number back to datetime.
43
+
44
+ Args:
45
+ julian: Julian Day number.
46
+
47
+ Returns:
48
+ UTC-aware datetime.
49
+ """
50
+ days_since_epoch = julian - JULIAN_EPOCH
51
+ timestamp = days_since_epoch * SECONDS_PER_DAY
52
+ return datetime.fromtimestamp(timestamp, tz=timezone.utc)
53
+
54
+
55
+ def _to_sqlite_bool(value: "bool | None") -> "int | None":
56
+ """Convert Python bool to SQLite INTEGER.
57
+
58
+ Args:
59
+ value: Boolean value or None.
60
+
61
+ Returns:
62
+ 1 for True, 0 for False, None for None.
63
+ """
64
+ if value is None:
65
+ return None
66
+ return 1 if value else 0
67
+
68
+
69
+ def _from_sqlite_bool(value: "int | None") -> "bool | None":
70
+ """Convert SQLite INTEGER to Python bool.
71
+
72
+ Args:
73
+ value: Integer value (0/1) or None.
74
+
75
+ Returns:
76
+ True for 1, False for 0, None for None.
77
+ """
78
+ if value is None:
79
+ return None
80
+ return bool(value)
81
+
82
+
83
+ class AiosqliteADKStore(BaseAsyncADKStore["AiosqliteConfig"]):
84
+ """Aiosqlite ADK store using asynchronous SQLite driver.
85
+
86
+ Implements session and event storage for Google Agent Development Kit
87
+ using SQLite via the asynchronous aiosqlite driver.
88
+
89
+ Provides:
90
+ - Session state management with JSON storage (as TEXT)
91
+ - Event history tracking with BLOB-serialized actions
92
+ - Julian Day timestamps (REAL) for efficient date operations
93
+ - Foreign key constraints with cascade delete
94
+ - Efficient upserts using INSERT OR REPLACE
95
+
96
+ Args:
97
+ config: AiosqliteConfig with extension_config["adk"] settings.
98
+
99
+ Example:
100
+ from sqlspec.adapters.aiosqlite import AiosqliteConfig
101
+ from sqlspec.adapters.aiosqlite.adk import AiosqliteADKStore
102
+
103
+ config = AiosqliteConfig(
104
+ connection_config={"database": ":memory:"},
105
+ extension_config={
106
+ "adk": {
107
+ "session_table": "my_sessions",
108
+ "events_table": "my_events"
109
+ }
110
+ }
111
+ )
112
+ store = AiosqliteADKStore(config)
113
+ await store.ensure_tables()
114
+
115
+ Notes:
116
+ - JSON stored as TEXT with SQLSpec serializers (msgspec/orjson/stdlib)
117
+ - BOOLEAN as INTEGER (0/1, with None for NULL)
118
+ - Timestamps as REAL (Julian day: julianday('now'))
119
+ - BLOB for pre-serialized actions from Google ADK
120
+ - PRAGMA foreign_keys = ON (enable per connection)
121
+ - Configuration is read from config.extension_config["adk"]
122
+ """
123
+
124
+ __slots__ = ()
125
+
126
+ def __init__(self, config: "AiosqliteConfig") -> None:
127
+ """Initialize Aiosqlite ADK store.
128
+
129
+ Args:
130
+ config: AiosqliteConfig instance.
131
+
132
+ Notes:
133
+ Configuration is read from config.extension_config["adk"]:
134
+ - session_table: Sessions table name (default: "adk_sessions")
135
+ - events_table: Events table name (default: "adk_events")
136
+ """
137
+ super().__init__(config)
138
+
139
+ async def _get_create_sessions_table_sql(self) -> str:
140
+ """Get SQLite CREATE TABLE SQL for sessions.
141
+
142
+ Returns:
143
+ SQL statement to create adk_sessions table with indexes.
144
+
145
+ Notes:
146
+ - TEXT for IDs, names, and JSON state
147
+ - REAL for Julian Day timestamps
148
+ - Composite index on (app_name, user_id)
149
+ - Index on update_time DESC for recent session queries
150
+ """
151
+ return f"""
152
+ CREATE TABLE IF NOT EXISTS {self._session_table} (
153
+ id TEXT PRIMARY KEY,
154
+ app_name TEXT NOT NULL,
155
+ user_id TEXT NOT NULL,
156
+ state TEXT NOT NULL DEFAULT '{{}}',
157
+ create_time REAL NOT NULL,
158
+ update_time REAL NOT NULL
159
+ );
160
+ CREATE INDEX IF NOT EXISTS idx_{self._session_table}_app_user
161
+ ON {self._session_table}(app_name, user_id);
162
+ CREATE INDEX IF NOT EXISTS idx_{self._session_table}_update_time
163
+ ON {self._session_table}(update_time DESC);
164
+ """
165
+
166
+ async def _get_create_events_table_sql(self) -> str:
167
+ """Get SQLite CREATE TABLE SQL for events.
168
+
169
+ Returns:
170
+ SQL statement to create adk_events table with indexes.
171
+
172
+ Notes:
173
+ - TEXT for IDs, strings, and JSON content
174
+ - BLOB for pickled actions
175
+ - INTEGER for booleans (0/1/NULL)
176
+ - REAL for Julian Day timestamps
177
+ - Foreign key to sessions with CASCADE delete
178
+ - Index on (session_id, timestamp ASC)
179
+ """
180
+ return f"""
181
+ CREATE TABLE IF NOT EXISTS {self._events_table} (
182
+ id TEXT PRIMARY KEY,
183
+ session_id TEXT NOT NULL,
184
+ app_name TEXT NOT NULL,
185
+ user_id TEXT NOT NULL,
186
+ invocation_id TEXT NOT NULL,
187
+ author TEXT NOT NULL,
188
+ actions BLOB NOT NULL,
189
+ long_running_tool_ids_json TEXT,
190
+ branch TEXT,
191
+ timestamp REAL NOT NULL,
192
+ content TEXT,
193
+ grounding_metadata TEXT,
194
+ custom_metadata TEXT,
195
+ partial INTEGER,
196
+ turn_complete INTEGER,
197
+ interrupted INTEGER,
198
+ error_code TEXT,
199
+ error_message TEXT,
200
+ FOREIGN KEY (session_id) REFERENCES {self._session_table}(id) ON DELETE CASCADE
201
+ );
202
+ CREATE INDEX IF NOT EXISTS idx_{self._events_table}_session
203
+ ON {self._events_table}(session_id, timestamp ASC);
204
+ """
205
+
206
+ def _get_drop_tables_sql(self) -> "list[str]":
207
+ """Get SQLite DROP TABLE SQL statements.
208
+
209
+ Returns:
210
+ List of SQL statements to drop tables and indexes.
211
+
212
+ Notes:
213
+ Order matters: drop events table (child) before sessions (parent).
214
+ SQLite automatically drops indexes when dropping tables.
215
+ """
216
+ return [f"DROP TABLE IF EXISTS {self._events_table}", f"DROP TABLE IF EXISTS {self._session_table}"]
217
+
218
+ async def _enable_foreign_keys(self, connection: Any) -> None:
219
+ """Enable foreign key constraints for this connection.
220
+
221
+ Args:
222
+ connection: Aiosqlite connection.
223
+
224
+ Notes:
225
+ SQLite requires PRAGMA foreign_keys = ON per connection.
226
+ """
227
+ await connection.execute("PRAGMA foreign_keys = ON")
228
+
229
+ async def create_tables(self) -> None:
230
+ """Create both sessions and events tables if they don't exist."""
231
+ async with self._config.provide_session() as driver:
232
+ await self._enable_foreign_keys(driver.connection)
233
+ await driver.execute_script(await self._get_create_sessions_table_sql())
234
+ await driver.execute_script(await self._get_create_events_table_sql())
235
+
236
+ async def create_session(
237
+ self, session_id: str, app_name: str, user_id: str, state: "dict[str, Any]", owner_id: "Any | None" = None
238
+ ) -> SessionRecord:
239
+ """Create a new session.
240
+
241
+ Args:
242
+ session_id: Unique session identifier.
243
+ app_name: Application name.
244
+ user_id: User identifier.
245
+ state: Initial session state.
246
+ owner_id: Optional owner ID value for owner_id_column.
247
+
248
+ Returns:
249
+ Created session record.
250
+
251
+ Notes:
252
+ Uses Julian Day for create_time and update_time.
253
+ State is JSON-serialized before insertion.
254
+ """
255
+ now = datetime.now(timezone.utc)
256
+ now_julian = _datetime_to_julian(now)
257
+ state_json = to_json(state) if state else None
258
+
259
+ params: tuple[Any, ...]
260
+ if self._owner_id_column_name:
261
+ sql = f"""
262
+ INSERT INTO {self._session_table}
263
+ (id, app_name, user_id, {self._owner_id_column_name}, state, create_time, update_time)
264
+ VALUES (?, ?, ?, ?, ?, ?, ?)
265
+ """
266
+ params = (session_id, app_name, user_id, owner_id, state_json, now_julian, now_julian)
267
+ else:
268
+ sql = f"""
269
+ INSERT INTO {self._session_table} (id, app_name, user_id, state, create_time, update_time)
270
+ VALUES (?, ?, ?, ?, ?, ?)
271
+ """
272
+ params = (session_id, app_name, user_id, state_json, now_julian, now_julian)
273
+
274
+ async with self._config.provide_connection() as conn:
275
+ await self._enable_foreign_keys(conn)
276
+ await conn.execute(sql, params)
277
+ await conn.commit()
278
+
279
+ return SessionRecord(
280
+ id=session_id, app_name=app_name, user_id=user_id, state=state, create_time=now, update_time=now
281
+ )
282
+
283
+ async def get_session(self, session_id: str) -> "SessionRecord | None":
284
+ """Get session by ID.
285
+
286
+ Args:
287
+ session_id: Session identifier.
288
+
289
+ Returns:
290
+ Session record or None if not found.
291
+
292
+ Notes:
293
+ SQLite returns Julian Day (REAL) for timestamps.
294
+ JSON is parsed from TEXT storage.
295
+ """
296
+ sql = f"""
297
+ SELECT id, app_name, user_id, state, create_time, update_time
298
+ FROM {self._session_table}
299
+ WHERE id = ?
300
+ """
301
+
302
+ async with self._config.provide_connection() as conn:
303
+ await self._enable_foreign_keys(conn)
304
+ cursor = await conn.execute(sql, (session_id,))
305
+ row = await cursor.fetchone()
306
+
307
+ if row is None:
308
+ return None
309
+
310
+ return SessionRecord(
311
+ id=row[0],
312
+ app_name=row[1],
313
+ user_id=row[2],
314
+ state=from_json(row[3]) if row[3] else {},
315
+ create_time=_julian_to_datetime(row[4]),
316
+ update_time=_julian_to_datetime(row[5]),
317
+ )
318
+
319
+ async def update_session_state(self, session_id: str, state: "dict[str, Any]") -> None:
320
+ """Update session state.
321
+
322
+ Args:
323
+ session_id: Session identifier.
324
+ state: New state dictionary (replaces existing state).
325
+
326
+ Notes:
327
+ This replaces the entire state dictionary.
328
+ Updates update_time to current Julian Day.
329
+ """
330
+ now_julian = _datetime_to_julian(datetime.now(timezone.utc))
331
+ state_json = to_json(state) if state else None
332
+
333
+ sql = f"""
334
+ UPDATE {self._session_table}
335
+ SET state = ?, update_time = ?
336
+ WHERE id = ?
337
+ """
338
+
339
+ async with self._config.provide_connection() as conn:
340
+ await self._enable_foreign_keys(conn)
341
+ await conn.execute(sql, (state_json, now_julian, session_id))
342
+ await conn.commit()
343
+
344
+ async def list_sessions(self, app_name: str, user_id: str | None = None) -> "list[SessionRecord]":
345
+ """List sessions for an app, optionally filtered by user.
346
+
347
+ Args:
348
+ app_name: Application name.
349
+ user_id: User identifier. If None, lists all sessions for the app.
350
+
351
+ Returns:
352
+ List of session records ordered by update_time DESC.
353
+
354
+ Notes:
355
+ Uses composite index on (app_name, user_id) when user_id is provided.
356
+ """
357
+ if user_id is None:
358
+ sql = f"""
359
+ SELECT id, app_name, user_id, state, create_time, update_time
360
+ FROM {self._session_table}
361
+ WHERE app_name = ?
362
+ ORDER BY update_time DESC
363
+ """
364
+ params: tuple[str, ...] = (app_name,)
365
+ else:
366
+ sql = f"""
367
+ SELECT id, app_name, user_id, state, create_time, update_time
368
+ FROM {self._session_table}
369
+ WHERE app_name = ? AND user_id = ?
370
+ ORDER BY update_time DESC
371
+ """
372
+ params = (app_name, user_id)
373
+
374
+ async with self._config.provide_connection() as conn:
375
+ await self._enable_foreign_keys(conn)
376
+ cursor = await conn.execute(sql, params)
377
+ rows = await cursor.fetchall()
378
+
379
+ return [
380
+ SessionRecord(
381
+ id=row[0],
382
+ app_name=row[1],
383
+ user_id=row[2],
384
+ state=from_json(row[3]) if row[3] else {},
385
+ create_time=_julian_to_datetime(row[4]),
386
+ update_time=_julian_to_datetime(row[5]),
387
+ )
388
+ for row in rows
389
+ ]
390
+
391
+ async def delete_session(self, session_id: str) -> None:
392
+ """Delete session and all associated events (cascade).
393
+
394
+ Args:
395
+ session_id: Session identifier.
396
+
397
+ Notes:
398
+ Foreign key constraint ensures events are cascade-deleted.
399
+ """
400
+ sql = f"DELETE FROM {self._session_table} WHERE id = ?"
401
+
402
+ async with self._config.provide_connection() as conn:
403
+ await self._enable_foreign_keys(conn)
404
+ await conn.execute(sql, (session_id,))
405
+ await conn.commit()
406
+
407
+ async def append_event(self, event_record: EventRecord) -> None:
408
+ """Append an event to a session.
409
+
410
+ Args:
411
+ event_record: Event record to store.
412
+
413
+ Notes:
414
+ Uses Julian Day for timestamp.
415
+ JSON fields are serialized to TEXT.
416
+ Boolean fields converted to INTEGER (0/1/NULL).
417
+ """
418
+ timestamp_julian = _datetime_to_julian(event_record["timestamp"])
419
+
420
+ content_json = to_json(event_record.get("content")) if event_record.get("content") else None
421
+ grounding_metadata_json = (
422
+ to_json(event_record.get("grounding_metadata")) if event_record.get("grounding_metadata") else None
423
+ )
424
+ custom_metadata_json = (
425
+ to_json(event_record.get("custom_metadata")) if event_record.get("custom_metadata") else None
426
+ )
427
+
428
+ partial_int = _to_sqlite_bool(event_record.get("partial"))
429
+ turn_complete_int = _to_sqlite_bool(event_record.get("turn_complete"))
430
+ interrupted_int = _to_sqlite_bool(event_record.get("interrupted"))
431
+
432
+ sql = f"""
433
+ INSERT INTO {self._events_table} (
434
+ id, session_id, app_name, user_id, invocation_id, author, actions,
435
+ long_running_tool_ids_json, branch, timestamp, content,
436
+ grounding_metadata, custom_metadata, partial, turn_complete,
437
+ interrupted, error_code, error_message
438
+ ) VALUES (
439
+ ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?
440
+ )
441
+ """
442
+
443
+ async with self._config.provide_connection() as conn:
444
+ await self._enable_foreign_keys(conn)
445
+ await conn.execute(
446
+ sql,
447
+ (
448
+ event_record["id"],
449
+ event_record["session_id"],
450
+ event_record["app_name"],
451
+ event_record["user_id"],
452
+ event_record["invocation_id"],
453
+ event_record["author"],
454
+ event_record["actions"],
455
+ event_record.get("long_running_tool_ids_json"),
456
+ event_record.get("branch"),
457
+ timestamp_julian,
458
+ content_json,
459
+ grounding_metadata_json,
460
+ custom_metadata_json,
461
+ partial_int,
462
+ turn_complete_int,
463
+ interrupted_int,
464
+ event_record.get("error_code"),
465
+ event_record.get("error_message"),
466
+ ),
467
+ )
468
+ await conn.commit()
469
+
470
+ async def get_events(
471
+ self, session_id: str, after_timestamp: "datetime | None" = None, limit: "int | None" = None
472
+ ) -> "list[EventRecord]":
473
+ """Get events for a session.
474
+
475
+ Args:
476
+ session_id: Session identifier.
477
+ after_timestamp: Only return events after this time.
478
+ limit: Maximum number of events to return.
479
+
480
+ Returns:
481
+ List of event records ordered by timestamp ASC.
482
+
483
+ Notes:
484
+ Uses index on (session_id, timestamp ASC).
485
+ Parses JSON fields and converts BLOB actions to bytes.
486
+ Converts INTEGER booleans back to bool/None.
487
+ """
488
+ where_clauses = ["session_id = ?"]
489
+ params: list[Any] = [session_id]
490
+
491
+ if after_timestamp is not None:
492
+ where_clauses.append("timestamp > ?")
493
+ params.append(_datetime_to_julian(after_timestamp))
494
+
495
+ where_clause = " AND ".join(where_clauses)
496
+ limit_clause = f" LIMIT {limit}" if limit else ""
497
+
498
+ sql = f"""
499
+ SELECT id, session_id, app_name, user_id, invocation_id, author, actions,
500
+ long_running_tool_ids_json, branch, timestamp, content,
501
+ grounding_metadata, custom_metadata, partial, turn_complete,
502
+ interrupted, error_code, error_message
503
+ FROM {self._events_table}
504
+ WHERE {where_clause}
505
+ ORDER BY timestamp ASC{limit_clause}
506
+ """
507
+
508
+ async with self._config.provide_connection() as conn:
509
+ await self._enable_foreign_keys(conn)
510
+ cursor = await conn.execute(sql, params)
511
+ rows = await cursor.fetchall()
512
+
513
+ return [
514
+ EventRecord(
515
+ id=row[0],
516
+ session_id=row[1],
517
+ app_name=row[2],
518
+ user_id=row[3],
519
+ invocation_id=row[4],
520
+ author=row[5],
521
+ actions=bytes(row[6]),
522
+ long_running_tool_ids_json=row[7],
523
+ branch=row[8],
524
+ timestamp=_julian_to_datetime(row[9]),
525
+ content=from_json(row[10]) if row[10] else None,
526
+ grounding_metadata=from_json(row[11]) if row[11] else None,
527
+ custom_metadata=from_json(row[12]) if row[12] else None,
528
+ partial=_from_sqlite_bool(row[13]),
529
+ turn_complete=_from_sqlite_bool(row[14]),
530
+ interrupted=_from_sqlite_bool(row[15]),
531
+ error_code=row[16],
532
+ error_message=row[17],
533
+ )
534
+ for row in rows
535
+ ]
536
+
537
+
538
+ class AiosqliteADKMemoryStore(BaseAsyncADKMemoryStore["AiosqliteConfig"]):
539
+ """Aiosqlite ADK memory store using asynchronous SQLite driver.
540
+
541
+ Implements memory entry storage for Google Agent Development Kit
542
+ using SQLite via the asynchronous aiosqlite driver. Provides:
543
+ - Session memory storage with JSON as TEXT
544
+ - Simple LIKE search (simple strategy)
545
+ - Optional FTS5 full-text search (sqlite_fts5 strategy)
546
+ - Julian Day timestamps (REAL) for efficient date operations
547
+ - Deduplication via event_id unique constraint
548
+ - Efficient upserts using INSERT OR IGNORE
549
+
550
+ Args:
551
+ config: AiosqliteConfig with extension_config["adk"] settings.
552
+
553
+ Example:
554
+ from sqlspec.adapters.aiosqlite import AiosqliteConfig
555
+ from sqlspec.adapters.aiosqlite.adk.store import AiosqliteADKMemoryStore
556
+
557
+ config = AiosqliteConfig(
558
+ connection_config={"database": ":memory:"},
559
+ extension_config={
560
+ "adk": {
561
+ "memory_table": "adk_memory_entries",
562
+ "memory_use_fts": False,
563
+ "memory_max_results": 20,
564
+ }
565
+ }
566
+ )
567
+ store = AiosqliteADKMemoryStore(config)
568
+ await store.ensure_tables()
569
+
570
+ Notes:
571
+ - JSON stored as TEXT with SQLSpec serializers
572
+ - REAL for Julian Day timestamps
573
+ - event_id UNIQUE constraint for deduplication
574
+ - Composite index on (app_name, user_id, timestamp DESC)
575
+ - Optional FTS5 virtual table for full-text search
576
+ - Configuration is read from config.extension_config["adk"]
577
+ """
578
+
579
+ __slots__ = ()
580
+
581
+ def __init__(self, config: "AiosqliteConfig") -> None:
582
+ """Initialize Aiosqlite ADK memory store.
583
+
584
+ Args:
585
+ config: AiosqliteConfig instance.
586
+
587
+ Notes:
588
+ Configuration is read from config.extension_config["adk"]:
589
+ - memory_table: Memory table name (default: "adk_memory_entries")
590
+ - memory_use_fts: Enable full-text search when supported (default: False)
591
+ - memory_max_results: Max search results (default: 20)
592
+ - owner_id_column: Optional owner FK column DDL (default: None)
593
+ - enable_memory: Whether memory is enabled (default: True)
594
+ """
595
+ super().__init__(config)
596
+
597
+ async def _get_create_memory_table_sql(self) -> str:
598
+ """Get SQLite CREATE TABLE SQL for memory entries.
599
+
600
+ Returns:
601
+ SQL statement to create memory table with indexes.
602
+
603
+ Notes:
604
+ - TEXT for IDs, names, and JSON content
605
+ - REAL for Julian Day timestamps
606
+ - UNIQUE constraint on event_id for deduplication
607
+ - Composite index on (app_name, user_id, timestamp DESC)
608
+ - Optional owner ID column for multi-tenancy
609
+ - Optional FTS5 virtual table for full-text search
610
+ """
611
+ owner_id_line = ""
612
+ if self._owner_id_column_ddl:
613
+ owner_id_line = f",\n {self._owner_id_column_ddl}"
614
+
615
+ fts_table = ""
616
+ if self._use_fts:
617
+ fts_table = f"""
618
+ CREATE VIRTUAL TABLE IF NOT EXISTS {self._memory_table}_fts USING fts5(
619
+ content_text,
620
+ content={self._memory_table},
621
+ content_rowid=rowid
622
+ );
623
+
624
+ CREATE TRIGGER IF NOT EXISTS {self._memory_table}_ai AFTER INSERT ON {self._memory_table} BEGIN
625
+ INSERT INTO {self._memory_table}_fts(rowid, content_text) VALUES (new.rowid, new.content_text);
626
+ END;
627
+
628
+ CREATE TRIGGER IF NOT EXISTS {self._memory_table}_ad AFTER DELETE ON {self._memory_table} BEGIN
629
+ INSERT INTO {self._memory_table}_fts({self._memory_table}_fts, rowid, content_text)
630
+ VALUES('delete', old.rowid, old.content_text);
631
+ END;
632
+
633
+ CREATE TRIGGER IF NOT EXISTS {self._memory_table}_au AFTER UPDATE ON {self._memory_table} BEGIN
634
+ INSERT INTO {self._memory_table}_fts({self._memory_table}_fts, rowid, content_text)
635
+ VALUES('delete', old.rowid, old.content_text);
636
+ INSERT INTO {self._memory_table}_fts(rowid, content_text) VALUES (new.rowid, new.content_text);
637
+ END;
638
+ """
639
+
640
+ return f"""
641
+ CREATE TABLE IF NOT EXISTS {self._memory_table} (
642
+ id TEXT PRIMARY KEY,
643
+ session_id TEXT NOT NULL,
644
+ app_name TEXT NOT NULL,
645
+ user_id TEXT NOT NULL,
646
+ event_id TEXT NOT NULL UNIQUE,
647
+ author TEXT{owner_id_line},
648
+ timestamp REAL NOT NULL,
649
+ content_json TEXT NOT NULL,
650
+ content_text TEXT NOT NULL,
651
+ metadata_json TEXT,
652
+ inserted_at REAL NOT NULL
653
+ );
654
+
655
+ CREATE INDEX IF NOT EXISTS idx_{self._memory_table}_app_user_time
656
+ ON {self._memory_table}(app_name, user_id, timestamp DESC);
657
+
658
+ CREATE INDEX IF NOT EXISTS idx_{self._memory_table}_session
659
+ ON {self._memory_table}(session_id);
660
+ {fts_table}
661
+ """
662
+
663
+ def _get_drop_memory_table_sql(self) -> "list[str]":
664
+ """Get SQLite DROP TABLE SQL statements."""
665
+ statements = [f"DROP TABLE IF EXISTS {self._memory_table}"]
666
+ if self._use_fts:
667
+ statements.extend([
668
+ f"DROP TABLE IF EXISTS {self._memory_table}_fts",
669
+ f"DROP TRIGGER IF EXISTS {self._memory_table}_ai",
670
+ f"DROP TRIGGER IF EXISTS {self._memory_table}_ad",
671
+ f"DROP TRIGGER IF EXISTS {self._memory_table}_au",
672
+ ])
673
+ return statements
674
+
675
+ async def create_tables(self) -> None:
676
+ """Create the memory table and indexes if they don't exist.
677
+
678
+ Skips table creation if memory store is disabled.
679
+ """
680
+ if not self._enabled:
681
+ return
682
+
683
+ async with self._config.provide_session() as driver:
684
+ await driver.execute_script(await self._get_create_memory_table_sql())
685
+
686
+ async def insert_memory_entries(self, entries: "list[MemoryRecord]", owner_id: "object | None" = None) -> int:
687
+ """Bulk insert memory entries with deduplication.
688
+
689
+ Uses INSERT OR IGNORE to skip duplicates based on event_id unique constraint.
690
+ """
691
+ if not self._enabled:
692
+ msg = "Memory store is disabled"
693
+ raise RuntimeError(msg)
694
+
695
+ if not entries:
696
+ return 0
697
+
698
+ inserted_count = 0
699
+ async with self._config.provide_connection() as conn:
700
+ for entry in entries:
701
+ params: tuple[Any, ...]
702
+ if self._owner_id_column_name:
703
+ sql = f"""
704
+ INSERT OR IGNORE INTO {self._memory_table}
705
+ (id, session_id, app_name, user_id, event_id, author,
706
+ {self._owner_id_column_name}, timestamp, content_json,
707
+ content_text, metadata_json, inserted_at)
708
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
709
+ """
710
+ params = (
711
+ entry["id"],
712
+ entry["session_id"],
713
+ entry["app_name"],
714
+ entry["user_id"],
715
+ entry["event_id"],
716
+ entry["author"],
717
+ owner_id,
718
+ _datetime_to_julian(entry["timestamp"]),
719
+ to_json(entry["content_json"]),
720
+ entry["content_text"],
721
+ to_json(entry["metadata_json"]),
722
+ _datetime_to_julian(entry["inserted_at"]),
723
+ )
724
+ else:
725
+ sql = f"""
726
+ INSERT OR IGNORE INTO {self._memory_table}
727
+ (id, session_id, app_name, user_id, event_id, author,
728
+ timestamp, content_json, content_text, metadata_json, inserted_at)
729
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
730
+ """
731
+ params = (
732
+ entry["id"],
733
+ entry["session_id"],
734
+ entry["app_name"],
735
+ entry["user_id"],
736
+ entry["event_id"],
737
+ entry["author"],
738
+ _datetime_to_julian(entry["timestamp"]),
739
+ to_json(entry["content_json"]),
740
+ entry["content_text"],
741
+ to_json(entry["metadata_json"]),
742
+ _datetime_to_julian(entry["inserted_at"]),
743
+ )
744
+ cursor = await conn.execute(sql, params)
745
+ inserted_count += cursor.rowcount
746
+ await cursor.close()
747
+ await conn.commit()
748
+ return inserted_count
749
+
750
+ async def search_entries(
751
+ self, query: str, app_name: str, user_id: str, limit: "int | None" = None
752
+ ) -> "list[MemoryRecord]":
753
+ """Search memory entries by text query."""
754
+ if not self._enabled:
755
+ msg = "Memory store is disabled"
756
+ raise RuntimeError(msg)
757
+
758
+ if not query:
759
+ return []
760
+
761
+ limit_value = limit or self._max_results
762
+ if self._use_fts:
763
+ sql = f"""
764
+ SELECT m.* FROM {self._memory_table} AS m
765
+ JOIN {self._memory_table}_fts AS fts ON m.rowid = fts.rowid
766
+ WHERE m.app_name = ? AND m.user_id = ? AND fts.content_text MATCH ?
767
+ ORDER BY m.timestamp DESC
768
+ LIMIT ?
769
+ """
770
+ params = (app_name, user_id, query, limit_value)
771
+ else:
772
+ sql = f"""
773
+ SELECT * FROM {self._memory_table}
774
+ WHERE app_name = ? AND user_id = ? AND content_text LIKE ?
775
+ ORDER BY timestamp DESC
776
+ LIMIT ?
777
+ """
778
+ params = (app_name, user_id, f"%{query}%", limit_value)
779
+
780
+ async with self._config.provide_connection() as conn:
781
+ cursor = await conn.execute(sql, params)
782
+ rows = await cursor.fetchall()
783
+ columns = [col[0] for col in cursor.description or []]
784
+ await cursor.close()
785
+ records: list[MemoryRecord] = []
786
+ for row in rows:
787
+ raw = dict(zip(columns, row, strict=False))
788
+ raw["timestamp"] = _julian_to_datetime(raw["timestamp"])
789
+ raw["inserted_at"] = _julian_to_datetime(raw["inserted_at"])
790
+ raw["content_json"] = from_json(raw["content_json"])
791
+ raw["metadata_json"] = from_json(raw["metadata_json"]) if raw["metadata_json"] else None
792
+ records.append(cast("MemoryRecord", raw))
793
+ return records
794
+
795
+ async def delete_entries_by_session(self, session_id: str) -> int:
796
+ """Delete all memory entries for a specific session."""
797
+ if not self._enabled:
798
+ msg = "Memory store is disabled"
799
+ raise RuntimeError(msg)
800
+
801
+ sql = f"DELETE FROM {self._memory_table} WHERE session_id = ?"
802
+ async with self._config.provide_connection() as conn:
803
+ cursor = await conn.execute(sql, (session_id,))
804
+ await conn.commit()
805
+ return cursor.rowcount
806
+
807
+ async def delete_entries_older_than(self, days: int) -> int:
808
+ """Delete memory entries older than specified days."""
809
+ if not self._enabled:
810
+ msg = "Memory store is disabled"
811
+ raise RuntimeError(msg)
812
+
813
+ cutoff = _datetime_to_julian(datetime.now(timezone.utc)) - days
814
+ sql = f"DELETE FROM {self._memory_table} WHERE inserted_at < ?"
815
+ async with self._config.provide_connection() as conn:
816
+ cursor = await conn.execute(sql, (cutoff,))
817
+ await conn.commit()
818
+ return cursor.rowcount