alibaba-cloud-ops-mcp-server 0.8.6__tar.gz → 0.8.8__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 (35) hide show
  1. alibaba_cloud_ops_mcp_server-0.8.8/.github/workflows/python-ci.yml +28 -0
  2. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/.gitignore +1 -0
  3. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/PKG-INFO +8 -4
  4. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/README.md +5 -2
  5. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/README_zh.md +4 -1
  6. alibaba_cloud_ops_mcp_server-0.8.8/examples/openapi_mcp_quickstart/server.py +17 -0
  7. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/pyproject.toml +9 -2
  8. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/alibabacloud/api_meta_client.py +2 -1
  9. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/server.py +1 -1
  10. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/tools/api_tools.py +33 -8
  11. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/tools/cms_tools.py +9 -9
  12. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/tools/oos_tools.py +10 -10
  13. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/tools/oss_tools.py +4 -4
  14. alibaba_cloud_ops_mcp_server-0.8.8/tests/alibabacloud/test_api_meta_client.py +292 -0
  15. alibaba_cloud_ops_mcp_server-0.8.8/tests/alibabacloud/test_exception.py +36 -0
  16. alibaba_cloud_ops_mcp_server-0.8.8/tests/alibabacloud/test_utils.py +15 -0
  17. alibaba_cloud_ops_mcp_server-0.8.8/tests/test_init.py +8 -0
  18. alibaba_cloud_ops_mcp_server-0.8.8/tests/test_server.py +30 -0
  19. alibaba_cloud_ops_mcp_server-0.8.8/tests/tools/test_api_tools.py +324 -0
  20. alibaba_cloud_ops_mcp_server-0.8.8/tests/tools/test_cms_tools.py +179 -0
  21. alibaba_cloud_ops_mcp_server-0.8.8/tests/tools/test_oos_tools.py +221 -0
  22. alibaba_cloud_ops_mcp_server-0.8.8/tests/tools/test_oss_tools.py +84 -0
  23. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/uv.lock +196 -6
  24. alibaba_cloud_ops_mcp_server-0.8.6/examples/openapi_mcp_quickstart/server.py +0 -0
  25. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/LICENSE +0 -0
  26. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/image/Alibaba-Cloud-Ops-MCP-User-Group-en.png +0 -0
  27. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/image/Alibaba-Cloud-Ops-MCP-User-Group-zh.png +0 -0
  28. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/image/alibaba-cloud.png +0 -0
  29. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/__init__.py +0 -0
  30. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/__init__.py +0 -0
  31. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/alibabacloud/__init__.py +0 -0
  32. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/alibabacloud/exception.py +0 -0
  33. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/alibabacloud/utils.py +0 -0
  34. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/config.py +0 -0
  35. {alibaba_cloud_ops_mcp_server-0.8.6 → alibaba_cloud_ops_mcp_server-0.8.8}/src/alibaba_cloud_ops_mcp_server/tools/__init__.py +0 -0
@@ -0,0 +1,28 @@
1
+ name: unit test
2
+
3
+ on:
4
+ push:
5
+ branches: [ master ]
6
+ pull_request:
7
+ branches: [ master ]
8
+
9
+ jobs:
10
+ test:
11
+ runs-on: ubuntu-latest
12
+ strategy:
13
+ matrix:
14
+ python-version: ['3.10', '3.11', '3.12', '3.13']
15
+ steps:
16
+ - uses: actions/checkout@v4
17
+ - name: Set up Python ${{ matrix.python-version }}
18
+ uses: actions/setup-python@v5
19
+ with:
20
+ python-version: ${{ matrix.python-version }}
21
+ - name: Install uv
22
+ run: |
23
+ pip install uv
24
+ - name: Run tests with coverage
25
+ env:
26
+ PYTHONPATH: src
27
+ run: |
28
+ uv run pytest --cov=src --cov-report=term-missing
@@ -5,6 +5,7 @@ build/
5
5
  dist/
6
6
  wheels/
7
7
  *.egg-info
8
+ .coverage
8
9
 
9
10
  # Virtual environments
10
11
  .venv
@@ -1,16 +1,17 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: alibaba-cloud-ops-mcp-server
3
- Version: 0.8.6
3
+ Version: 0.8.8
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
7
7
  Requires-Python: >=3.10
