solax-py-library 1.0.0.2521__tar.gz → 1.0.0.2602__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.
Files changed (83) hide show
  1. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/PKG-INFO +1 -1
  2. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/pyproject.toml +1 -1
  3. solax_py_library-1.0.0.2602/solax_py_library/device/types/device.py +26 -0
  4. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/constant/message_entry.py +13 -1
  5. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/cabinet_condition.py +17 -17
  6. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/condition.py +9 -2
  7. solax_py_library-1.0.0.2602/solax_py_library/smart_scene/types/condition_value.py +30 -0
  8. solax_py_library-1.0.0.2602/solax_py_library/test/test_smart_scene/test_condition.py +66 -0
  9. solax_py_library-1.0.0.2521/solax_py_library/test/test_smart_scene/test_condition.py +0 -11
  10. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/README.md +0 -0
  11. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/__init__.py +0 -0
  12. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/__init__.py +0 -0
  13. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/constant/__init__.py +0 -0
  14. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/constant/cabinet.py +0 -0
  15. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/constant/inverter_model_info.py +0 -0
  16. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/core/__init__.py +0 -0
  17. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/core/interver/__init__.py +0 -0
  18. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/core/interver/base.py +0 -0
  19. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/types/__init__.py +0 -0
  20. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/types/alarm.py +0 -0
  21. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/types/inverter_config.py +0 -0
  22. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/device/types/modbus_point.py +0 -0
  23. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/exception.py +0 -0
  24. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/__init__.py +0 -0
  25. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/constant/__init__.py +0 -0
  26. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/__init__.py +0 -0
  27. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/action/__init__.py +0 -0
  28. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/action/base.py +0 -0
  29. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/action/ems_action.py +0 -0
  30. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/action/system_action.py +0 -0
  31. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/__init__.py +0 -0
  32. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/base.py +0 -0
  33. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/date_condition.py +0 -0
  34. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/price_condition.py +0 -0
  35. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/system_condition.py +0 -0
  36. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/weather_condition.py +0 -0
  37. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/service/__init__.py +0 -0
  38. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/service/runner.py +0 -0
  39. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/exceptions/__init__.py +0 -0
  40. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/exceptions/price.py +0 -0
  41. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/exceptions/smart_scene.py +0 -0
  42. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/exceptions/weather.py +0 -0
  43. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/__init__.py +0 -0
  44. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/action.py +0 -0
  45. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/smart_scene_content.py +0 -0
  46. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/__init__.py +0 -0
  47. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/constant/__init__.py +0 -0
  48. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/constant/crc_table.py +0 -0
  49. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/core/__init__.py +0 -0
  50. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/core/base_modbus.py +0 -0
  51. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/core/parser.py +0 -0
  52. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/core/snap_shot.py +0 -0
  53. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/exceptions/__init__.py +0 -0
  54. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/exceptions/snap_shot.py +0 -0
  55. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/test/__init__.py +0 -0
  56. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/types/__init__.py +0 -0
  57. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/types/address.py +0 -0
  58. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/test/__init__.py +0 -0
  59. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/test/test_smart_scene/__init__.py +0 -0
  60. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/test/test_utils/__init__.py +0 -0
  61. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/test/test_utils/test_cloud_client.py +0 -0
  62. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/__init__.py +0 -0
  63. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/api/__init__.py +0 -0
  64. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/api/service.py +0 -0
  65. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/__init__.py +0 -0
  66. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/data_adapter/__init__.py +0 -0
  67. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/data_adapter/base.py +0 -0
  68. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/data_adapter/csv.py +0 -0
  69. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/upload_service/__init__.py +0 -0
  70. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/upload_service/base.py +0 -0
  71. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/upload_service/ftp.py +0 -0
  72. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/exceptions/__init__.py +0 -0
  73. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/exceptions/upload_error.py +0 -0
  74. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/test/__init__.py +0 -0
  75. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/test/test_ftp.py +0 -0
  76. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/types/__init__.py +0 -0
  77. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/types/client.py +0 -0
  78. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/upload/types/ftp.py +0 -0
  79. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/utils/__init__.py +0 -0
  80. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/utils/cloud_client.py +0 -0
  81. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/utils/common.py +0 -0
  82. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/utils/struct_util.py +0 -0
  83. {solax_py_library-1.0.0.2521 → solax_py_library-1.0.0.2602}/solax_py_library/utils/time_util.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: solax-py-library
