sonata-project / EntityAuditBundle

Audit for Doctrine Entities
https://sonata-project.org
MIT License
633 stars 261 forks source link

Argument 3 passed to SimpleThings\EntityAudit\Revision::__construct() must be of the type string, null given #457

Closed soullivaneuh closed 2 years ago

soullivaneuh commented 2 years ago

Environment

composer show --latest 'sonata-project/*'

Sonata packages

show

``` $ composer show --latest 'sonata-project/*' sonata-project/admin-bundle 3.105.0 4.2.1 The missing Symfony Admin Generator sonata-project/block-bundle 3.23.0 4.8.0 Symfony SonataBlockBundle sonata-project/cache 2.1.1 2.2.0 Cache library sonata-project/core-bundle 3.20.0 3.20.0 Symfony SonataCoreBundle (abandoned) Package sonata-project/core-bundle is abandoned, you should avoid using it. No replacement was suggested. sonata-project/doctrine-extensions 1.12.0 1.14.0 Doctrine2 behavioral extensions sonata-project/doctrine-orm-admin-bundle 3.35.0 4.1.0 Integrate Doctrine ORM into the SonataAdminBundle sonata-project/entity-audit-bundle 1.3.0 1.6.0 Audit for Doctrine Entities sonata-project/exporter 2.6.2 2.8.0 Lightweight Exporter library sonata-project/form-extensions 0.1.2 1.12.1 Symfony form extensions sonata-project/intl-bundle 2.7.0 2.10.2 Symfony SonataIntlBundle sonata-project/twig-extensions 0.1.1 1.9.0 Sonata twig extensions ```

Symfony packages

show

