| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- #!/usr/bin/env bash
- # ============================================================
- # lib/detect-plugins.sh — Single source of truth for plugin detection
- # Sourced by: session-start.sh, doctor.sh, install-plugins.sh
- #
- # Each function returns 0 (detected) or 1 (not detected).
- # No output — callers handle messaging.
- # ============================================================
- # --- Always-on plugins ---
- detect_rtk() {
- command -v rtk &>/dev/null
- }
- detect_superpowers() {
- # Fast check: filesystem (plugin cache)
- local cache_dir="$HOME/.claude/plugins/cache"
- if [ -d "$cache_dir" ]; then
- ls "$cache_dir" 2>/dev/null | grep -qi "superpowers" && return 0
- fi
- # Slow fallback: CLI (only if fast check fails)
- claude plugin list 2>/dev/null | grep -qi "superpowers" && return 0
- return 1
- }
- # --- Toggle plugins ---
- detect_gstack() {
- [ -d "$HOME/.claude/skills/gstack" ]
- }
- detect_gsd() {
- # GSD v2 (gsd-pi) is a standalone CLI, not a Claude Code plugin.
- # Detection: check for 'gsd' binary in PATH.
- command -v gsd &>/dev/null
- }
- # NOTE: frontend-design is a built-in Claude Code skill (/mnt/skills/public/frontend-design/).
- # It is always available and does not need detection. No detect_frontend_design() function needed.
- # NOTE: skill-creator is a built-in Claude Code skill (/mnt/skills/examples/skill-creator/).
- # It is always available and does not need detection. No detect_skill_creator() function needed.
- # NOTE: security-guidance does not exist as a plugin. RTK covers security hooks.
- # NOTE: pr-review-toolkit does not exist as a marketplace plugin.
- detect_uiux_pro_max() {
- local cache_dir="$HOME/.claude/plugins/cache"
- [ -d "$cache_dir" ] && ls "$cache_dir" 2>/dev/null | grep -qi "ui-ux-pro-max"
- }
- detect_context7() {
- # Fast check: read ~/.claude.json (MCP config) without spawning the claude CLI
- local cfg="$HOME/.claude.json"
- if [ -f "$cfg" ]; then
- grep -q "context7" "$cfg" 2>/dev/null && return 0
- fi
- # Fallback: ~/.mcp.json (project-scoped MCP config at user level)
- local mcp="$HOME/.mcp.json"
- if [ -f "$mcp" ]; then
- grep -q "context7" "$mcp" 2>/dev/null && return 0
- fi
- return 1
- }
- detect_ruflo() {
- # 1. Fast: check npm global binary
- command -v ruflo &>/dev/null && return 0
- # 2. Fast: check MCP config files (ruflo or ruvnet/claude-flow variants)
- for _cfg in "$HOME/.claude.json" "$HOME/.mcp.json"; do
- [ -f "$_cfg" ] && grep -qi "ruflo\|ruvnet\|claude-flow" "$_cfg" 2>/dev/null && return 0
- done
- # 3. Slow fallback: claude mcp list (only if fast checks fail, spawns subprocess)
- command -v claude &>/dev/null && claude mcp list 2>/dev/null | grep -qi "ruflo" && return 0
- return 1
- }
|