internal 0.1.0__py3-none-any.whl → 0.1.1__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.

Potentially problematic release.


This version of internal might be problematic. Click here for more details.

internal/base_factory.py CHANGED
@@ -6,13 +6,16 @@ from abc import ABCMeta, abstractmethod
6
6
 
7
7
  import dotenv
8
8
  import watchtower
9
- from fastapi import FastAPI
9
+ from fastapi import FastAPI, status
10
10
  from fastapi.middleware.cors import CORSMiddleware
11
11
  from fastapi.responses import JSONResponse
12
+ from starlette.requests import Request
13
+ from beanie import init_beanie
12
14
 
13
15
  from . import database
14
16
  from .base_config import get_app_config
15
17
  from .const import LOG_FMT, LOG_FMT_NO_DT, LOG_DT_FMT, DEFAULT_LOGGER_NAME
18
+ from .exception.base_exception import InternalBaseException
16
19
  from .utils import update_dict_with_cast
17
20
  from .ext.amazon import aws
18
21
 
@@ -24,7 +27,13 @@ class BaseFactory(metaclass=ABCMeta):
24
27
  @abstractmethod
25
28
  def init_modules(self, app):
26
29
  """
27
- Each factory should define what modules it want.
30
+ Each factory should define what modules it wants.
31
+ """
32
+
33
+ @abstractmethod
34
+ async def get_document_model_list(self) -> list:
35
+ """
36
+ Each factory should define what model it wants.
28
37
  """
29
38
 
30
39
  def create_app(self, title=DEFAULT_APP_NAME) -> FastAPI:
@@ -50,6 +59,8 @@ class BaseFactory(metaclass=ABCMeta):
50
59
  @app.on_event("startup")
51
60
  async def startup_db_client():
52
61
  await mongodb.connect()
62
+ document_model_list = await self.get_document_model_list()
63
+ await init_beanie(database=app.state.db.db_name, document_models=document_model_list)
53
64
  app.state.logger.info("Database connected")
54
65
 
55
66
  @app.on_event("shutdown")
@@ -57,11 +68,27 @@ class BaseFactory(metaclass=ABCMeta):
57
68
  await mongodb.close()
58
69
  app.state.logger.info("Database disconnected")
59
70
 
60
- app.db = mongodb
71
+ app.state.db = mongodb
61
72
 
62
73
  self.__init_modules(app)
63
74
  self.__init_builtin_api(app)
64
75
 
76
+ @app.exception_handler(InternalBaseException)
77
+ async def http_exception_handler(request: Request, exc: InternalBaseException):
78
+ return JSONResponse(
79
+ status_code=exc.status_code,
80
+ content=exc.detail
81
+ )
82
+
83
+ @app.exception_handler(Exception)
84
+ async def http_exception_handler(request: Request, exc: Exception):
85
+ app.state.logger.warn(f"Exception, request:{request.__dict__}, exc:{exc}")
86
+ detail = {"code": status.HTTP_500_INTERNAL_SERVER_ERROR, "message": "Internal server error"}
87
+ return JSONResponse(
88
+ status_code=status.HTTP_500_INTERNAL_SERVER_ERROR,
89
+ content=detail
90
+ )
91
+
65
92
  return app
66
93
 
67
94
  def __load_local_config(self):
@@ -118,7 +145,6 @@ class BaseFactory(metaclass=ABCMeta):
118
145
  boto3_client=logs_client, create_log_group=False)
119
146
  watchtower_handler.setFormatter(logging.Formatter(fmt=LOG_FMT_NO_DT, datefmt=LOG_DT_FMT))
120
147
  app.state.logger.addHandler(watchtower_handler)
121
- logging.getLogger('sqlalchemy').addHandler(watchtower_handler)
122
148
 
123
149
  def __init_builtin_api(self, app):
124
150
 
@@ -2,8 +2,10 @@ from fastapi import HTTPException
2
2
 
3
3
 
4
4
  class InternalBaseException(HTTPException):
5
- STATUS_CODE: int = None
6
- DETAIL: str = None
7
-
8
- def __init__(self):
9
- super().__init__(status_code=self.STATUS_CODE, detail=self.DETAIL)
5
+ def __init__(self, status_code: int = None, code: str = "SUCCESS", message: str = "success", **kwargs):
6
+ detail = {
7
+ "code": code,
8
+ "message": message,
9
+ "data": kwargs,
10
+ }
11
+ super().__init__(status_code=status_code, detail=detail)
internal/utils.py CHANGED
@@ -1,5 +1,6 @@
1
1
  # -*- coding: utf-8 -*-
2
2
  import hashlib
3
+ import json
3
4
 
4
5
  import arrow
5
6
 