8
8
  Requires-Dist: alibabacloud-cms20190101>=3.1.4
9
+ Requires-Dist: alibabacloud-credentials>=1.0.0
9
10
  Requires-Dist: alibabacloud-ecs20140526>=6.1.0
10
11
  Requires-Dist: alibabacloud-oos20190601>=3.4.1
11
12
  Requires-Dist: alibabacloud-oss-v2>=1.1.0
12
13
  Requires-Dist: click>=8.1.8
13
- Requires-Dist: mcp[cli]>=1.6.0
14
+ Requires-Dist: mcp[cli]>=1.9.0
14
15
  Description-Content-Type: text/markdown
15
16
 
16
17
  # Alibaba Cloud Ops MCP Server
@@ -57,16 +58,19 @@ To use `alibaba-cloud-ops-mcp-server` MCP Server with any other MCP Client, you
57
58
  ## MCP Maketplace Integration
58
59
 
59
60
  * [Cline](https://cline.bot/mcp-marketplace)
61
+ * [Cursor](https://docs.cursor.com/tools) [![Install MCP Server](https://cursor.com/deeplink/mcp-install-dark.svg)](https://cursor.com/install-mcp?name=alibaba-cloud-ops-mcp-server&config=eyJ0aW1lb3V0Ijo2MDAsImNvbW1hbmQiOiJ1dnggYWxpYmFiYS1jbG91ZC1vcHMtbWNwLXNlcnZlckBsYXRlc3QiLCJlbnYiOnsiQUxJQkFCQV9DTE9VRF9BQ0NFU1NfS0VZX0lEIjoiWW91ciBBY2Nlc3MgS2V5IElEIiwiQUxJQkFCQV9DTE9VRF9BQ0NFU1NfS0VZX1NFQ1JFVCI6IllvdXIgQWNjZXNzIEtleSBTRUNSRVQifX0%3D)
60
62
  * [ModelScope](https://www.modelscope.cn/mcp/servers/@aliyun/alibaba-cloud-ops-mcp-server?lang=en_US)
61
63
  * [Lingma](https://lingma.aliyun.com/)
62
64
  * [Smithery AI](https://smithery.ai/server/@aliyun/alibaba-cloud-ops-mcp-server)
63
65
  * [FC-Function AI](https://cap.console.aliyun.com/template-detail?template=237)
66
+ * [Alibaba Cloud Model Studio](https://bailian.console.aliyun.com/?tab=mcp#/mcp-market/detail/alibaba-cloud-ops)
64
67
 
65
68
  ## Know More
66
69
 
67
- * [Alibaba Cloud MCP Server is ready to use out of the box!!](https://developer.aliyun.com/article/1661348)
68
- * [Setup Alibaba Cloud MCP Server on Bailian](https://developer.aliyun.com/article/1662120)
70
+ * [Alibaba Cloud Ops MCP Server is ready to use out of the box!!](https://developer.aliyun.com/article/1661348)
71
+ * [Setup Alibaba Cloud Ops MCP Server on Bailian](https://developer.aliyun.com/article/1662120)
69
72
  * [Build your own Alibaba Cloud OpenAPI MCP Server with 10 lines of code](https://developer.aliyun.com/article/1662202)
73
+ * [Alibaba Cloud Ops MCP Server is officially available on the Alibaba Cloud Model Studio Platform MCP Marketplace](https://developer.aliyun.com/article/1665019)
70
74
 
71
75
  ## Tools
72
76
 
@@ -42,16 +42,19 @@ To use `alibaba-cloud-ops-mcp-server` MCP Server with any other MCP Client, you
42
42
  ## MCP Maketplace Integration
43
43
 
44
44
  * [Cline](https://cline.bot/mcp-marketplace)
45
+ * [Cursor](https://docs.cursor.com/tools) [![Install MCP Server](https://cursor.com/deeplink/mcp-install-dark.svg)](https://cursor.com/install-mcp?name=alibaba-cloud-ops-mcp-server&config=eyJ0aW1lb3V0Ijo2MDAsImNvbW1hbmQiOiJ1dnggYWxpYmFiYS1jbG91ZC1vcHMtbWNwLXNlcnZlckBsYXRlc3QiLCJlbnYiOnsiQUxJQkFCQV9DTE9VRF9BQ0NFU1NfS0VZX0lEIjoiWW91ciBBY2Nlc3MgS2V5IElEIiwiQUxJQkFCQV9DTE9VRF9BQ0NFU1NfS0VZX1NFQ1JFVCI6IllvdXIgQWNjZXNzIEtleSBTRUNSRVQifX0%3D)
45
46
  * [ModelScope](https://www.modelscope.cn/mcp/servers/@aliyun/alibaba-cloud-ops-mcp-server?lang=en_US)
46
47
  * [Lingma](https://lingma.aliyun.com/)
47
48
  * [Smithery AI](https://smithery.ai/server/@aliyun/alibaba-cloud-ops-mcp-server)
48
49
  * [FC-Function AI](https://cap.console.aliyun.com/template-detail?template=237)
50
+ * [Alibaba Cloud Model Studio](https://bailian.console.aliyun.com/?tab=mcp#/mcp-market/detail/alibaba-cloud-ops)
49
51
 
50
52
  ## Know More
51
53
 
52
- * [Alibaba Cloud MCP Server is ready to use out of the box!!](https://developer.aliyun.com/article/1661348)
53
- * [Setup Alibaba Cloud MCP Server on Bailian](https://developer.aliyun.com/article/1662120)
54
+ * [Alibaba Cloud Ops MCP Server is ready to use out of the box!!](https://developer.aliyun.com/article/1661348)
55
+ * [Setup Alibaba Cloud Ops MCP Server on Bailian](https://developer.aliyun.com/article/1662120)
54
56
  * [Build your own Alibaba Cloud OpenAPI MCP Server with 10 lines of code](https://developer.aliyun.com/article/1662202)
57
+ * [Alibaba Cloud Ops MCP Server is officially available on the Alibaba Cloud Model Studio Platform MCP Marketplace](https://developer.aliyun.com/article/1665019)
55
58
 
56
59
  ## Tools
57
60
 
@@ -4,7 +4,7 @@
4
4
 
5
5
  [English README](./README.md)
6
6
 
7
- Alibaba Cloud MCP Server是一个[模型上下文协议(MCP)](https://modelcontextprotocol.io/introduction)服务器,提供与阿里云API的无缝集成,使AI助手能够操作阿里云上的资源,支持ECS、云监控、OOS等广泛使用的云产品。
7
+ Alibaba Cloud Ops MCP Server是一个[模型上下文协议(MCP)](https://modelcontextprotocol.io/introduction)服务器,提供与阿里云API的无缝集成,使AI助手能够操作阿里云上的资源,支持ECS、云监控、OOS等广泛使用的云产品。
8
8
 
9
9
  ## 准备
10
10
 
@@ -42,16 +42,19 @@ curl -LsSf https://astral.sh/uv/install.sh | sh
42
42
  ## MCP市场集成
43
43
 
44
44
  * [Cline](https://cline.bot/mcp-marketplace)
45
+ * [Cursor](https://docs.cursor.com/tools) [![Install MCP Server](https://cursor.com/deeplink/mcp-install-dark.svg)](https://cursor.com/install-mcp?name=alibaba-cloud-ops-mcp-server&config=eyJ0aW1lb3V0Ijo2MDAsImNvbW1hbmQiOiJ1dnggYWxpYmFiYS1jbG91ZC1vcHMtbWNwLXNlcnZlckBsYXRlc3QiLCJlbnYiOnsiQUxJQkFCQV9DTE9VRF9BQ0NFU1NfS0VZX0lEIjoiWW91ciBBY2Nlc3MgS2V5IElEIiwiQUxJQkFCQV9DTE9VRF9BQ0NFU1NfS0VZX1NFQ1JFVCI6IllvdXIgQWNjZXNzIEtleSBTRUNSRVQifX0%3D)
45
46
  * [魔搭](https://www.modelscope.cn/mcp/servers/@aliyun/alibaba-cloud-ops-mcp-server)
46
47
  * [通义灵码](https://lingma.aliyun.com/)
47
48
  * [Smithery AI](https://smithery.ai/server/@aliyun/alibaba-cloud-ops-mcp-server)
48
49
  * [FC-Function AI](https://cap.console.aliyun.com/template-detail?template=237)
50
+ * [阿里云百炼平台](https://bailian.console.aliyun.com/?tab=mcp#/mcp-market/detail/alibaba-cloud-ops)
49
51
 
50
52
  ## 了解更多
51
53
 
52
54
  * [阿里云 MCP Server 开箱即用!](https://developer.aliyun.com/article/1661348)
53
55
  * [在百炼平台配置您的自定义阿里云MCP Server](https://developer.aliyun.com/article/1662120)
54
56
  * [10行代码,实现你的专属阿里云OpenAPI MCP Server](https://developer.aliyun.com/article/1662202)
57
+ * [阿里云CloudOps MCP正式上架百炼平台MCP市场](https://developer.aliyun.com/article/1665019)
55
58
 
56
59
  ## 功能点(Tool)
57
60
 
@@ -0,0 +1,17 @@
1
+ # Build your own Alibaba Cloud OpenAPI MCP Server with 10 lines of code
2
+ # https://developer.aliyun.com/article/1662202
3
+ # example codes
4
+ from mcp.server.fastmcp import FastMCP
5
+ from alibaba_cloud_ops_mcp_server.tools import api_tools
6
+
7
+ def main():
8
+ mcp = FastMCP("Example MCP server")
9
+ config = {
10
+ 'ecs': ['DescribeInstances', 'DescribeRegions'],
11
+ 'vpc': ['DescribeVpcs', 'DescribeVSwitches']
12
+ }
13
+ api_tools.create_api_tools(mcp, config)
14
+ mcp.run(transport='sse')
15
+
16
+ if __name__ == "__main__":
17
+ main()
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "alibaba-cloud-ops-mcp-server"
3
- version = "0.8.6"
3
+ version = "0.8.8"
4
4
  description = "A MCP server for Alibaba Cloud"
5
5
  readme = "README.md"
6
6
  authors = [
@@ -12,8 +12,9 @@ dependencies = [
12
12
  "alibabacloud-ecs20140526>=6.1.0",
13
13
  "alibabacloud-oos20190601>=3.4.1",
14
14
  "alibabacloud_oss_v2>=1.1.0",
15
+ "alibabacloud-credentials>=1.0.0",
15
16
  "click>=8.1.8",
16
- "mcp[cli]>=1.6.0",
17
+ "mcp[cli]>=1.9.0",
17
18
  ]
18
19
 
19
20
  [build-system]
@@ -26,5 +27,11 @@ dependencies = [
26
27
  [tool.hatch.build.targets.wheel]
27
28
  packages = ["src/alibaba_cloud_ops_mcp_server"]
28
29
 
30
+ [dependency-groups]
31
+ dev = [
32
+ "pytest>=8.4.0",
33
+ "pytest-cov>=6.1.1",
34
+ ]
35
+
29
36
  [project.scripts]
30
37
  alibaba-cloud-ops-mcp-server = "alibaba_cloud_ops_mcp_server:main"
@@ -30,12 +30,13 @@ class ApiMetaClient:
30
30
 
31
31
  @classmethod
32
32
  def get_response_from_pop_api(cls, pop_api_name, service=None, api=None, version=None):
33
+ url = None # 提前定义,防止 except 中引用未定义变量
33
34
  try:
34
35
  api_config = cls.config.get(pop_api_name)
35
36
  try:
36
37
  formatted_path = api_config[cls.PATH].format(service=service, api=api, version=version)
37
38
  except KeyError as e:
38
- raise Exception(f'Failed to format path, path: {api_config[cls.PATH]}, error: {e}')
39
+ raise Exception(f'Failed to format path, path: {api_config.get(cls.PATH)}, error: {e}')
39
40
 
40
41
  url = f'{cls.BASE_URL}/{formatted_path}'
41
42
  response = requests.get(url)
@@ -11,7 +11,7 @@ logger = logging.getLogger(__name__)
11
11
  @click.command()
12
12
  @click.option(
13
13
  "--transport",
14
- type=click.Choice(["stdio", "sse"]),
14
+ type=click.Choice(["stdio", "sse", "streamable-http"]),
15
15
  default="stdio",
16
16
  help="Transport type",
17
17
  )
@@ -2,6 +2,7 @@ import os
2
2
  from mcp.server.fastmcp import FastMCP, Context
3
3
  from pydantic import Field
4
4
  import logging
5
+ import json
5
6
 
6
7
  import inspect
7
8
  import types
@@ -32,6 +33,15 @@ def create_client(service: str, region_id: str) -> OpenApiClient:
32
33
  return OpenApiClient(config)
33
34
 
34
35
 
36
+ # 类型为String的JSON数组参数
37
+ ECS_LIST_PARAMETERS = {
38
+ 'HpcClusterIds', 'DedicatedHostClusterIds', 'DedicatedHostIds',
39
+ 'InstanceIds', 'DeploymentSetIds', 'KeyPairNames', 'SecurityGroupIds',
40
+ 'diskIds', 'repeatWeekdays', 'timePoints', 'DiskIds', 'SnapshotLinkIds',
41
+ 'EipAddresses', 'PublicIpAddresses', 'PrivateIpAddresses'
42
+ }
43
+
44
+
35
45
  def _tools_api_call(service: str, api: str, parameters: dict, ctx: Context):
36
46
  service = service.lower()
37
47
  api_meta, _ = ApiMetaClient.get_api_meta(service, api)
@@ -39,8 +49,16 @@ def _tools_api_call(service: str, api: str, parameters: dict, ctx: Context):
39
49
  method = 'POST' if api_meta.get('methods', [])[0] == 'post' else 'GET'
40
50
  path = api_meta.get('path', '/')
41
51
  style = ApiMetaClient.get_service_style(service)
52
+
53
+ # 处理特殊参数格式
54
+ processed_parameters = parameters.copy()
55
+ if service == 'ecs':
56
+ for param_name, param_value in parameters.items():
57
+ if param_name in ECS_LIST_PARAMETERS and isinstance(param_value, list):
58
+ processed_parameters[param_name] = json.dumps(param_value)
59
+
42
60
  req = open_api_models.OpenApiRequest(
43
- query=OpenApiUtilClient.query(parameters)
61
+ query=OpenApiUtilClient.query(processed_parameters)
44
62
  )
45
63
  params = open_api_models.Params(
46
64
  action=api,
@@ -53,7 +71,7 @@ def _tools_api_call(service: str, api: str, parameters: dict, ctx: Context):
53
71
  req_body_type='formData',
54
72
  body_type='json'
55
73
  )
56
- client = create_client(service, parameters.get('RegionId', 'cn-hangzhou'))
74
+ client = create_client(service, processed_parameters.get('RegionId', 'cn-hangzhou'))
57
75
  runtime = util_models.RuntimeOptions()
58
76
  return client.call_api(params, req, runtime)
59
77
 
@@ -75,9 +93,15 @@ def _create_function_schemas(service, api, api_meta):
75
93
  description = schema.get('description', '')
76
94
  example = schema.get('example', '')
77
95
  type_ = schema.get('type', '')
78
- description = f'{description} 请注意,提供参数要严格按照参数的类型和参数示例的提示,如果提到参数为String,且为一个 JSON 数组字符串,应在数组内使用单引号包裹对应的参数以避免转义问题,并在最外侧用双引号包裹以确保其是字符串,否则可能会导致参数解析错误。参数类型: {type_},参数示例:{example}'
96
+ description = f'{description} 参数类型: {type_},参数示例:{example}'
79
97
  required = schema.get('required', False)
80
- python_type = type_map.get(type_, str)
98
+
99
+ # 只有在service为ecs时,才对特定参数进行特殊处理
100
+ if service.lower() == 'ecs' and name in ECS_LIST_PARAMETERS and type_ == 'string':
101
+ python_type = list
102
+ else:
103
+ python_type = type_map.get(type_, str)
104
+
81
105
  field_info = (
82
106
  python_type,
83
107
  field(
@@ -97,7 +121,7 @@ def _create_function_schemas(service, api, api_meta):
97
121
  return schemas
98
122
 
99
123
 
100
- def _create_tool_function_with_signature(service: str, function_name: str, fields: dict, description: str):
124
+ def _create_tool_function_with_signature(service: str, api: str, fields: dict, description: str):
101
125
  """
102
126
  Dynamically creates a lambda function with a custom signature based on the provided fields.
103
127
  """
@@ -121,14 +145,14 @@ def _create_tool_function_with_signature(service: str, function_name: str, field
121
145
  defaults[name] = field_default
122
146
 
123
147
  signature = inspect.Signature(parameters)
124
-
148
+ function_name = f'{service.upper()}_{api}'
125
149
  def func_code(*args, **kwargs):
126
150
  bound_args = signature.bind(*args, **kwargs)
127
151
  bound_args.apply_defaults()
128
152
 
129
153
  return _tools_api_call(
130
154
  service=service,
131
- api=function_name,
155
+ api=api,
132
156
  parameters=bound_args.arguments,
133
157
  ctx=None
134
158
  )
@@ -154,7 +178,8 @@ def _create_and_decorate_tool(mcp: FastMCP, service: str, api: str):
154
178
  fields = _create_function_schemas(service, api, api_meta).get(api, {})
155
179
  description = api_meta.get('summary', '')
156
180
  dynamic_lambda = _create_tool_function_with_signature(service, api, fields, description)
157
- decorated_function = mcp.tool(name=api)(dynamic_lambda)
181
+ function_name = f'{service.upper()}_{api}'
182
+ decorated_function = mcp.tool(name=function_name)(dynamic_lambda)
158
183
 
159
184
  return decorated_function
160
185
 
@@ -36,7 +36,7 @@ def _get_cms_metric_data(region_id: str, instance_ids: List[str], metric_name: s
36
36
  return describe_metric_last_resp.body.datapoints
37
37
 
38
38
  @tools.append
39
- def GetCpuUsageData(
39
+ def CMS_GetCpuUsageData(
40
40
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
41
41
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
42
42
  ):
@@ -45,7 +45,7 @@ def GetCpuUsageData(
45
45
 
46
46
 
47
47
  @tools.append
48
- def GetCpuLoadavgData(
48
+ def CMS_GetCpuLoadavgData(
49
49
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
50
50
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
51
51
  ):
@@ -54,7 +54,7 @@ def GetCpuLoadavgData(
54
54
 
55
55
 
56
56
  @tools.append
57
- def GetCpuloadavg5mData(
57
+ def CMS_GetCpuloadavg5mData(
58
58
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
59
59
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
60
60
  ):
@@ -63,7 +63,7 @@ def GetCpuloadavg5mData(
63
63
 
64
64
 
65
65
  @tools.append
66
- def GetCpuloadavg15mData(
66
+ def CMS_GetCpuloadavg15mData(
67
67
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
68
68
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
69
69
  ):
@@ -71,7 +71,7 @@ def GetCpuloadavg15mData(
71
71
  return _get_cms_metric_data(RegionId, InstanceIds, 'load_15m')
72
72
 
73
73
  @tools.append
74
- def GetMemUsedData(
74
+ def CMS_GetMemUsedData(
75
75
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
76
76
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
77
77
  ):
@@ -80,7 +80,7 @@ def GetMemUsedData(
80
80
 
81
81
 
82
82
  @tools.append
83
- def GetMemUsageData(
83
+ def CMS_GetMemUsageData(
84
84
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
85
85
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
86
86
  ):
@@ -89,7 +89,7 @@ def GetMemUsageData(
89
89
 
90
90
 
91
91
  @tools.append
92
- def GetDiskUsageData(
92
+ def CMS_GetDiskUsageData(
93
93
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
94
94
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
95
95
  ):
@@ -98,7 +98,7 @@ def GetDiskUsageData(
98
98
 
99
99
 
100
100
  @tools.append
101
- def GetDiskTotalData(
101
+ def CMS_GetDiskTotalData(
102
102
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
103
103
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
104
104
  ):
@@ -107,7 +107,7 @@ def GetDiskTotalData(
107
107
 
108
108
 
109
109
  @tools.append
110
- def GetDiskUsedData(
110
+ def CMS_GetDiskUsedData(
111
111
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
112
112
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
113
113
  ):
@@ -46,7 +46,7 @@ def _start_execution_sync(region_id: str, template_name: str, parameters: dict):
46
46
  return list_executions_resp.body
47
47
  time.sleep(1)
48
48
  @tools.append
49
- def RunCommand(
49
+ def OOS_RunCommand(
50
50
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
51
51
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
52
52
  CommandType: str = Field(description='The type of command executed on the ECS instance, optional value:RunShellScript,RunPythonScript,RunPerlScript,RunBatScript,RunPowerShellScript', default='RunShellScript'),
@@ -73,7 +73,7 @@ def RunCommand(
73
73
 
74
74
 
75
75
  @tools.append
76
- def StartInstances(
76
+ def OOS_StartInstances(
77
77
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
78
78
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
79
79
  ):
@@ -92,7 +92,7 @@ def StartInstances(
92
92
 
93
93
 
94
94
  @tools.append
95
- def StopInstances(
95
+ def OOS_StopInstances(
96
96
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
97
97
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
98
98
  ForeceStop: bool = Field(description='Is forced shutdown required', default=False),
@@ -113,7 +113,7 @@ def StopInstances(
113
113
 
114
114
 
115
115
  @tools.append
116
- def RebootInstances(
116
+ def OOS_RebootInstances(
117
117
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
118
118
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
119
119
  ForeceStop: bool = Field(description='Is forced shutdown required', default=False),
@@ -134,7 +134,7 @@ def RebootInstances(
134
134
 
135
135
 
136
136
  @tools.append
137
- def RunInstances(
137
+ def OOS_RunInstances(
138
138
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
139
139
  ImageId: str = Field(description='Image ID'),
140
140
  InstanceType: str = Field(description='Instance Type'),
@@ -157,7 +157,7 @@ def RunInstances(
157
157
 
158
158
 
159
159
  @tools.append
160
- def ResetPassword(
160
+ def OOS_ResetPassword(
161
161
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
162
162
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
163
163
  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:<>,?/'),
@@ -176,7 +176,7 @@ def ResetPassword(
176
176
  return _start_execution_sync(region_id=RegionId, template_name='ACS-ECS-BulkyResetPassword', parameters=parameters)
177
177
 
178
178
  @tools.append
179
- def ReplaceSystemDisk(
179
+ def OOS_ReplaceSystemDisk(
180
180
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
181
181
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
182
182
  ImageId: str = Field(description='Image ID')
@@ -196,7 +196,7 @@ def ReplaceSystemDisk(
196
196
 
197
197
 
198
198
  @tools.append
199
- def StartRDSInstances(
199
+ def OOS_StartRDSInstances(
200
200
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
201
201
  InstanceIds: List[str] = Field(description='AlibabaCloud ECS instance ID List'),
202
202
  ):
@@ -215,7 +215,7 @@ def StartRDSInstances(
215
215
 
216
216
 
217
217
  @tools.append
218
- def StopRDSInstances(
218
+ def OOS_StopRDSInstances(
219
219
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
220
220
  InstanceIds: List[str] = Field(description='AlibabaCloud RDS instance ID List')
221
221
  ):
@@ -234,7 +234,7 @@ def StopRDSInstances(
234
234
 
235
235
 
236
236
  @tools.append
237
- def RebootRDSInstances(
237
+ def OOS_RebootRDSInstances(
238
238
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
239
239
  InstanceIds: List[str] = Field(description='AlibabaCloud RDS instance ID List')
240
240
  ):
@@ -35,7 +35,7 @@ def create_client(region_id: str) -> oss.Client:
35
35
 
36
36
 
37
37
  @tools.append
38
- def ListBuckets(
38
+ def OSS_ListBuckets(
39
39
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
40
40
  Prefix: str = Field(description='AlibabaCloud OSS Bucket Name prefix', default=None)
41
41
  ):
@@ -50,7 +50,7 @@ def ListBuckets(
50
50
 
51
51
 
52
52
  @tools.append
53
- def ListObjects(
53
+ def OSS_ListObjects(
54
54
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
55
55
  BucketName: str = Field(description='AlibabaCloud OSS Bucket Name'),
56
56
  Prefix: str = Field(description='AlibabaCloud OSS Bucket Name prefix', default=None)
@@ -71,7 +71,7 @@ def ListObjects(
71
71
 
72
72
 
73
73
  @tools.append
74
- def PutBucket(
74
+ def OSS_PutBucket(
75
75
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
76
76
  BucketName: str = Field(description='AlibabaCloud OSS Bucket Name'),
77
77
  StorageClass: str = Field(description='The Storage Type of AlibabaCloud OSS Bucket, The value range is as follows: '
@@ -99,7 +99,7 @@ def PutBucket(
99
99
 
100
100
 
101
101
  @tools.append
102
- def DeleteBucket(
102
+ def OSS_DeleteBucket(
103
103
  RegionId: str = Field(description='AlibabaCloud region ID', default='cn-hangzhou'),
104
104
  BucketName: str = Field(description='AlibabaCloud OSS Bucket Name')
105
105
  ):