Integrity constraint violation: 1048 Column 'name' cannot be null: INSERT INTO "users_field_data"

Created on 12 January 2023, about 2 years ago
Updated 17 February 2023, about 2 years ago

Problem/Motivation

SQL Error when Admin updating someone's password using change password page with Password Policy enable.

Error message

Drupal\Core\Entity\EntityStorageException: SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'name' cannot be null: INSERT INTO "users_field_data" ("uid", "langcode", "preferred_langcode", "preferred_admin_langcode", "name", "pass", "mail", "timezone", "status", "created", "changed", "access", "login", "init", "default_langcode", "content_translation_source", "content_translation_outdated", "content_translation_uid", "content_translation_status", "content_translation_created") VALUES (:db_insert_placeholder_0, :db_insert_placeholder_1, :db_insert_placeholder_2, :db_insert_placeholder_3, :db_insert_placeholder_4, :db_insert_placeholder_5, :db_insert_placeholder_6, :db_insert_placeholder_7, :db_insert_placeholder_8, :db_insert_placeholder_9, :db_insert_placeholder_10, :db_insert_placeholder_11, :db_insert_placeholder_12, :db_insert_placeholder_13, :db_insert_placeholder_14, :db_insert_placeholder_15, :db_insert_placeholder_16, :db_insert_placeholder_17, :db_insert_placeholder_18, :db_insert_placeholder_19); Array ( [:db_insert_placeholder_0] => 9 [:db_insert_placeholder_1] => es [:db_insert_placeholder_2] => es [:db_insert_placeholder_3] => es [:db_insert_placeholder_4] => [:db_insert_placeholder_5] => $S$Ek4aZ/l.OOAyGWuPiL78pW/FKD/lqaq0EztMZ9xtn3Y8JeGw8bQe [:db_insert_placeholder_6] => makbul.khan8@gmail.com [:db_insert_placeholder_7] => America/Argentina/Buenos_Aires [:db_insert_placeholder_8] => 1 [:db_insert_placeholder_9] => 1634645298 [:db_insert_placeholder_10] => 1673513738 [:db_insert_placeholder_11] => 1673510820 [:db_insert_placeholder_12] => 1673509019 [:db_insert_placeholder_13] => makbul.khan8@gmail.com [:db_insert_placeholder_14] => 1 [:db_insert_placeholder_15] => und [:db_insert_placeholder_16] => 0 [:db_insert_placeholder_17] => 0 [:db_insert_placeholder_18] => 1 [:db_insert_placeholder_19] => 1634645298 ) en Drupal\Core\Entity\Sql\SqlContentEntityStorage->save() (linea 811 de /var/www/html/web/core/lib/Drupal/Core/Entity/Sql/SqlContentEntityStorage.php).

Steps to reproduce

Steps to reproduce
1. Enable Password Policy 8.x-4.0
2. Enable Change Password Page 8.x-1.0
3. Create a default password policy with default setting.
4. Edit user with role for which password policy is enabled password.

Proposed resolution

  // set username if form_state name value is empty
  if (empty($form_state->getValue('name'))) {
    $user->setUsername($form_state->getValue('name', $user->name->value));
  }

Remaining tasks

User interface changes

API changes

Data model changes

🐛 Bug report
Status

Active

Version

4.0

Component

Code

Created by

