{"api_version":"1","generated_at":"2026-06-13T23:30:51+00:00","cve":"CVE-2026-9109","urls":{"html":"https://cve.report/CVE-2026-9109","api":"https://cve.report/api/cve/CVE-2026-9109.json","docs":"https://cve.report/api","cve_org":"https://www.cve.org/CVERecord?id=CVE-2026-9109","nvd":"https://nvd.nist.gov/vuln/detail/CVE-2026-9109"},"summary":{"title":"GPTranslate <= 2.31 - Unauthenticated Stored Cross-Site Scripting via REST API Translation Storage","description":"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.","state":"PUBLISHED","assigner":"Wordfence","published_at":"2026-06-13 07:16:14","updated_at":"2026-06-13 07:16:14"},"problem_types":["CWE-79","CWE-79 CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')"],"metrics":[{"version":"3.1","source":"security@wordfence.com","type":"Primary","score":"7.2","severity":"HIGH","vector":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N","data":{"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","attackVector":"NETWORK","attackComplexity":"LOW","privilegesRequired":"NONE","userInteraction":"NONE","scope":"CHANGED","confidentialityImpact":"LOW","integrityImpact":"LOW","availabilityImpact":"NONE"}},{"version":"3.1","source":"CNA","type":"DECLARED","score":"7.2","severity":"HIGH","vector":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N","data":{"baseScore":7.2,"baseSeverity":"HIGH","vectorString":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N","version":"3.1"}}],"references":[{"url":"https://www.wordfence.com/threat-intel/vulnerabilities/id/1c93b564-5428-4b0e-bbe8-f1e1e68940ac?source=cve","name":"https://www.wordfence.com/threat-intel/vulnerabilities/id/1c93b564-5428-4b0e-bbe8-f1e1e68940ac?source=cve","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/assets/js/admin.js#L1","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/assets/js/admin.js#L1","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L1134","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L1134","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/assets/js/admin.js#L1","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/assets/js/admin.js#L1","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L3574","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L3574","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3578","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3578","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3654","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3654","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L1104","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L1104","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L1134","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L1134","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/assets/js/admin.js#L1","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/assets/js/admin.js#L1","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3578","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3578","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3654","name":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3654","refsource":"security@wordfence.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://www.cve.org/CVERecord?id=CVE-2026-9109","name":"CVE Program record","refsource":"CVE.ORG","tags":["canonical"]},{"url":"https://nvd.nist.gov/vuln/detail/CVE-2026-9109","name":"NVD vulnerability detail","refsource":"NVD","tags":["canonical","analysis"]}],"affected":[{"source":"CNA","vendor":"john-dagelmore","product":"GPTranslate – Multilingual AI Translation for WordPress: Automatically Translate Websites","version":"affected 2.31 semver","platforms":[]}],"timeline":[{"source":"CNA","time":"2026-06-12T17:00:41.000Z","lang":"en","value":"Disclosed"}],"solutions":[],"workarounds":[],"exploits":[],"credits":[{"source":"CNA","value":"Hardeep","lang":"en"},{"source":"CNA","value":"Chris","lang":"en"}],"nvd_cpes":[],"vendor_comments":[],"enrichments":{"kev":null,"epss":null,"legacy_qids":[]},"source_records":{"cve_program":{"containers":{"cna":{"affected":[{"defaultStatus":"unaffected","product":"GPTranslate – Multilingual AI Translation for WordPress: Automatically Translate Websites","vendor":"john-dagelmore","versions":[{"lessThanOrEqual":"2.31","status":"affected","version":"0","versionType":"semver"}]}],"credits":[{"lang":"en","type":"finder","value":"Hardeep"},{"lang":"en","type":"finder","value":"Chris"}],"descriptions":[{"lang":"en","value":"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."}],"metrics":[{"cvssV3_1":{"baseScore":7.2,"baseSeverity":"HIGH","vectorString":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N","version":"3.1"}}],"problemTypes":[{"descriptions":[{"cweId":"CWE-79","description":"CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')","lang":"en","type":"CWE"}]}],"providerMetadata":{"dateUpdated":"2026-06-13T05:32:37.292Z","orgId":"b15e7b5b-3da4-40ae-a43c-f7aa60e62599","shortName":"Wordfence"},"references":[{"url":"https://www.wordfence.com/threat-intel/vulnerabilities/id/1c93b564-5428-4b0e-bbe8-f1e1e68940ac?source=cve"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/assets/js/admin.js#L1"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3654"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L3578"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.31/gptranslate.php#L1134"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/assets/js/admin.js#L1"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3654"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L3578"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.27.5/gptranslate.php#L1134"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/assets/js/admin.js#L1"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L3574"},{"url":"https://plugins.trac.wordpress.org/browser/gptranslate/tags/2.32/gptranslate.php#L1104"}],"timeline":[{"lang":"en","time":"2026-06-12T17:00:41.000Z","value":"Disclosed"}],"title":"GPTranslate <= 2.31 - Unauthenticated Stored Cross-Site Scripting via REST API Translation Storage"}},"cveMetadata":{"assignerOrgId":"b15e7b5b-3da4-40ae-a43c-f7aa60e62599","assignerShortName":"Wordfence","cveId":"CVE-2026-9109","datePublished":"2026-06-13T05:32:37.292Z","dateReserved":"2026-05-20T17:27:45.605Z","dateUpdated":"2026-06-13T05:32:37.292Z","state":"PUBLISHED"},"dataType":"CVE_RECORD","dataVersion":"5.2"},"nvd":{"publishedDate":"2026-06-13 07:16:14","lastModifiedDate":"2026-06-13 07:16:14","problem_types":["CWE-79","CWE-79 CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')"],"metrics":{"cvssMetricV31":[{"source":"security@wordfence.com","type":"Primary","cvssData":{"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","attackVector":"NETWORK","attackComplexity":"LOW","privilegesRequired":"NONE","userInteraction":"NONE","scope":"CHANGED","confidentialityImpact":"LOW","integrityImpact":"LOW","availabilityImpact":"NONE"},"exploitabilityScore":3.9,"impactScore":2.7}]},"configurations":[]},"legacy_mitre":{"record":{"CveYear":"2026","CveId":"9109","Ordinal":"1","Title":"GPTranslate <= 2.31 - Unauthenticated Stored Cross-Site Scriptin","CVE":"CVE-2026-9109","Year":"2026"},"notes":[{"CveYear":"2026","CveId":"9109","Ordinal":"1","NoteData":"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.","Type":"Description","Title":"GPTranslate <= 2.31 - Unauthenticated Stored Cross-Site Scriptin"}]}}}