internal 1.1.38__py3-none-any.whl → 1.1.39.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.

@@ -7,3 +7,4 @@ class OperatorTypeEnum(str, Enum):
7
7
  CUSTOMER = "customer"
8
8
  PROVIDER = "provider"
9
9
  CLIENT = "client"
10
+ ADMIN = "admin"
@@ -30,18 +30,24 @@ class LogRequestMiddleware(BaseHTTPMiddleware):
30
30
  params = {k: v[0] if len(v) == 1 else v for k, v in temp.items()}
31
31
 
32
32
  body = await request.body()
33
+
34
+ # 解碼 body 為字符串(如果不是 multipart)
33
35
  if is_multipart:
34
- self.logger.info(f"[Request id: {request_id}] \nURL: {method} {url} \nParams: {params} \nBody: 因上傳檔案不顯示body \nHeaders: {headers} \nstart processing...")
36
+ body_str = "因上傳檔案不顯示body"
35
37
  else:
36
- self.logger.info(f"[Request id: {request_id}] \nURL: {method} {url} \nParams: {params} \nBody: {body} \nHeaders: {headers} \nstart processing...")
38
+ try:
39
+ # 嘗試使用 UTF-8 解碼
40
+ body_str = body.decode('utf-8')
41
+ except UnicodeDecodeError:
42
+ # 如果解碼失敗,顯示原始 bytes
43
+ body_str = str(body)
44
+
45
+ self.logger.info(f"[Request id: {request_id}] \nURL: {method} {url} \nParams: {params} \nBody: {body_str} \nHeaders: {headers} \nstart processing...")
37
46
 
38
47
  # 记录请求处理时间
39
48
  start_time = time.time()
40
49
  response = await call_next(request)
41
50
  process_time = time.time() - start_time
42
51
 
43
- if is_multipart:
44
- self.logger.info(f"[Request id: {request_id}] \nURL: {method} {url} \nParams: {params} \nBody: 因上傳檔案不顯示body \nCompleted in {process_time:.4f} seconds")
45
- else:
46
- self.logger.info(f"[Request id: {request_id}] \nURL: {method} {url} \nParams: {params} \nBody: {body} \nCompleted in {process_time:.4f} seconds")
52
+ self.logger.info(f"[Request id: {request_id}] \nURL: {method} {url} \nParams: {params} \nBody: {body_str} \nCompleted in {process_time:.4f} seconds")
47
53
  return response
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: internal
3
- Version: 1.1.38
3
+ Version: 1.1.39.1
4
4
  Summary:
5
5
  Author: Ray
6
6
  Author-email: ray@cruisys.com
@@ -9,7 +9,7 @@ internal/common_enum/device_code.py,sha256=lDTqRmP8zl6-k62HCsRehNAKCTXxH6WltZnvi
9
9
  internal/common_enum/event_code.py,sha256=XpxbgpP8wkykEngma4cGgv_NefuSU6Juqy33x_vsWio,2119
10
10
  internal/common_enum/lpr_direction.py,sha256=glCGSkcXHUB6_p2jO_7IdEHycyFVhu0vHDDDXbFJ174,113
11
11
  internal/common_enum/notify_type.py,sha256=p01d9ODiJ9vDpFBJ55bhu7WOyO7Te3slToOhvFKxQbk,188
12
- internal/common_enum/operator_type.py,sha256=XfHwGDsuOG6-ajitDoRuLFLT1LhHKoXXzFRW4e5vmJ8,173
12
+ internal/common_enum/operator_type.py,sha256=RiAY5eUAWQRODG9XasYqsfZFRglCZv4Y0UbCSqBXKEk,193
13
13
  internal/common_enum/order_type.py,sha256=XwAl5JaZgFLahBQhBKG4VuMJ39Si9KZEhcSS0-DKKzQ,90
14
14
  internal/common_enum/point_type.py,sha256=nmrHw_6OJIadgWwqCa63IVnc4T5uf69vQojWPbAwCrE,120
15
15
  internal/common_enum/websocket_channel.py,sha256=BIhdE2z_xF3lgStS8GiaS5M8BXm4_g3vHQaaN5qNJTQ,283
@@ -29,12 +29,12 @@ internal/http/responses.py,sha256=75vJGS_aA9a5ff0HI6N03KM0CErIsAOtD06x7qr6yoQ,30
29
29
  internal/interface/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
30
30
  internal/interface/base_interface.py,sha256=3YaVjIgLi_pZpLk5SEIk8WVkuICM8qPavT8rB0MdB5U,1536
31
31
  internal/middleware/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
32
- internal/middleware/log_request.py,sha256=OFwWnGfzXnllcQsBHolAWVsahXKoEhw3OQ1YWOm7RHM,2087
32
+ internal/middleware/log_request.py,sha256=-UDH5u-Y8Lq0O1wzU7vYIEypP4K37mCE5cTH6dqmeeQ,2049
33
33
  internal/model/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
34
34
  internal/model/base_model.py,sha256=2M9EUWitzG-5FD4tYbUULBcWL6045HfS6OkpwzevmsY,7892
35
35
  internal/model/operate.py,sha256=QSM6yXYXpJMwrqkUGEWZLrEBaUgqHwVHY_Fi4S42hKc,3190
36
36
  internal/utils.py,sha256=wK1QumW1AaWE1ga2-WcDH2rtXRr2hSLwXzy-iI5dTzY,3962
37
37
  internal/validator_utils.py,sha256=CqjaVFoAu5MqvBG_AkTP-r7AliWawtUWB851USj4moI,1519
38
- internal-1.1.38.dist-info/METADATA,sha256=jrxrqhGAPBn8aifQnoksPEYfjit21Qe7uWwR7Fz18l8,939
39
- internal-1.1.38.dist-info/WHEEL,sha256=RaoafKOydTQ7I_I3JTrPCg6kUmTgtm4BornzOqyEfJ8,88
40
- internal-1.1.38.dist-info/RECORD,,
38
+ internal-1.1.39.1.dist-info/METADATA,sha256=V-StsSWjI00VoSnkPEY4JL-asH5V3AMFEFbIb415BZs,941
39
+ internal-1.1.39.1.dist-info/WHEEL,sha256=RaoafKOydTQ7I_I3JTrPCg6kUmTgtm4BornzOqyEfJ8,88
40
+ internal-1.1.39.1.dist-info/RECORD,,