Bulk update with first option create don't work on content with pattern

Created on 15 February 2023, about 2 years ago

Problem/Motivation

Even when some nodes types have a dedicated pattern on type + language, and the named node has no alias, bulk update on empty aliases doesn't generate any alias.

Steps to reproduce

1. Install Drupal Core
2. Install module pathauto
3. enable path and pathauto
4. enable languages and translations for nodes.
5. create 1 more language
6. create a node type
7. create a pattern for the created node type + dedicated language
8. Create a node of created type
8. go to pathauto bulk page: /admin/config/search/path/update_bulk
9. choose options "content" and "Generate an alias only for empty aliases."
10. Click on "update" button
11. edit the node.
12: check the alias : this one should be set, but it is not.

Proposed resolution

After investigation, I've found that nearly every nodes had a pathauto status 0 instead of 1 ($entity->path->pathauto).
And if this status is 0 + not 'force' option on it, then it isn't updated :-(

Remaining tasks

Somewhere $entity->path->pathauto should be turned on 1 and it isn't.

I can propose a patch that force this value to be updated during the bulk update.

Please tell me if there is a better way to fix this.

🐛 Bug report
Status

Active

Version

1.11

Component

Code

Created by

🇫🇷France frondeau Nantes, FRANCE

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

Comments & Activities

  • Issue created by @frondeau
  • 🇫🇷France frondeau Nantes, FRANCE
  • 🇫🇷France frondeau Nantes, FRANCE
  • 🇨🇦Canada Shiraz Dindar Sooke, BC

    I was having this issue and your patch fixed it for me. Thanks! The nodes in qusetion were originally imported from Salesforce so many that has something to do with it.

  • 🇨🇦Canada Shiraz Dindar Sooke, BC

    I also checked how I could enable this "force" option. I seem to remember it in D7 but I'm not seeing it implemented in D9. There are some references to it in the code, including what you saw, but nowhere where it actually sends the option.

  • 🇫🇷France frondeau Nantes, FRANCE

    I think that "force" option is the check-bos that appears in alias section of node edition... But it needs investigation.

    If so, this can't be manually forced in bulk update so the option should be true as default value, or not checked in bulk update, or as parameter...

    And how to manage with $entity->path->pathauto value ?

    In my website example, there was no imported node.

  • 🇺🇸United States wweibel

    I found `pathauto_state.[entity_type_id]` in the key_value table, with the `name == entity_id` and the `value as 0|1`. Deleting the rows for the entity you want to bulk generate (in my case media) allowed it to work as expected. There should be an option to clear these in the UI, the 'Regenerate URL aliases for all paths' does not do this

    Looking in `pathauto/src/PathautoState.php` in `bulkDelete` this will "Only delete aliases that were created by this module."

  • Open in Jenkins → Open on Drupal.org →
    Core: 10.1.x + Environment: PHP 8.1 & MySQL 5.7
    last update over 1 year ago
    Patch Failed to Apply
  • 🇺🇸United States alphex Atlanta, GA USA

    This patch doesn't work any more on 1.13.0

  • Status changed to Needs review 7 months ago
  • 🇮🇳India chaitanyadessai Goa

    Please review patch.

  • Status changed to Postponed: needs info 23 days ago
  • 🇫🇮Finland sokru

    I tried to replicate the issue with Drupal 11 and Pathauto 1.13, but didn't manage with steps from the issue summary. I also tried to switch steps 7 and 8, but no difference.
    The steps didn't mention the language to use on steps 8, 9, 13 and 14, but I assumed it to be the default language (English).
    I'd recommend checking the path alias (steps 13/14) from route /admin/config/search/path

Production build 0.71.5 2024