@@ -41,4 +42,6 @@ def export_time_format(date, fmt=ARR_EXPORT_DATETIME_FMT):
41
42
  def update_dict_with_cast(curr_settings: BaseConfig, new_conf: dict):
42
43
  for key, value in new_conf.items():
43
44
  if hasattr(curr_settings, key):
44
- setattr(curr_settings, key, value)
45
+ key_type = type(getattr(curr_settings, key))
46
+ cast_func = key_type if key_type in (str, int) else json.loads
47
+ setattr(curr_settings, key, cast_func(value))
@@ -1,9 +1,9 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: internal
3
- Version: 0.1.0
3
+ Version: 0.1.1
4
4
  Summary:
5
5
  Author: Ray
6
- Author-email: ray@RayMBP16
6
+ Author-email: ray@cruisys.com
7
7
  Requires-Python: >=3.11,<4.0
8
8
  Classifier: Programming Language :: Python :: 3
9
9
  Classifier: Programming Language :: Python :: 3.11
@@ -12,7 +12,6 @@ Requires-Dist: arrow (>=1.3.0,<2.0.0)
12
12
  Requires-Dist: beanie (>=1.24.0,<2.0.0)
13
13
  Requires-Dist: fastapi (>=0.109.0,<0.110.0)
14
14
  Requires-Dist: httpx (>=0.26.0,<0.27.0)
15
- Requires-Dist: motor (>=3.3.2,<4.0.0)
16
15
  Requires-Dist: pydantic-settings (>=2.1.0,<3.0.0)
17
16
  Requires-Dist: watchtower (>=3.0.1,<4.0.0)
18
17
  Description-Content-Type: text/markdown
@@ -1,10 +1,10 @@
1
1
  internal/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
2
  internal/base_config.py,sha256=_qJl5M5h8hGuaYJnoEwVnk2OP1OB4wy5WPtZAk_mpOY,1003
3
- internal/base_factory.py,sha256=TdaV2IJHaZXMKfJ8-K0UWiFE-qy9RnBSkSyDX69LnXc,4455
3
+ internal/base_factory.py,sha256=MVgrTDzqq8U7gT9BVgcdmdo6M8TfenO30FaT0VHTUDM,5574
4
4
  internal/const.py,sha256=uEhY93JxbquSivdR_PIzBff0kq3hlvLfdUCdvZLDoKU,1000
5
5
  internal/database.py,sha256=MyRLlb0W8FB8Odq0UQpN3R7OD3yUPWgJXsZRuDWQC_w,1010
6
6
  internal/exception/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
7
- internal/exception/base_exception.py,sha256=fmCv3Fw18e4CGOYd4P8ROGy9HKUaOh46HEbAbi1Pr2M,231
7
+ internal/exception/base_exception.py,sha256=h0jZLGbl7WL82j-39HKA4OOcJe1k18WjqOyy3yLyY0Q,368
8
8
  internal/ext/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
9
9
  internal/ext/amazon/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
10
10
  internal/ext/amazon/aws/__init__.py,sha256=BVc-P8NIh5P9XZxTdKwl48I3-LrBhclGJUtQ-_hYIT8,877
@@ -14,7 +14,7 @@ internal/http/requests.py,sha256=BZPlrfNbxO2-fOiIQxioX9qwiYlBsfwMF2tJN-AnOcE,502
14
14
  internal/model/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
15
15
  internal/model/base_model.py,sha256=ICLwfn0YZBU15zL9ImS5sMgKKGWkob28k_OMC5P3TBc,241
16
16
  internal/model/operate.py,sha256=B8P_yWLd3yg-Am_W5WB70sC6Zfz_sWO3myiimr8ysSk,224
17
- internal/utils.py,sha256=DEmWejd5AFyNXPQupnJtPRzgoKUz2K4j3AggXT4PJ8Q,1285
18
- internal-0.1.0.dist-info/METADATA,sha256=Truf3AqHgMpnVztHtdXzer8gSZWV3GBzbAmno6YKKHU,615
19
- internal-0.1.0.dist-info/WHEEL,sha256=FMvqSimYX_P7y0a7UY-_Mc83r5zkBZsCYPm7Lr0Bsq4,88
20
- internal-0.1.0.dist-info/RECORD,,
17
+ internal/utils.py,sha256=tDas83c_tDsWHBDMa-m3f3HXYbmel8kif8TWdLBr6LU,1440
18
+ internal-0.1.1.dist-info/METADATA,sha256=lOVtSdJR-sVjz6kXWxg9jQIS43TcvvNY0ARmufnAoFY,580
19
+ internal-0.1.1.dist-info/WHEEL,sha256=FMvqSimYX_P7y0a7UY-_Mc83r5zkBZsCYPm7Lr0Bsq4,88
20
+ internal-0.1.1.dist-info/RECORD,,