🇮🇳India makbul_khan8 Pune

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

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇮🇳India sourabhutani

    Patch is working for me, Thanks!!

  • Issue was unassigned.
  • I had the same error here, but it was the cron execution of the password policy that reported an error, so this patch didn't work for me; I recreated a patch.

  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.5 + Environment: PHP 5.6 & MySQL 5.5
    last update over 1 year ago
    Composer error. Unable to continue.
  • 🇮🇳India Akhildev.cs

    The patch #3 works fine for me.
    this removes database exceptions (SQLST ATE[23000]: Integrity constraint violation: 1048 Column 'name' ).
    I am using:-
    MySQL 5.6, drupal 9.5, and "drupal/password_policy": "^3.2",

  • Status changed to Postponed: needs info 12 months ago
  • 🇺🇸United States Kristen Pol Santa Cruz, CA, USA

    When providing a new patch, please move the state to "needs review".

    While this was tested in #9 and seems to be working, I would have instead loaded the user entity in order to save it.

    Why wasn't this done?

  • 🇨🇭Switzerland tcrawford

    I bumped in to the issue.
    In our case we have a form display mode that does not have the name field present, which is a valid use case.
    We have the MR from https://www.drupal.org/project/password_policy/issues/2451159 Password policy doesn't work when updating the user Needs work installed as a patch, but the issue can be reproduced without this and the patch resolves the issue regardless.
    The name is actually already persisted on the entity.

    Error:

    ```

    Warning: Undefined array key "account" in /app/docroot/modules/contrib/password_policy/password_policy.module on line 243

    Warning: Trying to access array offset on value of type null in /app/docroot/modules/contrib/password_policy/password_policy.module on line 243

    Warning: Trying to access array offset on value of type null in /app/docroot/modules/contrib/password_policy/password_policy.module on line 243

    Warning: Undefined array key "#default_value" in /app/docroot/modules/contrib/password_policy/password_policy.module on line 243
    The website encountered an unexpected error. Try again later.

    Drupal\Core\Entity\EntityStorageException: SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'name' cannot be null: INSERT INTO "users_field_data" ("uid", "langcode", "preferred_langcode", "preferred_admin_langcode", "name", "pass", "mail", "timezone", "status", "created", "changed", "access", "login", "init", "default_langcode") VALUES (:db_insert_placeholder_0, :db_insert_placeholder_1, :db_insert_placeholder_2, :db_insert_placeholder_3, :db_insert_placeholder_4, :db_insert_placeholder_5, :db_insert_placeholder_6, :db_insert_placeholder_7, :db_insert_placeholder_8, :db_insert_placeholder_9, :db_insert_placeholder_10, :db_insert_placeholder_11, :db_insert_placeholder_12, :db_insert_placeholder_13, :db_insert_placeholder_14); Array ( [:db_insert_placeholder_0] => 52200 [:db_insert_placeholder_1] => de [:db_insert_placeholder_2] => de [:db_insert_placeholder_3] => fr [:db_insert_placeholder_4] => [:db_insert_placeholder_5] => $2y$10$O0rUbJ7ueExLy7vEmBfVp.oOv5Vzl1xnQM52SOyp8rsy2JK5RcD0W [:db_insert_placeholder_6] => sanitized@example.com [:db_insert_placeholder_7] => Europe/Zurich [:db_insert_placeholder_8] => 1 [:db_insert_placeholder_9] => 1737379851 [:db_insert_placeholder_10] => 1737473718 [:db_insert_placeholder_11] => 1737380061 [:db_insert_placeholder_12] => 1737380061 [:db_insert_placeholder_13] => sanitized@example.com [:db_insert_placeholder_14] => 1 ) in Drupal\Core\Entity\Sql\SqlContentEntityStorage->save() (line 817 of core/lib/Drupal/Core/Entity/Sql/SqlContentEntityStorage.php).
    Drupal\Core\Database\StatementWrapperIterator->execute(Array, Array) (Line: 44)
    Drupal\mysql\Driver\Database\mysql\Insert->execute() (Line: 1022)
    Drupal\Core\Entity\Sql\SqlContentEntityStorage->saveToSharedTables(Object) (Line: 935)
    Drupal\Core\Entity\Sql\SqlContentEntityStorage->doSaveFieldItems(Object, Array) (Line: 33)
    Drupal\user\UserStorage->doSaveFieldItems(Object) (Line: 718)
    Drupal\Core\Entity\ContentEntityStorageBase->doSave('52200', Object) (Line: 486)
    Drupal\Core\Entity\EntityStorageBase->save(Object) (Line: 806)
    Drupal\Core\Entity\Sql\SqlContentEntityStorage->save(Object) (Line: 354)
    Drupal\Core\Entity\EntityBase->save() (Line: 293)
    Drupal\Core\Entity\EntityForm->save(Array, Object)
    call_user_func_array(Array, Array) (Line: 129)
    Drupal\Core\Form\FormSubmitter->executeSubmitHandlers(Array, Object) (Line: 67)
    Drupal\Core\Form\FormSubmitter->doSubmitForm(Array, Object) (Line: 597)
    Drupal\Core\Form\FormBuilder->processForm('user_pharmacies_form', Array, Object) (Line: 326)
    Drupal\Core\Form\FormBuilder->buildForm(Object, Object) (Line: 73)
    Drupal\Core\Controller\FormController->getContentResult(Object, Object)
    call_user_func_array(Array, Array) (Line: 123)
    Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->Drupal\Core\EventSubscriber\{closure}() (Line: 638)
    Drupal\Core\Render\Renderer->executeInRenderContext(Object, Object) (Line: 121)
    Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->wrapControllerExecutionInRenderContext(Array, Array) (Line: 97)
    Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->Drupal\Core\EventSubscriber\{closure}() (Line: 181)
    Symfony\Component\HttpKernel\HttpKernel->handleRaw(Object, 1) (Line: 76)
    Symfony\Component\HttpKernel\HttpKernel->handle(Object, 1, 1) (Line: 68)
    Drupal\simple_oauth\HttpMiddleware\BasicAuthSwap->handle(Object, 1, 1) (Line: 53)
    Drupal\Core\StackMiddleware\Session->handle(Object, 1, 1) (Line: 48)
    Drupal\Core\StackMiddleware\KernelPreHandle->handle(Object, 1, 1) (Line: 28)
    Drupal\Core\StackMiddleware\ContentLength->handle(Object, 1, 1) (Line: 32)
    Drupal\big_pipe\StackMiddleware\ContentLength->handle(Object, 1, 1) (Line: 106)
    Drupal\page_cache\StackMiddleware\PageCache->pass(Object, 1, 1) (Line: 85)
    Drupal\page_cache\StackMiddleware\PageCache->handle(Object, 1, 1) (Line: 53)
    Asm89\Stack\Cors->handle(Object, 1, 1) (Line: 48)
    Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle(Object, 1, 1) (Line: 51)
    Drupal\Core\StackMiddleware\NegotiationMiddleware->handle(Object, 1, 1) (Line: 36)
    Drupal\Core\StackMiddleware\AjaxPageState->handle(Object, 1, 1) (Line: 51)
    Drupal\Core\StackMiddleware\StackedHttpKernel->handle(Object, 1, 1) (Line: 742)
    Drupal\Core\DrupalKernel->handle(Object) (Line: 19)
    ```

    Cause:
    Function _password_policy_user_profile_form_validate(&$form, FormStateInterface $form_state) sets the name to an empty value if not found in the form.

    Proposed solution:
    As above. I am moving this back to needs review. Please consider again the prior proposed solution. https://www.drupal.org/files/issues/2023-01-12/3332884-integrity-constra...

    // set username if form_state name value is empty
    if (empty($form_state->getValue('name'))) {
    $user->setUsername($form_state->getValue('name', $user->name->value));
    }

Production build 0.71.5 2024