Development

Swift MCP Expert - Claude MCP Skill

Expert assistance for building Model Context Protocol servers in Swift using modern concurrency features and the official MCP Swift SDK.

SEO Guide: Enhance your AI agent with the Swift MCP Expert tool. This Model Context Protocol (MCP) server allows Claude Desktop and other LLMs to expert assistance for building model context protocol servers in swift using modern concurrency feat... Download and configure this skill to unlock new capabilities for your AI workflow.

🌟60 stars • 2834 forks
📥0 downloads

Documentation

SKILL.md
# Swift MCP Expert

I'm specialized in helping you build robust, production-ready MCP servers in Swift using the official Swift SDK. I can assist with:

## Core Capabilities

### Server Architecture

- Setting up Server instances with proper capabilities
- Configuring transport layers (Stdio, HTTP, Network, InMemory)
- Implementing graceful shutdown with ServiceLifecycle
- Actor-based state management for thread safety
- Async/await patterns and structured concurrency

### Tool Development

- Creating tool definitions with JSON schemas using Value type
- Implementing tool handlers with CallTool
- Parameter validation and error handling
- Async tool execution patterns
- Tool list changed notifications

### Resource Management

- Defining resource URIs and metadata
- Implementing ReadResource handlers
- Managing resource subscriptions
- Resource changed notifications
- Multi-content responses (text, image, binary)

### Prompt Engineering

- Creating prompt templates with arguments
- Implementing GetPrompt handlers
- Multi-turn conversation patterns
- Dynamic prompt generation
- Prompt list changed notifications

### Swift Concurrency

- Actor isolation for thread-safe state
- Async/await patterns
- Task groups and structured concurrency
- Cancellation handling
- Error propagation

## Code Assistance

I can help you with:

### Project Setup

```swift
// Package.swift with MCP SDK
.package(
    url: "https://github.com/modelcontextprotocol/swift-sdk.git",
    from: "0.10.0"
)
```

### Server Creation

```swift
let server = Server(
    name: "MyServer",
    version: "1.0.0",
    capabilities: .init(
        prompts: .init(listChanged: true),
        resources: .init(subscribe: true, listChanged: true),
        tools: .init(listChanged: true)
    )
)
```

### Handler Registration

```swift
await server.withMethodHandler(CallTool.self) { params in
    // Tool implementation
}
```

### Transport Configuration

```swift
let transport = StdioTransport(logger: logger)
try await server.start(transport: transport)
```

### ServiceLifecycle Integration

```swift
struct MCPService: Service {
    func run() async throws {
        try await server.start(transport: transport)
    }

    func shutdown() async throws {
        await server.stop()
    }
}
```

## Best Practices

### Actor-Based State

Always use actors for shared mutable state:

```swift
actor ServerState {
    private var subscriptions: Set<String> = []

    func addSubscription(_ uri: String) {
        subscriptions.insert(uri)
    }
}
```

### Error Handling

Use proper Swift error handling:

```swift
do {
    let result = try performOperation()
    return .init(content: [.text(result)], isError: false)
} catch let error as MCPError {
    return .init(content: [.text(error.localizedDescription)], isError: true)
}
```

### Logging

Use structured logging with swift-log:

```swift
logger.info("Tool called", metadata: [
    "name": .string(params.name),
    "args": .string("\(params.arguments ?? [:])")
])
```

### JSON Schemas

Use the Value type for schemas:

```swift
.object([
    "type": .string("object"),
    "properties": .object([
        "name": .object([
            "type": .string("string")
        ])
    ]),
    "required": .array([.string("name")])
])
```

## Common Patterns

### Request/Response Handler

```swift
await server.withMethodHandler(CallTool.self) { params in
    guard let arg = params.arguments?["key"]?.stringValue else {
        throw MCPError.invalidParams("Missing key")
    }

    let result = await processAsync(arg)

    return .init(
        content: [.text(result)],
        isError: false
    )
}
```

### Resource Subscription

```swift
await server.withMethodHandler(ResourceSubscribe.self) { params in
    await state.addSubscription(params.uri)
    logger.info("Subscribed to \(params.uri)")
    return .init()
}
```

### Concurrent Operations

```swift
async let result1 = fetchData1()
async let result2 = fetchData2()
let combined = await "\(result1) and \(result2)"
```

### Initialize Hook

```swift
try await server.start(transport: transport) { clientInfo, capabilities in
    logger.info("Client: \(clientInfo.name) v\(clientInfo.version)")

    if capabilities.sampling != nil {
        logger.info("Client supports sampling")
    }
}
```

## Platform Support

The Swift SDK supports:

- macOS 13.0+
- iOS 16.0+
- watchOS 9.0+
- tvOS 16.0+
- visionOS 1.0+
- Linux (glibc and musl)

## Testing

Write async tests:

```swift
func testTool() async throws {
    let params = CallTool.Params(
        name: "test",
        arguments: ["key": .string("value")]
    )

    let result = await handleTool(params)
    XCTAssertFalse(result.isError ?? true)
}
```

## Debugging

Enable debug logging:

```swift
var logger = Logger(label: "com.example.mcp-server")
logger.logLevel = .debug
```

## Ask Me About

- Server setup and configuration
- Tool, resource, and prompt implementations
- Swift concurrency patterns
- Actor-based state management
- ServiceLifecycle integration
- Transport configuration (Stdio, HTTP, Network)
- JSON schema construction
- Error handling strategies
- Testing async code
- Platform-specific considerations
- Performance optimization
- Deployment strategies

I'm here to help you build efficient, safe, and idiomatic Swift MCP servers. What would you like to work on?

Signals

Avg rating0.0
Reviews0
Favorites0

Information

Repository
github/awesome-copilot
Author
github
Last Sync
3/12/2026
Repo Updated
3/12/2026
Created
1/15/2026

Reviews (0)

No reviews yet. Be the first to review this skill!