aiteamutils 0.2.37__tar.gz → 0.2.38__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: aiteamutils
3
- Version: 0.2.37
3
+ Version: 0.2.38
4
4
  Summary: AI Team Utilities
5
5
  Project-URL: Homepage, https://github.com/yourusername/aiteamutils
6
6
  Project-URL: Issues, https://github.com/yourusername/aiteamutils/issues
@@ -9,6 +9,7 @@ from sqlalchemy import or_
9
9
  from fastapi import Request, Depends
10
10
  from ulid import ULID
11
11
  from sqlalchemy.sql import Select
12
+ import logging
12
13
 
13
14
  from .exceptions import ErrorCode, CustomException
14
15
  from .base_model import Base, BaseColumn
@@ -31,18 +32,33 @@ def get_database_service() -> 'DatabaseService':
31
32
  if _database_service is None:
32
33
  raise CustomException(
33
34
  ErrorCode.DB_CONNECTION_ERROR,
34
- detail="database_service",
35
+ detail="Database service is not initialized. Call init_database_service() first.",
35
36
  source_function="get_database_service"
36
37
  )
37
38
  return _database_service
38
39
 
39
40
  async def get_db() -> AsyncGenerator[AsyncSession, None]:
40
- """데이터베이스 세션을 생성하고 반환하는 비동기 제너레이터."""
41
+ """데이터베이스 세션을 생성하고 반환하는 비동기 제너레이터.
42
+
43
+ Yields:
44
+ AsyncSession: 데이터베이스 세션
45
+
46
+ Raises:
47
+ CustomException: 세션 생성 실패 시
48
+ """
41
49
  db_service = get_database_service()
42
- async with db_service.get_session() as session:
43
- try:
50
+ try:
51
+ async with db_service.get_session() as session:
44
52
  yield session
45
- finally:
53
+ except Exception as e:
54
+ raise CustomException(
55
+ ErrorCode.DB_CONNECTION_ERROR,
56
+ detail=f"Failed to get database session: {str(e)}",
57
+ source_function="get_db",
58
+ original_error=e
59
+ )
60
+ finally:
61
+ if 'session' in locals():
46
62
  await session.close()
47
63
 
48
64
  def get_database_session(db: AsyncSession = Depends(get_db)) -> 'DatabaseService':
@@ -921,14 +937,40 @@ def init_database_service(
921
937
 
922
938
  Returns:
923
939
  DatabaseService: 초기화된 데이터베이스 서비스 인스턴스
940
+
941
+ Raises:
942
+ CustomException: 데이터베이스 초기화 실패 시
924
943
  """
925
- global _database_service
926
- _database_service = DatabaseService(
927
- db_url=db_url,
928
- db_echo=db_echo,
929
- db_pool_size=db_pool_size,
930
- db_max_overflow=db_max_overflow,
931
- db_pool_timeout=db_pool_timeout,
932
- db_pool_recycle=db_pool_recycle
933
- )
934
- return _database_service
944
+ try:
945
+ global _database_service
946
+ if _database_service is not None:
947
+ logging.info("Database service already initialized")
948
+ return _database_service
949
+
950
+ logging.info(f"Initializing database service with URL: {db_url}")
951
+ _database_service = DatabaseService(
952
+ db_url=db_url,
953
+ db_echo=db_echo,
954
+ db_pool_size=db_pool_size,
955
+ db_max_overflow=db_max_overflow,
956
+ db_pool_timeout=db_pool_timeout,
957
+ db_pool_recycle=db_pool_recycle
958
+ )
959
+
960
+ if not _database_service.engine:
961
+ raise CustomException(
962
+ ErrorCode.DB_CONNECTION_ERROR,
963
+ detail="Database engine initialization failed",
964
+ source_function="init_database_service"
965
+ )
966
+
967
+ logging.info("Database service initialized successfully")
968
+ return _database_service
969
+ except Exception as e:
970
+ logging.error(f"Failed to initialize database service: {str(e)}")
971
+ raise CustomException(
972
+ ErrorCode.DB_CONNECTION_ERROR,
973
+ detail=f"Failed to initialize database service: {str(e)}",
974
+ source_function="init_database_service",
975
+ original_error=e
976
+ )
@@ -67,11 +67,22 @@ def get_service(name: str):
67
67
 
68
68
  Returns:
69
69
  Callable: 서비스 인스턴스를 반환하는 의존성 함수
70
+
71
+ Raises:
72
+ CustomException: 서비스 생성 실패 시
70
73
  """
71
74
  def _get_service(db_service: DatabaseService = Depends(get_database_service)):
72
- repository_class, service_class = service_registry.get(name)
73
- repository = repository_class(db_service)
74
- return service_class(repository, db_service)
75
+ try:
76
+ repository_class, service_class = service_registry.get(name)
77
+ repository = repository_class(db_service)
78
+ return service_class(repository)
79
+ except Exception as e:
80
+ raise CustomException(
81
+ ErrorCode.SERVICE_NOT_REGISTERED,
82
+ detail=f"Failed to create service {name}: {str(e)}",
83
+ source_function="dependencies.get_service",
84
+ original_error=e
85
+ )
75
86
  return _get_service
76
87
 
77
88
  oauth2_scheme = OAuth2PasswordBearer(tokenUrl="/users/token")
@@ -0,0 +1,2 @@
1
+ """버전 정보"""
2
+ __version__ = "0.2.38"
@@ -1,2 +0,0 @@
1
- """버전 정보"""
2
- __version__ = "0.2.37"
File without changes
File without changes
File without changes
File without changes