aiteamutils 0.2.46__py3-none-any.whl → 0.2.48__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- aiteamutils/database.py +23 -21
- aiteamutils/dependencies.py +5 -2
- aiteamutils/version.py +1 -1
- {aiteamutils-0.2.46.dist-info → aiteamutils-0.2.48.dist-info}/METADATA +1 -1
- {aiteamutils-0.2.46.dist-info → aiteamutils-0.2.48.dist-info}/RECORD +6 -6
- {aiteamutils-0.2.46.dist-info → aiteamutils-0.2.48.dist-info}/WHEEL +0 -0
aiteamutils/database.py
CHANGED
@@ -1021,27 +1021,30 @@ async def get_db() -> AsyncGenerator[AsyncSession, None]:
|
|
1021
1021
|
)
|
1022
1022
|
|
1023
1023
|
try:
|
1024
|
-
|
1025
|
-
|
1026
|
-
|
1027
|
-
|
1028
|
-
|
1029
|
-
|
1030
|
-
|
1024
|
+
session = db_service.get_session()
|
1025
|
+
if session is None:
|
1026
|
+
raise CustomException(
|
1027
|
+
ErrorCode.DB_CONNECTION_ERROR,
|
1028
|
+
detail="Failed to create database session",
|
1029
|
+
source_function="get_db"
|
1030
|
+
)
|
1031
|
+
|
1032
|
+
# 세션이 유효한지 확인
|
1033
|
+
try:
|
1034
|
+
await session.execute(select(1))
|
1035
|
+
except Exception as e:
|
1036
|
+
await session.close()
|
1037
|
+
raise CustomException(
|
1038
|
+
ErrorCode.DB_CONNECTION_ERROR,
|
1039
|
+
detail="Database session is not valid",
|
1040
|
+
source_function="get_db",
|
1041
|
+
original_error=e
|
1042
|
+
)
|
1031
1043
|
|
1032
|
-
|
1033
|
-
try:
|
1034
|
-
await session.execute(select(1))
|
1035
|
-
except Exception as e:
|
1036
|
-
raise CustomException(
|
1037
|
-
ErrorCode.DB_CONNECTION_ERROR,
|
1038
|
-
detail="Database session is not valid",
|
1039
|
-
source_function="get_db",
|
1040
|
-
original_error=e
|
1041
|
-
)
|
1042
|
-
|
1043
|
-
yield session
|
1044
|
+
yield session
|
1044
1045
|
except Exception as e:
|
1046
|
+
if isinstance(e, CustomException):
|
1047
|
+
raise e
|
1045
1048
|
raise CustomException(
|
1046
1049
|
ErrorCode.DB_CONNECTION_ERROR,
|
1047
1050
|
detail=f"Failed to get database session: {str(e)}",
|
@@ -1049,8 +1052,7 @@ async def get_db() -> AsyncGenerator[AsyncSession, None]:
|
|
1049
1052
|
original_error=e
|
1050
1053
|
)
|
1051
1054
|
finally:
|
1052
|
-
|
1053
|
-
await session.close()
|
1055
|
+
await session.close()
|
1054
1056
|
|
1055
1057
|
async def get_database_service() -> DatabaseService:
|
1056
1058
|
"""DatabaseService 의존성
|
aiteamutils/dependencies.py
CHANGED
@@ -5,7 +5,7 @@ from jose import JWTError, jwt
|
|
5
5
|
from sqlalchemy.ext.asyncio import AsyncSession
|
6
6
|
import logging
|
7
7
|
|
8
|
-
from .database import DatabaseServiceManager, get_db, get_database_service
|
8
|
+
from .database import DatabaseServiceManager, DatabaseService, get_db, get_database_service
|
9
9
|
from .exceptions import CustomException, ErrorCode
|
10
10
|
from .config import get_settings
|
11
11
|
|
@@ -56,7 +56,10 @@ def get_service(name: str):
|
|
56
56
|
Returns:
|
57
57
|
Callable: 서비스 인스턴스를 반환하는 의존성 함수
|
58
58
|
"""
|
59
|
-
|
59
|
+
def _get_service(
|
60
|
+
db_service: DatabaseService = Depends(get_database_service),
|
61
|
+
session: AsyncSession = Depends(get_db)
|
62
|
+
):
|
60
63
|
try:
|
61
64
|
repository_class, service_class = service_registry.get(name)
|
62
65
|
repository = repository_class(db_service)
|
aiteamutils/version.py
CHANGED
@@ -1,2 +1,2 @@
|
|
1
1
|
"""버전 정보"""
|
2
|
-
__version__ = "0.2.
|
2
|
+
__version__ = "0.2.48"
|
@@ -4,13 +4,13 @@ aiteamutils/base_repository.py,sha256=qdwQ7Sj2fUqxpDg6cWM48n_QbwPK_VUlG9zTSem8iC
|
|
4
4
|
aiteamutils/base_service.py,sha256=E4dHGE0DvhmRyFplh46SwKJOSF_nUL7OAsCkf_ZJF_8,24733
|
5
5
|
aiteamutils/cache.py,sha256=07xBGlgAwOTAdY5mnMOQJ5EBxVwe8glVD7DkGEkxCtw,1373
|
6
6
|
aiteamutils/config.py,sha256=OM_b7g8sqZ3zY_DSF9ry-zn5wn4dlXdx5OhjfTGr0TE,2876
|
7
|
-
aiteamutils/database.py,sha256=
|
8
|
-
aiteamutils/dependencies.py,sha256=
|
7
|
+
aiteamutils/database.py,sha256=rEKuZ8_3eBjP1KpTNVgWrVLAtKX_IkZJzul2pa8bDlg,40075
|
8
|
+
aiteamutils/dependencies.py,sha256=0mNmZiPlA8wTj4cgmjGXs6y9kkIQ5RtLZHdEeHxyblo,4490
|
9
9
|
aiteamutils/enums.py,sha256=ipZi6k_QD5-3QV7Yzv7bnL0MjDz-vqfO9I5L77biMKs,632
|
10
10
|
aiteamutils/exceptions.py,sha256=_lKWXq_ujNj41xN6LDE149PwsecAP7lgYWbOBbLOntg,15368
|
11
11
|
aiteamutils/security.py,sha256=KSZf3WJAlW0UXVM1GEHwuGy2x27UHwtMr8aq-GuIXZk,16016
|
12
12
|
aiteamutils/validators.py,sha256=3N245cZFjgwtW_KzjESkizx5BBUDaJLbbxfNO4WOFZ0,7764
|
13
|
-
aiteamutils/version.py,sha256=
|
14
|
-
aiteamutils-0.2.
|
15
|
-
aiteamutils-0.2.
|
16
|
-
aiteamutils-0.2.
|
13
|
+
aiteamutils/version.py,sha256=QOuBXnrQHPfVpSFpLi9n2XtFYH6CXKSg3p-oiLspDBg,42
|
14
|
+
aiteamutils-0.2.48.dist-info/METADATA,sha256=9gDfB-4023TWWGai8JWqujsazybfHZPDqnzrc9equJw,1718
|
15
|
+
aiteamutils-0.2.48.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
16
|
+
aiteamutils-0.2.48.dist-info/RECORD,,
|
File without changes
|