CVE-2026-4336 MEDIUM

CVE-2026-4336: Ultimate FAQ Accordion Plugin <= 2.4.7 - Authenticated (Author+) Stored Cross-Site Scripting via FAQ Content

Vendor Rustaurius
Product Ultimate FAQ Accordion Plugin
Weakness CWE-79 · XSS
Published April 9, 2026
Last update April 9, 2026

CVSS base score

6.4/10
Attack vector Network
Attack complexity Low
Privileges required Low
User interaction None
Confidentiality Low
Integrity Low

CVSS vector

CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:L/I:L/A:N

What the vulnerability does

01Description

The Ultimate FAQ Accordion plugin for WordPress is vulnerable to Stored Cross-Site Scripting via FAQ content in all versions up to, and including, 2.4.7. This is due to the plugin calling html_entity_decode() on post_content during rendering in the set_display_variables() function (View.FAQ.class.php, line 746), which converts HTML entity-encoded payloads back into executable HTML, combined with insufficient output escaping in the faq-answer.php template where the decoded content is echoed without wp_kses_post() or any other sanitization. The ufaq custom post type is registered with 'show_in_rest' => true and defaults to 'post' capability_type, allowing Author-level users to create and publish FAQs via the REST API. An Author can submit entity-encoded malicious HTML (e.g., &lt;img src=x onerror=alert()&gt;) which bypasses WordPress's kses sanitization at save time (since kses sees entities as plain text, not tags), but is then decoded back into executable HTML by html_entity_decode() at render time. This makes it possible for authenticated attackers, with Author-level access and above, to inject arbitrary web scripts in FAQ pages that will execute whenever a user accesses an injected FAQ, either directly or via the [ultimate-faqs] shortcode.

Explanation of Vulnerability in Simple Terms

02Summary

The Ultimate FAQ Accordion Plugin for WordPress contains a cross-site scripting (XSS) vulnerability in versions up to 2.4.7. An authenticated user with low privileges can inject malicious scripts that execute in other users' browsers, including site administrators. The vulnerability has scope change, meaning the impact extends beyond the plugin itself to affect the broader site.

What an attacker can do

03Attacker Capabilities

Inject malicious JavaScript that runs in other users' browsers, potentially stealing session tokens or performing actions as those users.

Potential impact on your site

04Site Impact

Authenticated attackers can compromise admin accounts and modify site content or settings through stored XSS attacks.

Conditions required to exploit

05Prerequisites

Attacker must have a low-privilege WordPress account (e.g., contributor or subscriber role). No user interaction required.

Key dates

06Disclosure timeline

April 9, 2026 CVE published
April 9, 2026 Record updated