Download the PHP package ahmed-bhs/doctrine-doctor without Composer
On this page you can find all versions of the php package ahmed-bhs/doctrine-doctor. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download ahmed-bhs/doctrine-doctor
More information about ahmed-bhs/doctrine-doctor
Files in ahmed-bhs/doctrine-doctor
Package doctrine-doctor
Short Description 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.
License MIT
Homepage https://github.com/ahmed-bhs/doctrine-doctor
Informations about the package doctrine-doctor
Doctrine Doctor
Runtime Analysis Tool for Doctrine ORM — Integrated into Symfony Web Profiler
Why Runtime Analysis?
Unlike static analysis tools (PHPStan, Psalm) that analyze code without execution, Doctrine Doctor:
- Detects runtime doctrine issues by analyzing real execution context (actual parameters, data volume, query plans), including N+1 queries, real query performance bottlenecks, and missing indexes.
- Integrated into your workflow: Results appear directly in Symfony Web Profiler during development
- 📍 Backtrace: Points to exact template line
- 💡 Suggestion: Use
->addSelect(..)to eager load products
Features
90+ 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
- Integrity — 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 (30 seconds)
Step 1: Install
Step 2: That's it!
Auto-configured via Symfony Flex. No YAML, no configuration files needed.
Step 3: See it in action
- Refresh any page in your Symfony app (in
devenvironment) - Open the Symfony Web Profiler (bottom toolbar)
- Click the "Doctrine Doctor" panel 🩺
Configuration (Optional)
Configure thresholds in config/packages/dev/doctrine_doctor.yaml:
Enable backtraces to see WHERE in your code issues originate:
Full configuration reference →
Example: N+1 Query Detection
| Before — 100 queries | After — 1 query |
| **Doctrine Doctor detects the N+1 pattern at runtime** — reports query count, execution time, points to the exact template line, and suggests eager loading with `addSelect()`. | |
Documentation
| Document | Description |
|---|---|
| Full Analyzers List | Complete catalog of all 90+ analyzers covering performance, security, integrity, 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 Guide for guidelines.
License
MIT License - see LICENSE for details.
All versions of doctrine-doctor with dependencies
doctrine/doctrine-bundle Version ^3.0
nikic/php-parser Version ^5.6
phpmyadmin/sql-parser Version ^6.0
symfony/framework-bundle Version ^6.0|^7.0|^8.0
webmozart/assert Version ^1.12 || ^2.0