mcp-capability-declarator
Scannednpx machina-cli add skill a5c-ai/babysitter/mcp-capability-declarator --openclawFiles (1)
SKILL.md
4.5 KB
MCP Capability Declarator
Generate MCP capability declarations from tool/resource inventory.
Capabilities
- Generate capability declarations from inventory
- Create initialization options
- Set up feature flags
- Implement capability negotiation
- Document server capabilities
- Generate capability tests
Usage
Invoke this skill when you need to:
- Declare MCP server capabilities
- Generate initialization options
- Document supported features
- Implement capability negotiation
Inputs
| Parameter | Type | Required | Description |
|---|---|---|---|
| serverName | string | Yes | Server name |
| version | string | Yes | Server version |
| tools | array | No | Tool capabilities |
| resources | array | No | Resource capabilities |
| prompts | array | No | Prompt capabilities |
Generated Patterns
TypeScript Capability Declaration
import { ServerCapabilities, InitializationOptions } from '@modelcontextprotocol/sdk/types.js';
// Server metadata
export const SERVER_INFO = {
name: 'my-mcp-server',
version: '1.0.0',
} as const;
// Capability declarations
export const CAPABILITIES: ServerCapabilities = {
tools: {
// Tool capabilities
listChanged: true,
},
resources: {
// Resource capabilities
subscribe: true,
listChanged: true,
},
prompts: {
// Prompt capabilities
listChanged: true,
},
logging: {},
};
// Tool definitions
export const TOOL_DEFINITIONS = [
{
name: 'search_files',
description: 'Search for files matching a pattern',
inputSchema: {
type: 'object',
properties: {
pattern: { type: 'string', description: 'Glob pattern' },
path: { type: 'string', description: 'Base path' },
},
required: ['pattern'],
},
},
{
name: 'read_file',
description: 'Read contents of a file',
inputSchema: {
type: 'object',
properties: {
path: { type: 'string', description: 'File path' },
},
required: ['path'],
},
},
] as const;
// Resource templates
export const RESOURCE_TEMPLATES = [
{
uriTemplate: 'file:///{path}',
name: 'File',
description: 'Access file contents',
mimeType: 'text/plain',
},
] as const;
// Create initialization options
export function createInitializationOptions(): InitializationOptions {
return {
serverInfo: SERVER_INFO,
capabilities: CAPABILITIES,
};
}
// Capability documentation
export const CAPABILITY_DOCS = `
# ${SERVER_INFO.name} v${SERVER_INFO.version}
## Supported Capabilities
### Tools
${TOOL_DEFINITIONS.map(t => `- **${t.name}**: ${t.description}`).join('\n')}
### Resources
- File access via \`file:///\` URI scheme
- Resource subscription support
- List change notifications
### Prompts
- Dynamic prompt templates
- List change notifications
## Feature Flags
- Tool list change notifications: enabled
- Resource subscriptions: enabled
`;
Python Capability Declaration
from dataclasses import dataclass
from typing import List, Dict, Any
@dataclass
class ServerInfo:
name: str = "my-mcp-server"
version: str = "1.0.0"
@dataclass
class ToolDefinition:
name: str
description: str
input_schema: Dict[str, Any]
TOOL_DEFINITIONS: List[ToolDefinition] = [
ToolDefinition(
name="search_files",
description="Search for files matching a pattern",
input_schema={
"type": "object",
"properties": {
"pattern": {"type": "string"},
"path": {"type": "string"},
},
"required": ["pattern"],
},
),
]
CAPABILITIES = {
"tools": {"listChanged": True},
"resources": {"subscribe": True, "listChanged": True},
"prompts": {"listChanged": True},
"logging": {},
}
def create_initialization_options() -> dict:
return {
"serverInfo": {
"name": ServerInfo.name,
"version": ServerInfo.version,
},
"capabilities": CAPABILITIES,
}
Workflow
- Inventory tools - List all tools
- Inventory resources - List all resources
- Define capabilities - Feature flags
- Generate declarations - Capability objects
- Create init options - Initialization
- Document capabilities - API docs
Target Processes
- mcp-server-bootstrap
- mcp-tool-implementation
- mcp-tool-documentation
Source
git clone https://github.com/a5c-ai/babysitter/blob/main/plugins/babysitter/skills/babysit/process/specializations/cli-mcp-development/skills/mcp-capability-declarator/SKILL.mdView on GitHub Overview
Generate MCP capability declarations from tool/resource inventories with proper versioning and feature flags. This skill produces typed declarations, initialization options, and capability docs to support negotiation and testing.
How This Skill Works
It ingests inventory data (tools, resources, prompts) and defines TOOL_DEFINITIONS and RESOURCE_TEMPLATES. It creates CAPABILITIES and a createInitializationOptions() function, then generates CAPABILITY_DOCS for documentation and feature flags.
When to Use It
- Declare MCP server capabilities for a new server
- Generate initialization options for deployment
- Document supported features for client integration
- Implement capability negotiation during startup
- Generate capability tests to validate support
Quick Start
- Step 1: Define SERVER_INFO with name and version
- Step 2: List TOOL_DEFINITIONS and RESOURCE_TEMPLATES to reflect inventory
- Step 3: Call createInitializationOptions() and review CAPABILITIES and CAPABILITY_DOCS
Best Practices
- Keep serverInfo in sync with actual server name and version
- Keep TOOL_DEFINITIONS inputSchemas accurate and minimal
- Describe resources with clear URI templates and mimeType in RESOURCE_TEMPLATES
- Explicitly map inventory capabilities to CAPABILITIES keys
- Regularly update CAPABILITY_DOCS and feature flags as capabilities evolve
Example Use Cases
- TypeScript capability file for my-mcp-server v1.0.0 with search_files and read_file tools enabled
- Python capability declaration showing file:///{path} resource template and subscribe/listChanged flags
- Initialize options generator producing serverInfo and capabilities for onboarding
- Documentation block listing tools/resources/prompts features and enabled flags
- Test suite that asserts capability negotiation respects tool/listChanged and resources/subscribe
Frequently Asked Questions
Add this skill to your agents