🤖 Agents IA

agent-claude-code-extension-builder

Construction d'extensions et skills pour Claude Code — slash commands, hooks, intégration MCP et commandes personnalisées.

⚡ Installation & lancement en 1 commande

Copiez-collez dans votre terminal : le skill s'installe dans ~/.claude/skills et Claude Code se lance directement dessus.

macOS / Linux
curl -fsSL https://raw.githubusercontent.com/khalilbenaz/claude-skills-collection/main/install.sh | sh -s -- agent-claude-code-extension-builder --launch
Windows (PowerShell)
iex "& { $(iwr -useb https://raw.githubusercontent.com/khalilbenaz/claude-skills-collection/main/install.ps1) } agent-claude-code-extension-builder -Launch"

🚀 Déjà installé ?

claude "/agent-claude-code-extension-builder"

Ou tapez /agent-claude-code-extension-builder dans une session Claude Code, ou décrivez simplement votre besoin — le skill se déclenche automatiquement via le skill-router.

🔑 Déclencheurs automatiques

Le skill s'active automatiquement quand votre demande contient :

extension Claude Codeskill Claudeslash commandClaude Code plugincustom command Claude

📦 Installation manuelle

git clone https://github.com/khalilbenaz/claude-skills-collection.git cp -r claude-skills-collection/skills/agent-claude-code-extension-builder ~/.claude/skills/

Payload du plugin : skills/agent-claude-code-extension-builder · source éditable : agent-skills/claude-code-extension-builder

📖 Manuel

Claude Code Extension Builder

Critères de décision — quel type d'extension créer ?

BesoinType d'extension
Réutiliser un workflow de promptSkill (SKILL.md)
Déclencher une action sur événement ClaudeHook (.claude/settings.json)
Exposer un outil externe (DB, API, fs)Serveur MCP
Composer plusieurs skills en une commandeSlash command custom

Workflow en étapes

1. Analyser le besoin


2. Créer un Skill (SKILL.md)

Structure minimale obligatoire :

---
name: mon-skill                    # kebab-case, unique dans la collection
description: Une ligne, termine avec les phrases de déclenchement entre guillemets. Se déclenche avec "mot-clé A", "mot-clé B".
---

# Mon Skill

## Workflow

1. **Étape 1** — description actionnable.
2. **Étape 2** — ...

## Règles

- Règle 1 (obligatoire, concise).

Bonnes pratiques :

Arborescence collection :

agent-skills/
  dev/
    mon-skill/
      SKILL.md
  devops/
    ...

3. Configurer des Hooks

Les hooks interceptent les événements Claude Code pour automatiser des actions.

Fichier : .claude/settings.json (projet) ou ~/.claude/settings.json (global).

{
  "hooks": {
    "PreToolUse": [
      {
        "matcher": "Bash",
        "hooks": [
          {
            "type": "command",
            "command": "echo '[hook] commande bash interceptée'"
          }
        ]
      }
    ],
    "PostToolUse": [
      {
        "matcher": "Write",
        "hooks": [
          {
            "type": "command",
            "command": "npx prettier --write $CLAUDE_TOOL_INPUT_FILE_PATH"
          }
        ]
      }
    ],
    "Stop": [
      {
        "hooks": [
          {
            "type": "command",
            "command": "node scripts/notify-slack.js"
          }
        ]
      }
    ]
  }
}

Événements disponibles : PreToolUse, PostToolUse, Notification, Stop.

Variables d'environnement injectées :

Cas d'usage typiques :


4. Intégrer un serveur MCP

Configuration dans ~/.claude/claude_desktop_config.json :

{
  "mcpServers": {
    "mon-serveur": {
      "command": "node",
      "args": ["/chemin/vers/mon-serveur/index.js"],
      "env": {
        "API_KEY": "xxxx"
      }
    }
  }
}

Squelette de serveur MCP (Node.js + SDK officiel) :

import { Server } from "@modelcontextprotocol/sdk/server/index.js";
import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";

const server = new Server({ name: "mon-serveur", version: "1.0.0" }, {
  capabilities: { tools: {} }
});

server.setRequestHandler("tools/list", async () => ({
  tools: [{
    name: "mon_outil",
    description: "Description courte de l'outil",
    inputSchema: {
      type: "object",
      properties: { param: { type: "string", description: "Paramètre" } },
      required: ["param"]
    }
  }]
}));

server.setRequestHandler("tools/call", async (request) => {
  if (request.params.name === "mon_outil") {
    const result = await faireQuelqueChose(request.params.arguments.param);
    return { content: [{ type: "text", text: result }] };
  }
});

await server.connect(new StdioServerTransport());

Vérifier la connexion :

claude mcp list          # lister les serveurs configurés
claude mcp get mon-serveur  # détails et outils exposés

5. Créer une Slash Command custom

Les slash commands combinent plusieurs skills ou enchaînent des instructions complexes.

Emplacement : .claude/commands/<nom-commande>.md

# /mon-workflow

Effectue les étapes suivantes dans l'ordre :

1. Appelle le skill `code-review` sur les fichiers modifiés.
2. Génère un changelog depuis les commits non publiés.
3. Propose un bump de version sémantique.

Arguments : `$ARGUMENTS` (optionnels, transmis à chaque étape).

Invoquer dans Claude Code : /mon-workflow ou /mon-workflow fix bug login.


6. Tester l'extension

# Lancer Claude Code en mode verbeux pour voir les hooks déclenchés
claude --debug

# Tester un skill manuellement
claude "utilise le skill mon-skill pour analyser ce fichier"

# Valider la structure frontmatter d'un SKILL.md
head -5 agent-skills/dev/mon-skill/SKILL.md

Checklist de validation :


Garde-fous / Anti-patterns / Pièges

Anti-patternConséquenceCorrectif
Triggers trop génériques ("aide", "code")Déclenchements non voulusTriggers spécifiques de 2-3 mots
Hook sans gestion d'erreurClaude bloqué si le script plante`commandtrue ou try/catch`
MCP server avec timeout élevéRalentissement de toutes les sessionsTimeout ≤ 5 s, async non-bloquant
Sections ## Communication Rules dans le corpsDoublon cassant le skillSupprimer — section auto-injectée
name avec espaces ou majusculesProblème de résolution du skillToujours kebab-case
Skill > 200 lignesDilution des instructions clésDécouper en sous-skills dédiés
Pas de required dans le schema MCPParamètres silencieusement ignorésToujours déclarer required: [...]

Bonnes pratiques 2026