🔐 CVE Alert

CVE-2026-9109

HIGH 7.2

GPTranslate <= 2.31 - Unauthenticated Stored Cross-Site Scripting via REST API Translation Storage

CVSS Score
7.2
EPSS Score
0.0%
EPSS Percentile
0th

The GPTranslate – Multilingual AI Translation for WordPress: Automatically Translate Websites plugin for WordPress is vulnerable to Stored Cross-Site Scripting via REST API Translation Storage in all versions up to, and including, 2.31 due to insufficient input sanitization and output escaping. This makes it possible for unauthenticated attackers to inject arbitrary web scripts in pages that will execute whenever a user accesses an injected page. The deterministically derived API key (sha256 of the site URL) is printed in the HTML source of every page via the JavaScript variable gptApiKey, meaning any unauthenticated visitor can retrieve the key and submit malicious translation payloads to the /wp-json/gptranslate/v1/request endpoint without any additional precondition.

CWE CWE-79
Vendor john-dagelmore
Product gptranslate – multilingual ai translation for wordpress: automatically translate websites
Published Jun 13, 2026
Stay Ahead of the Next One

Get instant alerts for john-dagelmore gptranslate – multilingual ai translation for wordpress: automatically translate websites

Be the first to know when new high vulnerabilities affecting john-dagelmore gptranslate – multilingual ai translation for wordpress: automatically translate websites are published — delivered to Slack, Telegram or Discord.

Get Free Alerts → Free · No credit card · 60 sec setup

CVSS v3 Breakdown

CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N
Attack Vector
Attack Complexity
Privileges Required
User Interaction
Scope
Confidentiality
Integrity
Availability

Affected Versions

john-dagelmore / GPTranslate – Multilingual AI Translation for WordPress: Automatically Translate Websites
0 ≤ 2.31

References

NVD ↗ CVE.org ↗ EPSS Data ↗
wordfence.com: https://www.wordfence.com/threat-intel/vulnerabilities/id/1c93b564-5428-4b0e-bbe8-f1e1e68940ac?source=cve plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/assets/js/admin.js#L1 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3654 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3578 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L1134 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/assets/js/admin.js#L1 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3654 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3578 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L1134 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/assets/js/admin.js#L1 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L3574 plugins.trac.wordpress.org: https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L1104

Credits

Hardeep Chris