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