add tools

pull/17608/head
fuwx 1 year ago
parent 5af25da1d3
commit d35b3c5bb7
No known key found for this signature in database
GPG Key ID: C8FA8C18DFB4702B

@ -0,0 +1,45 @@
import json
from collections.abc import Generator
from typing import Any, Optional
import requests
from configs import dify_config
from core.tools.builtin_tool.tool import BuiltinTool
from core.tools.entities.tool_entities import ToolInvokeMessage
from libs.apo_utils import APOUtils
class ContainerDiskTimeTool(BuiltinTool):
def _invoke(
self,
user_id: str,
tool_parameters: dict[str, Any],
conversation_id: Optional[str] = None,
app_id: Optional[str] = None,
message_id: Optional[str] = None,
) -> Generator[ToolInvokeMessage, None, None]:
pod = tool_parameters.get("pod")
namespace = tool_parameters.get("namespace")
start_time = tool_parameters.get("startTime")
end_time = tool_parameters.get("endTime")
params = {
'metricName': '基础设施情况 - 容器磁盘 - 读写花费时间 /s - Read',
'params': {
"pod": pod,
"namespace": namespace
},
'startTime': start_time,
'endTime': end_time,
'step': APOUtils.get_step(start_time, end_time),
}
resp = requests.post(dify_config.APO_BACKEND_URL + '/api/metric/query', json=params)
list = resp.json()['result']
list = json.dumps({
'type': 'metric',
'display': True,
'unit': list['unit'],
'data': {
"timeseries": list['timeseries']
}
})
yield self.create_text_message(list)

@ -0,0 +1,70 @@
identity:
name: select_container_cpu
author: APO
label:
en_US: Query the CPU utilization of the container
zh_Hans: 基础设施情况 - 容器磁盘 - 读写花费时间 /s - Read
pt_BR: Query the CPU utilization of the container
display:
type: metric
title: 基础设施情况 - 容器磁盘 - 读写花费时间 /s - Read
unit: percent(0-100)百分比
description:
human:
en_US: Query the CPU utilization of the container
zh_Hans: 基础设施情况 - 容器磁盘 - 读写花费时间 /s - Read
pt_BR: Query the CPU utilization of the container
llm: 基础设施情况 - 容器磁盘 - 读写花费时间 /s - Read
parameters:
- name: pod
type: string
required: true
label:
en_US: pod
zh_Hans: pod
pt_BR: pod
human_description:
en_US: Specified pod name
zh_Hans: 指定的容器POD名称
pt_BR: Specified pod name
llm_description: Specified pod name
form: llm
- name: namespace
type: string
required: true
label:
en_US: namespace
zh_Hans: namespace
pt_BR: namespace
human_description:
en_US: Specified namespace
zh_Hans: 指定的容器所在Namespace
pt_BR: Specified namespace
llm_description: Specified namespace
form: llm
- name: startTime
type: number
required: true
label:
en_US: startTime
zh_Hans: startTime
pt_BR: startTime
human_description:
en_US: Data query start time
zh_Hans: 开始时间 (微秒)
pt_BR: Data query start time
llm_description: Data query start time
form: llm
- name: endTime
type: number
required: true
label:
en_US: endTime
zh_Hans: endTime
pt_BR: endTime
human_description:
en_US: Data query end time
zh_Hans: 结束时间 (微秒)
pt_BR: Data query end time
llm_description: Data query start time
form: llm

