
Mcp Server Patterns
Implement or extend MCP servers in Node/TypeScript with correct tools, resources, prompts, validation, and transport choice.
Overview
MCP Server Patterns is an agent skill most often used in Build (also Ship testing and Operate iterate) that teaches Node/TypeScript MCP server design—tools, resources, prompts, validation, and stdio vs HTTP transport.
Install
npx skills add https://github.com/affaan-m/everything-claude-code --skill mcp-server-patternsWhat is this skill?
- Covers MCP tools, read-only resources, and parameterized prompts with SDK registration patterns
- Guidance on Zod validation and stdio vs Streamable HTTP transport selection
- Points to Context7 and official MCP docs because SDK method names evolve
- Links capability-surface selection (rule vs skill vs MCP vs CLI) for architecture decisions
- Use when debugging registration, transport, or SDK upgrade breaks
- Three MCP surface types: tools, resources, prompts
- Two transport modes emphasized: stdio and Streamable HTTP
Adoption & trust: 4.1k installs on skills.sh; 210k GitHub stars; 3/3 security scanners passed (skills.sh audits).
What problem does it solve?
You need agents to call your app safely, but ad-hoc scripts do not register on the protocol and SDK transport choices are easy to get wrong.
Who is it for?
Indie devs adding first-party MCP integrations to Claude Code, Cursor, or Desktop using TypeScript.
Skip if: Pure Python MCP stacks with no Node/TS footprint, or teams that only need a one-off shell script without protocol exposure.
When should I use this skill?
Implementing a new MCP server, adding tools or resources, choosing stdio vs HTTP, upgrading the SDK, or debugging MCP registration and transport issues.
What do I get? / Deliverables
You implement a maintainable MCP server with validated tool contracts and the right transport so clients can discover and invoke your capabilities reliably.
- MCP server with registered tools/resources/prompts
- Validated input schemas
- Working transport configuration
Recommended Skills
Journey fit
Spans multiple journey phases - primary shelf plus alternate fits below.
Builders add agent-callable surfaces during product construction; MCP servers are core agent-tooling infrastructure. Agent-tooling is the shelf for MCP SDK patterns—registration, transports, and protocol semantics—not generic backend CRUD.
Where it fits
Scaffold a new MCP server that exposes your SaaS search as a Zod-validated tool.
Choose HTTP transport so a remote teammate’s Cursor instance can reach your staging MCP host.
Verify tool list registration after an SDK bump before shipping to production agents.
Refactor resource handlers when URI schemes change without breaking Desktop clients.
How it compares
Protocol implementation patterns for MCP servers—not a marketplace skill pack and not a hosted MCP product.
Common Questions / FAQ
Who is mcp-server-patterns for?
Solo builders and small teams implementing MCP servers who already use Node/TypeScript and want SDK-aligned structure instead of copy-paste snippets.
When should I use mcp-server-patterns?
Use in Build/agent-tooling when scaffolding a server; in Ship/testing when verifying tool registration; in Operate/iterate when upgrading the MCP SDK or switching stdio to HTTP.
Is mcp-server-patterns safe to install?
The skill is documentation-style patterns; review the Security Audits panel on this page and harden any server you build with least-privilege tools and no exposed secrets.
SKILL.md
READMESKILL.md - Mcp Server Patterns
# MCP Server Patterns The Model Context Protocol (MCP) lets AI assistants call tools, read resources, and use prompts from your server. Use this skill when building or maintaining MCP servers. The SDK API evolves; check Context7 (query-docs for "MCP") or the official MCP documentation for current method names and signatures. For the broader routing decision of when a capability should be a rule, a skill, MCP, or a plain CLI/API workflow, see [docs/capability-surface-selection.md](../../docs/capability-surface-selection.md). ## When to Use Use when: implementing a new MCP server, adding tools or resources, choosing stdio vs HTTP, upgrading the SDK, or debugging MCP registration and transport issues. ## How It Works ### Core concepts - **Tools**: Actions the model can invoke (e.g. search, run a command). Register with `registerTool()` or `tool()` depending on SDK version. - **Resources**: Read-only data the model can fetch (e.g. file contents, API responses). Register with `registerResource()` or `resource()`. Handlers typically receive a `uri` argument. - **Prompts**: Reusable, parameterised prompt templates the client can surface (e.g. in Claude Desktop). Register with `registerPrompt()` or equivalent. - **Transport**: stdio for local clients (e.g. Claude Desktop); Streamable HTTP is preferred for remote (Cursor, cloud). Legacy HTTP/SSE is for backward compatibility. The Node/TypeScript SDK may expose `tool()` / `resource()` or `registerTool()` / `registerResource()`; the official SDK has changed over time. Always verify against the current [MCP docs](https://modelcontextprotocol.io) or Context7. ### Connecting with stdio For local clients, create a stdio transport and pass it to your server’s connect method. The exact API varies by SDK version (e.g. constructor vs factory). See the official MCP documentation or query Context7 for "MCP stdio server" for the current pattern. Keep server logic (tools + resources) independent of transport so you can plug in stdio or HTTP in the entrypoint. ### Remote (Streamable HTTP) For Cursor, cloud, or other remote clients, use **Streamable HTTP** (single MCP HTTP endpoint per current spec). Support legacy HTTP/SSE only when backward compatibility is required. ## Examples ### Install and server setup ```bash npm install @modelcontextprotocol/sdk zod ``` ```typescript import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js"; import { z } from "zod"; const server = new McpServer({ name: "my-server", version: "1.0.0" }); ``` Register tools and resources using the API your SDK version provides: some versions use `server.tool(name, description, schema, handler)` (positional args), others use `server.tool({ name, description, inputSchema }, handler)` or `registerTool()`. Same for resources — include a `uri` in the handler when the API provides it. Check the official MCP docs or Context7 for the current `@modelcontextprotocol/sdk` signatures to avoid copy-paste errors. Use **Zod** (or the SDK’s preferred schema format) for input validation. ## Best Practices - **Schema first**: Define input schemas for every tool; document parameters and return shape. - **Errors**: Return structured errors or messages the model can interpret; avoid raw stack traces. - **Idempotency**: Prefer idempotent tools where possible so retries are safe. - **Rate and cost**: For tools that call external APIs, consider rate limits and cost; document in the tool description. - **Versioning**: Pin SDK version in package.json; check release notes when upgrading. ## Official SDKs and Docs - **JavaScript/TypeScript**: `@modelcontextprotocol/sdk` (npm). Use Context7 with library name "MCP" for current registration and transport patterns. - **Go**: Official Go SDK on GitHub (`mode