copilot-studio-agent-direct-line-mcp
Enables interaction with Microsoft Copilot Studio Agents through the Direct Line 3.0 API, allowing users to start conversations, send messages, retrieve history, and end conversations directly from their code editor.
README
β Copilot Studio Agent Direct Line MCP Server
Easily install the Copilot Studio Agent Direct Line MCP Server for VS Code or VS Code Insiders:
This TypeScript project provides a local MCP server for Microsoft Copilot Studio Agents, enabling you to interact with your Copilot Studio Agents directly from your code editor via the Direct Line 3.0 API.
π Table of Contents
- β Copilot Studio Agent Direct Line MCP Server
- π Table of Contents
- πΊ Overview
- π Expectations
- βοΈ Features
- βοΈ Supported Tools
- π Installation & Getting Started
- π§ Configuration
- π Development
- π Usage
- ποΈ Architecture
- π Key Components
- π‘οΈ Error Handling
- π Security
- π Troubleshooting
- π§ͺ Testing
- π Contributing
- License
- π¬ Support
πΊ Overview
The Copilot Studio Agent Direct Line MCP Server brings Microsoft Copilot Studio Agent context to your development environment. Try prompts like:
- "Start a conversation with my Copilot Studio Agent"
- "Ask my agent about product sizing"
- "Send a message to the agent: What are your capabilities?"
- "Get the conversation history"
- "End the current conversation"
π Expectations
The Copilot Studio Agent Direct Line MCP Server is built with tools that are concise, simple, focused, and easy to useβeach designed for a specific scenario. We intentionally avoid complex tools that try to do too much. The goal is to provide a thin abstraction layer over the Direct Line 3.0 API, making agent interaction straightforward and letting the language model handle complex reasoning.
βοΈ Features
- β Direct Line 3.0 Integration - Full support for Microsoft Bot Framework Direct Line API
- β Token Management - Automatic token caching and proactive refresh
- β Conversation State - Manages conversation lifecycle with 30-minute idle timeout
- β MCP Tools - Four tools for agent interaction: send_message, start_conversation, end_conversation, get_conversation_history
- β Error Handling - Retry logic with exponential backoff, circuit breaker pattern
- β Input Validation - Zod schemas for type-safe validation
- β Security - Secret masking in logs, secure environment configuration
π Authentication Requirements
Important: This MCP server currently supports Copilot Studio Agents configured with "No authentication" only.
In Copilot Studio, ensure your agent's Security > Authentication setting is set to "No authentication" for this MCP server to work properly.
π§ Coming Soon: Entra ID (Azure AD) authentication support is under development and will be available in a future release.
βοΈ Supported Tools
Interact with your Copilot Studio Agent using these tools:
- send_message: Send a message to the Copilot Studio Agent and receive a response.
- start_conversation: Start a new conversation with the Agent, optionally with an initial message.
- end_conversation: End a conversation and clean up resources.
- get_conversation_history: Retrieve message history for a conversation.
π Installation & Getting Started
For the best experience, use Visual Studio Code and GitHub Copilot.
Prerequisites
- Install VS Code or VS Code Insiders
- Install Node.js 18+
- Microsoft Copilot Studio Agent with Direct Line 3.0 enabled
- Direct Line secret key from your Copilot Studio Agent
Installation
β¨ One-Click Install (Recommended)
Click one of the badges below to automatically configure the MCP server in VS Code:
After clicking, VS Code will:
- Prompt you for your Direct Line secret key
- Automatically configure the MCP server
- Start the server using
npx(no manual installation needed!)
Then:
- Select GitHub Copilot Agent Mode
- Click "Select Tools" and choose the available Copilot Studio tools
- Try a prompt like:
Start a conversation with my Copilot Studio Agent
Learn more about Agent Mode in the VS Code Documentation.
𧨠Manual Install with NPX
If you prefer manual configuration, add this to your .vscode/mcp.json file:
{
"inputs": [
{
"id": "direct_line_secret",
"type": "promptString",
"description": "Direct Line secret key from your Copilot Studio Agent"
}
],
"servers": {
"copilot-studio-agent-direct-line-mcp": {
"type": "stdio",
"command": "npx",
"args": ["-y", "copilot-studio-agent-direct-line-mcp"],
"env": {
"DIRECT_LINE_SECRET": "${input:direct_line_secret}"
}
}
}
}
Save the file and click 'Start' in the MCP Server panel. VS Code will prompt you for your Direct Line secret.
π οΈ Install from Source (For Development)
For contributing or local development:
# Clone and build
git clone https://github.com/bradcstevens/copilot-studio-agent-direct-line-mcp.git
cd copilot-studio-agent-direct-line-mcp
npm install
npm run build
# Add to .vscode/mcp.json
{
"inputs": [
{
"id": "direct_line_secret",
"type": "promptString",
"description": "Direct Line secret key from your Copilot Studio Agent"
}
],
"servers": {
"copilot-studio-agent-direct-line-mcp": {
"type": "stdio",
"command": "node",
"args": ["/absolute/path/to/copilot-studio-agent-direct-line-mcp/dist/index.js"],
"env": {
"DIRECT_LINE_SECRET": "${input:direct_line_secret}"
}
}
}
}
Important: Replace /absolute/path/to/ with the actual path to the cloned repository.
π₯ Pro Tip: Create a
.github/copilot-instructions.mdfile in your project with:This project uses Microsoft Copilot Studio Agents. Always check to see if the Copilot Studio MCP server has a tool relevant to the user's request.This will enhance your experience with GitHub Copilot Chat!
π§ Configuration
Using NPX (Recommended)
When using npx, configuration is handled through VS Code's MCP input prompts or environment variables:
- DIRECT_LINE_SECRET (required): Your Direct Line secret key from Copilot Studio
- LOG_LEVEL (optional): Logging level (default:
info) - TOKEN_REFRESH_INTERVAL (optional): Token refresh interval in milliseconds (default:
1800000= 30 minutes)
The one-click install will automatically prompt you for the Direct Line secret. For manual configuration, you can add these to the env section of your mcp.json file.
Using Source Installation
Create a .env file based on .env.example:
# Required
DIRECT_LINE_SECRET=your_direct_line_secret_here
# Optional
LOG_LEVEL=info
TOKEN_REFRESH_INTERVAL=1800000 # 30 minutes in ms
π Development
# Build
npm run build
# Development mode with watch
npm run dev
# Lint
npm run lint
# Format
npm run format
π Usage
Using with VS Code
After installation, the MCP server runs automatically when you use GitHub Copilot. The server is invoked via npx, which automatically downloads and runs the latest version from NPM.
Standalone Server Usage
You can run the server standalone for testing or integration with other MCP clients:
# Using npx (recommended)
DIRECT_LINE_SECRET=your_secret npx -y copilot-studio-agent-direct-line-mcp
# Or from source after building
node dist/index.js
The server uses stdio transport and will wait for MCP client connections.
Using the Tools
You can now interact with your Copilot Studio Agent directly from GitHub Copilot:
Start a conversation with my bot and ask about product sizing
GitHub Copilot will use the start_conversation and send_message tools to communicate with your Copilot Studio Agent.
MCP Tools Reference
send_message
Send a message to the Copilot Studio Agent.
Parameters:
message(string, required): The message textconversationId(string, optional): Conversation ID to continue existing conversation
Returns: JSON with conversationId, response, and activityId
start_conversation
Start a new conversation with the Agent.
Parameters:
initialMessage(string, optional): First message to send
Returns: JSON with conversationId, status, and optional response
end_conversation
End a conversation and clean up resources.
Parameters:
conversationId(string, required): Conversation ID to terminate
Returns: JSON with conversationId, status, and messageCount
get_conversation_history
Retrieve message history for a conversation.
Parameters:
conversationId(string, required): Conversation IDlimit(number, optional): Maximum number of messages to return
Returns: JSON with conversationId, messageCount, totalMessages, and messages array
ποΈ Architecture
src/
βββ config/ # Environment configuration with Zod validation
βββ server/ # MCP server implementation
β βββ mcp-server.ts # Main MCP server class
β βββ tool-schemas.ts # Zod validation schemas
β βββ mcp-response.ts # Response formatting & error handling
βββ services/ # Core business logic
β βββ directline-client.ts # Direct Line API client with circuit breaker
β βββ token-manager.ts # Token caching & refresh
β βββ conversation-manager.ts # Conversation lifecycle management
β βββ http-client.ts # Axios HTTP client
βββ types/ # TypeScript type definitions
βββ utils/ # Utility functions
βββ retry.ts # Retry logic with exponential backoff
βββ circuit-breaker.ts # Circuit breaker pattern
βββ secret-masking.ts # Security utilities
π Key Components
DirectLineClient
Handles all Direct Line API interactions with circuit breaker protection:
- Token generation
- Conversation creation
- Message sending
- Activity retrieval
TokenManager
Manages Direct Line tokens with:
- In-memory caching (no disk persistence for security)
- Automatic refresh 5 minutes before expiry
- Metrics tracking
ConversationManager
Tracks conversation state with:
- 30-minute idle timeout
- Watermark-based message tracking
- Message history buffering
- Automatic cleanup
CircuitBreaker
Prevents cascading failures with:
- 3 states: CLOSED, OPEN, HALF_OPEN
- Configurable failure threshold (5 failures in 30s)
- Recovery timeout (60s)
- Success threshold for recovery (3 consecutive successes)
π‘οΈ Error Handling
The server implements comprehensive error handling:
- Retry Logic: Exponential backoff (1s, 2s, 4s delays, max 3 retries)
- Circuit Breaker: Automatic fail-fast when service is degraded
- Error Classification: Categorizes errors (network, auth, rate limit, etc.)
- MCP Error Transformation: Converts internal errors to MCP-compliant responses
π Security
- No Secret Logging: Direct Line secret and tokens are never logged
- Secret Masking: Shows only first 4 and last 4 characters in logs
- Environment Validation: Zod schema validation for configuration
- In-Memory Only: No disk persistence of sensitive data
π Troubleshooting
MCP Server Not Connecting in VS Code
- Check the configuration path - Ensure the absolute path to
dist/index.jsis correct - Verify the build - Run
npm run buildto ensure TypeScript compiled successfully - Check logs - Look at VS Code logs for error messages
- Test standalone - Run
node dist/index.jsto verify the server starts without errors - Restart VS Code - After making config changes, fully quit and restart
Direct Line Connection Issues
- Verify Secret - Check that
DIRECT_LINE_SECRETis correct in your configuration - Check Bot Status - Ensure your Copilot Studio Agent is published and Direct Line channel is enabled
- Review Logs - Server logs will show connection attempts and errors
Common Errors
Failed to generate Direct Line token
- Verify your
DIRECT_LINE_SECRETis correct - Check that the Direct Line channel is enabled in Azure Bot Service
Conversation not found or expired
- Conversations expire after 30 minutes of inactivity
- Start a new conversation with
start_conversationtool
Circuit breaker is OPEN
- The server detected multiple failures and is protecting against cascading failures
- Wait 60 seconds for the circuit breaker to attempt recovery
- Check Direct Line API connectivity
Example VS Code mcp.json Configuration
Here's a complete example configuration using npx (works on all platforms):
{
"inputs": [
{
"id": "direct_line_secret",
"type": "promptString",
"description": "Direct Line secret key from your Copilot Studio Agent"
}
],
"servers": {
"copilot-studio-agent-direct-line-mcp": {
"type": "stdio",
"command": "npx",
"args": ["-y", "copilot-studio-agent-direct-line-mcp"],
"env": {
"DIRECT_LINE_SECRET": "${input:direct_line_secret}",
"LOG_LEVEL": "info",
"TOKEN_REFRESH_INTERVAL": "1800000"
}
}
}
}
Alternative: Hardcoded secret (not recommended for shared projects):
{
"servers": {
"copilot-studio-agent-direct-line-mcp": {
"type": "stdio",
"command": "npx",
"args": ["-y", "copilot-studio-agent-direct-line-mcp"],
"env": {
"DIRECT_LINE_SECRET": "your_secret_here"
}
}
}
}
π§ͺ Testing
Testing the MCP Server
The easiest way to test is through VS Code after installation:
- Install using the one-click badge or manual npx configuration
- Open GitHub Copilot Chat in Agent Mode
- Try prompts like:
- "Start a conversation with my Copilot Studio Agent"
- "Send a message: Hello, what can you help me with?"
- "Get the conversation history"
Running Test Client (For Development)
If you've cloned the repository, you can run the included test client:
# Set your Direct Line secret
export DIRECT_LINE_SECRET=your_secret_here
# Run tests
npx tsx tests/test-mcp-client.ts
This will test all 4 MCP tools and verify integration with your Copilot Studio Agent.
π Contributing
We welcome contributions! Please file issues for bugs, enhancements, or documentation improvements.
For development setup:
- Fork the repository
- Create a feature branch:
git checkout -b feature/my-feature - Make your changes
- Run tests:
npm test - Commit your changes:
git commit -am 'Add new feature' - Push to the branch:
git push origin feature/my-feature - Submit a pull request
License
Licensed under the MIT License.
π¬ Support
For issues or questions, please open an issue on GitHub.
This project is not affiliated with or endorsed by Microsoft Corporation.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.