{"document":{"category":"csaf_vex","csaf_version":"2.0","title":"CVE-2026-9109: GPTranslate <= 2.31 - Unauthenticated Stored Cross-Site Scripting via REST API Translation Storage","publisher":{"category":"vendor","name":"HarborGuard Database","namespace":"https://database.harborguard.co"},"tracking":{"id":"CVE-2026-9109","status":"final","version":"1","initial_release_date":"2026-06-13T05:32:37.292Z","current_release_date":"2026-06-15T17:23:28.784Z","revision_history":[{"date":"2026-06-13T05:32:37.292Z","number":"1","summary":"Initial machine-readable export from HarborGuard."}]},"distribution":{"tlp":{"label":"WHITE"},"text":"Public CVE data; freely redistributable."},"notes":[{"category":"description","text":"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.","title":"CVE description"}],"references":[{"category":"self","summary":"CVE-2026-9109 on HarborGuard Database","url":"https://database.harborguard.co/cve/CVE-2026-9109"},{"category":"external","summary":"CVE Record","url":"https://www.cve.org/CVERecord?id=CVE-2026-9109"},{"category":"external","summary":"wordfence.com","url":"https://www.wordfence.com/threat-intel/vulnerabilities/id/1c93b564-5428-4b0e-bbe8-f1e1e68940ac?source=cve"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/assets/js/admin.js#L1"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3654"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3578"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L1134"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/assets/js/admin.js#L1"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3654"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3578"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L1134"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/assets/js/admin.js#L1"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L3574"},{"category":"external","summary":"plugins.trac.wordpress.org","url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L1104"}]},"product_tree":{"branches":[{"category":"vendor","name":"john-dagelmore","branches":[{"category":"product_name","name":"GPTranslate – Multilingual AI Translation for WordPress: Automatically Translate Websites","branches":[{"category":"product_version_range","name":"<=2.31","product":{"name":"john-dagelmore GPTranslate – Multilingual AI Translation for WordPress: Automatically Translate Websites <=2.31","product_id":"CSAFPID-1","product_identification_helper":{"cpe":"cpe:2.3:a:john-dagelmore:gptranslate_–_multilingual_ai_translation_for_wordpress\\:_automatically_translate_websites:*:*:*:*:*:*:*:*"}}}]}]}]},"vulnerabilities":[{"cve":"CVE-2026-9109","title":"GPTranslate <= 2.31 - Unauthenticated Stored Cross-Site Scripting via REST API Translation Storage","notes":[{"category":"description","text":"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.","title":"CVE description"}],"product_status":{"known_affected":["CSAFPID-1"]},"scores":[{"cvss_v3":{"version":"3.1","vectorString":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N","baseScore":7.2,"baseSeverity":"HIGH"},"products":["CSAFPID-1"]}],"remediations":[{"category":"none_available","details":"No fixed version is published yet. Monitor the upstream advisory.","product_ids":["CSAFPID-1"]}]}]}