Ajout de logging avec LoggableInterface

VérifiéSûr

Ajoute l'interface LoggableInterface à une classe PHP et implémente la méthode toLog(). Les règles définissent les propriétés à inclure (identifiants, statuts, dates) et à exclure (mots de passe, secrets). Utile pour standardiser les logs métier lors du débogage ou du suivi d'événements.

Spar Skills Guide Bot
DeveloppementIntermédiaire
5002/06/2026
Claude Code
#php#logging#loggable-interface#code-generation

Recommandé pour

Notre avis

Ajoute automatiquement l'interface LoggableInterface et la méthode toLog() à une classe PHP, en respectant les règles de sécurité et de type.

Points forts

  • Détecte les classes liées qui implémentent déjà LoggableInterface pour les appeler dans toLog()
  • Exclut automatiquement les données sensibles (mots de passe, tokens)
  • Gère les collections avec typage précis pour PHPStan

Limites

  • Fonctionne uniquement avec des classes PHP utilisant l'interface Atournayre\Contracts\Log\LoggableInterface
  • N'effectue pas de refactorisation si la classe a déjà une méthode toLog()
  • Nécessite que les classes imbriquées soient déjà conformes pour un résultat optimal
Quand l'utiliser

Quand vous devez ajouter un logging structuré à une classe PHP existante dans un projet utilisant LoggableInterface.

Quand l'éviter

Si vous utilisez un autre système de logging (Monolog sans interface personnalisée) ou si la classe est déjà bien loguée.

Analyse de sécurité

Sûr
Score qualité85/100

The skill instructs to read and edit PHP files to add a logging interface; no execution of shell commands, no network access, and no destructive actions. Therefore, it's safe.

Aucun point d'attention détecté

Exemples

Ajouter LoggableInterface à une commande
Ajoute LoggableInterface à la classe Commande dans src/Entity/Commande.php en suivant les règles de sécurité et d'inclusion définies.
Loguer une collection d'articles
Applique le pattern LoggableInterface à la classe Panier dans src/Entity/Panier.php, en incluant les articles sous forme de collection avec count et items.

name: dev:log description: Ajoute des fonctionnalités de log au fichier en cours argument-hint: [FICHIER] allowed-tools: [Read, Edit, Grep, Glob] version: 1.0.0 license: MIT

Ajout de logging avec LoggableInterface

Instructions à Exécuter

IMPORTANT : Exécute ce workflow étape par étape :

Fichier cible : $ARGUMENTS

Workflow

1. Lire et analyser le fichier

  • Lire le contenu du fichier PHP
  • Identifier la classe principale et ses propriétés
  • Vérifier si LoggableInterface est déjà implémentée

2. Chercher les dépendances LoggableInterface

Pour chaque type-hint de propriété ou paramètre :

  • Utiliser Grep pour chercher si la classe implémente LoggableInterface
  • Noter les classes qui l'implémentent pour appeler ->toLog() dessus

3. Ajouter LoggableInterface

Si la classe n'implémente pas encore LoggableInterface :

Ajouter l'import :

use Atournayre\Contracts\Log\LoggableInterface;

Ajouter l'interface à la déclaration de classe :

final class NomClasse implements LoggableInterface

Ajouter la méthode toLog() :

/**
 * @return array<string, mixed>
 */
public function toLog(): array
{
    return [
        // Propriétés clés de l'objet
    ];
}

4. Règles pour le contenu de toLog()

Propriétés à inclure :

  • id (si présent)
  • Identifiants métier (email, code, référence...)
  • États/statuts importants
  • Dates clés (createdAt, updatedAt...)

Propriétés à exclure :

  • Mots de passe, tokens, secrets
  • Données personnelles sensibles
  • Propriétés volumineuses (blobs, textes longs)

Pour les objets imbriqués :

  • Si l'objet implémente LoggableInterface : 'relation' => $this->relation->toLog()
  • Sinon : 'relationId' => $this->relation->getId() ou ignorer

Pour les collections :

/**
 * @return array{count: int, items: array<int, array<string, mixed>>}
 */
public function toLog(): array
{
    return [
        'count' => $this->count(),
        'items' => array_map(fn ($item) => $item->toLog(), $this->items),
    ];
}

5. Vérification PHPStan

  • Toujours ajouter @return array<string, mixed> sur la méthode
  • Pour les collections : utiliser le type array shape approprié

Exemple de résultat

use Atournayre\Contracts\Log\LoggableInterface;

final class Commande implements LoggableInterface
{
    private Uuid $id;
    private string $reference;
    private Client $client;
    private \DateTimeImmutable $createdAt;
    private string $password; // Sensible, à exclure

    /**
     * @return array<string, mixed>
     */
    public function toLog(): array
    {
        return [
            'id' => $this->id->toRfc4122(),
            'reference' => $this->reference,
            'client' => $this->client->toLog(),
            'createdAt' => $this->createdAt->format('c'),
            // password exclu intentionnellement
        ];
    }
}
Skills similaires