detect-plugins.sh 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. #!/usr/bin/env bash
  2. # ============================================================
  3. # lib/detect-plugins.sh — Single source of truth for plugin detection
  4. # Sourced by: session-start.sh, doctor.sh, install-plugins.sh
  5. #
  6. # Each function returns 0 (detected) or 1 (not detected).
  7. # No output — callers handle messaging.
  8. # ============================================================
  9. # --- Always-on plugins ---
  10. detect_rtk() {
  11. command -v rtk &>/dev/null
  12. }
  13. detect_superpowers() {
  14. # Fast check: filesystem (plugin cache)
  15. local cache_dir="$HOME/.claude/plugins/cache"
  16. if [ -d "$cache_dir" ]; then
  17. ls "$cache_dir" 2>/dev/null | grep -qi "superpowers" && return 0
  18. fi
  19. # Slow fallback: CLI (only if fast check fails)
  20. claude plugin list 2>/dev/null | grep -qi "superpowers" && return 0
  21. return 1
  22. }
  23. detect_security_guidance() {
  24. local cache_dir="$HOME/.claude/plugins/cache"
  25. [ -d "$cache_dir" ] && ls "$cache_dir" 2>/dev/null | grep -qi "security-guidance"
  26. }
  27. # --- Toggle plugins ---
  28. detect_gstack() {
  29. [ -d "$HOME/.claude/skills/gstack" ]
  30. }
  31. detect_gsd() {
  32. # GSD v2 (gsd-pi) is a standalone CLI, not a Claude Code plugin.
  33. # Detection: check for 'gsd' binary in PATH.
  34. command -v gsd &>/dev/null
  35. }
  36. detect_frontend_design() {
  37. local cache_dir="$HOME/.claude/plugins/cache"
  38. [ -d "$cache_dir" ] && ls "$cache_dir" 2>/dev/null | grep -qi "frontend-design"
  39. }
  40. detect_plugin_dev() {
  41. # plugin-dev replaces the old "skill-creator" reference
  42. local cache_dir="$HOME/.claude/plugins/cache"
  43. [ -d "$cache_dir" ] && ls "$cache_dir" 2>/dev/null | grep -qi "plugin-dev"
  44. }
  45. detect_uiux_pro_max() {
  46. local cache_dir="$HOME/.claude/plugins/cache"
  47. [ -d "$cache_dir" ] && ls "$cache_dir" 2>/dev/null | grep -qi "ui-ux-pro-max"
  48. }
  49. detect_context7() {
  50. # Context7 CLI (ctx7) — installed globally via npm
  51. command -v ctx7 &>/dev/null
  52. }
  53. detect_ruflo() {
  54. # Ruflo CLI — installed globally via npm
  55. command -v ruflo &>/dev/null
  56. }
  57. detect_graphifyy() {
  58. # Graphifyy — codebase knowledge graph, installed via pipx
  59. command -v graphify &>/dev/null
  60. }
  61. # --- Plan detection ---
  62. detect_plan() {
  63. # Detect Claude plan: max, pro, or free.
  64. # Checks ~/.claude.json for model access hints.
  65. # Returns plan name on stdout, always exits 0.
  66. local claude_json="$HOME/.claude.json"
  67. if [ -f "$claude_json" ]; then
  68. # Max plan: has opus model access or max flag
  69. if grep -q '"planType".*"max"' "$claude_json" 2>/dev/null; then
  70. echo "max"; return 0
  71. fi
  72. # Check cached features for max indicators
  73. if grep -q '"tengu_cobalt_compass": true' "$claude_json" 2>/dev/null \
  74. && grep -q '"tengu_harbor": true' "$claude_json" 2>/dev/null; then
  75. echo "max"; return 0
  76. fi
  77. fi
  78. # Fallback: check if claude CLI reports plan
  79. local plan
  80. plan=$(claude config get planType 2>/dev/null || true)
  81. case "$plan" in
  82. max|Max|MAX) echo "max" ;;
  83. pro|Pro|PRO) echo "pro" ;;
  84. free|Free|FREE) echo "free" ;;
  85. *) echo "pro" ;; # default assumption
  86. esac
  87. }