sqlspec 0.32.0__py3-none-any.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 (262) hide show
  1. sqlspec/__init__.py +104 -0
  2. sqlspec/__main__.py +12 -0
  3. sqlspec/__metadata__.py +14 -0
  4. sqlspec/_serialization.py +312 -0
  5. sqlspec/_typing.py +784 -0
  6. sqlspec/adapters/__init__.py +0 -0
  7. sqlspec/adapters/adbc/__init__.py +5 -0
  8. sqlspec/adapters/adbc/_types.py +12 -0
  9. sqlspec/adapters/adbc/adk/__init__.py +5 -0
  10. sqlspec/adapters/adbc/adk/store.py +880 -0
  11. sqlspec/adapters/adbc/config.py +436 -0
  12. sqlspec/adapters/adbc/data_dictionary.py +537 -0
  13. sqlspec/adapters/adbc/driver.py +841 -0
  14. sqlspec/adapters/adbc/litestar/__init__.py +5 -0
  15. sqlspec/adapters/adbc/litestar/store.py +504 -0
  16. sqlspec/adapters/adbc/type_converter.py +153 -0
  17. sqlspec/adapters/aiosqlite/__init__.py +29 -0
  18. sqlspec/adapters/aiosqlite/_types.py +13 -0
  19. sqlspec/adapters/aiosqlite/adk/__init__.py +5 -0
  20. sqlspec/adapters/aiosqlite/adk/store.py +536 -0
  21. sqlspec/adapters/aiosqlite/config.py +310 -0
  22. sqlspec/adapters/aiosqlite/data_dictionary.py +260 -0
  23. sqlspec/adapters/aiosqlite/driver.py +463 -0
  24. sqlspec/adapters/aiosqlite/litestar/__init__.py +5 -0
  25. sqlspec/adapters/aiosqlite/litestar/store.py +281 -0
  26. sqlspec/adapters/aiosqlite/pool.py +500 -0
  27. sqlspec/adapters/asyncmy/__init__.py +25 -0
  28. sqlspec/adapters/asyncmy/_types.py +12 -0
  29. sqlspec/adapters/asyncmy/adk/__init__.py +5 -0
  30. sqlspec/adapters/asyncmy/adk/store.py +503 -0
  31. sqlspec/adapters/asyncmy/config.py +246 -0
  32. sqlspec/adapters/asyncmy/data_dictionary.py +241 -0
  33. sqlspec/adapters/asyncmy/driver.py +632 -0
  34. sqlspec/adapters/asyncmy/litestar/__init__.py +5 -0
  35. sqlspec/adapters/asyncmy/litestar/store.py +296 -0
  36. sqlspec/adapters/asyncpg/__init__.py +23 -0
  37. sqlspec/adapters/asyncpg/_type_handlers.py +76 -0
  38. sqlspec/adapters/asyncpg/_types.py +23 -0
  39. sqlspec/adapters/asyncpg/adk/__init__.py +5 -0
  40. sqlspec/adapters/asyncpg/adk/store.py +460 -0
  41. sqlspec/adapters/asyncpg/config.py +464 -0
  42. sqlspec/adapters/asyncpg/data_dictionary.py +321 -0
  43. sqlspec/adapters/asyncpg/driver.py +720 -0
  44. sqlspec/adapters/asyncpg/litestar/__init__.py +5 -0
  45. sqlspec/adapters/asyncpg/litestar/store.py +253 -0
  46. sqlspec/adapters/bigquery/__init__.py +18 -0
  47. sqlspec/adapters/bigquery/_types.py +12 -0
  48. sqlspec/adapters/bigquery/adk/__init__.py +5 -0
  49. sqlspec/adapters/bigquery/adk/store.py +585 -0
  50. sqlspec/adapters/bigquery/config.py +298 -0
  51. sqlspec/adapters/bigquery/data_dictionary.py +256 -0
  52. sqlspec/adapters/bigquery/driver.py +1073 -0
  53. sqlspec/adapters/bigquery/litestar/__init__.py +5 -0
  54. sqlspec/adapters/bigquery/litestar/store.py +327 -0
  55. sqlspec/adapters/bigquery/type_converter.py +125 -0
  56. sqlspec/adapters/duckdb/__init__.py +24 -0
  57. sqlspec/adapters/duckdb/_types.py +12 -0
  58. sqlspec/adapters/duckdb/adk/__init__.py +14 -0
  59. sqlspec/adapters/duckdb/adk/store.py +563 -0
  60. sqlspec/adapters/duckdb/config.py +396 -0
  61. sqlspec/adapters/duckdb/data_dictionary.py +264 -0
  62. sqlspec/adapters/duckdb/driver.py +604 -0
  63. sqlspec/adapters/duckdb/litestar/__init__.py +5 -0
  64. sqlspec/adapters/duckdb/litestar/store.py +332 -0
  65. sqlspec/adapters/duckdb/pool.py +273 -0
  66. sqlspec/adapters/duckdb/type_converter.py +133 -0
  67. sqlspec/adapters/oracledb/__init__.py +32 -0
  68. sqlspec/adapters/oracledb/_numpy_handlers.py +133 -0
  69. sqlspec/adapters/oracledb/_types.py +39 -0
  70. sqlspec/adapters/oracledb/_uuid_handlers.py +130 -0
  71. sqlspec/adapters/oracledb/adk/__init__.py +5 -0
  72. sqlspec/adapters/oracledb/adk/store.py +1632 -0
  73. sqlspec/adapters/oracledb/config.py +469 -0
  74. sqlspec/adapters/oracledb/data_dictionary.py +717 -0
  75. sqlspec/adapters/oracledb/driver.py +1493 -0
  76. sqlspec/adapters/oracledb/litestar/__init__.py +5 -0
  77. sqlspec/adapters/oracledb/litestar/store.py +765 -0
  78. sqlspec/adapters/oracledb/migrations.py +532 -0
  79. sqlspec/adapters/oracledb/type_converter.py +207 -0
  80. sqlspec/adapters/psqlpy/__init__.py +16 -0
  81. sqlspec/adapters/psqlpy/_type_handlers.py +44 -0
  82. sqlspec/adapters/psqlpy/_types.py +12 -0
  83. sqlspec/adapters/psqlpy/adk/__init__.py +5 -0
  84. sqlspec/adapters/psqlpy/adk/store.py +483 -0
  85. sqlspec/adapters/psqlpy/config.py +271 -0
  86. sqlspec/adapters/psqlpy/data_dictionary.py +179 -0
  87. sqlspec/adapters/psqlpy/driver.py +892 -0
  88. sqlspec/adapters/psqlpy/litestar/__init__.py +5 -0
  89. sqlspec/adapters/psqlpy/litestar/store.py +272 -0
  90. sqlspec/adapters/psqlpy/type_converter.py +102 -0
  91. sqlspec/adapters/psycopg/__init__.py +32 -0
  92. sqlspec/adapters/psycopg/_type_handlers.py +90 -0
  93. sqlspec/adapters/psycopg/_types.py +18 -0
  94. sqlspec/adapters/psycopg/adk/__init__.py +5 -0
  95. sqlspec/adapters/psycopg/adk/store.py +962 -0
  96. sqlspec/adapters/psycopg/config.py +487 -0
  97. sqlspec/adapters/psycopg/data_dictionary.py +630 -0
  98. sqlspec/adapters/psycopg/driver.py +1336 -0
  99. sqlspec/adapters/psycopg/litestar/__init__.py +5 -0
  100. sqlspec/adapters/psycopg/litestar/store.py +554 -0
  101. sqlspec/adapters/spanner/__init__.py +38 -0
  102. sqlspec/adapters/spanner/_type_handlers.py +186 -0
  103. sqlspec/adapters/spanner/_types.py +12 -0
  104. sqlspec/adapters/spanner/adk/__init__.py +5 -0
  105. sqlspec/adapters/spanner/adk/store.py +435 -0
  106. sqlspec/adapters/spanner/config.py +241 -0
  107. sqlspec/adapters/spanner/data_dictionary.py +95 -0
  108. sqlspec/adapters/spanner/dialect/__init__.py +6 -0
  109. sqlspec/adapters/spanner/dialect/_spangres.py +52 -0
  110. sqlspec/adapters/spanner/dialect/_spanner.py +123 -0
  111. sqlspec/adapters/spanner/driver.py +366 -0
  112. sqlspec/adapters/spanner/litestar/__init__.py +5 -0
  113. sqlspec/adapters/spanner/litestar/store.py +266 -0
  114. sqlspec/adapters/spanner/type_converter.py +46 -0
  115. sqlspec/adapters/sqlite/__init__.py +18 -0
  116. sqlspec/adapters/sqlite/_type_handlers.py +86 -0
  117. sqlspec/adapters/sqlite/_types.py +11 -0
  118. sqlspec/adapters/sqlite/adk/__init__.py +5 -0
  119. sqlspec/adapters/sqlite/adk/store.py +582 -0
  120. sqlspec/adapters/sqlite/config.py +221 -0
  121. sqlspec/adapters/sqlite/data_dictionary.py +256 -0
  122. sqlspec/adapters/sqlite/driver.py +527 -0
  123. sqlspec/adapters/sqlite/litestar/__init__.py +5 -0
  124. sqlspec/adapters/sqlite/litestar/store.py +318 -0
  125. sqlspec/adapters/sqlite/pool.py +140 -0
  126. sqlspec/base.py +811 -0
  127. sqlspec/builder/__init__.py +146 -0
  128. sqlspec/builder/_base.py +900 -0
  129. sqlspec/builder/_column.py +517 -0
  130. sqlspec/builder/_ddl.py +1642 -0
  131. sqlspec/builder/_delete.py +84 -0
  132. sqlspec/builder/_dml.py +381 -0
  133. sqlspec/builder/_expression_wrappers.py +46 -0
  134. sqlspec/builder/_factory.py +1537 -0
  135. sqlspec/builder/_insert.py +315 -0
  136. sqlspec/builder/_join.py +375 -0
  137. sqlspec/builder/_merge.py +848 -0
  138. sqlspec/builder/_parsing_utils.py +297 -0
  139. sqlspec/builder/_select.py +1615 -0
  140. sqlspec/builder/_update.py +161 -0
  141. sqlspec/builder/_vector_expressions.py +259 -0
  142. sqlspec/cli.py +764 -0
  143. sqlspec/config.py +1540 -0
  144. sqlspec/core/__init__.py +305 -0
  145. sqlspec/core/cache.py +785 -0
  146. sqlspec/core/compiler.py +603 -0
  147. sqlspec/core/filters.py +872 -0
  148. sqlspec/core/hashing.py +274 -0
  149. sqlspec/core/metrics.py +83 -0
  150. sqlspec/core/parameters/__init__.py +64 -0
  151. sqlspec/core/parameters/_alignment.py +266 -0
  152. sqlspec/core/parameters/_converter.py +413 -0
  153. sqlspec/core/parameters/_processor.py +341 -0
  154. sqlspec/core/parameters/_registry.py +201 -0
  155. sqlspec/core/parameters/_transformers.py +226 -0
  156. sqlspec/core/parameters/_types.py +430 -0
  157. sqlspec/core/parameters/_validator.py +123 -0
  158. sqlspec/core/pipeline.py +187 -0
  159. sqlspec/core/result.py +1124 -0
  160. sqlspec/core/splitter.py +940 -0
  161. sqlspec/core/stack.py +163 -0
  162. sqlspec/core/statement.py +835 -0
  163. sqlspec/core/type_conversion.py +235 -0
  164. sqlspec/driver/__init__.py +36 -0
  165. sqlspec/driver/_async.py +1027 -0
  166. sqlspec/driver/_common.py +1236 -0
  167. sqlspec/driver/_sync.py +1025 -0
  168. sqlspec/driver/mixins/__init__.py +7 -0
  169. sqlspec/driver/mixins/_result_tools.py +61 -0
  170. sqlspec/driver/mixins/_sql_translator.py +122 -0
  171. sqlspec/driver/mixins/_storage.py +311 -0
  172. sqlspec/exceptions.py +321 -0
  173. sqlspec/extensions/__init__.py +0 -0
  174. sqlspec/extensions/adk/__init__.py +53 -0
  175. sqlspec/extensions/adk/_types.py +51 -0
  176. sqlspec/extensions/adk/converters.py +172 -0
  177. sqlspec/extensions/adk/migrations/0001_create_adk_tables.py +144 -0
  178. sqlspec/extensions/adk/migrations/__init__.py +0 -0
  179. sqlspec/extensions/adk/service.py +181 -0
  180. sqlspec/extensions/adk/store.py +536 -0
  181. sqlspec/extensions/aiosql/__init__.py +10 -0
  182. sqlspec/extensions/aiosql/adapter.py +471 -0
  183. sqlspec/extensions/fastapi/__init__.py +19 -0
  184. sqlspec/extensions/fastapi/extension.py +341 -0
  185. sqlspec/extensions/fastapi/providers.py +543 -0
  186. sqlspec/extensions/flask/__init__.py +36 -0
  187. sqlspec/extensions/flask/_state.py +72 -0
  188. sqlspec/extensions/flask/_utils.py +40 -0
  189. sqlspec/extensions/flask/extension.py +402 -0
  190. sqlspec/extensions/litestar/__init__.py +23 -0
  191. sqlspec/extensions/litestar/_utils.py +52 -0
  192. sqlspec/extensions/litestar/cli.py +92 -0
  193. sqlspec/extensions/litestar/config.py +90 -0
  194. sqlspec/extensions/litestar/handlers.py +316 -0
  195. sqlspec/extensions/litestar/migrations/0001_create_session_table.py +137 -0
  196. sqlspec/extensions/litestar/migrations/__init__.py +3 -0
  197. sqlspec/extensions/litestar/plugin.py +638 -0
  198. sqlspec/extensions/litestar/providers.py +454 -0
  199. sqlspec/extensions/litestar/store.py +265 -0
  200. sqlspec/extensions/otel/__init__.py +58 -0
  201. sqlspec/extensions/prometheus/__init__.py +107 -0
  202. sqlspec/extensions/starlette/__init__.py +10 -0
  203. sqlspec/extensions/starlette/_state.py +26 -0
  204. sqlspec/extensions/starlette/_utils.py +52 -0
  205. sqlspec/extensions/starlette/extension.py +257 -0
  206. sqlspec/extensions/starlette/middleware.py +154 -0
  207. sqlspec/loader.py +716 -0
  208. sqlspec/migrations/__init__.py +36 -0
  209. sqlspec/migrations/base.py +728 -0
  210. sqlspec/migrations/commands.py +1140 -0
  211. sqlspec/migrations/context.py +142 -0
  212. sqlspec/migrations/fix.py +203 -0
  213. sqlspec/migrations/loaders.py +450 -0
  214. sqlspec/migrations/runner.py +1024 -0
  215. sqlspec/migrations/templates.py +234 -0
  216. sqlspec/migrations/tracker.py +403 -0
  217. sqlspec/migrations/utils.py +256 -0
  218. sqlspec/migrations/validation.py +203 -0
  219. sqlspec/observability/__init__.py +22 -0
  220. sqlspec/observability/_config.py +228 -0
  221. sqlspec/observability/_diagnostics.py +67 -0
  222. sqlspec/observability/_dispatcher.py +151 -0
  223. sqlspec/observability/_observer.py +180 -0
  224. sqlspec/observability/_runtime.py +381 -0
  225. sqlspec/observability/_spans.py +158 -0
  226. sqlspec/protocols.py +530 -0
  227. sqlspec/py.typed +0 -0
  228. sqlspec/storage/__init__.py +46 -0
  229. sqlspec/storage/_utils.py +104 -0
  230. sqlspec/storage/backends/__init__.py +1 -0
  231. sqlspec/storage/backends/base.py +163 -0
  232. sqlspec/storage/backends/fsspec.py +398 -0
  233. sqlspec/storage/backends/local.py +377 -0
  234. sqlspec/storage/backends/obstore.py +580 -0
  235. sqlspec/storage/errors.py +104 -0
  236. sqlspec/storage/pipeline.py +604 -0
  237. sqlspec/storage/registry.py +289 -0
  238. sqlspec/typing.py +219 -0
  239. sqlspec/utils/__init__.py +31 -0
  240. sqlspec/utils/arrow_helpers.py +95 -0
  241. sqlspec/utils/config_resolver.py +153 -0
  242. sqlspec/utils/correlation.py +132 -0
  243. sqlspec/utils/data_transformation.py +114 -0
  244. sqlspec/utils/dependencies.py +79 -0
  245. sqlspec/utils/deprecation.py +113 -0
  246. sqlspec/utils/fixtures.py +250 -0
  247. sqlspec/utils/logging.py +172 -0
  248. sqlspec/utils/module_loader.py +273 -0
  249. sqlspec/utils/portal.py +325 -0
  250. sqlspec/utils/schema.py +288 -0
  251. sqlspec/utils/serializers.py +396 -0
  252. sqlspec/utils/singleton.py +41 -0
  253. sqlspec/utils/sync_tools.py +277 -0
  254. sqlspec/utils/text.py +108 -0
  255. sqlspec/utils/type_converters.py +99 -0
  256. sqlspec/utils/type_guards.py +1324 -0
  257. sqlspec/utils/version.py +444 -0
  258. sqlspec-0.32.0.dist-info/METADATA +202 -0
  259. sqlspec-0.32.0.dist-info/RECORD +262 -0
  260. sqlspec-0.32.0.dist-info/WHEEL +4 -0
  261. sqlspec-0.32.0.dist-info/entry_points.txt +2 -0
  262. sqlspec-0.32.0.dist-info/licenses/LICENSE +21 -0
