Home

Description

The WP Carousel Free plugin for WordPress is vulnerable to Stored Cross-Site Scripting via crafted fancybox `data-caption` attributes in all versions up to, and including, 2.7.10. This is due to the `fancybox-config.js` script reading the carousel container's `id` attribute directly from the DOM to construct a jQuery selector without sanitization. When a Contributor crafts an HTML block with a malformed carousel container ID (containing characters invalid for jQuery selectors), the custom fancybox configuration throws a JavaScript error and fails to initialize. This causes the bundled fancybox library (v3.5.7) to fall back to its default caption handling, which renders the `data-caption` attribute content as raw HTML. Since WordPress allows `data-*` attributes through `wp_kses_post()`, this makes it possible for authenticated attackers, with Contributor-level access and above, to inject arbitrary web scripts in pages that will execute whenever a user clicks an image in the crafted carousel lightbox.

PUBLISHED Reserved 2026-03-23 | Published 2026-05-05 | Updated 2026-05-05 | Assigner Wordfence




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

Problem types

CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')

Product status

Default status
unaffected

Any version
affected

Timeline

2026-03-25:Vendor Notified
2026-05-04:Disclosed

Credits

Craig Smith finder

References

www.wordfence.com/...-2414-47f3-b0c4-e5d3e2cb369d?source=cve

plugins.trac.wordpress.org/...0/public/js/fancybox-config.js

plugins.trac.wordpress.org/...k/public/js/fancybox-config.js

plugins.trac.wordpress.org/...ee/trunk/public/js/fancybox.js

cve.org (CVE-2026-4665)

nvd.nist.gov (CVE-2026-4665)

Download JSON