``` $ composer show --latest 'symfony/*' symfony/asset v5.2.4 v5.3.4 Manages URL generation and versioning of web assets such as CSS stylesheets, JavaScript files and image files symfony/browser-kit v5.2.0 v5.3.4 Symfony BrowserKit Component symfony/cache v5.2.6 v5.3.10 Provides an extended PSR-6, PSR-16 (and tags) implementation symfony/cache-contracts v2.4.0 v2.4.0 Generic abstractions related to caching symfony/config v4.4.30 v5.3.10 Helps you find, load, combine, autofill and validate configuration values of any kind symfony/console v4.4.30 v5.3.10 Eases the creation of beautiful and testable command line interfaces symfony/contracts v1.1.0 v2.4.0 A set of abstractions extracted out of the Symfony components symfony/css-selector v5.0.8 v5.3.4 Symfony CssSelector Component symfony/debug v4.4.20 v4.4.31 Provides tools to ease debugging PHP code symfony/debug-bundle v4.4.8 v5.3.4 Symfony DebugBundle symfony/dependency-injection v4.4.21 v5.3.10 Allows you to standardize and centralize the way objects are constructed in your application symfony/deprecation-contracts v2.4.0 v2.4.0 A generic function and convention to trigger deprecation notices symfony/doctrine-bridge v4.4.31 v5.3.8 Provides integration for Doctrine with various Symfony components symfony/dom-crawler v5.2.0 v5.3.7 Symfony DomCrawler Component symfony/dotenv v4.4.8 v5.3.10 Registers environment variables from a .env file symfony/error-handler v4.4.21 v5.3.7 Provides tools to manage errors and ease debugging PHP code symfony/event-dispatcher v4.4.20 v5.3.7 Provides tools that allow your application components to communicate with each other by dispatching events and lis... symfony/event-dispatcher-contracts v1.1.9 v2.4.0 Generic abstractions related to dispatching event symfony/expression-language v4.4.20 v5.3.7 Provides an engine that can compile and evaluate expressions symfony/filesystem v4.4.27 v5.3.4 Provides basic utilities for the filesystem symfony/finder v5.2.4 v5.3.7 Finds files and directories via an intuitive fluent interface symfony/flex v1.11.0 v1.17.2 Composer plugin for Symfony symfony/form v4.4.21 v5.3.10 Allows to easily create, process and reuse HTML forms symfony/framework-bundle v4.4.21 v5.3.10 Provides a tight integration between Symfony components and the Symfony full-stack framework symfony/http-client v5.3.2 v5.3.10 Provides powerful methods to fetch HTTP resources synchronously or asynchronously symfony/http-client-contracts v2.4.0 v2.4.0 Generic abstractions related to HTTP clients symfony/http-foundation v4.4.20 v5.3.10 Defines an object-oriented layer for the HTTP specification symfony/http-kernel v4.4.21 v5.3.10 Provides a structured process for converting a Request into a Response symfony/inflector v5.2.6 v5.3.4 Converts words between their singular and plural forms (English only) Package symfony/inflector is abandoned, you should avoid using it. Use use `EnglishInflector` from the String component instead instead. symfony/intl v4.4.20 v5.3.8 Provides a PHP replacement layer for the C intl extension that includes additional data from the ICU library symfony/lock v4.4.8 v5.3.10 Symfony Lock Component symfony/messenger v4.4.19 v5.3.10 Helps applications send and receive messages to/from other applications or via message queues symfony/mime v5.2.6 v5.3.8 Allows manipulating MIME messages symfony/monolog-bridge v5.0.8 v5.3.7 Symfony Monolog Bridge symfony/monolog-bundle v3.5.0 v3.7.0 Symfony MonologBundle symfony/options-resolver v4.4.20 v5.3.7 Provides an improved replacement for the array_replace PHP function symfony/orm-pack v2.1.0 v2.1.0 A pack for the Doctrine ORM symfony/phpunit-bridge v4.4.8 v5.3.10 Symfony PHPUnit Bridge symfony/polyfill-ctype v1.23.0 v1.23.0 Symfony polyfill for ctype functions symfony/polyfill-iconv v1.15.0 v1.23.0 Symfony polyfill for the Iconv extension symfony/polyfill-intl-grapheme v1.22.1 v1.23.1 Symfony polyfill for intl's grapheme_* functions symfony/polyfill-intl-icu v1.22.1 v1.23.0 Symfony polyfill for intl's ICU-related data and classes symfony/polyfill-intl-idn v1.22.1 v1.23.0 Symfony polyfill for intl's idn_to_ascii and idn_to_utf8 functions symfony/polyfill-intl-normalizer v1.22.1 v1.23.0 Symfony polyfill for intl's Normalizer class and related functions symfony/polyfill-mbstring v1.23.1 v1.23.1 Symfony polyfill for the Mbstring extension symfony/polyfill-php72 v1.23.0 v1.23.0 Symfony polyfill backporting some PHP 7.2+ features to lower PHP versions symfony/polyfill-php73 v1.23.0 v1.23.0 Symfony polyfill backporting some PHP 7.3+ features to lower PHP versions symfony/polyfill-php80 v1.23.1 v1.23.1 Symfony polyfill backporting some PHP 8.0+ features to lower PHP versions symfony/polyfill-php81 v1.23.0 v1.23.0 Symfony polyfill backporting some PHP 8.1+ features to lower PHP versions symfony/polyfill-uuid v1.23.0 v1.23.0 Symfony polyfill for uuid functions symfony/process v4.4.8 v5.3.7 Symfony Process Component symfony/property-access v4.4.20 v5.3.8 Provides functions to read and write from/to an object or array using a simple string notation symfony/property-info v5.2.4 v5.3.8 Extracts information about PHP class' properties using metadata of popular sources symfony/proxy-manager-bridge v4.4.20 v5.3.4 Provides integration for ProxyManager with various Symfony components symfony/psr-http-message-bridge v1.3.0 v2.1.1 PSR HTTP message bridge symfony/routing v4.4.20 v5.3.7 Maps an HTTP request to a set of configuration variables symfony/security v4.4.26 v4.4.33 Provides a complete security system for your web application symfony/security-acl v3.1.1 v3.2.0 Symfony Security Component - ACL (Access Control List) symfony/security-bundle v4.4.21 v5.3.8 Provides a tight integration of the Security component into the Symfony full-stack framework symfony/serializer v4.4.20 v5.3.10 Handles serializing and deserializing data structures, including object graphs, into array structures or other for... symfony/serializer-pack v1.0.4 v1.0.4 A pack for the Symfony serializer symfony/service-contracts v2.4.0 v2.4.0 Generic abstractions related to writing services symfony/stopwatch v5.2.4 v5.3.4 Provides a way to profile code symfony/string v5.2.6 v5.3.10 Provides an object-oriented API to strings and deals with bytes, UTF-8 code points and grapheme clusters in a unif... symfony/swiftmailer-bundle v3.4.0 v3.5.2 Symfony SwiftmailerBundle symfony/templating v4.4.20 v5.3.7 Provides all the tools needed to build any kind of template system symfony/translation v4.4.21 v5.3.10 Provides tools to internationalize your application symfony/translation-contracts v2.4.0 v2.4.0 Generic abstractions related to translation symfony/twig-bridge v4.4.21 v5.3.7 Provides integration for Twig with various Symfony components symfony/twig-bundle v4.4.20 v5.3.10 Provides a tight integration of Twig into the Symfony full-stack framework symfony/validator v4.4.21 v5.3.10 Provides tools to validate values symfony/var-dumper v4.4.21 v5.3.10 Provides mechanisms for walking through any arbitrary PHP variable symfony/var-exporter v5.2.4 v5.3.8 Allows exporting any serializable PHP data structure to plain PHP code symfony/web-link v4.4.21 v5.3.4 Manages links between resources symfony/web-profiler-bundle v4.4.8 v5.3.8 Symfony WebProfilerBundle symfony/webpack-encore-bundle v1.7.3 v1.12.0 Integration with your Symfony app & Webpack Encore! symfony/yaml v4.4.21 v5.3.6 Loads and dumps YAML files ```

