This is a bare bones example server designed for testing MCP Streamable HTTP protocol functionality. It is NOT intended for production use and lacks proper authentication and security measures.
A Model Context Protocol (MCP) server providing time-related tools, implemented as a Cloudflare Worker.
This server allows LLMs to access various date/time functions.
Provides the following MCP tools:
current_time: Get the current date and time in specified formats and timezones.relative_time: Get a human-readable relative time string (e.g., "in 5 minutes", "2 hours ago").days_in_month: Get the number of days in a specific month.get_timestamp: Get the Unix timestamp (milliseconds) for a given time.convert_time: Convert a time between different IANA timezones.get_week_year: Get the week number and ISO week number for a given date.
mcp-server-http-time/
├── src/
│ └── index.ts # Cloudflare Worker entry point & MCP logic
├── package.json # Project dependencies and scripts
├── tsconfig.json # TypeScript configuration
└── wrangler.toml # Cloudflare Worker configuration
- Clone the Repository:
git clone https://github.com/Cam10001110101/mcp-server-http-time.git cd mcp-server-http-time
-
Install Dependencies:
npm install
-
Build: Compile the TypeScript code:
npm run build
(This compiles
src/index.tstodist/index.js) -
Local Development (using Wrangler): Run the worker locally for testing:
npx wrangler dev
This will typically start the server on
http://localhost:8787. You can then point your MCP client configuration to this local endpoint.
Before deploying, you need to configure your Cloudflare Worker:
-
Copy the example configuration file:
cp wrangler.toml.example wrangler.toml
-
Edit
wrangler.tomlto configure your domain (optional):- Uncomment and modify the
[[routes]]section if you want to use a custom domain - Replace
your-subdomain.your-domain.comwith your actual domain - Update
zone_namewith your domain
- Uncomment and modify the
Deploy the worker to Cloudflare:
npx wrangler deploy(Ensure you are logged into Cloudflare via wrangler login first).
NEW: Major providers have adopted the Model Context Protocol and now support Streamable HTTP servers directly. Anthropic, OpenAI, and Microsoft have all adopted this modern transport protocol.
📋 Protocol Note: Streamable HTTP is the modern replacement for the deprecated HTTP+SSE transport.
Anthropic's MCP Connector allows you to use Streamable HTTP servers directly through the Messages API without needing a separate MCP client.
The MCP Connector is perfect for this server since it uses the Streamable HTTP architecture. Simply include the server in your API requests:
curl https://api.anthropic.com/v1/messages \
-H "Content-Type: application/json" \
-H "X-API-Key: $ANTHROPIC_API_KEY" \
-H "anthropic-version: 2023-06-01" \
-H "anthropic-beta: mcp-client-2025-04-04" \
-d '{
"model": "claude-sonnet-4-20250514",
"max_tokens": 1000,
"messages": [{
"role": "user",
"content": "What time is it in Tokyo?"
}],
"mcp_servers": [{
"type": "url",
"url": "https://your.worker.url.workers.dev",
"name": "http-time-server"
}]
}'- No client setup required - Connect directly through the API
- Native Streamable HTTP support - Designed for servers like this one
OpenAI also supports Streamable HTTP servers through their Agents SDK using the MCPServerStreamableHttp class:
from agents.mcp.server import MCPServerStreamableHttp
# Connect to this Streamable HTTP server
server = MCPServerStreamableHttp({
"url": "https://your.worker.url.workers.dev",
"headers": {"Authorization": "Bearer your-token"}, # if needed
})
# Use the server in your OpenAI agent
await server.connect()
tools = await server.list_tools()
result = await server.call_tool("current_time", {"timezone": "Asia/Tokyo"})Microsoft Copilot Studio now supports Streamable HTTP servers with MCP integration generally available. You can connect this server to Copilot Studio by:
- Building a custom connector that links your MCP server to Copilot Studio
- Adding the tool in Copilot Studio by selecting 'Add a Tool' and searching for your MCP server
- Using the server directly in your agents with generative orchestration enabled
Keep an eye out as more MCP clients adopt support for Streamable HTTP. Here are a few resources that maintain lists of MCP clients and their capabilities:
- PulseMCP Client Directory - Comprehensive list of MCP clients
- Official MCP Servers Repository - Official collection including client information
- MCP.so Client Listings - Community-maintained client directory
The easiest way to test and validate your MCP server is using the official MCP Inspector tool. This web-based interface allows you to connect to your server and test all available tools interactively.
-
Start your server (either locally or deploy to Cloudflare):
# Local development npx wrangler dev # Or use your deployed Cloudflare Worker URL # https://your.worker.url.workers.dev
-
Open the MCP Inspector in your browser:
- Go to: https://github.com/modelcontextprotocol/inspector
- Or run locally:
npx @modelcontextprotocol/inspector
-
Configure the connection:
- Select "Streamable HTTP" as the transport type
- Enter your server URL:
- Local:
http://localhost:8787 - Deployed:
https://your.worker.url.workers.dev
- Local:
- Click "Connect"
-
Test the tools:
- Navigate to the "Tools" tab
- Click "List Tools" to see all available functions
- Select any tool to view its schema and parameters
- Test tools by providing parameters and clicking "Run"
The inspector will show all six time-related tools:
current_time: Test with different timezones (e.g., "America/New_York", "Europe/London")relative_time: Test with various time strings (e.g., "2024-12-25T00:00:00Z")days_in_month: Test with different months and yearsget_timestamp: Convert date-time strings to Unix timestampsconvert_time: Convert between different timezonesget_week_year: Get week numbers for specific dates
Try these test cases in the inspector:
// current_time
{"timezone": "Asia/Tokyo", "format": "iso"}
// relative_time
{"time": "2024-12-25T00:00:00Z"}
// days_in_month
{"month": 2, "year": 2024}
// get_timestamp
{"time": "2024-06-15T12:00:00Z"}
// convert_time
{"time": "2024-06-15T12:00:00", "from": "UTC", "to": "America/Los_Angeles"}
// get_week_year
{"date": "2024-06-15"}Use the inspector to verify:
- ✅ Server connects successfully
- ✅ All 6 tools are listed
- ✅ Tool schemas are properly defined
- ✅ Tools execute without errors
- ✅ Results are formatted correctly
- ✅ Error handling works for invalid inputs
The MCP Inspector provides the most comprehensive way to test your server before integrating it with AI clients.
For production MCP servers, you should implement proper authentication as outlined in the official MCP documentation