mcsmapi 0.1.7__py3-none-any.whl → 0.1.8b1__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.
- mcsmapi/apis/daemon.py +21 -28
- mcsmapi/apis/file.py +88 -113
- mcsmapi/apis/image.py +18 -24
- mcsmapi/apis/instance.py +87 -116
- mcsmapi/apis/overview.py +1 -1
- mcsmapi/apis/user.py +30 -34
- mcsmapi/models/common.py +5 -5
- mcsmapi/models/daemon.py +21 -29
- mcsmapi/models/file.py +48 -43
- mcsmapi/models/image.py +17 -11
- mcsmapi/models/instance.py +71 -65
- mcsmapi/models/overview.py +72 -39
- mcsmapi/models/user.py +67 -51
- {mcsmapi-0.1.7.dist-info → mcsmapi-0.1.8b1.dist-info}/METADATA +4 -3
- mcsmapi-0.1.8b1.dist-info/RECORD +24 -0
- mcsmapi-0.1.7.dist-info/RECORD +0 -24
- {mcsmapi-0.1.7.dist-info → mcsmapi-0.1.8b1.dist-info}/WHEEL +0 -0
- {mcsmapi-0.1.7.dist-info → mcsmapi-0.1.8b1.dist-info}/licenses/LICENSE +0 -0
- {mcsmapi-0.1.7.dist-info → mcsmapi-0.1.8b1.dist-info}/top_level.txt +0 -0
mcsmapi/apis/daemon.py
CHANGED
@@ -10,8 +10,7 @@ class Daemon:
|
|
10
10
|
"""
|
11
11
|
获取全部节点配置信息
|
12
12
|
|
13
|
-
|
14
|
-
- List[DaemonConfig]: 节点的配置信息列表
|
13
|
+
:returns: 节点的配置信息列表
|
15
14
|
"""
|
16
15
|
daemons = send(
|
17
16
|
"GET",
|
@@ -24,8 +23,7 @@ class Daemon:
|
|
24
23
|
"""
|
25
24
|
获取全部节点的系统信息
|
26
25
|
|
27
|
-
|
28
|
-
- List[DaemonModel]: 节点系统信息列表
|
26
|
+
:returns: 节点系统信息列表
|
29
27
|
"""
|
30
28
|
daemons = send(
|
31
29
|
"GET",
|
@@ -36,64 +34,59 @@ class Daemon:
|
|
36
34
|
@staticmethod
|
37
35
|
def add(config: dict[str, Any]) -> str:
|
38
36
|
"""
|
39
|
-
|
37
|
+
新增一个节点
|
40
38
|
|
41
|
-
|
42
|
-
- config (dict): 节点的配置信息,以字典形式提供,缺失内容由DaemonConfig模型补全。
|
39
|
+
:params config: 节点的配置信息,以字典形式提供,缺失内容由DaemonConfig模型补全
|
43
40
|
|
44
|
-
|
45
|
-
- str: 新增节点的ID
|
41
|
+
:returns: 新增节点的UUID
|
46
42
|
"""
|
47
43
|
return send(
|
48
44
|
"POST",
|
49
45
|
f"{ApiPool.SERVICE}/remote_service",
|
50
|
-
data=DaemonConfig(**config).
|
46
|
+
data=DaemonConfig(**config).model_dump(),
|
51
47
|
)
|
48
|
+
|
52
49
|
@staticmethod
|
53
50
|
def delete(daemonId: str) -> bool:
|
54
51
|
"""
|
55
|
-
|
52
|
+
删除一个节点
|
56
53
|
|
57
|
-
|
58
|
-
- daemonId (str): 节点的唯一标识符。
|
54
|
+
:params daemonId: 节点的UUID
|
59
55
|
|
60
|
-
|
61
|
-
- bool: 删除成功后返回True
|
56
|
+
:returns: 删除成功后返回True
|
62
57
|
"""
|
63
58
|
return send(
|
64
59
|
"DELETE", f"{ApiPool.SERVICE}/remote_service", params={"uuid": daemonId}
|
65
60
|
)
|
61
|
+
|
66
62
|
@staticmethod
|
67
63
|
def link(daemonId: str) -> bool:
|
68
64
|
"""
|
69
|
-
|
65
|
+
连接一个节点
|
70
66
|
|
71
|
-
|
72
|
-
- daemonId (str): 节点的唯一标识符。
|
67
|
+
:params daemonId: 节点的UUID
|
73
68
|
|
74
|
-
|
75
|
-
- bool: 连接成功后返回True
|
69
|
+
:returns: 连接成功后返回True
|
76
70
|
"""
|
77
71
|
return send(
|
78
72
|
"GET", f"{ApiPool.SERVICE}/link_remote_service", params={"uuid": daemonId}
|
79
73
|
)
|
74
|
+
|
80
75
|
@staticmethod
|
81
76
|
def update(daemonId: str, config: dict[str, Any]) -> bool:
|
82
77
|
"""
|
83
|
-
|
78
|
+
更新一个节点的配置
|
84
79
|
|
85
|
-
**不建议直接使用此函数,建议调用overview()后在remote
|
80
|
+
**不建议直接使用此函数,建议调用overview()后在remote属性内使用节点对象的updateConfig方法按需更新**
|
86
81
|
|
87
|
-
|
88
|
-
|
89
|
-
- config (dict): 节点的配置信息,以字典形式提供,缺失内容由DaemonConfig模型补全。
|
82
|
+
:params daemonId: 节点的UUID
|
83
|
+
:params config: 节点的配置信息,以字典形式提供,缺失内容由DaemonConfig模型补全
|
90
84
|
|
91
|
-
|
92
|
-
- bool: 更新成功后返回True
|
85
|
+
:returns: 更新成功后返回True
|
93
86
|
"""
|
94
87
|
return send(
|
95
88
|
"PUT",
|
96
89
|
f"{ApiPool.SERVICE}/remote_service",
|
97
90
|
params={"uuid": daemonId},
|
98
|
-
data=DaemonConfig(**config).
|
91
|
+
data=DaemonConfig(**config).model_dump(),
|
99
92
|
)
|
mcsmapi/apis/file.py
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
from typing import Literal
|
1
2
|
from mcsmapi.pool import ApiPool
|
2
3
|
from mcsmapi.request import Request, send, upload
|
3
4
|
from mcsmapi.models.file import FileDownloadConfig, FileList
|
@@ -18,16 +19,14 @@ class File:
|
|
18
19
|
"""
|
19
20
|
获取文件列表
|
20
21
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
- file_name (str, 可选): 用于在文件列表中过滤出名称包含指定字符串的文件或文件夹
|
22
|
+
:params daemonId: 节点的UUID
|
23
|
+
:params uuid: 实例的UUID
|
24
|
+
:params target: 用于文件过滤的目标路径
|
25
|
+
:params page: 指定分页的页码
|
26
|
+
:params page_size: 指定每页的文件数量
|
27
|
+
:params file_name: 用于在文件列表中过滤出名称包含指定字符串的文件或文件夹
|
28
28
|
|
29
|
-
|
30
|
-
- FileList: 包含文件列表信息和分页详情的FileList模型。
|
29
|
+
:returns: 包含文件列表信息和分页详情的FileList模型
|
31
30
|
"""
|
32
31
|
result = send(
|
33
32
|
"GET",
|
@@ -44,17 +43,15 @@ class File:
|
|
44
43
|
return FileList(**result, daemonId=daemonId, uuid=uuid)
|
45
44
|
|
46
45
|
@staticmethod
|
47
|
-
def content(daemonId: str, uuid: str, target: str) -> str
|
46
|
+
def content(daemonId: str, uuid: str, target: str) -> str:
|
48
47
|
"""
|
49
48
|
获取文件内容
|
50
49
|
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
- target (str): 文件的目标路径。
|
50
|
+
:params daemonId: 节点的UUID
|
51
|
+
:params uuid: 实例的UUID
|
52
|
+
:params target: 文件的目标路径
|
55
53
|
|
56
|
-
|
57
|
-
- str: 文件的内容信息。
|
54
|
+
:returns: 文件的内容信息
|
58
55
|
"""
|
59
56
|
return send(
|
60
57
|
"PUT",
|
@@ -68,14 +65,12 @@ class File:
|
|
68
65
|
"""
|
69
66
|
更新文件内容
|
70
67
|
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
- text (str): 新的文件内容。
|
68
|
+
:params daemonId: 节点的UUID
|
69
|
+
:params uuid: 实例的UUID
|
70
|
+
:params target: 目标文件的路径
|
71
|
+
:params text: 新的文件内容
|
76
72
|
|
77
|
-
|
78
|
-
- bool: 更新成功后返回True。
|
73
|
+
:returns: 更新成功后返回True
|
79
74
|
"""
|
80
75
|
return send(
|
81
76
|
"PUT",
|
@@ -89,13 +84,11 @@ class File:
|
|
89
84
|
"""
|
90
85
|
下载文件
|
91
86
|
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
- file_name (str): 要下载的文件名。路径+名字, 示例: /backup/world.zip
|
87
|
+
:params daemonId: 节点的UUID
|
88
|
+
:params uuid: 实例的UUID
|
89
|
+
:params file_name: 要下载的文件的实例内完整路径, eg: /backup/world.zip
|
96
90
|
|
97
|
-
|
98
|
-
- str: 文件下载URL。
|
91
|
+
:returns: 文件下载URL
|
99
92
|
"""
|
100
93
|
|
101
94
|
result = send(
|
@@ -113,14 +106,12 @@ class File:
|
|
113
106
|
"""
|
114
107
|
上传文件
|
115
108
|
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
- upload_dir (str): 文件上传到的目标路径。
|
109
|
+
:params daemonId: 节点的UUID
|
110
|
+
:params uuid: 实例的UUID
|
111
|
+
:params file: 要上传的文件内容
|
112
|
+
:params upload_dir: 文件上传到的目标路径
|
121
113
|
|
122
|
-
|
123
|
-
- bool: 上传成功后返回True。
|
114
|
+
:returns: 上传成功后返回True
|
124
115
|
"""
|
125
116
|
result = send(
|
126
117
|
"POST",
|
@@ -137,15 +128,13 @@ class File:
|
|
137
128
|
@staticmethod
|
138
129
|
def copy(daemonId: str, uuid: str, copy_map: dict[str, str]) -> bool:
|
139
130
|
"""
|
140
|
-
|
131
|
+
复制多个文件夹或文件到指定位置
|
141
132
|
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
- copy_map (dict): 复制映射,格式为 {源路径: 目标路径}
|
133
|
+
:params daemonId: 节点的UUID
|
134
|
+
:params uuid: 实例的UUID
|
135
|
+
:params copy_map: 复制映射,格式为 {源路径: 目标路径}
|
146
136
|
|
147
|
-
|
148
|
-
- bool: 上传成功后返回True。
|
137
|
+
:returns: 复制成功后返回True
|
149
138
|
"""
|
150
139
|
targets = [[source, target] for source, target in copy_map.items()]
|
151
140
|
return send(
|
@@ -158,31 +147,27 @@ class File:
|
|
158
147
|
@staticmethod
|
159
148
|
def copyOne(daemonId: str, uuid: str, source: str, target: str) -> bool:
|
160
149
|
"""
|
161
|
-
|
150
|
+
复制单个文件或文件夹到指定位置
|
162
151
|
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
- target (str): 目标文件或文件夹的路径。
|
152
|
+
:params daemonId: 节点的UUID
|
153
|
+
:params uuid: 实例的UUID
|
154
|
+
:params source: 源文件或文件夹的路径
|
155
|
+
:params target: 目标文件或文件夹的路径
|
168
156
|
|
169
|
-
|
170
|
-
- bool: 移动成功后返回True。
|
157
|
+
:return: 移动成功后返回True
|
171
158
|
"""
|
172
159
|
return File.copy(daemonId, uuid, {source: target})
|
173
160
|
|
174
161
|
@staticmethod
|
175
162
|
def move(daemonId: str, uuid: str, copy_map: dict[str, str]) -> bool:
|
176
163
|
"""
|
177
|
-
|
164
|
+
移动多个文件或文件夹到指定位置
|
178
165
|
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
- copy_map (dict): 移动映射,格式为 {源路径: 目标路径}
|
166
|
+
:params daemonId: 节点的UUID
|
167
|
+
:params uuid: 实例的UUID
|
168
|
+
:params copy_map: 移动映射,格式为 {源路径: 目标路径}
|
183
169
|
|
184
|
-
|
185
|
-
- bool: 移动成功后返回True。
|
170
|
+
:returns: 移动成功后返回True
|
186
171
|
"""
|
187
172
|
targets = [[source, target] for source, target in copy_map.items()]
|
188
173
|
return send(
|
@@ -195,32 +180,28 @@ class File:
|
|
195
180
|
@staticmethod
|
196
181
|
def moveOne(daemonId: str, uuid: str, source: str, target: str) -> bool:
|
197
182
|
"""
|
198
|
-
|
183
|
+
从源路径移动单个文件或文件夹到目标路径
|
199
184
|
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
- target (str): 目标文件或文件夹的路径。
|
185
|
+
:params daemonId: 节点的UUID
|
186
|
+
:params uuid: 实例的UUID
|
187
|
+
:params source: 源文件或文件夹的路径
|
188
|
+
:params target: 目标文件或文件夹的路径
|
205
189
|
|
206
|
-
|
207
|
-
- bool: 移动成功后返回True。
|
190
|
+
:returns: 移动成功后返回True
|
208
191
|
"""
|
209
192
|
return File.move(daemonId, uuid, {source: target})
|
210
193
|
|
211
194
|
@staticmethod
|
212
195
|
def rename(daemonId: str, uuid: str, source: str, new_name: str) -> bool:
|
213
196
|
"""
|
214
|
-
|
197
|
+
重命名单个文件或文件夹
|
215
198
|
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
- new_name (str): 源文件或文件夹的新名字。
|
199
|
+
:params daemonId: 节点的UUID
|
200
|
+
:params uuid: 实例的UUID
|
201
|
+
:params source: 源文件或文件夹的路径
|
202
|
+
:params new_name: 源文件或文件夹的新名字
|
221
203
|
|
222
|
-
|
223
|
-
- bool: 重命名成功后返回True。
|
204
|
+
:returns: 重命名成功后返回True
|
224
205
|
"""
|
225
206
|
directory = os.path.dirname(source)
|
226
207
|
target = os.path.join(directory, new_name)
|
@@ -229,16 +210,15 @@ class File:
|
|
229
210
|
@staticmethod
|
230
211
|
def zip(daemonId: str, uuid: str, source: str, targets: list[str]) -> bool:
|
231
212
|
"""
|
232
|
-
|
213
|
+
压缩多个文件或文件夹到指定位置
|
233
214
|
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
- targets (list): 要压缩到的目标文件的路径。
|
215
|
+
:params daemonId: 节点的UUID
|
216
|
+
:params uuid: 实例的UUID
|
217
|
+
:params source: 要压缩到的目标文件的路径
|
218
|
+
:params targets: 需要压缩的文件路径
|
239
219
|
|
240
220
|
**返回:**
|
241
|
-
- bool: 压缩成功后返回True
|
221
|
+
- bool: 压缩成功后返回True
|
242
222
|
"""
|
243
223
|
return send(
|
244
224
|
"POST",
|
@@ -249,41 +229,40 @@ class File:
|
|
249
229
|
|
250
230
|
@staticmethod
|
251
231
|
def unzip(
|
252
|
-
daemonId: str,
|
232
|
+
daemonId: str,
|
233
|
+
uuid: str,
|
234
|
+
source: str,
|
235
|
+
targets: str,
|
236
|
+
code: Literal["utf-8", "gbk", "big5"] = "utf-8",
|
253
237
|
) -> bool:
|
254
238
|
"""
|
255
|
-
解压缩指定的zip
|
239
|
+
解压缩指定的zip文件到目标位置
|
256
240
|
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
- code (str, optional): 压缩文件的编码方式,默认为"utf-8"。
|
263
|
-
可选值: utf-8, gbk, big5
|
241
|
+
:params daemonId: 节点的UUID
|
242
|
+
:params uuid: 实例的UUID
|
243
|
+
:params source: 需要解压的zip文件路径
|
244
|
+
:params targets: 解压到的目标路径
|
245
|
+
:params code: 压缩文件的编码方式
|
264
246
|
|
265
|
-
|
266
|
-
- bool: 解压成功后返回True。
|
247
|
+
:returns: 解压成功后返回True
|
267
248
|
"""
|
268
249
|
return send(
|
269
250
|
"POST",
|
270
251
|
f"{ApiPool.FILE}/compress",
|
271
252
|
params={"daemonId": daemonId, "uuid": uuid},
|
272
|
-
data={"type": 2, "code": code, "source": source, "targets":
|
253
|
+
data={"type": 2, "code": code, "source": source, "targets": targets},
|
273
254
|
)
|
274
255
|
|
275
256
|
@staticmethod
|
276
257
|
def delete(daemonId: str, uuid: str, targets: list[str]) -> bool:
|
277
258
|
"""
|
278
|
-
|
259
|
+
删除多个文件或文件夹
|
279
260
|
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
- targets (list): 要删除的文件或文件夹的路径。
|
261
|
+
:params daemonId: 节点的UUID
|
262
|
+
:params uuid: 实例的UUID
|
263
|
+
:params targets: 要删除的文件或文件夹的路径
|
284
264
|
|
285
|
-
|
286
|
-
- bool: 删除成功后返回True。
|
265
|
+
:returns: 删除成功后返回True
|
287
266
|
"""
|
288
267
|
return send(
|
289
268
|
"DELETE",
|
@@ -295,15 +274,13 @@ class File:
|
|
295
274
|
@staticmethod
|
296
275
|
def createFile(daemonId: str, uuid: str, target: str) -> bool:
|
297
276
|
"""
|
298
|
-
|
277
|
+
创建文件
|
299
278
|
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
- target (str): 目标文件的路径,包含文件名。
|
279
|
+
:params daemonId: 节点的UUID
|
280
|
+
:params uuid: 实例的UUID
|
281
|
+
:params target: 目标文件的路径,包含文件名
|
304
282
|
|
305
|
-
|
306
|
-
- bool: 创建成功后返回True。
|
283
|
+
:returns: 创建成功后返回True
|
307
284
|
"""
|
308
285
|
return send(
|
309
286
|
"POST",
|
@@ -317,13 +294,11 @@ class File:
|
|
317
294
|
"""
|
318
295
|
创建文件夹
|
319
296
|
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
- target (str): 目标文件夹的路径。
|
297
|
+
:params daemonId: 节点的UUID
|
298
|
+
:params uuid: 实例的UUID
|
299
|
+
:params target: 目标文件夹的路径
|
324
300
|
|
325
|
-
|
326
|
-
- bool: 创建成功后返回True。
|
301
|
+
:returns: 创建成功后返回True
|
327
302
|
"""
|
328
303
|
return send(
|
329
304
|
"POST",
|
mcsmapi/apis/image.py
CHANGED
@@ -9,11 +9,9 @@ class Image:
|
|
9
9
|
"""
|
10
10
|
获取镜像列表
|
11
11
|
|
12
|
-
|
13
|
-
- daemonId (str): 守护进程的唯一标识符。
|
12
|
+
:params daemonId: 节点的UUID
|
14
13
|
|
15
|
-
|
16
|
-
- list[ImageModel]: 包含镜像列表详情的 ImageModel 模型的列表。
|
14
|
+
:returns: 包含镜像列表详情的 ImageModel 模型的列表
|
17
15
|
"""
|
18
16
|
result = send(
|
19
17
|
"GET",
|
@@ -30,11 +28,9 @@ class Image:
|
|
30
28
|
"""
|
31
29
|
获取容器列表
|
32
30
|
|
33
|
-
|
34
|
-
- daemonId (str): 守护进程的唯一标识符。
|
31
|
+
:params daemonId: 节点的UUID
|
35
32
|
|
36
|
-
|
37
|
-
- list[DockerContainerItem]: 包含容器列表详情的 DockerContainerItem 模型的列表。
|
33
|
+
:params: 包含容器列表详情的 DockerContainerItem 模型的列表
|
38
34
|
"""
|
39
35
|
result = send(
|
40
36
|
"GET",
|
@@ -51,11 +47,9 @@ class Image:
|
|
51
47
|
"""
|
52
48
|
获取网络接口列表
|
53
49
|
|
54
|
-
|
55
|
-
- daemonId (str): 守护进程的唯一标识符。
|
50
|
+
:params daemonId: 节点的UUID
|
56
51
|
|
57
|
-
|
58
|
-
- list[DockerNetworkItem]: 包含网络接口列表详情的 DockerNetworkItem 模型的列表。
|
52
|
+
:returns: 包含网络接口列表详情的 DockerNetworkItem 模型的列表
|
59
53
|
"""
|
60
54
|
result = send(
|
61
55
|
"GET",
|
@@ -71,14 +65,12 @@ class Image:
|
|
71
65
|
"""
|
72
66
|
新增一个镜像
|
73
67
|
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
- tag (str): 镜像版本。
|
68
|
+
:params daemonId: 节点的UUID
|
69
|
+
:params dockerFile: DockerFile Config 内容
|
70
|
+
:params name: 镜像名称
|
71
|
+
:params tag: 镜像版本
|
79
72
|
|
80
|
-
|
81
|
-
- bool: 新增镜像成功后返回True。
|
73
|
+
:returns: 新增镜像成功后返回True
|
82
74
|
"""
|
83
75
|
return send(
|
84
76
|
"POST",
|
@@ -92,13 +84,15 @@ class Image:
|
|
92
84
|
"""
|
93
85
|
获取镜像构建进度
|
94
86
|
|
95
|
-
|
87
|
+
:params daemonId: 节点的UUID
|
96
88
|
|
97
|
-
|
98
|
-
- daemonId (str): 守护进程的唯一标识符。
|
89
|
+
:returns: {容器名称: 当前状态}
|
99
90
|
|
100
|
-
|
101
|
-
|
91
|
+
状态码对照:
|
92
|
+
```
|
93
|
+
-1: 镜像构建失败
|
94
|
+
1: 镜像构建中
|
95
|
+
2: 镜像构建完成
|
102
96
|
"""
|
103
97
|
return send(
|
104
98
|
"GET",
|