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 vous devez ajouter un logging structuré à une classe PHP existante dans un projet utilisant LoggableInterface.
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ûrThe 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
Ajoute LoggableInterface à la classe Commande dans src/Entity/Commande.php en suivant les règles de sécurité et d'inclusion définies.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
LoggableInterfaceest 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
];
}
}
Expert Next.js App Router
Developpement
Un skill qui transforme Claude en expert Next.js App Router.
Générateur de README
Developpement
Crée des README.md professionnels et complets pour vos projets.
Rédacteur de Documentation API
Developpement
Génère de la documentation API complète au format OpenAPI/Swagger.