Error when updating user role

Created on 14 March 2025, 22 days ago

Problem/Motivation

This might be related to 📌 Introduce class WorkflowTargetEntity Active where WorkflowTargetEntity was introduced, but I see an error when trying to import a role config that updates an existing one, immediately after the site install finishes. The relevant bit of the call stack looks like so:

Error: Call to a member function getWeight() on null in /var/www/html/web/modules/contrib/workflow/modules/workflow_access/workflow_access.module on line 131 #0 [internal function]: workflow_
access_user_role_update(Object(Drupal\user\Entity\Role))
#1 /var/www/html/web/core/lib/Drupal/Core/Extension/ModuleHandler.php(416): call_user_func_array(Object(Closure), Array)
#2 /var/www/html/web/core/lib/Drupal/Core/Extension/ModuleHandler.php(395): Drupal\Core\Extension\ModuleHandler->Drupal\Core\Extension\{closure}(Object(Closure), 'workflow_access')
#3 /var/www/html/web/core/lib/Drupal/Core/Extension/ModuleHandler.php(415): Drupal\Core\Extension\ModuleHandler->invokeAllWith('user_role_updat...', Object(Closure))
#4 /var/www/html/web/core/lib/Drupal/Core/Config/Entity/ConfigEntityStorage.php(341): Drupal\Core\Extension\ModuleHandler->invokeAll('user_role_updat...', Array)
#5 /var/www/html/web/core/lib/Drupal/Core/Entity/EntityStorageBase.php(564): Drupal\Core\Config\Entity\ConfigEntityStorage->invokeHook('update', Object(Drupal\user\Entity\Role))
#6 /var/www/html/web/core/lib/Drupal/Core/Entity/EntityStorageBase.php(489): Drupal\Core\Entity\EntityStorageBase->doPostSave(Object(Drupal\user\Entity\Role), true)
#7 /var/www/html/web/core/lib/Drupal/Core/Config/Entity/ConfigEntityStorage.php(257): Drupal\Core\Entity\EntityStorageBase->save(Object(Drupal\user\Entity\Role))
#8 /var/www/html/web/core/lib/Drupal/Core/Entity/EntityBase.php(354): Drupal\Core\Config\Entity\ConfigEntityStorage->save(Object(Drupal\user\Entity\Role))
#9 /var/www/html/web/core/lib/Drupal/Core/Config/Entity/ConfigEntityBase.php(614): Drupal\Core\Entity\EntityBase->save()
#10 /var/www/html/web/core/lib/Drupal/Core/Config/ConfigInstaller.php(389): Drupal\Core\Config\Entity\ConfigEntityBase->save()
#11 /var/www/html/web/core/lib/Drupal/Core/Config/ConfigInstaller.php(149): Drupal\Core\Config\ConfigInstaller->createConfiguration('', Array)

Steps to reproduce

In my context, this happens as part of the site-install, because we have a custom install profile that has user.role.*.yml</a> configs within its <code>config/install directory. Based on the call-stack, it looks like it's specifically *updating* a module, so I assume this is related to either the user.role.administrator or user.role.authenticated that get created by the base install profile from core. As such, it should suffice to do the following steps:

  1. Create a custom module .info.yml, and a config/install directory
  2. Export or otherwise place a user.role.administrator.yml config in the module (with other-than-default permissions)
  3. Enable the module, triggering the import of the config

It may even work to simply `drush config-import --partial` and point to a directory with such a role config.

Proposed resolution

I was able to correct the proximate error by simply adding a null check just before the line that fails. I'm not sure this is the best solution as I don't have the larger context, but within that function it *seems* reasonable :)

Remaining tasks

Evaluate simple fix, and improve if needed :)

🐛 Bug report
Status

Active

Version

1.0

Component

Code

Created by

🇨🇦Canada spiderman Halifax, NS

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

Comments & Activities

Production build 0.71.5 2024