Home

Description

The Coachific Shortcode plugin for WordPress is vulnerable to Stored Cross-Site Scripting via the 'userhash' shortcode attribute in all versions up to and including 1.0. This is due to insufficient input sanitization and output escaping. The plugin uses sanitize_text_field() on the 'userhash' parameter, which strips HTML tags but does not escape characters significant in a JavaScript string context (such as double quotes, semicolons, and parentheses). The sanitized value is then directly interpolated into a JavaScript string within a <script> tag on line 29 without any JavaScript-specific escaping (e.g., wp_json_encode() or esc_js()). 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 accesses an injected page.

PUBLISHED Reserved 2026-03-11 | Published 2026-04-15 | Updated 2026-04-16 | 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-04-14:Disclosed

Credits

zakaria finder

References

www.wordfence.com/...-0b34-460e-9fdb-b99165ebca78?source=cve

plugins.trac.wordpress.org/...-shortcode/trunk/coachific.php

plugins.trac.wordpress.org/...ortcode/tags/1.0/coachific.php

plugins.trac.wordpress.org/...-shortcode/trunk/coachific.php

plugins.trac.wordpress.org/...ortcode/tags/1.0/coachific.php

cve.org (CVE-2026-4005)

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

Download JSON