Catalog
affaan-m/mcp-server-patterns

affaan-m

mcp-server-patterns

Build MCP servers with Node/TypeScript SDK — tools, resources, prompts, Zod validation, stdio vs Streamable HTTP. Use Context7 or official MCP docs for latest API.

global
New~1.0k
v1.1Saved May 11, 2026

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.

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 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

npm install @modelcontextprotocol/sdk zod
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 (modelcontextprotocol/go-sdk).
  • C#: Official C# SDK for .NET.
Files1
1 files · 1.0 KB

Select a file to preview

Overall Score

78/100

Grade

B

Good

Safety

85

Quality

72

Clarity

82

Completeness

68

Summary

This skill teaches developers how to build MCP (Model Context Protocol) servers using the Node/TypeScript SDK. It covers registering tools, resources, and prompts; choosing between stdio and HTTP transports; input validation with Zod; and best practices like schema-first design and error handling. The skill explicitly acknowledges SDK API evolution and directs users to official documentation for current patterns.

Detected Capabilities

code generation guidanceAPI pattern referenceschema validation (Zod)npm package installationTypeScript/Node.js developmentdocumentation reference

Trigger Keywords

Phrases that MCP clients use to match this skill to user intent.

build mcp servermcp tools setupmcp resourcesmodel context protocolstdio vs http transportmcp validation

Risk Signals

INFO

External documentation references to modelcontextprotocol.io

Multiple references throughout skill
INFO

Directs to 'Context7' for API updates, which is an external context system

Opening paragraph and multiple sections
WARNING

References changing SDK APIs without providing detailed version guards

Transport and registration sections

Referenced Domains

External domains referenced in skill content, detected by static analysis.

modelcontextprotocol.io

Use Cases

  • Implement a new MCP server for local or remote clients
  • Add tools or resources to an existing MCP server
  • Choose the right transport (stdio vs Streamable HTTP) for your deployment scenario
  • Validate MCP tool inputs using Zod schemas
  • Upgrade an MCP server when the SDK version changes
  • Debug MCP registration and transport issues

Quality Notes

  • Skill appropriately acknowledges that the MCP SDK API evolves and explicitly directs developers to official docs for current patterns
  • Clear separation of concerns: core concepts (tools, resources, prompts, transport) are well-defined before examples
  • Good use of code snippets to show basic setup, but registration examples are intentionally vague (acknowledging API drift)
  • Strong best practices section covering schema validation, error handling, idempotency, rate limiting, and versioning
  • Limitations are explicitly documented: directs users to external references (Context7 and official MCP docs) for exact API signatures
  • Transport choice guidance is clear and practical (stdio for local, Streamable HTTP for remote)
  • No edge cases documented (e.g., handling connection failures, backpressure in Streamable HTTP, large resource responses)
  • Does not provide complete working examples — examples are partial by design (to avoid lock-in to specific SDK versions)
Model: claude-haiku-4-5-20251001Analyzed: May 11, 2026

Reviews

Add this skill to your library to leave a review.

No reviews yet

Be the first to share your experience.

Version History

v1.1

Content updated

2026-04-20

Latest
v1.0

No changelog

2026-04-12

Add affaan-m/mcp-server-patterns to your library

Command Palette

Search for a command to run...