fastapi-async-sqlalchemy 0.7.0.dev3__py3-none-any.whl → 0.7.0.dev5__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.
@@ -1,5 +1,9 @@
1
- from fastapi_async_sqlalchemy.middleware import SQLAlchemyMiddleware, db
1
+ from fastapi_async_sqlalchemy.middleware import (
2
+ SQLAlchemyMiddleware,
3
+ create_middleware_and_session_proxy,
4
+ db,
5
+ )
2
6
 
3
- __all__ = ["db", "SQLAlchemyMiddleware"]
7
+ __all__ = ["db", "SQLAlchemyMiddleware", "create_middleware_and_session_proxy"]
4
8
 
5
- __version__ = "0.7.0.dev3"
9
+ __version__ = "0.7.0.dev5"
@@ -1,23 +1,33 @@
1
1
  import asyncio
2
2
  from contextvars import ContextVar
3
- from typing import Dict, Optional, Union
3
+ from typing import Dict, Optional, Type, Union
4
4
 
5
- from sqlalchemy.engine import Engine
6
5
  from sqlalchemy.engine.url import URL
7
- from sqlalchemy.ext.asyncio import AsyncSession, async_sessionmaker, create_async_engine
6
+ from sqlalchemy.ext.asyncio import AsyncEngine, AsyncSession, create_async_engine
8
7
  from starlette.middleware.base import BaseHTTPMiddleware, RequestResponseEndpoint
9
8
  from starlette.requests import Request
10
9
  from starlette.types import ASGIApp
11
10
 
12
- from fastapi_async_sqlalchemy.exceptions import MissingSessionError, SessionNotInitialisedError
11
+ from fastapi_async_sqlalchemy.exceptions import (
12
+ MissingSessionError,
13
+ SessionNotInitialisedError,
14
+ )
13
15
 
14
16
  try:
15
- from sqlalchemy.ext.asyncio import async_sessionmaker # noqa: F811
17
+ from sqlalchemy.ext.asyncio import async_sessionmaker
16
18
  except ImportError:
17
- from sqlalchemy.orm import sessionmaker as async_sessionmaker
19
+ from sqlalchemy.orm import sessionmaker as async_sessionmaker # type: ignore
20
+
21
+ # Try to import SQLModel's AsyncSession which has the .exec() method
22
+ try:
23
+ from sqlmodel.ext.asyncio.session import AsyncSession as SQLModelAsyncSession
24
+
25
+ DefaultAsyncSession: Type[AsyncSession] = SQLModelAsyncSession # type: ignore
26
+ except ImportError:
27
+ DefaultAsyncSession: Type[AsyncSession] = AsyncSession # type: ignore
18
28
 
19
29
 
20
- def create_middleware_and_session_proxy():
30
+ def create_middleware_and_session_proxy() -> tuple:
21
31
  _Session: Optional[async_sessionmaker] = None
22
32
  _session: ContextVar[Optional[AsyncSession]] = ContextVar("_session", default=None)
23
33
  _multi_sessions_ctx: ContextVar[bool] = ContextVar("_multi_sessions_context", default=False)
@@ -31,9 +41,9 @@ def create_middleware_and_session_proxy():
31
41
  self,
32
42
  app: ASGIApp,
33
43
  db_url: Optional[Union[str, URL]] = None,
34
- custom_engine: Optional[Engine] = None,
35
- engine_args: Dict = None,
36
- session_args: Dict = None,
44
+ custom_engine: Optional[AsyncEngine] = None,
45
+ engine_args: Optional[Dict] = None,
46
+ session_args: Optional[Dict] = None,
37
47
  commit_on_exit: bool = False,
38
48
  ):
39
49
  super().__init__(app)
@@ -44,13 +54,18 @@ def create_middleware_and_session_proxy():
44
54
  if not custom_engine and not db_url:
45
55
  raise ValueError("You need to pass a db_url or a custom_engine parameter.")
46
56
  if not custom_engine:
57
+ if db_url is None:
58
+ raise ValueError("db_url cannot be None when custom_engine is not provided")
47
59
  engine = create_async_engine(db_url, **engine_args)
48
60
  else:
49
61
  engine = custom_engine
50
62
 
51
63
  nonlocal _Session
52
64
  _Session = async_sessionmaker(
53
- engine, class_=AsyncSession, expire_on_commit=False, **session_args
65
+ engine,
66
+ class_=DefaultAsyncSession,
67
+ expire_on_commit=False,
68
+ **session_args,
54
69
  )
55
70
 
56
71
  async def dispatch(self, request: Request, call_next: RequestResponseEndpoint):
@@ -115,7 +130,7 @@ def create_middleware_and_session_proxy():
115
130
  class DBSession(metaclass=DBSessionMeta):
116
131
  def __init__(
117
132
  self,
118
- session_args: Dict = None,
133
+ session_args: Optional[Dict] = None,
119
134
  commit_on_exit: bool = False,
120
135
  multi_sessions: bool = False,
121
136
  ):
@@ -1,6 +1,6 @@
1
- Metadata-Version: 2.1
1
+ Metadata-Version: 2.4
2
2
  Name: fastapi-async-sqlalchemy