3
- Version: 1.0.0.2521
3
+ Version: 1.0.0.2602
4
4
  Summary: some common tool
5
5
  Author: shenlvyu
6
6
  Author-email: 13296718439@163.com
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "solax-py-library"
3
- version = "1.0.0.2521"
3
+ version = "1.0.0.2602"
4
4
  description = "some common tool"
5
5
  authors = ["shenlvyu <13296718439@163.com>", "x5m8944pjl <371630856@qq.com>"]
6
6
  readme = "README.md"
@@ -0,0 +1,26 @@
1
+ from enum import IntEnum
2
+
3
+
4
+ class DeviceType(IntEnum):
5
+ EMS_TYPE = 100
6
+ PCS_TYPE = 1
7
+ BMS_TYPE = 2 # 电池簇
8
+ ELM_TYPE = 3
9
+ EVC_TYPE = 4
10
+ IO_TYPE = 5
11
+ ESS_TYPE = 6 # 机柜
12
+ CELL_TYPE = 7 # 单体
13
+ AIRCONDITIONER_TYPE = 501
14
+ FIRE_SAFETY_TYPE = 502
15
+ COLD_TYPE = 503
16
+ DEHUMIDIFY_TYPE = 504
17
+
18
+ def __str__(self):
19
+ return {
20
+ DeviceType.PCS_TYPE: "pcs",
21
+ DeviceType.BMS_TYPE: "bms",
22
+ DeviceType.ELM_TYPE: "elm",
23
+ DeviceType.IO_TYPE: "io",
24
+ DeviceType.AIRCONDITIONER_TYPE: "air_conditioner",
25
+ DeviceType.COLD_TYPE: "liquid_cooling_unit",
26
+ }.get(self)
@@ -170,10 +170,22 @@ MESSAGE_ENTRY = {
170
170
  "EMERGENCY": {"zh_CN": "紧急告警", "en_US": "Emergency alarm"},
171
171
  "TIPS": {"zh_CN": "状态提醒", "en_US": "State Tips"},
172
172
  "NORMAL": {"zh_CN": "普通告警", "en_US": "Normal alarm"},
173
- "cabinetAlarm": {"zh_CN": "机柜发生{}", "en_US": "cabinet occurs {}"},
173
+ "cabinetAlarm": {
174
+ "zh_CN": "机柜下属({})设备发生{}",
175
+ "en_US": "The equipments({}) under the cabinet occurs {}",
176
+ },
174
177
  "OR": {"zh_CN": "满足任一条件", "en_US": "Meet any of the conditions"},
175
178
  "AND": {"zh_CN": "满足所有条件", "en_US": "Meet all conditions"},
176
179
  "tips_alarm": {"zh_CN": "状态提醒", "en_US": "Alarm tips"},
177
180
  "normal_alarm": {"zh_CN": "普通告警", "en_US": "Normal alarm"},
178
181
  "emergency_alarm": {"zh_CN": "紧急告警", "en_US": "Emergency alarm"},
182
+ "pcs": {"zh_CN": "逆变器", "en_US": "Inverter"},
183
+ "bms": {"zh_CN": "电池", "en_US": "Battery"},
184
+ "elm": {
185
+ "zh_CN": "电表",
186
+ "en_US": "Meter",
187
+ },
188
+ "io": {"zh_CN": "IO模块", "en_US": "IO Module"},
189
+ "air_conditioner": {"zh_CN": "空调", "en_US": "Air conditioner"},
190
+ "liquid_cooling_unit": {"zh_CN": "液冷机组", "en_US": "Liquid Cooling Unit"},
179
191
  }
@@ -6,7 +6,7 @@ from solax_py_library.smart_scene.types.condition import (
6
6
  CabinetConditionType,
7
7
  ConditionType,
8
8
  )
