baldwin / magento2-module-url-data-integrity-checker
baldwin/magento2-module-url-data-integrity-checker
Magento 2 module which can find potential url related problems in your catalog data
Url data integrity checker module for Magento 2
Purpose
The purpose of this module is to give store owners of a Magento 2 shop insight into what url-related problems they have in their products, categories and url rewrites.
It was explicitly chosen not to have automated fixers for these problems, since fixing these issues can have a significant SEO impact.
It should be up to the store owner to figure out how he/she wants to fix these problems. Doing this with an automated tool might have a negative impact on SEO rankings, hence why it only reports problems and doesn't try to fix them.
Implemented features
- It can detect categories having incorrect
url_pathattribute values - It can detect categories having duplicated
url_keyattribute values within the same parent - It can detect categories having an empty
url_keyattribute value - It can detect products having non-empty
url_pathattribute values - It can detect products having duplicated
url_keyattribute values on the same store view - It can detect products having an empty
url_keyattribute value
Roadmap
- Detecting incorrectly generated url rewrites
- Making cronjob execution times configurable
- Increasing performance of checkers, these are currently written for accuracy and not for speed
- Add a legend above the admin grids with a mapping of store view id's with their names
- Improve tests
- ...
Compatibility
This module should be compatible with Magento 2.1.x, 2.2.x, 2.3.x and 2.4.x versions.
Some code in this module is using old ways of doing things. It could have been written in a more modern way (using message queues instead of cronjobs, use newer syntax for UI components, ...). But we wanted this module to be compatible with older versions of Magento, so we've chosen this route for now.
The module should be compatible with PHP 7.1, 7.2, 7.3, 7.4, 8.1, 8.2, 8.3 and 8.4
Installation
You can use composer to install this module:
composer require baldwin/magento2-module-url-data-integrity-checker
Or download the code and put all the files in the directory app/code/Baldwin/UrlDataIntegrityChecker
After which you can then activate it in Magento using:
bin/magento setup:upgrade
Usage
There are some automatic cronjobs running every night at 02:10, 02:15, 02:20 and 02:30 which will run the various checkers of this module.
You can also opt to manually refresh one of the checkers in the Magento admin, which will schedule one of the cronjobs to be ran the next minute. You'll have to wait a few minutes (depending on the number of problems and how big your catalog is) before you'll see the results appearing. You'll need to refresh the page yourself btw, it won't happen by itself.
There are also some cli commands you can execute, which will give you instant feedback about found problems, and will also store that data so you can see them in the Magento admin:
bin/magento catalog:category:integrity:urlkeybin/magento catalog:category:integrity:urlpathbin/magento catalog:product:integrity:urlkeybin/magento catalog:product:integrity:urlpath
In the Magento admin, you can find the results in:
- for Magento 2.1.x: Products > Data Integrity Checker
- for Magento 2.2.0 and higher: Catalog > Data Integrity Checker
The results of the checkers are currently stored by default in the directory var/tmp as .json files.
But you can change the path in the backend settings under Stores > Configuration > Catalog > Url Data Integrity Checker by entering a relative path starting from the Magento installation directory or an absolute path. The directory you enter there needs to exist before it will work.
You can configure this module to ignore problems with invisible products (via Stores > Configuration > Catalog > Url Data Integrity Checker). Because in recent versions of Magento, url rewrites for invisible products are not being generated, so if there are problems with the url_path or url_key attributes of such products, they should not cause issues with url rewrites. An additional benefit of this option is that it will use less time and less memory to run the product checkers. This option is disabled by default, so you'll need to enable it.
Some screenshots
Example of backend report for product url key problems
[image: Backend example for product url keys]
Example of cli report for category url path problems
[image: CLI example for category url paths]
Contributing
After cloning your fork:
- Create an
auth.jsonfile with your credentials for https://repo.magento.com/ - Run
composer install - Make sure running
make checkdoesn't report problems with proposed changes
No changelog yet
The vendor hasn't published a changelog. Tagged releases appear in the Versions tab.
| Version | Stability | QA Status | Compatibility | Released |
|---|---|---|---|---|
| 1.6.1 | stable | Fail | Magento 2.4.7-2.4.9 Details | 2026-04-14 16:28:58 |
| 1.6.0 | stable | Not tested | Not yet tested Details | 2025-04-09 15:59:12 |
| 1.5.3 | stable | Not tested | Not yet tested Details | 2024-03-22 16:53:02 |
| 1.5.2 | stable | Not tested | Not yet tested Details | 2023-03-16 17:23:25 |
| 1.5.1 | stable | Not tested | Not yet tested Details | 2023-03-01 14:51:25 |
| 1.5.0 | stable | Not tested | Not yet tested Details | 2022-07-07 14:51:48 |
| 1.4.0 | stable | Not tested | Not yet tested Details | 2022-01-30 10:41:54 |
| 1.3.2 | stable | Not tested | Not yet tested Details | 2021-12-20 10:55:18 |
| 1.3.1 | stable | Not tested | Not yet tested Details | 2021-10-23 15:51:58 |
| 1.3.0 | stable | Not tested | Not yet tested Details | 2021-09-26 18:24:04 |
| 1.2.2 | stable | Not tested | Not yet tested Details | 2021-03-22 09:25:10 |
| 1.2.1 | stable | Not tested | Not yet tested Details | 2021-03-04 21:39:43 |
| 1.2.0 | stable | Not tested | Not yet tested Details | 2020-08-02 16:17:07 |
| 1.1.0 | stable | Not tested | Not yet tested Details | 2020-06-26 22:13:44 |
| 1.0.0 | stable | Not tested | Not yet tested Details | 2020-01-26 13:48:45 |
Requires 10
| Package | Constraint |
|---|---|
| php | ~7.1.0 || ~7.2.0 || ~7.3.0 || ~7.4.0 || ~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.0 || ~8.5.0 |
| magento/framework | ^100.1 || ^101.0 || ^102.0 || ^103.0 |
| magento/module-backend | ^100.1 || ^101.0 || ^102.0 |
| magento/module-catalog | ^101.0 || ^102.0 || ^103.0 || ^104.0 |
| magento/module-config | ^100.1 || ^101.0 |
| magento/module-cron | ^100.1 |
| magento/module-store | ^100.1 || ^101.0 |
| magento/module-theme | ^100.1 || ^101.0 |
| magento/module-ui | ^100.1 || ^101.0 |
| symfony/console | ^2.5 || ^3.0 || ^4.0 || ^5.0 || ^6.0 || ^7.0 |
Requires-dev 4
| Package | Constraint |
|---|---|
| bamarni/composer-bin-plugin | ^1.7 |
| ergebnis/composer-normalize | ^2.17 |
| mikey179/vfsstream | ^1.6 |
| phpunit/phpunit | ^12.5 |
Compatibility
Each Magento release line is installed on its supported PHP versions, then the module is built (DI compilation + static-content deploy) and its unit and integration suites are run. The matrix shows the lines and PHP versions the module is confirmed to install and run on. Code-quality results further down (phpstan, phpcs, …) are reported separately and never affect compatibility.
Code Quality
Advisory checks against the module's source. Static analysis runs once across the whole module; PHPStan re-runs per Magento + PHP version because resolvable symbols differ between releases. These NEVER affect the Compatibility badge — a phpcs finding can't make a module incompatible.
Static analysis
Coding standards (phpcs), mess detection (phpmd), copy-pasted code (cpd), PHP cross-version compatibility, composer.json validity. Each runs once for the whole module.
| Tool | Status | Findings | Summary |
|---|---|---|---|
| PHPCS | Fail | 140 | 14 errors, 126 warnings (ruleset: Magento2) — 19 auto-fixable with phpcbf |
| PHPMD | Warning | 35 | 35 rule violations (UnusedFormalParameter:25, MissingImport:5, ExcessiveMethodLength:3, CyclomaticComplexity:1, NPathComplexity:1) |
| Cpd | Warning | 4 | 4 duplicated chunks spanning 435 total lines (min-lines=5, min-tokens=70) |
| Composer validate | Pass | 0 |
PHPStan
Type-checks the module's PHP against a real Magento install at the configured gate level. Re-runs per Magento and PHP version because resolvable symbols differ between releases. Cell → details modal.
Tests
Unit and integration suites, run for each applicable Magento and PHP version. A test failure speaks to the module's behaviour, not its compatibility with a Magento line, so it is reported here separately and never reddens the compatibility matrix.
Unit tests
| Magento | PHP 8.2 | PHP 8.3 | PHP 8.4 | PHP 8.5 |
|---|---|---|---|---|
| 2.4.7 | N/A | N/A | ||
| 2.4.8 | N/A | N/A | ||
| 2.4.9 | N/A | N/A |
Integration tests
| Magento | PHP 8.2 | PHP 8.3 | PHP 8.4 | PHP 8.5 |
|---|---|---|---|---|
| 2.4.7 | N/A | N/A | ||
| 2.4.8 | N/A | N/A | ||
| 2.4.9 | N/A | N/A |
Security
Security checks run directly against the module: an audit of its declared dependencies for known vulnerabilities (composer audit) and a scan of its source for malware and web-shell signatures. Each runs once. A malware detection fails the version outright.
More from baldwin
View vendorAllows Magento 2 to compile less files using the less nodejs compiler
Magento 2 module which replaces the default Magento CSP module and effectively disables its functionality
Magento 2 module which can cleanup old image files that are no longer being used
Turn an existing module into recurring revenue.
If you already maintain a Magento 2 module on GitHub or GitLab, listing it on Packagento takes about five minutes. We mirror your tags, handle distribution signing, and route paid licenses through Stripe Connect, so you can keep shipping the way you already do.