@ -0,0 +1,43 @@
import json
from collections.abc import Generator
from typing import Any, Optional
import requests
from configs import dify_config
from core.tools.builtin_tool.tool import BuiltinTool
from core.tools.entities.tool_entities import ToolInvokeMessage
from libs.apo_utils import APOUtils
class HostCPUIoWaitRespTool(BuiltinTool):
def _invoke(
self,
user_id: str,
tool_parameters: dict[str, Any],
conversation_id: Optional[str] = None,
app_id: Optional[str] = None,
message_id: Optional[str] = None,
) -> Generator[ToolInvokeMessage, None, None]:
node = tool_parameters.get("node")
start_time = tool_parameters.get("startTime")
end_time = tool_parameters.get("endTime")
params = {
'metricName': '宿主机监控指标 - Basic CPU / Mem / Net / Disk - CPU Basic - Busy Iowait',
'params': {
"node": node
},
'startTime': start_time,
'endTime': end_time,
'step': APOUtils.get_step(start_time, end_time),
}
resp = requests.post(dify_config.APO_BACKEND_URL + '/api/metric/query', json=params)
list = resp.json()['result']
list = json.dumps({
'type': 'metric',
'display': True,
'unit': list['unit'],
'data': {
"timeseries": list['timeseries']
}
})
yield self.create_text_message(list)

@ -0,0 +1,57 @@
identity:
name: host_cpu_iowait
author: APO
label:
en_US: Query the CPU utilization of the host
zh_Hans: 宿主机监控指标 - Basic CPU / Mem / Net / Disk - CPU Basic - Busy Iowait
pt_BR: Query the CPU utilization of the host
description:
human:
en_US: Query the CPU utilization of the host
zh_Hans: 宿主机监控指标 - Basic CPU / Mem / Net / Disk - CPU Basic - Busy Iowait
pt_BR: Query the CPU utilization of the host
llm: 宿主机监控指标 - Basic CPU / Mem / Net / Disk - CPU Basic - Busy Iowait
display:
type: metric
title: 宿主机监控指标 - Basic CPU / Mem / Net / Disk - CPU Basic - Busy Iowait
unit: percent(0-100)百分比
parameters:
- name: node
type: string
required: true
label:
en_US: node
zh_Hans: node
pt_BR: node
human_description:
en_US: Specified host name
zh_Hans: 指定的主机名
pt_BR: Specified host name
llm_description: Specified host name
form: llm
- name: startTime
type: number
required: true
label:
en_US: startTime
zh_Hans: startTime
pt_BR: startTime
human_description:
en_US: Data query start time
zh_Hans: 开始时间 (微秒)
pt_BR: Data query start time
llm_description: Data query start time
form: llm
- name: endTime
type: number
required: true
label:
en_US: endTime
zh_Hans: endTime
pt_BR: endTime
human_description:
en_US: Data query end time
zh_Hans: 结束时间 (微秒)
pt_BR: Data query end time
llm_description: Data query start time
form: llm

@ -0,0 +1,43 @@
import json
from collections.abc import Generator
from typing import Any, Optional
import requests
from configs import dify_config
from core.tools.builtin_tool.tool import BuiltinTool
from core.tools.entities.tool_entities import ToolInvokeMessage
from libs.apo_utils import APOUtils
class HostCPUIoWaitRespTool(BuiltinTool):
def _invoke(
self,
user_id: str,
tool_parameters: dict[str, Any],
conversation_id: Optional[str] = None,
app_id: Optional[str] = None,
message_id: Optional[str] = None,
) -> Generator[ToolInvokeMessage, None, None]:
node = tool_parameters.get("node")
start_time = tool_parameters.get("startTime")
end_time = tool_parameters.get("endTime")
params = {
'metricName': '宿主机监控指标 - System Misc - File Descriptors - Open file descriptors',
'params': {
"node": node
},
'startTime': start_time,
'endTime': end_time,
'step': APOUtils.get_step(start_time, end_time),
}
resp = requests.post(dify_config.APO_BACKEND_URL + '/api/metric/query', json=params)
list = resp.json()['result']
list = json.dumps({
'type': 'metric',
'display': True,
'unit': list['unit'],
'data': {
"timeseries": list['timeseries']
}
})
yield self.create_text_message(list)