9
- from solax_py_library.device.types.alarm import AlarmLevel
9
+ from solax_py_library.smart_scene.types.condition_value import CabinetValue
10
10
 
11
11
 
12
12
  class CabinetCondition(BaseCondition):
@@ -14,31 +14,31 @@ class CabinetCondition(BaseCondition):
14
14
 
15
15
  def __init__(self, update_value_function, **kwargs):
16
16
  super().__init__(update_value_function, **kwargs)
17
- self.value = defaultdict(
18
- lambda: {
19
- "soc": 0,
20
- "alarm_level": {
21
- AlarmLevel.EMERGENCY: False,
22
- AlarmLevel.NORMAL: False,
23
- AlarmLevel.TIPS: False,
24
- },
25
- }
26
- )
17
+ self.value = defaultdict(lambda: CabinetValue)
27
18
 
28
19
  def meet_func(self, data: CabinetConditionItemData, ctx):
29
20
  if not self.value:
30
21
  return False
31
22
  cabinet = ctx["cabinet"] or []
23
+ condition_data = data.childData.data
32
24
  for cabinet_sn in cabinet:
25
+ cabinet_value = self.value[cabinet_sn]
26
+ if not cabinet_value:
27
+ continue
33
28
  if data.childType == CabinetConditionType.cabinetSoc:
34
- if self.value[cabinet_sn]["soc"] is None:
35
- return False
29
+ if self.value[cabinet_sn].soc is None:
30
+ continue
36
31
  if data.childData.function.function()(
37
- compare_value=self.value[cabinet_sn]["soc"],
38
- base_value=data.childData.data[0],
32
+ compare_value=self.value[cabinet_sn].soc,
33
+ base_value=condition_data[0],
39
34
  ):
40
35
  return True
41
36
  elif data.childType == CabinetConditionType.cabinetAlarm:
42
- if self.value[cabinet_sn]["alarm_level"][data.childData.data[0]]:
43
- return True
37
+ alarm_type = condition_data[-1]
38
+ for device_type in condition_data[:-1]:
39
+ alarm_info = cabinet_value.alarm_info(device_type)
40
+ if not alarm_info:
41
+ continue
42
+ if alarm_info[alarm_type - 1] is True:
43
+ return True
44
44
  return False
@@ -5,6 +5,7 @@ from typing import Optional, List, Union, Any
5
5
  from pydantic import BaseModel, validator, root_validator
6
6
 
7
7
  from solax_py_library.device.types.alarm import AlarmLevel
8
+ from solax_py_library.device.types.device import DeviceType
8
9
  from solax_py_library.smart_scene.constant.message_entry import MESSAGE_ENTRY
9
10
 
10
11
 
@@ -163,7 +164,7 @@ class CabinetConditionItemData(BaseModel):
163
164
  def _check_child_data(cls, value, values):
164
165
  child_type = values.get("childType")
165
166
  if child_type == CabinetConditionType.cabinetAlarm:
