|
1 | 1 | from typing import Any |
2 | 2 | from pydantic import BaseModel |
3 | | -from mcsmapi.models.instance import InstanceCreateResult |
4 | | -from mcsmapi.models.common import ProcessInfo, InstanceInfo, CpuMemChart |
| 3 | +from mcsmapi.models.instance import InstanceCreateResult, InstanceDetail |
| 4 | +from mcsmapi.models.common import ProcessInfo, InstanceStat, CpuMemChart |
5 | 5 |
|
6 | 6 |
|
7 | | -class DaemonSystemInfo(BaseModel): |
| 7 | +class SystemInfo(BaseModel): |
8 | 8 | """节点系统信息""" |
9 | 9 |
|
10 | 10 | type: str |
@@ -35,31 +35,44 @@ class DaemonSystemInfo(BaseModel): |
35 | 35 | """未知""" |
36 | 36 |
|
37 | 37 |
|
38 | | -class DaemonModel(BaseModel): |
39 | | - """节点详细信息""" |
| 38 | +class DaemonSetting(BaseModel): |
| 39 | + """节点系统配置信息""" |
| 40 | + |
| 41 | + language: str |
| 42 | + """节点语言""" |
| 43 | + uploadSpeedRate: int |
| 44 | + """上传速度限制(0为不限制, 限制为(n * 64)KB/s)""" |
| 45 | + downloadSpeedRate: int |
| 46 | + """下载速度限制(0为不限制, 限制为(n * 64)KB/s)""" |
| 47 | + portRangeStart: int |
| 48 | + """端口范围起始值""" |
| 49 | + portRangeEnd: int |
| 50 | + """端口范围结束值""" |
| 51 | + portAssignInterval: int |
| 52 | + """未知""" |
| 53 | + port: int |
| 54 | + """节点监听端口""" |
| 55 | + |
| 56 | + |
| 57 | +class DaemonSystemInfo(BaseModel): |
| 58 | + """节点系统信息""" |
40 | 59 |
|
41 | | - version: str |
| 60 | + version: str | None = None |
42 | 61 | """远程节点版本""" |
43 | | - process: ProcessInfo |
| 62 | + process: ProcessInfo | None = None |
44 | 63 | """远程节点的基本信息""" |
45 | | - instance: InstanceInfo |
| 64 | + instance: InstanceStat | None = None |
46 | 65 | """远程节点实例基本信息""" |
47 | | - system: DaemonSystemInfo |
| 66 | + system: SystemInfo | None = None |
48 | 67 | """远程节点系统信息""" |
49 | | - cpuMemChart: list[CpuMemChart] |
| 68 | + cpuMemChart: list[CpuMemChart] | None = None |
50 | 69 | """cpu和内存使用趋势""" |
| 70 | + config: DaemonSetting |
| 71 | + |
| 72 | + |
| 73 | +class DaemonOperation(BaseModel): |
51 | 74 | uuid: str |
52 | | - """远程节点的uuid""" |
53 | | - ip: str |
54 | | - """远程节点的ip""" |
55 | | - port: int |
56 | | - """远程节点的端口""" |
57 | | - prefix: str |
58 | | - """远程节点的路径前缀""" |
59 | | - available: bool |
60 | | - """远程节点的可用状态""" |
61 | | - remarks: str |
62 | | - """远程节点的名称""" |
| 75 | + """节点UUID""" |
63 | 76 |
|
64 | 77 | def delete(self): |
65 | 78 | """ |
@@ -93,14 +106,8 @@ def updateConfig(self, config: dict[str, Any]) -> bool: |
93 | 106 |
|
94 | 107 | updated_config = self.model_dump() |
95 | 108 | updated_config.update(config) |
96 | | - # 过滤节点配置中不需要的字段 |
97 | | - daemon_config_dict = { |
98 | | - key: updated_config[key] |
99 | | - for key in DaemonConfig.model_fields.keys() |
100 | | - if key in updated_config |
101 | | - } |
102 | 109 |
|
103 | | - daemon_config = DaemonConfig(**daemon_config_dict).model_dump() |
| 110 | + daemon_config = DaemonUpdateConfig(**updated_config).model_dump() |
104 | 111 |
|
105 | 112 | return Daemon.update(self.uuid, daemon_config) |
106 | 113 |
|
@@ -142,5 +149,29 @@ class DaemonConfig(BaseModel): |
142 | 149 | """远程节点的路径前缀""" |
143 | 150 | remarks: str = "Unnamed Node" |
144 | 151 | """远程节点的备注""" |
145 | | - available: bool = True |
146 | | - """远程节点的可用状态""" |
| 152 | + apiKey: str = "" |
| 153 | + """远程节点的apiKey""" |
| 154 | + |
| 155 | + |
| 156 | +class DaemonStatus(DaemonOperation): |
| 157 | + """节点状态信息""" |
| 158 | + ip: str = "localhost" |
| 159 | + """远程节点的ip""" |
| 160 | + port: int = 24444 |
| 161 | + """远程节点的端口""" |
| 162 | + prefix: str = "" |
| 163 | + """远程节点的路径前缀""" |
| 164 | + remarks: str = "Unnamed Node" |
| 165 | + """远程节点的备注""" |
| 166 | + available: bool |
| 167 | + """节点可用状态""" |
| 168 | + |
| 169 | + |
| 170 | +class DaemonInfo(DaemonStatus): |
| 171 | + """节点信息""" |
| 172 | + instances: list[InstanceDetail] |
| 173 | + |
| 174 | + |
| 175 | +class DaemonUpdateConfig(DaemonConfig): |
| 176 | + """节点更新配置信息""" |
| 177 | + setting: DaemonSetting |
0 commit comments