aiteamutils 0.2.71__tar.gz → 0.2.72__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/PKG-INFO +1 -1
- aiteamutils-0.2.72/aiteamutils/base_service.py +78 -0
- aiteamutils-0.2.72/aiteamutils/version.py +2 -0
- aiteamutils-0.2.71/aiteamutils/base_service.py +0 -47
- aiteamutils-0.2.71/aiteamutils/version.py +0 -2
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/.cursorrules +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/.gitignore +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/README.md +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/__init__.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/base_model.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/base_repository.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/cache.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/config.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/database.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/enums.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/exceptions.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/security.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/aiteamutils/validators.py +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/pyproject.toml +0 -0
- {aiteamutils-0.2.71 → aiteamutils-0.2.72}/setup.py +0 -0
@@ -0,0 +1,78 @@
|
|
1
|
+
#기본 라이브러리
|
2
|
+
from fastapi import Request
|
3
|
+
from typing import TypeVar, Generic, Type, Dict, Any, Union, List
|
4
|
+
from sqlalchemy.orm import DeclarativeBase
|
5
|
+
from sqlalchemy.ext.asyncio import AsyncSession
|
6
|
+
from datetime import datetime
|
7
|
+
|
8
|
+
#패키지 라이브러리
|
9
|
+
from .exceptions import ErrorCode, CustomException
|
10
|
+
from .base_repository import BaseRepository
|
11
|
+
from .database import (
|
12
|
+
process_response,
|
13
|
+
build_search_filters
|
14
|
+
)
|
15
|
+
|
16
|
+
ModelType = TypeVar("ModelType", bound=DeclarativeBase)
|
17
|
+
|
18
|
+
class BaseService(Generic[ModelType]):
|
19
|
+
##################
|
20
|
+
# 1. 초기화 영역 #
|
21
|
+
##################
|
22
|
+
def __init__(
|
23
|
+
self,
|
24
|
+
model: Type[ModelType],
|
25
|
+
repository: BaseRepository[ModelType],
|
26
|
+
db_session: AsyncSession,
|
27
|
+
additional_models: Dict[str, Type[DeclarativeBase]] = None,
|
28
|
+
):
|
29
|
+
self.model = model
|
30
|
+
self.repository = repository
|
31
|
+
self.db_session = db_session
|
32
|
+
self.additional_models = additional_models or {},
|
33
|
+
|
34
|
+
async def list(
|
35
|
+
self,
|
36
|
+
skip: int = 0,
|
37
|
+
limit: int = 100,
|
38
|
+
filters: Dict[str, Any] | None = None,
|
39
|
+
search_params: Dict[str, Any] | None = None,
|
40
|
+
model_name: str | None = None,
|
41
|
+
request: Request | None = None,
|
42
|
+
response_model: Any = None
|
43
|
+
) -> List[Dict[str, Any]]:
|
44
|
+
try:
|
45
|
+
# 검색 조건 처리 및 필터 병합
|
46
|
+
if search_params:
|
47
|
+
search_filters = build_search_filters(request, search_params)
|
48
|
+
if filters:
|
49
|
+
# 기존 filters와 search_filters 병합 (search_filters가 우선 적용)
|
50
|
+
filters.update(search_filters)
|
51
|
+
else:
|
52
|
+
filters = search_filters
|
53
|
+
|
54
|
+
# 모델 이름을 통한 동적 처리
|
55
|
+
if model_name:
|
56
|
+
if model_name not in self.additional_models:
|
57
|
+
raise CustomException(
|
58
|
+
ErrorCode.INVALID_REQUEST,
|
59
|
+
detail=f"Model {model_name} not registered",
|
60
|
+
source_function=f"{self.__class__.__name__}.list"
|
61
|
+
)
|
62
|
+
model = self.additional_models[model_name]
|
63
|
+
return await self.repository.list(skip=skip, limit=limit, filters=filters, model=model)
|
64
|
+
|
65
|
+
return await self.repository.list(skip=skip, limit=limit, filters=filters)
|
66
|
+
except CustomException as e:
|
67
|
+
e.detail = f"Service list error for {self.repository.model.__tablename__}: {e.detail}"
|
68
|
+
e.source_function = f"{self.__class__.__name__}.list -> {e.source_function}"
|
69
|
+
raise e
|
70
|
+
except Exception as e:
|
71
|
+
raise CustomException(
|
72
|
+
ErrorCode.INTERNAL_ERROR,
|
73
|
+
detail=str(e),
|
74
|
+
source_function=f"{self.__class__.__name__}.list",
|
75
|
+
original_error=e
|
76
|
+
)
|
77
|
+
|
78
|
+
|
@@ -1,47 +0,0 @@
|
|
1
|
-
#기본 라이브러리
|
2
|
-
from fastapi import Request
|
3
|
-
from typing import TypeVar, Generic, Type, Dict, Any, Union, List
|
4
|
-
from sqlalchemy.orm import DeclarativeBase
|
5
|
-
from sqlalchemy.ext.asyncio import AsyncSession
|
6
|
-
from datetime import datetime
|
7
|
-
|
8
|
-
#패키지 라이브러리
|
9
|
-
from .exceptions import ErrorCode, CustomException
|
10
|
-
from .base_repository import BaseRepository
|
11
|
-
from .database import (
|
12
|
-
process_response,
|
13
|
-
build_search_filters
|
14
|
-
)
|
15
|
-
|
16
|
-
ModelType = TypeVar("ModelType", bound=DeclarativeBase)
|
17
|
-
|
18
|
-
class BaseService(Generic[ModelType]):
|
19
|
-
##################
|
20
|
-
# 1. 초기화 영역 #
|
21
|
-
##################
|
22
|
-
def __init__(
|
23
|
-
self,
|
24
|
-
model: Type[ModelType],
|
25
|
-
repository: BaseRepository[ModelType],
|
26
|
-
db_session: AsyncSession,
|
27
|
-
additional_models: Dict[str, Type[DeclarativeBase]] = None,
|
28
|
-
):
|
29
|
-
self.model = model
|
30
|
-
self.repository = repository
|
31
|
-
self.db_session = db_session
|
32
|
-
self.additional_models = additional_models or {},
|
33
|
-
|
34
|
-
async def list(
|
35
|
-
self,
|
36
|
-
skip: int = 0,
|
37
|
-
limit: int = 100,
|
38
|
-
filters: Dict[str, Any] | None =
|
39
|
-
except Exception as e:
|
40
|
-
raise CustomException(
|
41
|
-
ErrorCode.INTERNAL_ERROR,
|
42
|
-
detail=str(e),
|
43
|
-
source_function=f"{self.__class__.__name__}.list",
|
44
|
-
original_error=e
|
45
|
-
)
|
46
|
-
|
47
|
-
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|