ahmed-bhs/doctrine-doctor

Runtime analysis tool for Doctrine ORM integrated into Symfony Web Profiler. Unlike static linters, it analyzes actual query execution at runtime to detect performance bottlenecks, security vulnerabilities, and best practice violations during development with real execution context and data.

Installs: 22

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

Type:symfony-bundle

pkg:composer/ahmed-bhs/doctrine-doctor

This package is auto-updated.

Last update: 2025-11-10 21:44:49 UTC


README

Doctrine Doctor Logo

Runtime Analysis Tool for Doctrine ORM — Integrated into Symfony Web Profiler

PHP 8.1+ Symfony 6.4+ | 7.x Doctrine ORM License MIT CI PHPStan Level 9 Code Style Packagist Version

Why Runtime Analysis?

Unlike static analysis tools (PHPStan, Psalm) that analyze code without execution, Doctrine Doctor:

  • Detects runtime-only issues: N+1 queries, actual query performance, missing indexes on real database
  • Analyzes real execution context: Actual parameter values, data volumes, execution plans
  • Integrated into your workflow: Results appear directly in Symfony Web Profiler during development

Doctrine Doctor Demo

Features

66 Specialized Analyzers

  • Performance — Detects N+1 queries, missing database indexes, slow queries, excessive hydration, findAll() without limits, setMaxResults() with collection joins, too many JOINs, and query caching opportunities
  • Security — Identifies DQL/SQL injection vulnerabilities, QueryBuilder SQL injection risks, sensitive data exposure in serialization, unprotected sensitive fields, and insecure random generators
  • Code Quality — Detects cascade configuration issues, bidirectional inconsistencies, missing orphan removal, type mismatches, float usage for money, uninitialized collections, EntityManager in entities, and architectural violations
  • Configuration — Validates database charset/collation settings, timezone handling, Gedmo trait configurations, MySQL strict mode, and other database-level configurations

Quick Start

Zero configuration needed — auto-configured via Symfony Flex.

Installation

composer require --dev ahmed-bhs/doctrine-doctor

Auto-configures via Symfony Flex. Check the Doctrine Doctor panel in the Symfony Profiler.

Configuration (Optional)

Configure thresholds in config/packages/dev/doctrine_doctor.yaml:

doctrine_doctor:
    analyzers:
        n_plus_one:
            threshold: 3
        slow_query:
            threshold: 50  # milliseconds

Full configuration reference →

Example: N+1 Query Detection

**Problem** **Detection** **Solution**

Template triggers lazy loading

// Controller
$users = $repository
    ->findAll();

// Template
{% for user in users %}
    {{ user.profile.bio }}
{% endfor %}

Triggers 100 queries

Doctrine Doctor detects N+1

100 queries instead of 1

Shows exact query count, execution time, and suggests eager loading

Real-time detection

Eager load with JOIN

$users = $repository
    ->createQueryBuilder('u')
    ->leftJoin('u.profile', 'p')
    ->addSelect('p')
    ->getQuery()
    ->getResult();

Single query

Documentation

Document Description
Full Analyzers List Complete catalog of all 66 analyzers covering performance, security, code quality, and configuration - find the perfect analyzer for your specific needs
Architecture Guide Deep dive into system design, architecture patterns, and technical internals - understand how Doctrine Doctor works under the hood
Configuration Reference Comprehensive guide to all configuration options - customize analyzers, thresholds, and outputs to match your workflow
Template Security Essential security best practices for PHP templates - prevent XSS attacks and ensure safe template rendering

Contributing

See CONTRIBUTING.md for guidelines.

License

MIT License - see LICENSE for details.

Created by Ahmed EBEN HASSINE

Sponsor me on GitHub Buy Me A Coffee