This repo demonstrates the integration of an Azure OpenAI-powered AI agent with a Microsoft Fabric data warehouse using the Model Context Protocol (MCP), open integration standard for AI agents by Anthropic.
MCP enables dynamic discovery of tools, data resources and prompt templates (with more coming soon), unifying their integration with AI agents. GraphQL provides an abstraction layer for universal data connection. Below, you will find detailed steps on how to combine MCP and GraphQL to enable bidirectional access to enterprise data for your AI agent.
Note
In the MCP server's script, some query parameter values are hard-coded for the sake of this example. In a real-world scenario, these values would be dynamically generated or retrieved.
- Part 1: Configuring Microsoft Fabric Backend
- Part 2: Configuring Local Client Environment
- Part 3: User Experience - Gradio UI
- Part 4: Demo video on YouTube
- In Microsoft Fabric, create a new data warehouse pre-populated by sample data by clicking New item -> Sample warehouse:
- Next, create a GraphQL API endpoint by clicking New item -> API for GraphQL:
- In the data configuration of GraphQL API, choose the Trip (dbo.Trip) table:
- Copy the endpoint URL of your GraphQL API:
- Install the required Python packages, listed in the provided requirements.txt:
pip install -r requirements.txt
- Configure environmnet variables for the MCP client:
Variable | Description |
---|---|
AOAI_API_BASE |
Base URL of the Azure OpenAI endpoint |
AOAI_API_VERSION |
API version of the Azure OpenAI endpoint |
AOAI_DEPLOYMENT |
Deployment name of the Azure OpenAI model |
- Set the value of the
AZURE_FABRIC_GRAPHQL_ENDPOINT
variable with the GraphQL endpoint URL from Step 1.4 above. It will be utilised by the MCP Server script to establish connectivity with Microsoft Fabric:
Variable | Description |
---|---|
AZURE_FABRIC_GRAPHQL_ENDPOINT |
Microsoft Fabric's GraphQL API endpoint |
- Launch the MCP client in your command prompt:
python MCP_Client_Gradio.py
- Click the Initialise System button to start the MCP server and connect your AI agent to the Microsoft Fabric's GraphQL API endpoint:
- You can now pull and push data to your data warehouse using GraphQL's queries and mutations enabled by this MCP connector:
A practical demo of the provided MCP connector can be found on this YouTube video.