alibaba-cloud-ops-mcp-server 0.9.0__py3-none-any.whl → 0.9.2__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.
- alibaba_cloud_ops_mcp_server/alibabacloud/utils.py +39 -2
- alibaba_cloud_ops_mcp_server/config.py +1 -1
- alibaba_cloud_ops_mcp_server/server.py +5 -5
- alibaba_cloud_ops_mcp_server/tools/api_tools.py +25 -3
- alibaba_cloud_ops_mcp_server/tools/cms_tools.py +9 -9
- alibaba_cloud_ops_mcp_server/tools/oos_tools.py +24 -24
- alibaba_cloud_ops_mcp_server/tools/oss_tools.py +15 -8
- {alibaba_cloud_ops_mcp_server-0.9.0.dist-info → alibaba_cloud_ops_mcp_server-0.9.2.dist-info}/METADATA +2 -2
- alibaba_cloud_ops_mcp_server-0.9.2.dist-info/RECORD +20 -0
- alibaba_cloud_ops_mcp_server-0.9.0.dist-info/RECORD +0 -20
- {alibaba_cloud_ops_mcp_server-0.9.0.dist-info → alibaba_cloud_ops_mcp_server-0.9.2.dist-info}/WHEEL +0 -0
- {alibaba_cloud_ops_mcp_server-0.9.0.dist-info → alibaba_cloud_ops_mcp_server-0.9.2.dist-info}/entry_points.txt +0 -0
- {alibaba_cloud_ops_mcp_server-0.9.0.dist-info → alibaba_cloud_ops_mcp_server-0.9.2.dist-info}/licenses/LICENSE +0 -0
|
@@ -1,9 +1,46 @@
|
|
|
1
|
+
import logging
|
|
2
|
+
|
|
1
3
|
from alibabacloud_credentials.client import Client as CredClient
|
|
2
4
|
from alibabacloud_tea_openapi.models import Config
|
|
5
|
+
from fastmcp.server.dependencies import get_http_request
|
|
6
|
+
|
|
7
|
+
logger = logging.getLogger(__name__)
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
def get_credentials_from_header():
|
|
11
|
+
credentials = None
|
|
12
|
+
try:
|
|
13
|
+
request = get_http_request()
|
|
14
|
+
headers = request.headers
|
|
15
|
+
access_key_id = headers.get('x-acs-accesskey-id', None)
|
|
16
|
+
access_key_secret = headers.get('x-acs-accesskey-secret', None)
|
|
17
|
+
token = headers.get('x-acs-security-token', None)
|
|
18
|
+
|
|
19
|
+
if access_key_id:
|
|
20
|
+
credentials = {
|
|
21
|
+
'AccessKeyId': access_key_id,
|
|
22
|
+
'AccessKeySecret': access_key_secret,
|
|
23
|
+
'SecurityToken': token
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
except Exception as e:
|
|
27
|
+
logger.info(f'get_credentials_from_header error: {e}')
|
|
28
|
+
return credentials
|
|
3
29
|
|
|
4
30
|
|
|
5
31
|
def create_config():
|
|
6
|
-
|
|
7
|
-
|
|
32
|
+
credentials = get_credentials_from_header()
|
|
33
|
+
if credentials:
|
|
34
|
+
access_key_id = credentials.get('AccessKeyId', None)
|
|
35
|
+
access_key_secret = credentials.get('AccessKeySecret', None)
|
|
36
|
+
token = credentials.get('SecurityToken', None)
|
|
37
|
+
config = Config(
|
|
38
|
+
access_key_id=access_key_id,
|
|
39
|
+
access_key_secret=access_key_secret,
|
|
40
|
+
security_token=token
|
|
41
|
+
)
|
|
42
|
+
else:
|
|
43
|
+
credentialsClient = CredClient()
|
|
44
|
+
config = Config(credential=credentialsClient)
|
|
8
45
|
config.user_agent = 'alibaba-cloud-ops-mcp-server'
|
|
9
46
|
return config
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
from
|
|
1
|
+
from fastmcp import FastMCP
|
|
2
2
|
import click
|
|
3
3
|
import logging
|
|
4
4
|
|
|
@@ -60,13 +60,13 @@ def main(transport: str, port: int, host: str, services: str):
|
|
|
60
60
|
service_list = [(key, SUPPORTED_SERVICES_MAP.get(key, key)) for key in service_keys]
|
|
61
61
|
set_custom_service_list(service_list)
|
|
62
62
|
for tool in common_api_tools.tools:
|
|
63
|
-
mcp.
|
|
63
|
+
mcp.tool(tool)
|
|
64
64
|
for tool in oos_tools.tools:
|
|
65
|
-
mcp.
|
|
65
|
+
mcp.tool(tool)
|
|
66
66
|
for tool in cms_tools.tools:
|
|
67
|
-
mcp.
|
|
67
|
+
mcp.tool(tool)
|
|
68
68
|
for tool in oss_tools.tools:
|
|
69
|
-
mcp.
|
|
69
|
+
mcp.tool(tool)
|
|
70
70
|
api_tools.create_api_tools(mcp, config)
|
|
71
71
|
|
|
72
72
|
# Initialize and run the server
|
|
@@ -110,24 +110,37 @@ def _create_function_schemas(service, api, api_meta):
|
|
|
110
110
|
schemas = {}
|
|
111
111
|
schemas[api] = {}
|
|
112
112
|
parameters = api_meta.get('parameters', [])
|
|
113
|
+
|
|
114
|
+
required_params = []
|
|
115
|
+
optional_params = []
|
|
116
|
+
|
|
113
117
|
for parameter in parameters:
|
|
114
118
|
name = parameter.get('name')
|
|
115
119
|
# TODO 目前忽略了带'.'的参数
|
|
116
120
|
if '.' in name:
|
|
117
121
|
continue
|
|
118
122
|
schema = parameter.get('schema', '')
|
|
123
|
+
required = schema.get('required', False)
|
|
124
|
+
|
|
125
|
+
if required:
|
|
126
|
+
required_params.append(parameter)
|
|
127
|
+
else:
|
|
128
|
+
optional_params.append(parameter)
|
|
129
|
+
|
|
130
|
+
def process_parameter(parameter):
|
|
131
|
+
name = parameter.get('name')
|
|
132
|
+
schema = parameter.get('schema', '')
|
|
119
133
|
description = schema.get('description', '')
|
|
120
134
|
example = schema.get('example', '')
|
|
121
135
|
type_ = schema.get('type', '')
|
|
122
136
|
description = f'{description} 参数类型: {type_},参数示例:{example}'
|
|
123
137
|
required = schema.get('required', False)
|
|
124
|
-
|
|
125
|
-
# 只有在service为ecs时,才对特定参数进行特殊处理
|
|
138
|
+
|
|
126
139
|
if service.lower() == 'ecs' and name in ECS_LIST_PARAMETERS and type_ == 'string':
|
|
127
140
|
python_type = list
|
|
128
141
|
else:
|
|
129
142
|
python_type = type_map.get(type_, str)
|
|
130
|
-
|
|
143
|
+
|
|
131
144
|
field_info = (
|
|
132
145
|
python_type,
|
|
133
146
|
field(
|
|
@@ -135,7 +148,16 @@ def _create_function_schemas(service, api, api_meta):
|
|
|
135
148
|
metadata={'description': description, 'required': required}
|
|
136
149
|
)
|
|
137
150
|
)
|
|
151
|
+
return name, field_info
|
|
152
|
+
|
|
153
|
+
for parameter in required_params:
|
|
154
|
+
name, field_info = process_parameter(parameter)
|
|
138
155
|
schemas[api][name] = field_info
|
|
156
|
+
|
|
157
|
+
for parameter in optional_params:
|
|
158
|
+
name, field_info = process_parameter(parameter)
|
|
159
|
+
schemas[api][name] = field_info
|
|
160
|
+
|
|
139
161
|
if 'RegionId' not in schemas[api]:
|
|
140
162
|
schemas[api]['RegionId'] = (
|
|
141
163
|
str,
|
|
@@ -37,8 +37,8 @@ def _get_cms_metric_data(region_id: str, instance_ids: List[str], metric_name: s
|
|
|
37
37
|
|
|
38
38
|
@tools.append
|
|
39
39
|
def CMS_GetCpuUsageData(
|
|
40
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
41
40
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
41
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
42
42
|
):
|
|
43
43
|
"""获取ECS实例的CPU使用率数据"""
|
|
44
44
|
return _get_cms_metric_data(RegionId, InstanceIds, 'cpu_total')
|
|
@@ -46,8 +46,8 @@ def CMS_GetCpuUsageData(
|
|
|
46
46
|
|
|
47
47
|
@tools.append
|
|
48
48
|
def CMS_GetCpuLoadavgData(
|
|
49
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
50
49
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
50
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
51
51
|
):
|
|
52
52
|
"""获取CPU一分钟平均负载指标数据"""
|
|
53
53
|
return _get_cms_metric_data(RegionId, InstanceIds, 'load_1m')
|
|
@@ -55,8 +55,8 @@ def CMS_GetCpuLoadavgData(
|
|
|
55
55
|
|
|
56
56
|
@tools.append
|
|
57
57
|
def CMS_GetCpuloadavg5mData(
|
|
58
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
59
58
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
59
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
60
60
|
):
|
|
61
61
|
"""获取CPU五分钟平均负载指标数据"""
|
|
62
62
|
return _get_cms_metric_data(RegionId, InstanceIds, 'load_5m')
|
|
@@ -64,16 +64,16 @@ def CMS_GetCpuloadavg5mData(
|
|
|
64
64
|
|
|
65
65
|
@tools.append
|
|
66
66
|
def CMS_GetCpuloadavg15mData(
|
|
67
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
68
67
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
68
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
69
69
|
):
|
|
70
70
|
"""获取CPU十五分钟平均负载指标数据"""
|
|
71
71
|
return _get_cms_metric_data(RegionId, InstanceIds, 'load_15m')
|
|
72
72
|
|
|
73
73
|
@tools.append
|
|
74
74
|
def CMS_GetMemUsedData(
|
|
75
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
76
75
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
76
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
77
77
|
):
|
|
78
78
|
"""获取内存使用量指标数据"""
|
|
79
79
|
return _get_cms_metric_data(RegionId, InstanceIds, 'memory_usedspace')
|
|
@@ -81,8 +81,8 @@ def CMS_GetMemUsedData(
|
|
|
81
81
|
|
|
82
82
|
@tools.append
|
|
83
83
|
def CMS_GetMemUsageData(
|
|
84
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
85
84
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
85
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
86
86
|
):
|
|
87
87
|
"""获取内存利用率指标数据"""
|
|
88
88
|
return _get_cms_metric_data(RegionId, InstanceIds, 'memory_usedutilization')
|
|
@@ -90,8 +90,8 @@ def CMS_GetMemUsageData(
|
|
|
90
90
|
|
|
91
91
|
@tools.append
|
|
92
92
|
def CMS_GetDiskUsageData(
|
|
93
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
94
93
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
94
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
95
95
|
):
|
|
96
96
|
"""获取磁盘利用率指标数据"""
|
|
97
97
|
return _get_cms_metric_data(RegionId, InstanceIds, 'diskusage_utilization')
|
|
@@ -99,8 +99,8 @@ def CMS_GetDiskUsageData(
|
|
|
99
99
|
|
|
100
100
|
@tools.append
|
|
101
101
|
def CMS_GetDiskTotalData(
|
|
102
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
103
102
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
103
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
104
104
|
):
|
|
105
105
|
"""获取磁盘分区总容量指标数据"""
|
|
106
106
|
return _get_cms_metric_data(RegionId, InstanceIds, 'diskusage_total')
|
|
@@ -108,8 +108,8 @@ def CMS_GetDiskTotalData(
|
|
|
108
108
|
|
|
109
109
|
@tools.append
|
|
110
110
|
def CMS_GetDiskUsedData(
|
|
111
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
112
111
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
112
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
113
113
|
):
|
|
114
114
|
"""获取磁盘分区使用量指标数据"""
|
|
115
115
|
return _get_cms_metric_data(RegionId, InstanceIds, 'diskusage_used')
|
|
@@ -47,10 +47,10 @@ def _start_execution_sync(region_id: str, template_name: str, parameters: dict):
|
|
|
47
47
|
time.sleep(1)
|
|
48
48
|
@tools.append
|
|
49
49
|
def OOS_RunCommand(
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
50
|
+
Command: str = Field(description='Content of the command executed on the ECS instance'),
|
|
51
|
+
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
52
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
53
|
+
CommandType: str = Field(description='The type of command executed on the ECS instance, optional value:RunShellScript,RunPythonScript,RunPerlScript,RunBatScript,RunPowerShellScript', default='RunShellScript')
|
|
54
54
|
):
|
|
55
55
|
"""批量在多台ECS实例上运行云助手命令,适用于需要同时管理多台ECS实例的场景,如应用程序管理和资源标记操作等。"""
|
|
56
56
|
|
|
@@ -74,8 +74,8 @@ def OOS_RunCommand(
|
|
|
74
74
|
|
|
75
75
|
@tools.append
|
|
76
76
|
def OOS_StartInstances(
|
|
77
|
-
|
|
78
|
-
|
|
77
|
+
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
78
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
79
79
|
):
|
|
80
80
|
"""批量启动ECS实例,适用于需要同时管理和启动多台ECS实例的场景,例如应用部署和高可用性场景。"""
|
|
81
81
|
|
|
@@ -93,9 +93,9 @@ def OOS_StartInstances(
|
|
|
93
93
|
|
|
94
94
|
@tools.append
|
|
95
95
|
def OOS_StopInstances(
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
96
|
+
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
97
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
98
|
+
ForeceStop: bool = Field(description='Is forced shutdown required', default=False)
|
|
99
99
|
):
|
|
100
100
|
"""批量停止ECS实例,适用于需要同时管理和停止多台ECS实例的场景。"""
|
|
101
101
|
|
|
@@ -114,9 +114,9 @@ def OOS_StopInstances(
|
|
|
114
114
|
|
|
115
115
|
@tools.append
|
|
116
116
|
def OOS_RebootInstances(
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
117
|
+
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
118
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
119
|
+
ForeceStop: bool = Field(description='Is forced shutdown required', default=False)
|
|
120
120
|
):
|
|
121
121
|
"""批量重启ECS实例,适用于需要同时管理和重启多台ECS实例的场景。"""
|
|
122
122
|
|
|
@@ -135,13 +135,13 @@ def OOS_RebootInstances(
|
|
|
135
135
|
|
|
136
136
|
@tools.append
|
|
137
137
|
def OOS_RunInstances(
|
|
138
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
139
138
|
ImageId: str = Field(description='Image ID'),
|
|
140
139
|
InstanceType: str = Field(description='Instance Type'),
|
|
141
140
|
SecurityGroupId: str = Field(description='SecurityGroup ID'),
|
|
142
141
|
VSwitchId: str = Field(description='VSwitch ID'),
|
|
142
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
143
143
|
Amount: int = Field(description='Number of ECS instances', default=1),
|
|
144
|
-
InstanceName: str = Field(description='Instance Name', default='')
|
|
144
|
+
InstanceName: str = Field(description='Instance Name', default='')
|
|
145
145
|
):
|
|
146
146
|
"""批量创建ECS实例,适用于需要同时创建多台ECS实例的场景,例如应用部署和高可用性场景。"""
|
|
147
147
|
|
|
@@ -158,9 +158,9 @@ def OOS_RunInstances(
|
|
|
158
158
|
|
|
159
159
|
@tools.append
|
|
160
160
|
def OOS_ResetPassword(
|
|
161
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
162
161
|
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
163
162
|
Password: str = Field(description='The password of the ECS instance must be 8-30 characters and must contain only the following characters: lowercase letters, uppercase letters, numbers, and special characters only.()~!@#$%^&*-_+=(40:<>,?/'),
|
|
163
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
164
164
|
):
|
|
165
165
|
"""批量修改ECS实例的密码,请注意,本操作将会重启ECS实例"""
|
|
166
166
|
parameters = {
|
|
@@ -177,9 +177,9 @@ def OOS_ResetPassword(
|
|
|
177
177
|
|
|
178
178
|
@tools.append
|
|
179
179
|
def OOS_ReplaceSystemDisk(
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
180
|
+
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
181
|
+
ImageId: str = Field(description='Image ID'),
|
|
182
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
183
183
|
):
|
|
184
184
|
"""批量替换ECS实例的系统盘,更换操作系统"""
|
|
185
185
|
parameters = {
|
|
@@ -197,8 +197,8 @@ def OOS_ReplaceSystemDisk(
|
|
|
197
197
|
|
|
198
198
|
@tools.append
|
|
199
199
|
def OOS_StartRDSInstances(
|
|
200
|
-
|
|
201
|
-
|
|
200
|
+
InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
|
|
201
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
202
202
|
):
|
|
203
203
|
"""批量启动RDS实例,适用于需要同时管理和启动多台RDS实例的场景,例如应用部署和高可用性场景。"""
|
|
204
204
|
|
|
@@ -216,8 +216,8 @@ def OOS_StartRDSInstances(
|
|
|
216
216
|
|
|
217
217
|
@tools.append
|
|
218
218
|
def OOS_StopRDSInstances(
|
|
219
|
-
|
|
220
|
-
|
|
219
|
+
InstanceIds: List[str] = Field(description='AlibabaCloud RDS instance ID List'),
|
|
220
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
221
221
|
):
|
|
222
222
|
"""批量停止RDS实例,适用于需要同时管理和停止多台RDS实例的场景。"""
|
|
223
223
|
|
|
@@ -235,8 +235,8 @@ def OOS_StopRDSInstances(
|
|
|
235
235
|
|
|
236
236
|
@tools.append
|
|
237
237
|
def OOS_RebootRDSInstances(
|
|
238
|
-
|
|
239
|
-
|
|
238
|
+
InstanceIds: List[str] = Field(description='AlibabaCloud RDS instance ID List'),
|
|
239
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
240
240
|
):
|
|
241
241
|
"""批量重启RDS实例,适用于需要同时管理和重启多台RDS实例的场景。"""
|
|
242
242
|
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
# oss_tools.py
|
|
2
2
|
import os
|
|
3
3
|
import alibabacloud_oss_v2 as oss
|
|
4
|
+
from alibaba_cloud_ops_mcp_server.alibabacloud.utils import get_credentials_from_header
|
|
4
5
|
|
|
5
6
|
from pydantic import Field
|
|
6
7
|
from alibabacloud_oss_v2 import Credentials
|
|
@@ -13,10 +14,16 @@ tools = []
|
|
|
13
14
|
|
|
14
15
|
class CredentialsProvider(EnvironmentVariableCredentialsProvider):
|
|
15
16
|
def __init__(self) -> None:
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
17
|
+
credentials = get_credentials_from_header()
|
|
18
|
+
if credentials:
|
|
19
|
+
access_key_id = credentials.get('AccessKeyId', None)
|
|
20
|
+
access_key_secret = credentials.get('AccessKeySecret', None)
|
|
21
|
+
session_token = credentials.get('SecurityToken', None)
|
|
22
|
+
else:
|
|
23
|
+
credentialsClient = CredClient()
|
|
24
|
+
access_key_id = credentialsClient.get_credential().access_key_id
|
|
25
|
+
access_key_secret = credentialsClient.get_credential().access_key_secret
|
|
26
|
+
session_token = credentialsClient.get_credential().security_token
|
|
20
27
|
|
|
21
28
|
self._credentials = Credentials(
|
|
22
29
|
access_key_id, access_key_secret, session_token)
|
|
@@ -51,8 +58,8 @@ def OSS_ListBuckets(
|
|
|
51
58
|
|
|
52
59
|
@tools.append
|
|
53
60
|
def OSS_ListObjects(
|
|
54
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
55
61
|
BucketName: str = Field(description='AlibabaCloud OSS Bucket Name'),
|
|
62
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
56
63
|
Prefix: str = Field(description='AlibabaCloud OSS Bucket Name prefix', default=None)
|
|
57
64
|
):
|
|
58
65
|
"""获取指定OSS存储空间中的所有文件信息。"""
|
|
@@ -72,8 +79,8 @@ def OSS_ListObjects(
|
|
|
72
79
|
|
|
73
80
|
@tools.append
|
|
74
81
|
def OSS_PutBucket(
|
|
75
|
-
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
76
82
|
BucketName: str = Field(description='AlibabaCloud OSS Bucket Name'),
|
|
83
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
|
|
77
84
|
StorageClass: str = Field(description='The Storage Type of AlibabaCloud OSS Bucket, The value range is as follows: '
|
|
78
85
|
'Standard (default): standard storage, '
|
|
79
86
|
'IA: infrequent access, Archive: archive storage, '
|
|
@@ -100,8 +107,8 @@ def OSS_PutBucket(
|
|
|
100
107
|
|
|
101
108
|
@tools.append
|
|
102
109
|
def OSS_DeleteBucket(
|
|
103
|
-
|
|
104
|
-
|
|
110
|
+
BucketName: str = Field(description='AlibabaCloud OSS Bucket Name'),
|
|
111
|
+
RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou')
|
|
105
112
|
):
|
|
106
113
|
"""删除指定的OSS存储空间。"""
|
|
107
114
|
client = create_client(region_id=RegionId)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: alibaba-cloud-ops-mcp-server
|
|
3
|
-
Version: 0.9.
|
|
3
|
+
Version: 0.9.2
|
|
4
4
|
Summary: A MCP server for Alibaba Cloud
|
|
5
5
|
Author-email: Zheng Dayu <dayu.zdy@alibaba-inc.com>
|
|
6
6
|
License-File: LICENSE
|
|
@@ -11,7 +11,7 @@ Requires-Dist: alibabacloud-ecs20140526>=6.1.0
|
|
|
11
11
|
Requires-Dist: alibabacloud-oos20190601>=3.4.1
|
|
12
12
|
Requires-Dist: alibabacloud-oss-v2>=1.1.0
|
|
13
13
|
Requires-Dist: click>=8.1.8
|
|
14
|
-
Requires-Dist:
|
|
14
|
+
Requires-Dist: fastmcp==2.8.0
|
|
15
15
|
Description-Content-Type: text/markdown
|
|
16
16
|
|
|
17
17
|
# Alibaba Cloud Ops MCP Server
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
alibaba_cloud_ops_mcp_server/__init__.py,sha256=BaluUNyRz8Qw-X7Y0ywDezwbkqiSvWlSYn2452XeGcA,213
|
|
2
|
+
alibaba_cloud_ops_mcp_server/config.py,sha256=PizctjXsQUWoMWBY1dFjNffVlZr9K6hNvqA4DpayR_o,513
|
|
3
|
+
alibaba_cloud_ops_mcp_server/server.py,sha256=1TRZMsgicsnaK_YFktL8JPglIc7Z-EQgDmSd0Ww_wdI,2219
|
|
4
|
+
alibaba_cloud_ops_mcp_server/alibabacloud/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
5
|
+
alibaba_cloud_ops_mcp_server/alibabacloud/api_meta_client.py,sha256=t2TSc0Gzcy_uEcaCgiHHuLoMiEGu3-NCtYmwYjyPWsY,7973
|
|
6
|
+
alibaba_cloud_ops_mcp_server/alibabacloud/exception.py,sha256=7PdhgqgXEGrTPL1cj98h9EH-RrM6-2TT89PDtcmlpmU,1230
|
|
7
|
+
alibaba_cloud_ops_mcp_server/alibabacloud/utils.py,sha256=7PldufvFOb9GcXLHbUxKV6m9XqJpoNe4FVdQcg7Zeuk,1495
|
|
8
|
+
alibaba_cloud_ops_mcp_server/alibabacloud/static/PROMPT_UNDERSTANDING.md,sha256=494HcCQQCc_iqDrRKhk7eWXB4I0dMtqCseT78KphDHg,3553
|
|
9
|
+
alibaba_cloud_ops_mcp_server/alibabacloud/static/__init__.py,sha256=wJrYamaIb7e_kA4ILZpdP1f1TUUTXMGqEhA4IbSZ2Ts,230
|
|
10
|
+
alibaba_cloud_ops_mcp_server/tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
11
|
+
alibaba_cloud_ops_mcp_server/tools/api_tools.py,sha256=T5Zat31yjEBEmILKbb2uDUkgDHSqOIlPAjpi47hsCz8,8220
|
|
12
|
+
alibaba_cloud_ops_mcp_server/tools/cms_tools.py,sha256=_M13s87WxxiHp3Phu5AmXKkHOj0KDvUlodJ6z5Ndi7E,4182
|
|
13
|
+
alibaba_cloud_ops_mcp_server/tools/common_api_tools.py,sha256=ccQAWqS1I9F-fdOdjLcXN-dIhNqSbZV8T5ODuGXlfXM,2711
|
|
14
|
+
alibaba_cloud_ops_mcp_server/tools/oos_tools.py,sha256=8CLidg8Vrzpxv4lEOokPdScv31xlg_gX7glifiSqa8g,10063
|
|
15
|
+
alibaba_cloud_ops_mcp_server/tools/oss_tools.py,sha256=MUAiYL4VlsYQPoR_JtHOLcF1i4VYK9KE6ff9BTqJr9E,5014
|
|
16
|
+
alibaba_cloud_ops_mcp_server-0.9.2.dist-info/METADATA,sha256=j-SZxCA0-iHZGMWqaJ4z9-vXq3rYs1du4FQ9822zAFc,5965
|
|
17
|
+
alibaba_cloud_ops_mcp_server-0.9.2.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
|
18
|
+
alibaba_cloud_ops_mcp_server-0.9.2.dist-info/entry_points.txt,sha256=ESGAWXKEp184forhs7VzTD4P1AUdZz6vCW6hRUKITGw,83
|
|
19
|
+
alibaba_cloud_ops_mcp_server-0.9.2.dist-info/licenses/LICENSE,sha256=gQgVkp2ttRCjodiPpXZZR-d7JnrYIYNiHk1YDUYgpa4,11331
|
|
20
|
+
alibaba_cloud_ops_mcp_server-0.9.2.dist-info/RECORD,,
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
alibaba_cloud_ops_mcp_server/__init__.py,sha256=BaluUNyRz8Qw-X7Y0ywDezwbkqiSvWlSYn2452XeGcA,213
|
|
2
|
-
alibaba_cloud_ops_mcp_server/config.py,sha256=Nq6AT8bqSVa6zu9xjInaSjFcxA-GC7MLlCsV1q53yO0,514
|
|
3
|
-
alibaba_cloud_ops_mcp_server/server.py,sha256=tvRVQi1d7oPc-OsBHf6Za1Qht_bhNm2nf4B2aQ84Fyw,2246
|
|
4
|
-
alibaba_cloud_ops_mcp_server/alibabacloud/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
5
|
-
alibaba_cloud_ops_mcp_server/alibabacloud/api_meta_client.py,sha256=t2TSc0Gzcy_uEcaCgiHHuLoMiEGu3-NCtYmwYjyPWsY,7973
|
|
6
|
-
alibaba_cloud_ops_mcp_server/alibabacloud/exception.py,sha256=7PdhgqgXEGrTPL1cj98h9EH-RrM6-2TT89PDtcmlpmU,1230
|
|
7
|
-
alibaba_cloud_ops_mcp_server/alibabacloud/utils.py,sha256=jWQtP59P4ejh7N6xiYSDq1WgCd3Les0aSZr2pLGzkls,299
|
|
8
|
-
alibaba_cloud_ops_mcp_server/alibabacloud/static/PROMPT_UNDERSTANDING.md,sha256=494HcCQQCc_iqDrRKhk7eWXB4I0dMtqCseT78KphDHg,3553
|
|
9
|
-
alibaba_cloud_ops_mcp_server/alibabacloud/static/__init__.py,sha256=wJrYamaIb7e_kA4ILZpdP1f1TUUTXMGqEhA4IbSZ2Ts,230
|
|
10
|
-
alibaba_cloud_ops_mcp_server/tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
11
|
-
alibaba_cloud_ops_mcp_server/tools/api_tools.py,sha256=G3IsVOuvOGFupteJmESJowlbGGj2po2uJpcx53gzvRA,7702
|
|
12
|
-
alibaba_cloud_ops_mcp_server/tools/cms_tools.py,sha256=GFSBDTddvQ7M9fDGm69jvH6Yt4nui5uOVjwD61CZKT4,4191
|
|
13
|
-
alibaba_cloud_ops_mcp_server/tools/common_api_tools.py,sha256=ccQAWqS1I9F-fdOdjLcXN-dIhNqSbZV8T5ODuGXlfXM,2711
|
|
14
|
-
alibaba_cloud_ops_mcp_server/tools/oos_tools.py,sha256=l228yl_SGg_rNdrBSDeqWYI8ZE1XUAHhsPLArvfE4A8,10116
|
|
15
|
-
alibaba_cloud_ops_mcp_server/tools/oss_tools.py,sha256=c7D1fAjFBqHl0oMy0O6i7onoXeAN9cpdBdLtXKrxVQE,4615
|
|
16
|
-
alibaba_cloud_ops_mcp_server-0.9.0.dist-info/METADATA,sha256=uDR__noYnkGhBgvSiLicUYGUAdUOwshyTKlCz5WNenM,5966
|
|
17
|
-
alibaba_cloud_ops_mcp_server-0.9.0.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
|
18
|
-
alibaba_cloud_ops_mcp_server-0.9.0.dist-info/entry_points.txt,sha256=ESGAWXKEp184forhs7VzTD4P1AUdZz6vCW6hRUKITGw,83
|
|
19
|
-
alibaba_cloud_ops_mcp_server-0.9.0.dist-info/licenses/LICENSE,sha256=gQgVkp2ttRCjodiPpXZZR-d7JnrYIYNiHk1YDUYgpa4,11331
|
|
20
|
-
alibaba_cloud_ops_mcp_server-0.9.0.dist-info/RECORD,,
|
{alibaba_cloud_ops_mcp_server-0.9.0.dist-info → alibaba_cloud_ops_mcp_server-0.9.2.dist-info}/WHEEL
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|