internal 1.0.50__tar.gz → 1.0.52__tar.gz
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-1.0.50 → internal-1.0.52}/PKG-INFO +1 -1
- {internal-1.0.50 → internal-1.0.52}/pyproject.toml +1 -1
- {internal-1.0.50 → internal-1.0.52}/src/internal/http/responses.py +6 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/model/operate.py +11 -0
- {internal-1.0.50 → internal-1.0.52}/README.md +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/base_config.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/base_factory.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/common_enum/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/common_enum/contact_type.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/common_enum/description_type.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/common_enum/event_trigger_type.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/common_enum/lpnr_direction.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/common_enum/operator_type.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/common_enum/order_type.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/const.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/database.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/exception/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/exception/base_exception.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/exception/internal_exception.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/ext/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/ext/amazon/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/ext/amazon/aws/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/ext/amazon/aws/const.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/http/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/http/requests.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/interface/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/interface/base_interface.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/middleware/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/middleware/log_request.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/model/__init__.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/model/base_model.py +0 -0
- {internal-1.0.50 → internal-1.0.52}/src/internal/utils.py +0 -0
|
@@ -42,6 +42,12 @@ async def async_response(data=None, message=None, code=None, page_no=None, total
|
|
|
42
42
|
if data[field_name]:
|
|
43
43
|
data[field_name] = arrow.get(data[field_name]).to(time_zone).format(date_format)
|
|
44
44
|
|
|
45
|
+
if "create_time" in data.keys() and data.get("create_time"):
|
|
46
|
+
data["create_time"] = arrow.get(data["create_time"]).to(time_zone).format(ARR_HUMAN_READ_FMT)
|
|
47
|
+
|
|
48
|
+
if "update_time" in data.keys() and data.get("update_time"):
|
|
49
|
+
data["update_time"] = arrow.get(data["update_time"]).to(time_zone).format(ARR_HUMAN_READ_FMT)
|
|
50
|
+
|
|
45
51
|
return data
|
|
46
52
|
|
|
47
53
|
if isinstance(data, httpx.Response):
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import arrow
|
|
2
|
+
from datetime import datetime
|
|
1
3
|
from typing import Optional
|
|
2
4
|
|
|
3
5
|
import dictdiffer
|
|
@@ -13,11 +15,13 @@ class Operate(BaseModel):
|
|
|
13
15
|
async def generate_operate(cls, original: dict = None, compare: dict = None):
|
|
14
16
|
if original:
|
|
15
17
|
original = await cls.remove_ignore_field(original)
|
|
18
|
+
await cls.convert_datetime_timezone_utc_field(original)
|
|
16
19
|
else:
|
|
17
20
|
original = {}
|
|
18
21
|
|
|
19
22
|
if compare:
|
|
20
23
|
compare = await cls.remove_ignore_field(compare)
|
|
24
|
+
await cls.convert_datetime_timezone_utc_field(compare)
|
|
21
25
|
else:
|
|
22
26
|
compare = {}
|
|
23
27
|
|
|
@@ -43,3 +47,10 @@ class Operate(BaseModel):
|
|
|
43
47
|
@classmethod
|
|
44
48
|
async def remove_ignore_field(cls, model_dict: dict):
|
|
45
49
|
return {k: v for k, v in model_dict.items() if k not in ['create_time', 'update_time']}
|
|
50
|
+
|
|
51
|
+
@classmethod
|
|
52
|
+
async def convert_datetime_timezone_utc_field(cls, model_dict: dict):
|
|
53
|
+
# 統一使用arrow.get取代datetime,使其包含tzinfo,避免diff因時區有無判斷錯誤
|
|
54
|
+
for k, v in model_dict.items():
|
|
55
|
+
if isinstance(v, datetime):
|
|
56
|
+
model_dict[k] = arrow.get(v).datetime
|
|
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
|
|
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
|