huluti/doctrine-relations-analyser

A Symfony bundle that provides tools for analyzing Doctrine relationships

Fund package maintenance!
Liberapay

Installs: 2 800

Dependents: 0

Suggesters: 0

Security: 0

Stars: 12

Watchers: 1

Forks: 1

Open Issues: 0

Type:symfony-bundle

pkg:composer/huluti/doctrine-relations-analyser

0.6.0 2025-05-26 12:37 UTC

This package is auto-updated.

Last update: 2025-09-26 13:17:54 UTC


README

Packagist Version Packagist License Packagist Downloads

Overview

Doctrine Relations Analyzer is a tool designed to analyze and visualize cascade relationships within Doctrine ORM entities in Symfony projects. It helps developers understand how deletion operations propagate through related entities and assists in identifying potential issues or optimizations in data management strategies.

Note

Why is it important?

Managing cascade operations, especially deletions, is crucial to avoid unintentional data loss. This tool provides a human-readable summary to help developers review and understand these relationships, ensuring they are intentional and correctly implemented.

Warning

This project is a work in progress. Contributions and feedback are welcome.
It is currently in an exploratory or "discovery" phase, which means many things are subject to change — including configuration formats, naming conventions, and APIs.
We're very open to suggestions and improvements, and that's why we're keeping the version under 0.x for now.

Usage

Requirements

  • PHP >= 8.1
  • Symfony >= 6.4
  • Doctrine 2|3
  • Graphviz package:
    • For Alpine Linux: graphviz fontconfig ttf-freefont

Installation

Applications that use Symfony Flex

Open a command console, enter your project directory and execute:

composer require --dev huluti/doctrine-relations-analyser

Applications that don't use Symfony Flex

Step 1: Download the Bundle

Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:

composer require --dev huluti/doctrine-relations-analyser
Step 2: Enable the Bundle

Then, enable the bundle by adding it to the list of registered bundles in the config/bundles.php file of your project:

// config/bundles.php

return [
    // ...
    DoctrineRelationsAnalyserBundle\DoctrineRelationsAnalyserBundle::class => ['dev' => true, 'test' => true],
];

Usage

Analysis

Command to easily visualise the relationships between Doctrine entities

php bin/console doctrine-relations-analyser:analyse
Command-line Arguments
  • --entities: Optional. Comma-separated list of entities to analyze
  • -m, --mode: Optional. Analysis mode (all, deletions) [default: "all"]
  • -o, --output: Optional. Output path for reports generated
  • -g, --graph: Optional. Generate Graphviz graph
  • --graph-format: Optional. Graph image format (png, svg) [default: "png"]
  • -V, --version: Optional. Display help for the given command. When no command is given display help for the list command
  • -h, --help: Optional. Display this application version

Examples

To check deletion relations of two entities in a graph:

php bin/console doctrine-relations-analyser:analyse -o data/ -g --entities="App\\Entity\\User,App\\Entity\\Workspace" -m deletions

Validation

Command to validate Doctrine relationships between entities against configuration file of bundle. It can be integrated into CI/CD pipelines to ensure that the expected relationships are maintained.

php bin/console doctrine-relations-analyser:validate
Configuration file

The configuration file is located at config/packages/doctrine_relations_analyser.yaml. It allows you to define the expected relationships between entities, including which entities should be deleted when a parent entity is deleted.

# config/packages/doctrine_relations_analyser.yaml
doctrine_relations_analyser:
  entities:
    DoctrineRelationsAnalyserBundle\Tests\Entity\Post:  # to customize with your own entities
      relations:
        comments:
          class: DoctrineRelationsAnalyserBundle\Tests\Entity\Comment  # to customize with your own entities
          deletion: true
          deletion_type: database  # or 'orm'
Command-line Arguments
  • -V, --version: Optional. Display help for the given command. When no command is given display help for the list command
  • -h, --help: Optional. Display this application version

Limitations

  • Only work with first joinColumn for now.

Contributions

Contributions are welcome! If you have ideas for improvements, new features, or bug fixes, please open an issue or a pull request.

Interesting readings

Donations

Do you like the tool? Would you like to support its development? Feel free to donate 🤗

Liberapay receiving Liberapay patrons

License

This project is licensed under the MIT License.