Changes in site building process can run into Cannot access offset of type StringTranslation\TranslatableMarkup on field creation path

Created on 19 September 2024, 7 months ago

Problem/Motivation

Under hard to tackle down circumstances an error makes admin paths like  admin/structure/types/manage/node-type/fields/add-field inaccessible with WSOD making it impossible to create new fields on any content or custom entity type from the UI:

Cannot access offset of type Drupal\Core\StringTranslation\TranslatableMarkup in isset or empty in Drupal\Core\Plugin\DefaultPluginManager->doGetDefinition() (line 45 of core/lib/Drupal/Component/Plugin/Discovery/DiscoveryTrait.php).

DiscoveryTrait.php did not help me a lot on api.d.org to bring up more here or where to look at or to investigate further. Usually you would get a listing of field types at that point entering the field creation path, so maybe it belongs to query existing field types or the admin UI of that path.

Reusing an existing field works without issues from UI and this is probably why we discovered the issue too late to have an idea what change here lately has caused this. But the irreversible behavior and WSOD made me consider a core issue report, because we maybe do have an underlying problem here where contrib modules do something they should not be allowed to causing breaking core.

Steps to reproduce

Sadly this will be hard to reproduce and is probably caused by left overs from module configurations and installations and deinstallations and many back and forth in the site building process. We discovered this on a Drupal 11.04 upgraded project which came from 10.3.3 with far too much contrib modules. All uninstalled step by step in the hope to find the one maybe causing this. First of all of course we thought modules creating new field types are suspicious but non of the uninstalls stopped this error.

Furthermore this error depends on UI because the field creation process via console (drush field:create) works without flaws.

Proposed resolution

There are some issues open mentioning TranslatableMarkup and other Cannot access offset of type xxx issues all not related in that sense but interestingly enough most of the latter raised in the last 2 years. So it probably belongs to newer PHP versions being more strict in the requirements of type checking and error behavior. Mainly in cases where array are empty or similar. Some of the issues discuss is_array() and similar workarounds.

Maybe related but I did not wanted to reference them yet if not, to prevent unnecessary noise:

Remaining tasks

Needs more steps/tests to reproduce.

Full error log

The website encountered an unexpected error. Try again later.  

TypeError: Cannot access offset of type Drupal\Core\StringTranslation\TranslatableMarkup in isset or empty in Drupal\Core\Plugin\DefaultPluginManager->doGetDefinition() (line 45 of core/lib/Drupal/Component/Plugin/Discovery/DiscoveryTrait.php).

Drupal\Core\Plugin\DefaultPluginManager->getDefinition() (Line: 16)  
Drupal\Core\Plugin\Factory\ContainerFactory->createInstance() (Line: 76)  
Drupal\Component\Plugin\PluginManagerBase->createInstance() (Line: 136)  
Drupal\field_ui\Form\FieldStorageAddForm->processFieldDefinitions() (Line: 80)  
Drupal\field_ui\Form\FieldStorageAddForm->buildForm()  
call_user_func_array() (Line: 528)  
Drupal\Core\Form\FormBuilder->retrieveForm() (Line: 279)  
Drupal\Core\Form\FormBuilder->buildForm() (Line: 73)  
Drupal\Core\Controller\FormController->getContentResult()  
call_user_func_array() (Line: 123)  
Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->Drupal\Core\EventSubscriber\{closure}() (Line: 593)  
Drupal\Core\Render\Renderer->executeInRenderContext() (Line: 121)  
Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->wrapControllerExecutionInRenderContext() (Line: 97)  
Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->Drupal\Core\EventSubscriber\{closure}() (Line: 183)  
Symfony\Component\HttpKernel\HttpKernel->handleRaw() (Line: 76)  
Symfony\Component\HttpKernel\HttpKernel->handle() (Line: 53)  
Drupal\Core\StackMiddleware\Session->handle() (Line: 48)  
Drupal\Core\StackMiddleware\KernelPreHandle->handle() (Line: 28)  
Drupal\Core\StackMiddleware\ContentLength->handle() (Line: 32)  
Drupal\big_pipe\StackMiddleware\ContentLength->handle() (Line: 53)  
Asm89\Stack\Cors->handle() (Line: 50)  
Drupal\ban\BanMiddleware->handle() (Line: 48)  
Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle() (Line: 51)  
Drupal\Core\StackMiddleware\NegotiationMiddleware->handle() (Line: 36)  
Drupal\Core\StackMiddleware\AjaxPageState->handle() (Line: 51)  
Drupal\Core\StackMiddleware\StackedHttpKernel->handle() (Line: 709)  
Drupal\Core\DrupalKernel->handle() (Line: 19)
πŸ› Bug report
Status

Active

Version

