mirror of
https://github.com/trustgraph-ai/trustgraph.git
synced 2026-04-25 08:26:21 +02:00
Key Features - MCP Tool Integration: Added core MCP tool support with ToolClientSpec and ToolClient classes - API Enhancement: New mcp_tool method for flow-specific tool invocation - CLI Tooling: New tg-invoke-mcp-tool command for testing MCP integration - React Agent Enhancement: Fixed and improved multi-tool invocation capabilities - Tool Management: Enhanced CLI for tool configuration and management Changes - Added MCP tool invocation to API with flow-specific integration - Implemented ToolClientSpec and ToolClient for tool call handling - Updated agent-manager-react to invoke MCP tools with configurable types - Enhanced CLI with new commands and improved help text - Added comprehensive documentation for new CLI commands - Improved tool configuration management Testing - Added tg-invoke-mcp-tool CLI command for isolated MCP integration testing - Enhanced agent capability to invoke multiple tools simultaneously
87 lines
1.7 KiB
Python
Executable file
87 lines
1.7 KiB
Python
Executable file
#!/usr/bin/env python3
|
|
|
|
"""
|
|
Dumps out the current agent tool configuration
|
|
"""
|
|
|
|
import argparse
|
|
import os
|
|
from trustgraph.api import Api, ConfigKey
|
|
import json
|
|
import tabulate
|
|
import textwrap
|
|
|
|
default_url = os.getenv("TRUSTGRAPH_URL", 'http://localhost:8088/')
|
|
|
|
def show_config(url):
|
|
|
|
api = Api(url).config()
|
|
|
|
values = api.get([
|
|
ConfigKey(type="agent", key="tool-index")
|
|
])
|
|
|
|
ix = json.loads(values[0].value)
|
|
|
|
values = api.get([
|
|
ConfigKey(type="agent", key=f"tool.{v}")
|
|
for v in ix
|
|
])
|
|
|
|
for n, key in enumerate(ix):
|
|
|
|
data = json.loads(values[n].value)
|
|
|
|
table = []
|
|
|
|
table.append(("id", data["id"]))
|
|
table.append(("name", data["name"]))
|
|
table.append(("description", data["description"]))
|
|
table.append(("type", data["type"]))
|
|
|
|
for n, arg in enumerate(data["arguments"]):
|
|
table.append((
|
|
f"arg {n}",
|
|
f"{arg['name']}: {arg['type']}\n{arg['description']}"
|
|
))
|
|
|
|
|
|
print()
|
|
print(key + ":")
|
|
|
|
print(tabulate.tabulate(
|
|
table,
|
|
tablefmt="pretty",
|
|
maxcolwidths=[None, 70],
|
|
stralign="left"
|
|
))
|
|
|
|
print()
|
|
|
|
def main():
|
|
|
|
parser = argparse.ArgumentParser(
|
|
prog='tg-show-tools',
|
|
description=__doc__,
|
|
)
|
|
|
|
parser.add_argument(
|
|
'-u', '--api-url',
|
|
default=default_url,
|
|
help=f'API URL (default: {default_url})',
|
|
)
|
|
|
|
args = parser.parse_args()
|
|
|
|
try:
|
|
|
|
show_config(
|
|
url=args.api_url,
|
|
)
|
|
|
|
except Exception as e:
|
|
|
|
print("Exception:", e, flush=True)
|
|
|
|
main()
|
|
|