Search criteria Use this form to refine search results.
Full-text search supports keyword queries with ranking and filtering.
You can combine vendor, product, and sources to narrow results.
Enable “Apply ordering” to sort by date instead of relevance.

1 vulnerability by john-dagelmore

CVE-2026-9109 (GCVE-0-2026-9109)

Vulnerability from cvelistv5 – Published: 2026-06-13 05:32 – Updated: 2026-06-13 05:32
VLAI
Title
GPTranslate <= 2.31 - Unauthenticated Stored Cross-Site Scripting via REST API Translation Storage
Summary
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 - Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')
Assigner
Credits
Hardeep Chris
Show details on NVD website

{
  "containers": {
    "cna": {
      "affected": [
        {
          "defaultStatus": "unaffected",
          "product": "GPTranslate \u2013 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 \u2013 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 (\u0027Cross-site Scripting\u0027)",
              "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 \u003c= 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"
}