From design-ops
Evaluates tools during /design-ops:setup by checking installation status, invoking mcp-discovery for MCP availability, and assessing API capabilities. Returns unified matrix with connection types, setup needs, and reporting options.
npx claudepluginhub opensesh/design-ops --plugin design-opsThis skill uses the workspace's default tool permissions.
Sub-agent skill for evaluating tools during `/design-ops:setup`. Coordinates MCP availability checks and API capability evaluation.
Discovers MCP servers for tools by querying npm for official/community packages, GitHub/Anthropic repos, and API docs during setup flows.
Audits repo, MCP servers, plugins, connectors, env surfaces, and harness setup; recommends top ECC-native skills, hooks, agents, workflows. Use for Claude Code setup or discovering available capabilities.
Displays MCP integration status dashboard: connected/available connectors by category (CRM, SEO, etc.), unlocked skills, coverage summary, and setup instructions. Use for verifying plugin capabilities.
Share bugs, ideas, or general feedback.
Sub-agent skill for evaluating tools during /design-ops:setup. Coordinates MCP availability checks and API capability evaluation.
When a user selects tools in the setup flow, this skill:
mcp-discovery skill for unknown toolsInvoked by /design-ops:setup during tool evaluation phase. Should run as a background sub-agent.
tools:
- name: "notion"
pillar: "operations"
- name: "figma"
pillar: "design"
- name: "substack"
pillar: "analytics"
Returns a capability matrix for each tool, including discovery metadata:
results:
- tool: notion
connection_type: mcp
mcp_name: "notion"
status: connected # connected | available | api_only | unavailable | skipped
# Discovery metadata (from mcp-discovery skill)
mcp_source: official # official | vendor | community | none
mcp_package: "@notionhq/notion-mcp-server"
mcp_confidence: high # high | medium | low
# Capabilities
capabilities:
data_types: [pages, databases, tasks, comments]
reporting:
daily: [recent_pages, task_counts, recent_comments]
weekly: [page_activity, task_completion]
monthly: [content_growth]
setup_required: false
warning: null
- tool: figma
connection_type: api
status: api_only
# Discovery metadata
mcp_source: official
mcp_package: null # MCP exists but is code-focused
mcp_confidence: low
api_docs_url: "https://www.figma.com/developers/api"
capabilities:
data_types: [files, versions, comments, users]
reporting:
daily: [files_edited, active_users]
weekly: [design_versions, comment_activity]
monthly: [project_progress]
setup_required: true
setup_instructions: "Generate API token at figma.com/developers"
note: "Official MCP is code-focused. Use API for reporting."
- tool: gitlab
connection_type: mcp
status: available
# Discovery metadata
mcp_source: community
mcp_package: "mcp-gitlab"
mcp_confidence: medium
capabilities:
data_types: [projects, commits, merge_requests, issues, pipelines]
reporting:
daily: [recent_commits, open_mrs]
weekly: [contributions, mr_activity]
setup_required: true
setup_instructions: "claude mcp add gitlab -- npx -y mcp-gitlab"
warning: "Community package - not officially supported"
warning_code: community_package
- tool: instagram
connection_type: unavailable
status: unavailable
mcp_source: none
mcp_confidence: none
reason: "API limited to business accounts with complex approval process"
alternatives: ["Buffer", "Later", "Sprout Social"]
Read ~/.claude/settings.json and check for MCP servers:
cat ~/.claude/settings.json | jq '.mcpServers'
For each tool, check:
If installed and responding → status: connected
If not installed, delegate to the mcp-discovery skill:
skill: mcp-discovery
input:
tool: "gitlab"
pillar: "design"
The discovery skill returns:
mcp_source: official | vendor | community | nonemcp_package: npm package name (or null)mcp_confidence: high | medium | lowapi_docs_url: API documentation URLrecommendation: mcp | api | both | unavailablewarning: any warnings about community packagesBased on discovery_result.recommendation:
| Recommendation | Confidence | Status | Connection Type |
|---|---|---|---|
| mcp | high | available | mcp |
| mcp | medium | available (with warning) | mcp |
| mcp | low | api_only suggested | api |
| api | — | api_only | api |
| unavailable | — | unavailable | unavailable |
For connected/available tools, populate capabilities from known data:
Operations pillar:
Design pillar:
Analytics pillar:
Notion
Google Workspace
Linear
Slack
GitHub
GitLab
Figma (API only for reporting)
Google Analytics (GA4)
Dub.co
Plausible (API only)
Substack (API only, needs wrapper)
User selects: [Notion, Google Workspace, Slack]
↓
Spawn tool-evaluator sub-agent:
- Check Notion MCP → Found, connected → status: connected
- Check Google Workspace MCP → Found, connected → status: connected
- Check Slack MCP → Not found → invoke mcp-discovery
→ mcp-discovery returns: community, medium confidence, warning
→ Slack status: available (with warning)
↓
Return capability matrix
↓
Main agent presents findings with status indicators
User selects: [GitHub, Figma]
↓
Spawn tool-evaluator sub-agent:
- Check GitHub MCP → Found, connected → status: connected
- Check Figma MCP → Found, but code-focused → invoke mcp-discovery
→ mcp-discovery returns: official but code-focused, api recommended
→ Figma status: api_only (with note)
↓
Return capability matrix
↓
Main agent guides Figma API token setup
User selects: [GA4, Substack, Instagram]
↓
Spawn tool-evaluator sub-agent:
- Check GA4 MCP → Found, connected → status: connected
- Check Substack → invoke mcp-discovery
→ Returns: no MCP, API available, needs wrapper
→ Substack status: api_only (with wrapper option)
- Check Instagram → invoke mcp-discovery
→ Returns: unavailable
→ Instagram status: unavailable
↓
Return capability matrix
↓
Main agent offers Substack wrapper creation, skips Instagram
MCP not responding:
tool: notion
connection_type: mcp
status: error
error: "MCP timeout - server not responding"
suggestion: "Restart Claude or check MCP server"
Discovery failed:
tool: unknown_tool
connection_type: unknown
status: error
error: "Discovery could not determine connection method"
suggestion: "Check if tool has public API documentation"
When invoked by setup flow:
# Pseudo-code for sub-agent task
def evaluate_tools(tools: list[dict]) -> dict:
results = []
for tool_info in tools:
tool = tool_info['name']
# Step 1: Check if already installed
mcp_info = check_installed_mcp(tool)
if mcp_info.found and mcp_info.connected:
results.append({
'tool': tool,
'connection_type': 'mcp',
'status': 'connected',
'mcp_source': 'installed',
'mcp_confidence': 'high',
'capabilities': get_capabilities(tool)
})
else:
# Step 2: Invoke mcp-discovery skill
discovery = invoke_skill('mcp-discovery', tool=tool)
# Step 3: Determine status from discovery
if discovery.recommendation == 'mcp':
if discovery.mcp_confidence == 'high':
status = 'available'
warning = None
else:
status = 'available'
warning = discovery.warning
results.append({
'tool': tool,
'connection_type': 'mcp',
'status': status,
'mcp_source': discovery.mcp_source,
'mcp_package': discovery.mcp_package,
'mcp_confidence': discovery.mcp_confidence,
'capabilities': get_capabilities(tool),
'setup_instructions': f"claude mcp add {tool} -- npx -y {discovery.mcp_package}",
'warning': warning
})
elif discovery.recommendation == 'api':
results.append({
'tool': tool,
'connection_type': 'api',
'status': 'api_only',
'mcp_source': discovery.mcp_source,
'api_docs_url': discovery.api_docs_url,
'capabilities': get_capabilities(tool),
'setup_required': True,
'note': discovery.note
})
else:
results.append({
'tool': tool,
'connection_type': 'unavailable',
'status': 'unavailable',
'mcp_source': 'none',
'reason': discovery.reason,
'alternatives': discovery.alternatives
})
return {'results': results}
skills/mcp-discovery/SKILL.md — Dynamic MCP discoveryreferences/tool-registry.md — Reference documentation (not source of truth)references/config-schema.md — Config structure for storing resultsVersion: 2.0