irstea / plantuml-bundle
Un bundle pour génerer des schémas UML à partir du code.
Requires
- php: ^7.1
- ext-json: *
- doctrine/doctrine-bundle: ^1.6 || ^2.0
- doctrine/orm: ^2.5
- psr/container: ^1.0
- symfony/config: ^3.0 || ^4.0
- symfony/console: ^3.0 || ^4.0
- symfony/dependency-injection: ^3.0 || ^4.0
- symfony/filesystem: ^3.0 || ^4.0
- symfony/finder: ^3.0 || ^4.0
- symfony/framework-bundle: ^3.0 || ^4.0
- symfony/http-kernel: ^3.0 || ^4.0
- symfony/process: ^3.0 || ^4.0
- symfony/security: ^3.0 || ^4.0
- webmozart/path-util: ^2.3
Requires (Dev)
- irstea/dev-pack: @stable
- irstea/phpstan-config: >=1.0.2
- phpmd/phpmd: >=2.8
- roave/security-advisories: dev-master
This package is auto-updated.
Last update: 2023-11-23 13:17:05 UTC
README
Ce bundle permet de générer des diagrammes de classe à partir des sources d'une application PHP.
Il utilise à la fois l'API de Reflection de PHP et les métadonnées de Doctrine ORM.
Le rendu se fait avec PlantUML.
Installation
Installer le package via composer :
composer require --dev irstea/plantuml-bundle
Lister le bundle dans le kernel de Symfony :
// bundles en environnement dev et test
if (in_array($this->getEnvironment(), array('dev', 'test'))) {
// ...
$bundles[] = new Irstea\PlantUmlBundle\IrsteaPlantUmlBundle();
// ...
}
Les dépendances sont dans les dépôts standards de Debian :
sudo apt-get install default-jre-headless
PlantUML peut se télécharger depuis leur site web.
Principe
Le bundle permet de générer plusieurs graphes différents, c-à-d plusieurs vues différentes des modèles. Il faut décrire ces vues dans la configuration.
Pour chaque graphe, le bundle par d'une collection de classe de départ, qu'il va analyser, regrouper et décorer. Certains décorateurs permet de "découvrir" nouvelles classes, par exemple par héritage, associations, ...
Pour chaque vue, il faut définir :
- comment trouver les classes de départ,
- quelles classes tracer et comment les regrouper,
- quelles classes décorer.
Cela correspondent respectiviement aux sections sources
, layout
et decoration
de la configuration de chaque graphe.
Nota bene : les graphes dont le nom commence par un point (.
) sont ignorés. Cela permet de définir des modèles
grâce aux systèmes d'ancres YAML.
Sources
Il y a deux façons de trouver les classes à tracer :
entities
: utilise les entités trouvées par le manager désigné parentity_manager
.classes
: charge toutes les classes trouvées dans les répertoires listés pardirectories
.
Les sections include
ou exclude
permettent de raffiner la sélection.
Layout
Le paramètre namespaces
permet choisir quel style de namespace doit être utiliser .
php
: utilise les namespaces PHP.flat
: n'utilise pas de namespaces.bundles
: regroupe les classes par bundle Symfony.entities
: regroupe les classes par "alias" Doctrine.
Les sections include
ou exclude
permettent de filtrer quelles classes seront filtrées et parcourues.
Décoration
La décoration consiste à afficher des informations sur chacune des classes. Certains décorateur ajoutent des informations dans la classe, d'autres ajoutent des liens avec d'autres classes. Sans décorateur, chaque classe ne serait qu'une boîte avec un nom, et rien d'autre.
Les décorateurs suivants sont basés sur la Reflection du PHP :
- inheritance : affiche les liens d'héritage de classe.
- traits : affiche les liens d'utilisation de trait.
- interfaces : affiche les liens d'implémentation d'interface.
- attributes : liste les attributs.
- methods : liste les méthodes.
Les décorateurs suivants sont basés sur les métadonnées Doctrine ; ils sont ignorés si la classe n'est pas une entité :
- entity : affiche le type d'entité.
- associations : affiche les associations d'entités.
- fields : affiche les définitions des champs (=colonnes) de l'entité.
Les sections include
ou exclude
permettent de filtrer quelles classes seront décorées.
Fonctionnement include/exclude
Les 3 sections peuvent contenir des sections include
et exclude
, qui permet de filter les classes par namespace ou répertoire.
Les filtres s'appliquent aux répertoires/namespaces et tous leurs sous-niveaux.
Le fonctionnement est le suivant :
- les sections vides ou absentes n'ont absolument aucun effet.
- S'il y a une section
include
, seuls les répertoires/namespaces listés seront acceptés. - S'il y a une section
exclude
, les répertoires/namespaces listés seront ignorés. - Si les deux sections sont présentes, une classe est acceptée si elle est validé par
include
ET qu'elle n'est pas ignoré par unexclude
.
Usage
Génération du source du diagramme
La génération se fait par un seule commande, qui pour l'instant ne fait qu'envoyer un fichier sur la sortie standard:
app/console irstea:plantuml:generate mongraph >mongraph.puml
Rendu graphique
Le rendu graphique se fait avec PlantUML, par exemple, pour générer un SVG :
app/console irstea:plantuml:render -o output_dir mongraph