@@ -0,0 +1,341 @@
1
+ from typing import TYPE_CHECKING, Any, overload
2
+
3
+ from fastapi import FastAPI, Request
4
+
5
+ from sqlspec.base import SQLSpec
6
+ from sqlspec.extensions.fastapi.providers import DEPENDENCY_DEFAULTS
7
+ from sqlspec.extensions.fastapi.providers import provide_filters as _provide_filters
8
+ from sqlspec.extensions.starlette.extension import SQLSpecPlugin as _StarlettePlugin
9
+
10
+ if TYPE_CHECKING:
11
+ from collections.abc import Callable
12
+
13
+ from sqlspec.config import AsyncDatabaseConfig, SyncDatabaseConfig
14
+ from sqlspec.core import FilterTypes
15
+ from sqlspec.driver import AsyncDriverAdapterBase, SyncDriverAdapterBase
16
+ from sqlspec.extensions.fastapi.providers import DependencyDefaults, FilterConfig
17
+
18
+ __all__ = ("SQLSpecPlugin",)
19
+
20
+
21
+ class SQLSpecPlugin(_StarlettePlugin):
22
+ """SQLSpec integration for FastAPI applications.
23
+
24
+ Extends Starlette integration with dependency injection helpers for FastAPI's
25
+ Depends() system.
26
+
27
+ Example:
28
+ from fastapi import Depends, FastAPI
29
+ from sqlspec import SQLSpec
30
+ from sqlspec.adapters.asyncpg import AsyncpgConfig
31
+ from sqlspec.extensions.fastapi import SQLSpecPlugin
32
+
33
+ sqlspec = SQLSpec()
34
+ config = AsyncpgConfig(
35
+ pool_config={"dsn": "postgresql://localhost/mydb"},
36
+ extension_config={
37
+ "starlette": {
38
+ "commit_mode": "autocommit",
39
+ "session_key": "db"
40
+ }
41
+ }
42
+ )
43
+ sqlspec.add_config(config, name="default")
44
+
45
+ app = FastAPI()
46
+ db_ext = SQLSpecPlugin(sqlspec, app)
47
+
48
+ @app.get("/users")
49
+ async def list_users(db = Depends(db_ext.provide_session())):
50
+ result = await db.execute("SELECT * FROM users")
51
+ return {"users": result.all()}
52
+ """
53
+
54
+ def __init__(self, sqlspec: SQLSpec, app: "FastAPI | None" = None) -> None:
55
+ """Initialize SQLSpec FastAPI extension.
56
+
57
+ Args:
58
+ sqlspec: Pre-configured SQLSpec instance with registered configs.
59
+ app: Optional FastAPI application to initialize immediately.
60
+ """
61
+ super().__init__(sqlspec, app)
62
+
63
+ @overload
64
+ def provide_session(
65
+ self, key: None = None
66
+ ) -> "Callable[[Request], AsyncDriverAdapterBase | SyncDriverAdapterBase]": ...
67
+
68
+ @overload
69
+ def provide_session(self, key: str) -> "Callable[[Request], AsyncDriverAdapterBase | SyncDriverAdapterBase]": ...
70
+
71
+ @overload
72
+ def provide_session(self, key: "type[AsyncDatabaseConfig]") -> "Callable[[Request], AsyncDriverAdapterBase]": ...
73
+
74
+ @overload
75
+ def provide_session(self, key: "type[SyncDatabaseConfig]") -> "Callable[[Request], SyncDriverAdapterBase]": ...
76
+
77
+ @overload
78
+ def provide_session(self, key: "AsyncDatabaseConfig") -> "Callable[[Request], AsyncDriverAdapterBase]": ...
79
+
80
+ @overload
81
+ def provide_session(self, key: "SyncDatabaseConfig") -> "Callable[[Request], SyncDriverAdapterBase]": ...
82
+
83
+ def provide_session(
84
+ self,
85
+ key: "str | type[AsyncDatabaseConfig | SyncDatabaseConfig] | AsyncDatabaseConfig | SyncDatabaseConfig | None" = None,
86
+ ) -> "Callable[[Request], AsyncDriverAdapterBase | SyncDriverAdapterBase]":
87
+ """Create dependency factory for session injection.
88
+
89
+ Returns a callable that can be used with FastAPI's Depends() to inject
90
+ a database session into route handlers.
91
+
92
+ Args:
93
+ key: Optional session key (str), config type for type narrowing, or None.
94
+
95
+ Returns:
96
+ Dependency callable for FastAPI Depends().
97
+
98
+ Example:
99
+ # No args - returns union type
100
+ @app.get("/users")
101
+ async def get_users(db = Depends(db_ext.provide_session())):
102
+ return await db.execute("SELECT * FROM users")
103
+
104
+ # String key for multi-database
105
+ @app.get("/products")
106
+ async def get_products(db = Depends(db_ext.provide_session("products"))):
107
+ return await db.execute("SELECT * FROM products")
108
+
109
+ # Config instance for type narrowing
110
+ config = AsyncpgConfig(...)
111
+ @app.get("/typed")
112
+ async def typed_query(db = Depends(db_ext.provide_session(config))):
113
+ # db is properly typed as AsyncDriverAdapterBase
114
+ return await db.execute("SELECT 1")
115
+
116
+ # Config type/class for type narrowing
117
+ @app.get("/typed2")
118
+ async def typed_query2(db = Depends(db_ext.provide_session(AsyncpgConfig))):
119
+ # db is properly typed as AsyncDriverAdapterBase
120
+ return await db.execute("SELECT 1")
121
+ """
122
+ # Extract string key if provided, ignore config types/instances (used only for type narrowing)
123
+ session_key = key if isinstance(key, str) or key is None else None
124
+
125
+ def dependency(request: Request) -> "AsyncDriverAdapterBase | SyncDriverAdapterBase":
126
+ return self.get_session(request, session_key) # type: ignore[no-any-return]
127
+
128
+ return dependency
129
+
130
+ def provide_async_session(self, key: "str | None" = None) -> "Callable[[Request], AsyncDriverAdapterBase]":
131
+ """Create dependency factory for async session injection.
132
+
133
+ Type-narrowed version of provide_session() that returns AsyncDriverAdapterBase.
134
+ Useful when using string keys and you know the config is async.
135
+
136
+ Args:
137
+ key: Optional session key for multi-database configurations.
138
+
139
+ Returns:
140
+ Dependency callable that returns AsyncDriverAdapterBase.
141
+
142
+ Example:
143
+ @app.get("/users")
144
+ async def get_users(db = Depends(db_ext.provide_async_session())):
145
+ # db is AsyncDriverAdapterBase
146
+ return await db.execute("SELECT * FROM users")
147
+
148
+ @app.get("/products")
149
+ async def get_products(db = Depends(db_ext.provide_async_session("products_db"))):
150
+ # db is AsyncDriverAdapterBase for "products_db" key
151
+ return await db.execute("SELECT * FROM products")
152
+ """
153
+
154
+ def dependency(request: Request) -> "AsyncDriverAdapterBase":
155
+ return self.get_session(request, key) # type: ignore[no-any-return]
156
+
157
+ return dependency
158
+
159
+ def provide_sync_session(self, key: "str | None" = None) -> "Callable[[Request], SyncDriverAdapterBase]":
160
+ """Create dependency factory for sync session injection.
161
+
162
+ Type-narrowed version of provide_session() that returns SyncDriverAdapterBase.
163
+ Useful when using string keys and you know the config is sync.
164
+
165
+ Args:
166
+ key: Optional session key for multi-database configurations.
167
+
168
+ Returns:
169
+ Dependency callable that returns SyncDriverAdapterBase.
170
+
171
+ Example:
172
+ @app.get("/users")
173
+ def get_users(db = Depends(db_ext.provide_sync_session())):
174
+ # db is SyncDriverAdapterBase
175
+ return db.execute("SELECT * FROM users")
176
+ """
177
+
178
+ def dependency(request: Request) -> "SyncDriverAdapterBase":
179
+ return self.get_session(request, key) # type: ignore[no-any-return]
180
+
181
+ return dependency
182
+
183
+ @overload
184
+ def provide_connection(self, key: None = None) -> "Callable[[Request], Any]": ...
185
+
186
+ @overload
187
+ def provide_connection(self, key: str) -> "Callable[[Request], Any]": ...
188
+
189
+ @overload
190
+ def provide_connection(self, key: "type[AsyncDatabaseConfig]") -> "Callable[[Request], Any]": ...
191
+
192
+ @overload
193
+ def provide_connection(self, key: "type[SyncDatabaseConfig]") -> "Callable[[Request], Any]": ...
194
+
195
+ @overload
196
+ def provide_connection(self, key: "AsyncDatabaseConfig") -> "Callable[[Request], Any]": ...
197
+
198
+ @overload
199
+ def provide_connection(self, key: "SyncDatabaseConfig") -> "Callable[[Request], Any]": ...
200
+
201
+ def provide_connection(
202
+ self,
203
+ key: "str | type[AsyncDatabaseConfig | SyncDatabaseConfig] | AsyncDatabaseConfig | SyncDatabaseConfig | None" = None,
204
+ ) -> "Callable[[Request], Any]":
205
+ """Create dependency factory for connection injection.
206
+
207
+ Returns a callable that can be used with FastAPI's Depends() to inject
208
+ a database connection into route handlers.
209
+
210
+ Args:
211
+ key: Optional session key (str), config type for type narrowing, or None.
212
+
213
+ Returns:
214
+ Dependency callable for FastAPI Depends().
215
+
216
+ Example:
217
+ # No args
218
+ @app.get("/raw")
219
+ async def raw_query(conn = Depends(db_ext.provide_connection())):
220
+ cursor = await conn.cursor()
221
+ await cursor.execute("SELECT 1")
222
+ return await cursor.fetchone()
223
+
224
+ # With config instance
225
+ config = AsyncpgConfig(...)
226
+ @app.get("/typed")
227
+ async def typed_query(conn = Depends(db_ext.provide_connection(config))):
228
+ cursor = await conn.cursor()
229
+ await cursor.execute("SELECT 1")
230
+ return await cursor.fetchone()
231
+
232
+ # With config type/class
233
+ @app.get("/typed2")
234
+ async def typed_query2(conn = Depends(db_ext.provide_connection(AsyncpgConfig))):
235
+ cursor = await conn.cursor()
236
+ await cursor.execute("SELECT 1")
237
+ return await cursor.fetchone()
238
+ """
239
+ # Extract string key if provided, ignore config types/instances (used only for type narrowing)
240
+ connection_key = key if isinstance(key, str) or key is None else None
241
+
242
+ def dependency(request: Request) -> Any:
243
+ return self.get_connection(request, connection_key)
244
+
245
+ return dependency
246
+
247
+ def provide_async_connection(self, key: "str | None" = None) -> "Callable[[Request], Any]":
248
+ """Create dependency factory for async connection injection.
249
+
250
+ Type-narrowed version of provide_connection() for async connections.
251
+ Useful when using string keys and you know the config is async.
252
+
253
+ Args:
254
+ key: Optional session key for multi-database configurations.
255
+
256
+ Returns:
257
+ Dependency callable for async connection.
258
+
259
+ Example:
260
+ @app.get("/raw")
261
+ async def raw_query(conn = Depends(db_ext.provide_async_connection())):
262
+ cursor = await conn.cursor()
263
+ await cursor.execute("SELECT 1")
264
+ return await cursor.fetchone()
265
+ """
266
+
267
+ def dependency(request: Request) -> Any:
268
+ return self.get_connection(request, key)
269
+
270
+ return dependency
271
+
272
+ def provide_sync_connection(self, key: "str | None" = None) -> "Callable[[Request], Any]":
273
+ """Create dependency factory for sync connection injection.
274
+
275
+ Type-narrowed version of provide_connection() for sync connections.
276
+ Useful when using string keys and you know the config is sync.
277
+
278
+ Args:
279
+ key: Optional session key for multi-database configurations.
280
+
281
+ Returns:
282
+ Dependency callable for sync connection.
283
+
284
+ Example:
285
+ @app.get("/raw")
286
+ def raw_query(conn = Depends(db_ext.provide_sync_connection())):
287
+ cursor = conn.cursor()
288
+ cursor.execute("SELECT 1")
289
+ return cursor.fetchone()
290
+ """
291
+
292
+ def dependency(request: Request) -> Any:
293
+ return self.get_connection(request, key)
294
+
295
+ return dependency
296
+
297
+ @staticmethod
298
+ def provide_filters(
299
+ config: "FilterConfig", dep_defaults: "DependencyDefaults | None" = None
300
+ ) -> "Callable[..., list[FilterTypes]]":
301
+ """Create filter dependency for FastAPI routes.
302
+
303
+ Dynamically generates a FastAPI dependency function that parses query
304
+ parameters into SQLSpec filter objects. The returned callable can be used
305
+ with FastAPI's Depends() for automatic filter injection.
306
+
307
+ Args:
308
+ config: Filter configuration specifying which filters to enable.
309
+ dep_defaults: Optional dependency defaults for customization.
310
+
311
+ Returns:
312
+ Callable for use with Depends() that returns list of filters.
313
+
314
+ Example:
315
+ from fastapi import Depends
316
+ from sqlspec.extensions.fastapi import FilterConfig
317
+
318
+ @app.get("/users")
319
+ async def list_users(
320
+ db = Depends(db_ext.provide_session()),
321
+ filters = Depends(
322
+ db_ext.provide_filters({
323
+ "id_filter": UUID,
324
+ "search": "name,email",
325
+ "search_ignore_case": True,
326
+ "pagination_type": "limit_offset",
327
+ "sort_field": "created_at",
328
+ })
329
+ ),
330
+ ):
331
+ stmt = sql("SELECT * FROM users")
332
+ for filter in filters:
333
+ stmt = filter.append_to_statement(stmt)
334
+ result = await db.execute(stmt)
335
+ return result.all()
336
+ """
337
+
338
+ if dep_defaults is None:
339
+ dep_defaults = DEPENDENCY_DEFAULTS
340
+
341
+ return _provide_filters(config, dep_defaults=dep_defaults)