mcp-rag-workflow / mcp_client.py
betki's picture
Update mcp_client.py
0716324 verified
raw
history blame
1.15 kB
"""
This is a Gradio MCP client that connects to my MCP server (mcp-rag-workflow).
This script initializes a Gradio interface for an agent that uses tools from the MCP server.
It connects to the MCP server, retrieves available tools, and sets up a chat interface where users can interact with the agent.
"""
import os
from dotenv import load_dotenv
load_dotenv() # Load environment variables from .env file
import gradio as gr
from smolagents import InferenceClientModel, CodeAgent, MCPClient
try:
mcp_client = MCPClient(
{
"url": "https://agents-mcp-hackathon-mcp-rag-workflow.hf.space/gradio_api/mcp/sse",
"transport": "sse"
}
)
tools = mcp_client.get_tools()
model = InferenceClientModel(token=os.getenv("HUGGINGFACE_API_TOKEN"))
agent = CodeAgent(tools=[*tools], model=model)
demo = gr.ChatInterface(
fn=lambda message, history: str(agent.run(message)),
type="messages",
title="Agent with MCP Tools",
description="MCP Client build with Gradio to use (mcp-rag-workflow) MCP tools.",
)
demo.launch()
finally:
mcp_client.disconnect()