WordPress Plugin Vulnerabilities

MW WP Form < 5.1.2 - Unauthenticated Arbitrary File Move via regenerate_upload_file_keys

Description

The plugin is vulnerable to Arbitrary File Move/Read due to insufficient validation of the $name parameter (upload field key) passed to the generate_user_file_dirpath() function, which uses WordPress's path_join() — a function that returns absolute paths unchanged, discarding the intended base directory. The attacker-controlled key is injected via the mwf_upload_files[] POST parameter, which is loaded into the plugin's Data model via _set_request_valiables(). During form processing, regenerate_upload_file_keys() iterates over these keys and calls generate_user_filepath() with the attacker-supplied key as the $name argument — the key survives validation because the targeted file (e.g., wp-config.php) genuinely exists at the absolute path. The _get_attachments() method then re-reads the same surviving keys and passes the resolved file path to move_temp_file_to_upload_dir(), which calls rename() to move the file into the uploads folder. This makes it possible for unauthenticated attackers to move arbitrary files on the server, which can easily lead to remote code execution when the right file is moved (such as wp-config.php). The vulnerability is only exploitable if a file upload field is added to the form and the “Saving inquiry data in database” option is enabled.

Affects Plugins

Fixed in 5.1.2

References

Classification

Type
LFI
OWASP top 10
CWE
CVSS

Miscellaneous

Original Researcher
Sander Horsman
Verified
No

Timeline

Publicly Published
2026-04-08 (about 1 month ago)
Added
2026-04-08 (about 1 month ago)
Last Updated
2026-04-08 (about 1 month ago)

Other