@ -0,0 +1,57 @@
identity:
name: host_cpu_iowait
author: APO
label:
en_US: Query the CPU utilization of the host
zh_Hans: 宿主机监控指标 - System Misc - File Descriptors - Open file descriptors
pt_BR: Query the CPU utilization of the host
description:
human:
en_US: Query the CPU utilization of the host
zh_Hans: 宿主机当前打开文件描述符数
pt_BR: Query the CPU utilization of the host
llm: 宿主机监控指标 - System Misc - File Descriptors - Open file descriptors
display:
type: metric
title: 宿主机监控指标 - System Misc - File Descriptors - Open file descriptors
unit: percent(0-100)百分比
parameters:
- name: node
type: string
required: true
label:
en_US: node
zh_Hans: node
pt_BR: node
human_description:
en_US: Specified host name
zh_Hans: 指定的主机名
pt_BR: Specified host name
llm_description: Specified host name
form: llm
- name: startTime
type: number
required: true
label:
en_US: startTime
zh_Hans: startTime
pt_BR: startTime
human_description:
en_US: Data query start time
zh_Hans: 开始时间 (微秒)
pt_BR: Data query start time
llm_description: Data query start time
form: llm
- name: endTime
type: number
required: true
label:
en_US: endTime
zh_Hans: endTime
pt_BR: endTime
human_description:
en_US: Data query end time
zh_Hans: 结束时间 (微秒)
pt_BR: Data query end time
llm_description: Data query start time
form: llm

@ -0,0 +1,43 @@
import json
from collections.abc import Generator
from typing import Any, Optional
import requests
from configs import dify_config
from core.tools.builtin_tool.tool import BuiltinTool
from core.tools.entities.tool_entities import ToolInvokeMessage
from libs.apo_utils import APOUtils
class PolarProcessAllRespTool(BuiltinTool):
def _invoke(
self,
user_id: str,
tool_parameters: dict[str, Any],
conversation_id: Optional[str] = None,
app_id: Optional[str] = None,
message_id: Optional[str] = None,
) -> Generator[ToolInvokeMessage, None, None]:
pod = tool_parameters.get("pod")
start_time = tool_parameters.get("startTime")
end_time = tool_parameters.get("endTime")
params = {
'metricName': 'Thread Polaris Metrics - 北极星指标(进程) - 各类型耗时折线图 - 所有类型列表',
'params': {
"pod": pod
},
'startTime': start_time,
'endTime': end_time,
'step': APOUtils.get_step(start_time, end_time),
}
resp = requests.post(dify_config.APO_BACKEND_URL + '/api/metric/query', json=params)
list = resp.json()['result']
list = json.dumps({
'type': 'metric',
'display': True,
'unit': list['unit'],
'data': {
"timeseries": list['timeseries']
}
})
yield self.create_text_message(list)

@ -0,0 +1,57 @@
identity:
name: polar_process_all_resp
author: APO
label:
en_US: Query the CPU utilization of the host
zh_Hans: Thread Polaris Metrics - 北极星指标(进程) - 各类型耗时折线图 - 所有类型列表
pt_BR: Query the CPU utilization of the host
description:
human:
en_US: Query the CPU utilization of the host
zh_Hans: Thread Polaris Metrics - 北极星指标(进程) - 各类型耗时折线图 - 所有类型列表
pt_BR: Query the CPU utilization of the host
llm: Thread Polaris Metrics - 北极星指标(进程) - 各类型耗时折线图 - 所有类型列表
display:
type: metric
title: Thread Polaris Metrics - 北极星指标(进程) - 各类型耗时折线图 - 所有类型列表
unit: ns
parameters:
- name: pod
type: string
required: true
label:
en_US: pod
zh_Hans: pod
pt_BR: pod
human_description:
en_US: Specified pod name
zh_Hans: 指定的容器POD名称
pt_BR: Specified pod name
llm_description: Specified pod name
form: llm
- name: startTime
type: number
required: true
label:
en_US: startTime
zh_Hans: startTime
pt_BR: startTime
human_description:
en_US: Data query start time
zh_Hans: 开始时间 (微秒)
pt_BR: Data query start time
llm_description: Data query start time
form: llm
- name: endTime
type: number
required: true
label:
en_US: endTime
zh_Hans: endTime
pt_BR: endTime
human_description:
en_US: Data query end time
zh_Hans: 结束时间 (微秒)
pt_BR: Data query end time
llm_description: Data query start time
form: llm
Loading…
Cancel
Save