Aller au contenu principal

Scan de secrets pour les outils de codage IA

Les développeurs s'appuient de plus en plus sur des outils de codage IA comme Cursor, Claude Code et Codex pour écrire et modifier du code. Ces outils peuvent involontairement exposer des secrets : un développeur peut coller des identifiants dans un prompt, ou l'agent IA peut lire un fichier ou exécuter une commande contenant des clés API ou des tokens. Une fois qu'un secret atteint le modèle IA, il peut être journalisé, mis en cache ou envoyé à des services tiers.

ggshield s'intègre aux outils de codage IA via leurs systèmes de hooks pour scanner les interactions en temps réel. Lorsqu'un secret est détecté, ggshield bloque l'action avant qu'elle n'atteigne le modèle et indique au développeur de retirer le secret.

Fonctionnement

Les outils de codage IA prennent en charge les hooks : des commandes personnalisées qui s'exécutent à des moments précis durant une interaction IA. ggshield s'enregistre comme un hook et scanne le contenu à trois étapes :

ÉtapeCe qu'il faitComportement
Soumission du promptScanne le prompt de l'utilisateur avant qu'il ne soit envoyé au modèle IABloque le prompt si des secrets sont détectés
Pré-utilisation d'outilScanne les commandes, lectures de fichiers et appels MCP avant que l'IA ne les exécuteBloque l'action si des secrets sont détectés
Post-utilisation d'outilScanne les sorties des outils après exécutionEnvoie une notification de bureau si des secrets sont détectés

ggshield utilise le même moteur de détection que toutes les autres commandes de scan, couvrant plus de 500 types de secrets.

Prérequis

  • ggshield version 1.49.0 ou ultérieure (1.51.0 ou ultérieure pour Codex)
  • Une clé API GitGuardian (voir Démarrer)
  • L'un des outils de codage IA pris en charge : Cursor, Claude Code, Codex, ou VS Code avec GitHub Copilot

Installation

ggshield fournit un installateur en une seule commande qui écrit la configuration de hook correcte pour chaque outil.

Cursor

ggshield install -t cursor -m global

Cela écrit les hooks dans votre fichier global .cursor/hooks.json. Pour installer uniquement pour le projet courant :

ggshield install -t cursor -m local

La configuration générée enregistre ggshield sur les trois étapes de hook (soumission du prompt, pré-utilisation d'outil et post-utilisation d'outil).

Claude Code

ggshield install -t claude-code -m global

Cela écrit les hooks dans votre fichier global .claude/settings.json. Pour installer uniquement pour le projet courant :

ggshield install -t claude-code -m local

La configuration générée enregistre ggshield sur les trois étapes de hook (soumission du prompt, pré-utilisation d'outil et post-utilisation d'outil).

Codex

ggshield install -t codex -m global

Cela écrit les hooks dans votre fichier global ~/.codex/hooks.json. Pour installer uniquement pour le projet courant :

ggshield install -t codex -m local

La configuration générée enregistre ggshield sur les trois étapes de hook (soumission du prompt, pré-utilisation d'outil et post-utilisation d'outil).

VS Code avec GitHub Copilot

ggshield install -t copilot -m global

Cela écrit les hooks dans vos paramètres globaux VS Code. Pour installer uniquement pour le projet courant :

ggshield install -t copilot -m local

vscode est accepté comme alias pour copilot (ggshield install -t vscode …).

La configuration générée enregistre ggshield sur les trois étapes de hook (soumission du prompt, pré-utilisation d'outil et post-utilisation d'outil).

astuce

Si vous avez déjà des configurations de hook pour l'outil cible, ggshield fusionne ses hooks dans le fichier existant sans toucher aux autres hooks. Utilisez --force pour écraser les hooks propres à ggshield (par exemple, s'ils ont été personnalisés et que vous souhaitez les réinitialiser).

Ce que le développeur voit

Lorsque ggshield détecte un secret, l'outil de codage IA affiche un message bloquant. Par exemple, dans Cursor :

Detected 1 secret

  • Google API Key (valid): AIzaSyC****************-*********d5oii7Y

Please remove the secrets from the content before proceeding.

Le prompt ou l'action est bloqué(e) jusqu'à ce que le développeur retire le secret et réessaie.

Pour les détections post-utilisation d'outil (lorsque l'action a déjà été exécutée), ggshield envoie une notification de bureau pour alerter le développeur.

Gestion des faux positifs

Si ggshield bloque une action sur un secret qui est un faux positif connu, vous pouvez indiquer à ggshield de l'ignorer :

ggshield secret ignore --last-found

Cela ajoute le secret détecté à votre liste d'exclusion .gitguardian.yaml. Les scans futurs (y compris les scans de hook IA) l'ignoreront.

Désinstallation

Pour supprimer les hooks, supprimez les entrées ggshield du fichier de configuration de l'outil :

  • Cursor : .cursor/hooks.json
  • Claude Code : .claude/settings.json
  • Codex : .codex/hooks.json
  • VS Code avec GitHub Copilot : paramètres VS Code

Voir aussi