PHP version

$ php -v
PHP 7.4.13 (cli) (built: Dec  1 2020 04:25:48) ( NTS )
Copyright (c) The PHP Group
Zend Engine v3.4.0, Copyright (c) Zend Technologies
    with Zend OPcache v7.4.13, Copyright (c), by Zend Technologies

Subject

I have this bundle installed from a while when it was under the simplethings namespace.

I have millions of record from the revisions table with a NULL username, generated by the bundle itself.

Since v1.3.0 of this bundle, you added string typing on the Revision object: https://github.com/sonata-project/EntityAuditBundle/pull/382/files#diff-3c56e918aeda21a792f49b1172c796667fc0eeda49452c49adcabd8a983d1cd2R36

Because of that, some revision fetching crash with the following error:

TypeError:
Argument 3 passed to SimpleThings\EntityAudit\Revision::__construct() must be of the type string, null given, called in /app/vendor/php/sonata-project/entity-audit-bundle/src/AuditReader.php on line 555

  at /app/vendor/php/sonata-project/entity-audit-bundle/src/Revision.php:36
  at SimpleThings\EntityAudit\Revision->__construct('26763903', object(DateTime), null)
     (/app/vendor/php/sonata-project/entity-audit-bundle/src/AuditReader.php:555)
  at SimpleThings\EntityAudit\AuditReader->findRevisions('App\\Entity\\Ticket', array('id' => 21016))
     (/app/src/Manager/TicketManager.php:121)
  at App\Manager\TicketManager->getTimeLine(object(Ticket))
     (/app/src/Controller/TicketController.php:312)
  at App\Controller\TicketController->showAction(object(Request), object(Ticket))
     (/app/vendor/php/symfony/http-kernel/HttpKernel.php:158)
  at Symfony\Component\HttpKernel\HttpKernel->handleRaw(object(Request), 1)
     (/app/vendor/php/symfony/http-kernel/HttpKernel.php:80)
  at Symfony\Component\HttpKernel\HttpKernel->handle(object(Request), 1, true)
     (/app/vendor/php/symfony/http-kernel/Kernel.php:201)
  at Symfony\Component\HttpKernel\Kernel->handle(object(Request))
     (/app/public/index.php:34) 

This must be considered as a regression. The null value case should be considered at some point.

soullivaneuh commented 2 years ago

Surely related: https://github.com/sonata-project/EntityAuditBundle/pull/291

soullivaneuh commented 2 years ago

Note: If not having null is "the way to go", we should at least change the Doctrine data structure for that.

Currently, null values are technically allowed on the database.

soullivaneuh commented 2 years ago

Workaround for another users: Update the database like this:

update revisions set username = "" where username is null;