3
- Version: 0.7.0.dev3
3
+ Version: 0.7.0.dev5
4
4
  Summary: SQLAlchemy middleware for FastAPI
5
5
  Home-page: https://github.com/h0rn3t/fastapi-async-sqlalchemy.git
6
6
  Author: Eugene Shershen
@@ -28,8 +28,20 @@ Classifier: Topic :: Software Development :: Libraries :: Python Modules
28
28
  Requires-Python: >=3.7
29
29
  Description-Content-Type: text/markdown
30
30
  License-File: LICENSE
31
- Requires-Dist: starlette >=0.13.6
32
- Requires-Dist: SQLAlchemy >=1.4.19
31
+ Requires-Dist: starlette>=0.13.6
32
+ Requires-Dist: SQLAlchemy>=1.4.19
33
+ Dynamic: author
34
+ Dynamic: author-email
35
+ Dynamic: classifier
36
+ Dynamic: description
37
+ Dynamic: description-content-type
38
+ Dynamic: home-page
39
+ Dynamic: license
40
+ Dynamic: license-file
41
+ Dynamic: project-url
42
+ Dynamic: requires-dist
43
+ Dynamic: requires-python
44
+ Dynamic: summary
33
45
 
34
46
  # SQLAlchemy FastAPI middleware
35
47
 
@@ -48,7 +60,7 @@ Provides SQLAlchemy middleware for FastAPI using AsyncSession and async engine.
48
60
  ### Install
49
61
 
50
62
  ```bash
51
- pip install fastapi-async-sqlalchemy
63
+ pip install fastapi-async-sqlalchemy
52
64
  ```
53
65
 
54
66
 
@@ -0,0 +1,9 @@
1
+ fastapi_async_sqlalchemy/__init__.py,sha256=BoDxfjumJJk-SFHEb2H93y9RBmeBvsYa0DNqsms4bAg,236
2
+ fastapi_async_sqlalchemy/exceptions.py,sha256=dH3xjPE7B6kgq8L3LvxK-MsGZ_ZnW2WH2drLkK2oD-4,887
3
+ fastapi_async_sqlalchemy/middleware.py,sha256=P7fTBvh5L7VO1fwRAvecJ24vGhFhE7hAaM3-kDtiJZg,7122
4
+ fastapi_async_sqlalchemy/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
+ fastapi_async_sqlalchemy-0.7.0.dev5.dist-info/licenses/LICENSE,sha256=OhSfEMY0WqZhq41M6mLmkuFloAG7ZJYKfryF2jyxkfY,1108
6
+ fastapi_async_sqlalchemy-0.7.0.dev5.dist-info/METADATA,sha256=RQZ9tcP69Tqzn9I3kZvo7C1gzk25MudNs-4EQFnjlPs,7090
7
+ fastapi_async_sqlalchemy-0.7.0.dev5.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
8
+ fastapi_async_sqlalchemy-0.7.0.dev5.dist-info/top_level.txt,sha256=po-P5Tif35GmAaUR0mgZr5uBwN91iAgszaKI_r4ZTZA,25
9
+ fastapi_async_sqlalchemy-0.7.0.dev5.dist-info/RECORD,,
@@ -1,5 +1,5 @@
1
1
  Wheel-Version: 1.0
2
- Generator: setuptools (75.2.0)
2
+ Generator: setuptools (80.9.0)
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any
5
5
 
@@ -1,9 +0,0 @@
1
- fastapi_async_sqlalchemy/__init__.py,sha256=Ruw-Q02MYDqljZux5Sq35zVhXhuf8d4ykGr6sOrHKXo,143
2
- fastapi_async_sqlalchemy/exceptions.py,sha256=dH3xjPE7B6kgq8L3LvxK-MsGZ_ZnW2WH2drLkK2oD-4,887
3
- fastapi_async_sqlalchemy/middleware.py,sha256=0jrZrrH9YsimOqsx7hFtO-BvKiNLFeDuDcqYLSS7E_g,6577
4
- fastapi_async_sqlalchemy/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
- fastapi_async_sqlalchemy-0.7.0.dev3.dist-info/LICENSE,sha256=OhSfEMY0WqZhq41M6mLmkuFloAG7ZJYKfryF2jyxkfY,1108
6
- fastapi_async_sqlalchemy-0.7.0.dev3.dist-info/METADATA,sha256=rPGtBpw-ksoML8ZVDjstRs49_0alHHZpSlvRbf_9Rw4,6831
7
- fastapi_async_sqlalchemy-0.7.0.dev3.dist-info/WHEEL,sha256=OVMc5UfuAQiSplgO0_WdW7vXVGAt9Hdd6qtN4HotdyA,91
8
- fastapi_async_sqlalchemy-0.7.0.dev3.dist-info/top_level.txt,sha256=po-P5Tif35GmAaUR0mgZr5uBwN91iAgszaKI_r4ZTZA,25
9
- fastapi_async_sqlalchemy-0.7.0.dev3.dist-info/RECORD,,