wpscanteam / wpscan

WPScan WordPress security scanner. Written for security professionals and blog maintainers to test the security of their WordPress websites. Contact us via contact@wpscan.com
https://wpscan.com/wordpress-cli-scanner
Other
8.63k stars 1.27k forks source link

Populate valid versions from metadata, too #1850

Closed Nirusu closed 2 months ago

Nirusu commented 3 months ago

Currently, WPScan populates its list of valid WordPress versions from a list of fingerprinted WordPress files.

However, this file is not always up-to-date, causing version detection to fail as WPScan thinks its not a valid version and raises a InvalidWordPressVersion exception.

Since a lot of the version information is also pulled from metadata.json anyway, also include this file for the initial version detection, instead of just relying on the list of fingerprinted files.

Fixes #1849

Discussion Question

I don't know why exactly the versions were pulled from the fingerprint files, anyway. Maybe it makes sense to remove it completely? Since I did not know, I went for the defensive approach and just determining the version based on both of them.

But I wonder why if there is a specific reason why it was not pulled from the metadata before, or why it was based on the fingerprints only.

Licensing

By submitting code contributions to the WPScan development team via Github Pull Requests, or any other method, it is understood that the contributor is offering the WPScan company (company number 83421476900012), which is registered in France, the unlimited, non-exclusive right to reuse, modify, and relicense the code.