11.0 πŸ”₯

Component
FieldΒ  β†’

Last updated about 13 hours ago

Created by

πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @dqd
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin
  • πŸ‡³πŸ‡ΏNew Zealand quietone
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin

    Thanks @quietone for correcting the version scope.

    To save time of all who want to chime in I would like to let you know: I probably am about to change the summary over the next days after more investigations again. Because we're may be on the trail of something in a bigger picture here which maybe rather leads to an FR, like:

    "Let's provide a better exception not breaking frontpage or admin pages for all the type and offset errors raising now with newer PHP versions."

  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin

    Maybe another related (still not linking them since it needs to cleared how and IF the are related really): πŸ› Cannot access offset of type Drupal\Core\StringTranslation\TranslatableMarkup in isset or empty in Drupal\update\ProjectCoreCompatibility->getPossibleCoreUpdateVersions Active

  • πŸ‡«πŸ‡·France cassien

    hi there,
    I'm facing this issue with d11.
    Everything was working pretty good, and this morning... field additions broke on content type, product types, commerce types, etc.
    I tried to trace the problem by adding a line of code in the DiscoveryTrait file :
    if (isset($plugin_id)) { print($plugin_id); echo "<br>"; }
    It results in a long list, in which the last value is "Commerce" (with cap).
    I lowercased $plugin_id, and it finally throws another error :
    TypeError: Cannot access offset of type Drupal\Core\StringTranslation\TranslatableMarkup on array in Drupal\field_ui\Form\FieldStorageAddForm->processFieldDefinitions() (line 141 of core/modules/field_ui/src/Form/FieldStorageAddForm.php).
    The last value displayed in my list is "general".
    Hope it helps ... it's my sixth hour of research :D I need a break and a pizza !

  • πŸ‡«πŸ‡·France cassien

    Ok guys,
    I have the confirmation that the issue is related to commerce in my case.
    The freak variables are isolated with this code :

        if($plugin_id=="Commerce") {
          echo "<pre>";
          print_r($definitions);
          echo "</pre><br>";
        } else {
              // Avoid using a ternary that would create a copy of the array.
              if (isset($definitions[$plugin_id])) {
                return $definitions[$plugin_id];
              }
              elseif (!$exception_on_invalid) {
                return NULL;
              }
        }
    

    The add field form is working now, even if the problem is not solved.
    At the moment I don't understand what's happening.

  • πŸ‡¨πŸ‡³China qiutuo

    I'm also getting the same error today, and the research found that it was caused by the missing "category" in the custom field.

  • Status changed to Needs work 5 months ago
  • πŸ‡«πŸ‡·France dqd London | N.Y.C | Paris | Hamburg | Berlin

    Thanks for all the reports. This indicates that we maybe need a proper exception handling and warning for such cases to prevent WSOD and sites being unmaintainable in this state.

  • I have encountered this issue as well, but in my case it was with the Prism module: https://www.drupal.org/project/prism/issues/3491768 πŸ› Prism causes WSOD on field creation for all field types Active

    In my case, I think the problem was caused by setting 'category' to a Translation in the FieldType definition.

  • First commit to issue fork.
  • πŸ‡¨πŸ‡­Switzerland berdir Switzerland

    Created a merge request that throws an exception when the field type category is not valid.

  • Pipeline finished with Success
    4 months ago
    Total: 3848s
    #368623
  • πŸ‡©πŸ‡ͺGermany Anybody Porta Westfalica

    We're running into a very similar issue in the function:

    TypeError: Cannot access offset of type Drupal\Core\StringTranslation\TranslatableMarkup on array in Drupal\Core\Plugin\DefaultPluginManager->doGetDefinition() (line 45 of core/lib/Drupal/Component/Plugin/Discovery/DiscoveryTrait.php). 
    
    Drupal\Core\Plugin\DefaultPluginManager->getDefinition() (Line: 16)
    Drupal\Core\Plugin\Factory\ContainerFactory->createInstance() (Line: 76)
    Drupal\Component\Plugin\PluginManagerBase->createInstance() (Line: 136)
    Drupal\field_ui\Form\FieldStorageAddForm->processFieldDefinitions() (Line: 80)
    Drupal\field_ui\Form\FieldStorageAddForm->buildForm()
    call_user_func_array() (Line: 528)
    Drupal\Core\Form\FormBuilder->retrieveForm() (Line: 279)
    Drupal\Core\Form\FormBuilder->buildForm() (Line: 73)
    Drupal\Core\Controller\FormController->getContentResult()
    call_user_func_array() (Line: 123)
    Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->Drupal\Core\EventSubscriber\{closure}() (Line: 593)
    Drupal\Core\Render\Renderer->executeInRenderContext() (Line: 121)
    Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->wrapControllerExecutionInRenderContext() (Line: 97)
    Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->Drupal\Core\EventSubscriber\{closure}() (Line: 183)
    Symfony\Component\HttpKernel\HttpKernel->handleRaw() (Line: 76)
    Symfony\Component\HttpKernel\HttpKernel->handle() (Line: 53)
    Drupal\Core\StackMiddleware\Session->handle() (Line: 48)
    Drupal\Core\StackMiddleware\KernelPreHandle->handle() (Line: 28)
    Drupal\Core\StackMiddleware\ContentLength->handle() (Line: 32)
    Drupal\big_pipe\StackMiddleware\ContentLength->handle() (Line: 116)
    Drupal\page_cache\StackMiddleware\PageCache->pass() (Line: 90)
    Drupal\page_cache\StackMiddleware\PageCache->handle() (Line: 50)
    Drupal\ban\BanMiddleware->handle() (Line: 96)
    Drupal\crowdsec\Middleware->handle() (Line: 263)
    Drupal\shield\ShieldMiddleware->bypass() (Line: 162)
    Drupal\shield\ShieldMiddleware->handle() (Line: 48)
    Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle() (Line: 51)
    Drupal\Core\StackMiddleware\NegotiationMiddleware->handle() (Line: 36)
    Drupal\Core\StackMiddleware\AjaxPageState->handle() (Line: 49)
    Drupal\remove_http_headers\StackMiddleware\RemoveHttpHeadersMiddleware->handle() (Line: 51)
    Drupal\Core\StackMiddleware\StackedHttpKernel->handle() (Line: 709)
    Drupal\Core\DrupalKernel->handle() (Line: 19)
    

    I'll try to find the root cause now.

  • πŸ‡©πŸ‡ͺGermany Anybody Porta Westfalica

    Update: The attached MR adding an exception with very helpful details GREAT!

    Instead of the message in #20 we now see a nice verbose error:
    Exception: Invalid field category for field typeentity_reference_display, category must be the ID of aa defined field category, got Referenz. in Drupal\field_ui\Form\FieldStorageAddForm->processFieldDefinitions() (line 136 of core/modules/field_ui/src/Form/FieldStorageAddForm.php). from which we can see it's a migration issue and how to fix this.

    RTBC! Would be nice to cherry-pick this into 10.4.x and 10.5.x

  • πŸ‡©πŸ‡ͺGermany Grevil

    Confirming RTBC and fixed typo

  • πŸ‡©πŸ‡ͺGermany Anybody Porta Westfalica

    Root cause for us (we were able to find that thank to @berdir's MR): πŸ› Using a translatable string as a category for field type is deprecated Active

  • Pipeline finished with Success
    4 months ago
    #374709
  • There's still a missing space typo.

  • πŸ‡©πŸ‡ͺGermany Anybody Porta Westfalica

    Thanks @godotislate, sorry I didn't see that. Fixed that. As both were only textual changes, I'm setting this back to RTBC, but feel free to confirm that.

  • Pipeline finished with Failed
    3 months ago
    Total: 686s
    #375686
  • Pipeline finished with Failed
    3 months ago
    Total: 416s
    #395322
  • πŸ‡³πŸ‡ΏNew Zealand quietone

    I read the IS, MR and the comments . I didn't find any unanswered questions. I did leave a comment on the MR but before taking action it would be better to get the opinion of another committer to determine if this is the correct fix.

  • πŸ‡¬πŸ‡§United Kingdom catch

    I think I agree with @quietone's review - doesn't look like it loses any information from the error message, and moving one line earlier seems fine too.

  • Pipeline finished with Success
    about 2 months ago
    Total: 382s
    #427040
  • Made the change per @quietone and @catch. Back to NR.

    Does this need a test? It was at RTBC previously without one.

  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    As a bug I would assume it would need a test as mentioned no?

  • πŸ‡¨πŸ‡­Switzerland berdir Switzerland

    We have some rules around skipping tests if the fix is straightforward and unlikely to break again. This is just a safety guard against code that was not properly updated to D10+ to provide a more helpful error.

    Testing it would require that we add an invalid test implementation of a field type and that seems a lot of trouble for this.

    Lets try :)

  • πŸ‡¦πŸ‡ΉAustria maxilein

    Thanks. It is easy to find the culprit now!

  • πŸ‡¨πŸ‡­Switzerland berdir Switzerland

    ✨ Use modal in add new field flow Active completely removed the exception. In manual testing, I don't even get far enough because there's an assertion in \Drupal\Core\Field\FieldTypePluginManager::getGroupedDefinitions(), but that was there before and it's not as helpful I think. Maybe instead of that assert(), we should throw the exception there?

Production build 0.71.5 2024