A powerful Model Control Protocol (MCP) server implementation for Google Dialogflow CX, enabling seamless integration between AI assistants and Google's advanced conversational platform.
π‘ Pro Tip: This server bridges the gap between AI assistants and Dialogflow CX, unlocking powerful conversational capabilities!
This project provides a suite of tools that allow AI assistants to interact with Dialogflow CX agents through a standardized protocol. The server handles all the complexity of managing conversations, processing intent detection, and interfacing with Google's powerful NLU systems.
- π Bidirectional communication with Dialogflow CX
- π― Intent detection and matching capabilities
- π€ Audio processing for speech recognition
- π Webhook request/response handling
- π Session management for persistent conversations
- π Secure API authentication
| Requirement | Description | Version |
|---|---|---|
| π Python | Programming language | 3.12+ |
| βοΈ Google Cloud | Project with Dialogflow CX enabled | Latest |
| π€ Dialogflow CX | Conversational agent | Latest |
| π API Credentials | Authentication for Google services | - |
# Clone the repository
git clone https://github.com/Yash-Kavaiya/mcp-server-conversation-agents.git
cd mcp-server-conversation-agents
# Build the Docker image
docker build -t dialogflow-cx-mcp .
# Run the container
docker run -it dialogflow-cx-mcp# Clone the repository
git clone https://github.com/Yash-Kavaiya/mcp-server-conversation-agents.git
cd mcp-server-conversation-agents
# Create a virtual environment (optional but recommended)
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
# Install the package
pip install -e .You'll need to provide the following configuration parameters:
| Parameter | Description | Example |
|---|---|---|
dialogflowApiKey |
Your Dialogflow API key | "abc123def456" |
projectId |
Google Cloud project ID | "my-dialogflow-project" |
location |
Location of the agent | "us-central1" |
agentId |
ID of your Dialogflow CX agent | "12345-abcde-67890" |
These can be set as environment variables:
export DIALOGFLOW_API_KEY=your_api_key
export PROJECT_ID=your_project_id
export LOCATION=your_location
export AGENT_ID=your_agent_idgraph TD
A[AI Assistant] <-->|MCP Protocol| B[MCP Server]
B <-->|Google API| C[Dialogflow CX]
C <-->|NLU Processing| D[Intent Detection]
C <-->|Conversation Management| E[Session Management]
B <-->|Webhooks| F[External Services]
The MCP server exposes the following tools for AI assistants:
Initialize the Dialogflow CX client with your project details.
await initialize_dialogflow(
project_id="your-project-id",
location="us-central1",
agent_id="your-agent-id",
credentials_path="/path/to/credentials.json" # Optional
)Detect intent from text input.
response = await detect_intent(
text="Hello, how can you help me?",
session_id="user123", # Optional
language_code="en-US" # Optional
)Process audio files to detect intent.
response = await detect_intent_from_audio(
audio_file_path="/path/to/audio.wav",
session_id="user123", # Optional
sample_rate_hertz=16000, # Optional
audio_encoding="AUDIO_ENCODING_LINEAR_16", # Optional
language_code="en-US" # Optional
)Match intent without affecting the conversation session.
response = await match_intent(
text="What are your hours?",
session_id="user123", # Optional
language_code="en-US" # Optional
)Parse webhook requests and create webhook responses:
# Parse a webhook request
parsed_request = await parse_webhook_request(request_json)
# Create a webhook response
response = await create_webhook_response({
"messages": ["Hello! How can I help you today?"],
"parameter_updates": {"user_name": "John"}
})Here's an example of the response format:
π Click to expand
{
"messages": [
{
"type": "text",
"content": "Hello! How can I help you today?"
}
],
"intent": {
"name": "greeting",
"confidence": 0.95
},
"parameters": {
"user_name": "John"
},
"current_page": "Welcome Page",
"session_id": "user123",
"end_interaction": false
}This project is configured to work with Smithery.ai, a platform that allows for easy deployment and management of MCP servers.
π‘ Pro Tip: Smithery.ai integration enables one-click deployment and simplified management of your Dialogflow CX MCP server!
Contributions are welcome! Please feel free to submit a Pull Request.
- π΄ Fork the repository
- π§ Create a feature branch (
git checkout -b feature/amazing-feature) - π» Commit your changes (
git commit -m 'Add some amazing feature') - π Push to the branch (
git push origin feature/amazing-feature) - π Open a Pull Request
Built with β€οΈ by the MCP Server team