166
- assert value.data[0] in {
167
+ assert value.data[-1] in {
167
168
  AlarmLevel.TIPS,
168
169
  AlarmLevel.NORMAL,
169
170
  AlarmLevel.EMERGENCY,
@@ -181,7 +182,13 @@ class CabinetConditionItemData(BaseModel):
181
182
  )
182
183
  elif self.childType == CabinetConditionType.cabinetAlarm:
183
184
  return MESSAGE_ENTRY[self.childType][lang].format(
184
- MESSAGE_ENTRY[str(AlarmLevel(data[0]))][lang], lang
185
+ ",".join(
186
+ [
187
+ MESSAGE_ENTRY[str(DeviceType(device_type))][lang]
188
+ for device_type in data[:-1]
189
+ ]
190
+ ),
191
+ MESSAGE_ENTRY[str(AlarmLevel(data[-1]))][lang],
185
192
  )
186
193
 
187
194
 
@@ -0,0 +1,30 @@
1
+ from typing import List
2
+
3
+ from pydantic import BaseModel, Field
4
+
5
+ from solax_py_library.device.types.device import DeviceType
6
+
7
+
8
+ class CabinetValue(BaseModel):
9
+ soc: int = None
10
+ cabinet_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
11
+ pcs_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
12
+ io_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
13
+ bms_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
14
+ air_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
15
+ liquid_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
16
+
17
+ def alarm_info(self, device_type):
18
+ if device_type == DeviceType.EMS_TYPE:
19
+ return self.cabinet_alarm
20
+ elif device_type == DeviceType.PCS_TYPE:
21
+ return self.pcs_alarm
22
+ elif device_type == DeviceType.IO_TYPE:
23
+ return self.io_alarm
24
+ elif device_type == DeviceType.BMS_TYPE:
25
+ return self.bms_alarm
26
+ elif device_type == DeviceType.AIRCONDITIONER_TYPE:
27
+ return self.air_alarm
28
+ elif device_type == DeviceType.COLD_TYPE:
29
+ return self.liquid_alarm
30
+ return None
@@ -0,0 +1,66 @@
1
+ from unittest import TestCase
2
+
3
+ from solax_py_library.device.types.device import DeviceType
4
+ from solax_py_library.smart_scene.core.condition import (
5
+ DateCondition,
6
+ BaseCondition,
7
+ CabinetCondition,
8
+ )
9
+ from solax_py_library.smart_scene.types.condition import (
10
+ CabinetConditionItemData,
11
+ CabinetConditionType,
12
+ ConditionItemChildData,
13
+ )
14
+ from solax_py_library.smart_scene.types.condition_value import CabinetValue
15
+
16
+
17
+ class TestCondition(TestCase):
18
+ def test_condition_build(self):
19
+ date_condition = DateCondition(
20
+ update_value_function=lambda: 1,
21
+ )
22
+ assert isinstance(date_condition, BaseCondition)
23
+
24
+ def test_cabinet_condition_to_text(self):
25
+ cabinet_condition = CabinetConditionItemData(
26
+ childType=CabinetConditionType.cabinetAlarm,
27
+ childData=ConditionItemChildData(
28
+ data=[DeviceType.IO_TYPE, DeviceType.COLD_TYPE, 1]
29
+ ),
30
+ )
31
+ print(cabinet_condition.to_text(lang="zh_CN", unit="嘻嘻"))
32
+
33
+ def test_cabinet_condition_check(self):
34
+ cabinet_condition = CabinetCondition(
35
+ update_value_function=lambda: {
36
+ "SN1": CabinetValue(
37
+ soc=0,
38
+ io_alarm=[False, True, False],
39
+ ),
40
+ },
41
+ )
42
+ cabinet_condition.update_value()
43
+ assert (
44
+ cabinet_condition.meet_func(
45
+ data=CabinetConditionItemData(
46
+ childType=CabinetConditionType.cabinetAlarm,
47
+ childData=ConditionItemChildData(
48
+ data=[DeviceType.IO_TYPE, DeviceType.COLD_TYPE, 1]
49
+ ),
50
+ ),
51
+ ctx={"cabinet": ["SN1"]},
52
+ )
53
+ is False
54
+ )
55
+ assert (
56
+ cabinet_condition.meet_func(
57
+ data=CabinetConditionItemData(
58
+ childType=CabinetConditionType.cabinetAlarm,
59
+ childData=ConditionItemChildData(
60
+ data=[DeviceType.IO_TYPE, DeviceType.COLD_TYPE, 2]
61
+ ),
62
+ ),
63
+ ctx={"cabinet": ["SN1"]},
64
+ )
65
+ is True
66
+ )
@@ -1,11 +0,0 @@
1
- from unittest import TestCase
2
-
3
- from solax_py_library.smart_scene.core.condition import DateCondition, BaseCondition
4
-
5
-
6
- class TestCondition(TestCase):
7
- def test_condition(self):
8
- date_condition = DateCondition(
9
- update_value_function=lambda: 1,
10
- )
11
- assert isinstance(date_condition, BaseCondition)