PHP implementation of the Model Context Protocol (MCP), enabling seamless integration between LLM applications and external data sources and tools.
- π Complete MCP Protocol Support - Full implementation of the MCP specification
- π§ Type-Safe - Leverages PHP 8.1+ type system with enums, union types, and strict typing
- β‘ Async First - Built on Amphp for non-blocking I/O operations
- π Multiple Transports - STDIO, HTTP Streaming, and WebSocket
- π OAuth 2.0 Ready - Built-in authentication with PKCE support
- ποΈ Framework Integration - Laravel, Symfony, and PSR-compatible design
- π¦ PSR Compliant - Follows PSR-4, PSR-7, PSR-12, and PSR-15 standards
- π‘οΈ Production Ready - Comprehensive error handling, logging, and monitoring
- π€ Agentic AI Support - Build intelligent AI agents with MCP tool orchestration
- π Real-World Examples - Complete applications (Blog CMS, Task Manager, API Gateway)
- π Comprehensive Documentation - Best-in-class documentation with tested examples
- π§ͺ Automated Testing - All documentation examples are automatically tested
- PHP 8.1+ - Leverages modern PHP features
- Composer - For dependency management
- ext-json - JSON processing
- ext-mbstring - String handling
composer require dalehurley/php-mcp-sdk
composer require dalehurley/php-mcp-sdk:dev-main
#!/usr/bin/env php
<?php
require_once __DIR__ . '/vendor/autoload.php';
use MCP\Server\McpServer;
use MCP\Server\Transport\StdioServerTransport;
use MCP\Types\Implementation;
use function Amp\async;
// Create the simplest possible MCP server
$server = new McpServer(
new Implementation(
'hello-world-server',
'1.0.0'
)
);
// Add a simple "say_hello" tool
$server->tool(
'say_hello',
'Says hello to someone',
[
'type' => 'object',
'properties' => [
'name' => [
'type' => 'string',
'description' => 'Name of the person to greet'
]
],
'required' => ['name']
],
function (array $args): array {
$name = $args['name'] ?? 'World';
return [
'content' => [
[
'type' => 'text',
'text' => "Hello, {$name}! π Welcome to MCP!"
]
]
];
}
);
// Start the server
async(function () use ($server) {
echo "π Hello World MCP Server starting...\n";
$transport = new StdioServerTransport();
$server->connect($transport)->await();
})->await();
#!/usr/bin/env php
<?php
require_once __DIR__ . '/vendor/autoload.php';
use MCP\Client\Client;
use MCP\Client\Transport\StdioClientTransport;
use MCP\Types\Implementation;
use Amp\Loop;
// Create client
$client = new Client(
new Implementation('weather-client', '1.0.0')
);
// Connect to weather server
$transport = new StdioClientTransport([
'command' => 'php',
'args' => [__DIR__ . '/weather-server.php']
]);
Amp\async(function() use ($client, $transport) {
try {
// Connect to server
yield $client->connect($transport);
echo "β
Connected to weather server\n";
// List available tools
$result = yield $client->listTools();
echo "π Available tools:\n";
foreach ($result['tools'] as $tool) {
echo " - {$tool['name']}: {$tool['description']}\n";
}
// Call the weather tool
$result = yield $client->callTool('get-weather', [
'location' => 'London, UK'
]);
echo "\nπ€οΈ Weather result:\n";
echo $result['content'][0]['text'] . "\n";
yield $client->close();
} catch (\Exception $error) {
echo "β Error: " . $error->getMessage() . "\n";
} finally {
Loop::stop();
}
});
Loop::run();
# Run the hello-world server
php examples/getting-started/hello-world-server.php
# Test with Claude Desktop by adding to your configuration:
{
"mcpServers": {
"hello-world": {
"command": "php",
"args": ["/path/to/examples/getting-started/hello-world-server.php"]
}
}
}
# Or test with the MCP Inspector (Node.js required)
npx @modelcontextprotocol/inspector examples/getting-started/hello-world-server.php
The PHP MCP SDK includes 20+ comprehensive examples across all skill levels:
- Hello World - Simplest possible server and client
- Calculator - Multi-tool server with math operations
- File Reader - Secure file system integration
- Weather Client - External API integration patterns
- Laravel Integration - Complete Laravel patterns with service container
- Symfony Integration - Full Symfony integration with DI container
- Working Agentic Demo - Rule-based agent reasoning
- Personal Assistant - Multi-MCP server coordination
- Multi-Agent Orchestrator - Specialized agent coordination
- OpenAI Integration - LLM-powered intelligent agents
- Blog CMS - Complete content management system
- Task Manager - Project management with analytics
- API Gateway - Enterprise API orchestration
- Code Analyzer - Development quality tools
- Data Pipeline - ETL and data processing
- Docker Deployment - Production containerization
- Microservices Architecture - Distributed systems patterns
- Monitoring & Observability - Production monitoring
All examples are tested and working! π
The PHP MCP SDK is designed to work with any PHP framework through its PSR-compliant architecture.
You can use the core PHP MCP SDK directly in Laravel applications:
composer require dalehurley/php-mcp-sdk
// In a Laravel controller or service
use MCP\Server\McpServer;
use MCP\Types\Implementation;
class McpController extends Controller
{
public function createServer()
{
$server = new McpServer(
new Implementation('my-laravel-app', '1.0.0')
);
// Register your tools, resources, and prompts
$server->tool('search-users', 'Search for users', [
'type' => 'object',
'properties' => [
'query' => ['type' => 'string', 'description' => 'Search query']
]
], function($params) {
return [
'content' => [
[
'type' => 'text',
'text' => json_encode(User::where('name', 'like', "%{$params['query']}%")->get())
]
]
];
});
return $server;
}
}
For a complete Laravel package with service providers, Artisan commands, and Laravel-specific features, see the separate laravel-mcp-sdk
package.
The most comprehensive MCP SDK documentation in the ecosystem is available in the docs/ directory:
- π Complete Documentation - Start here for full overview
- β‘ Quick Start Guide - Get up and running in 5 minutes
- ποΈ First Server - Build your first server in 10 minutes
- π± First Client - Build your first client in 10 minutes
- π§ Understanding MCP - Deep dive into MCP protocol
- π‘ Core Concepts - Understand MCP fundamentals
- π§ Troubleshooting - Common issues and solutions
- π± Creating Clients - Build MCP clients
- π Security Best Practices - OAuth 2.0 and security
- π οΈ Tools Guide - Server development with tools
- π Resources Guide - Server development with resources
- π€ OpenAI Integration - AI tool calling
- π FullCX Integration - Product management
- π§ Build Agentic AI Agents - Complete agentic AI tutorial
- π― Agent Examples - Working agent implementations
- π Multi-Agent Systems - Agent coordination
- π Blog CMS - Complete content management system
- π Task Manager - Project management system
- π API Gateway - Enterprise API management
- π Code Analyzer - Development quality tools
- π Data Pipeline - ETL and data processing
- π³ Docker Deployment - Containerization
- ποΈ Microservices - Distributed systems
- π Monitoring - Observability
- π§ Server API - Complete server API
- π‘ Client API - Complete client API
- π Types & Schemas - Type system reference
- π» Working Examples - 20+ tested examples
- π TypeScript Migration - Migration guide
# Run tests
composer test
# Run tests with coverage
composer test-coverage
# Run static analysis
composer phpstan
composer psalm
# Fix code style
composer cs-fix
# Run all checks
composer check
Contributions are welcome! Please read our Contributing Guide for details.
All notable changes to this project are documented in the CHANGELOG.md. Please update it when making changes.
This project is licensed under the MIT License - see the LICENSE file for details.
- Based on the MCP TypeScript SDK
- Built with Amphp for async operations
- Uses Respect/Validation for schema validation