GHSA-x8qp-wqqm-57ph

Suggest an improvement
Source
https://github.com/advisories/GHSA-x8qp-wqqm-57ph
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2025/07/GHSA-x8qp-wqqm-57ph/GHSA-x8qp-wqqm-57ph.json
JSON Data
https://api.test.osv.dev/v1/vulns/GHSA-x8qp-wqqm-57ph
Aliases
Published
2025-07-16T19:32:48Z
Modified
2025-07-17T20:58:49Z
Severity
  • 5.3 (Medium) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:P/VC:N/VI:N/VA:N/SC:L/SI:L/SA:N CVSS Calculator
Summary
vue-i18n's escapeParameterHtml does not prevent DOM-based XSS through its tag attributes
Details

Summary

The escapeParameterHtml: true option in Vue I18n is designed to protect against HTML/script injection by escaping interpolated parameters. However, this setting fails to prevent execution of certain tag-based payloads, such as <img src=x onerror=...>, if the interpolated value is inserted inside an HTML context using v-html.

This may lead to a DOM-based XSS vulnerability, even when using escapeParameterHtml: true, if a translation string includes minor HTML and is rendered via v-html.

Details

When escapeParameterHtml: true is enabled, it correctly escapes common injection points.

However, it does not sanitize entire attribute contexts, which can be used as XSS vectors via:

<img src=x onerror=alert(1)>

PoC

In your Vue I18n configuration:

const i18n = createI18n({
  escapeParameterHtml: true,
  messages: {
    en: {
      vulnerable: 'Caution: <img src=x onerror="{payload}">'
    }
  }
});

Use this interpolated payload:

const payload = '<script>alert("xss")</script>'; Render the translation using v-html (even not using v-html):

<p v-html="$t('vulnerable', { payload })"></p> Expected: escaped content should render as text, not execute.

Actual: script executes in some environments (or the payload is partially parsed as HTML).

Impact

This creates a DOM-based Cross-Site Scripting (XSS) vulnerability despite enabling a security option (escapeParameterHtml) .

Database specific
{
    "severity": "MODERATE",
    "nvd_published_at": "2025-07-16T14:15:28Z",
    "github_reviewed": true,
    "github_reviewed_at": "2025-07-16T19:32:48Z",
    "cwe_ids": [
        "CWE-79"
    ]
}
References

Affected packages

npm / vue-i18n

Package

Affected ranges

Type
SEMVER
Events
Introduced
9.0.0
Fixed
9.14.5

npm / vue-i18n

Package

Affected ranges

Type
SEMVER
Events
Introduced
10.0.0
Fixed
10.0.8

npm / vue-i18n

Package

Affected ranges

Type
SEMVER
Events
Introduced
11.0.0
Fixed
11.1.10

npm / @intlify/core

Package

Name
@intlify/core
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/core

Affected ranges

Type
SEMVER
Events
Introduced
9.0.0
Fixed
9.14.5

npm / @intlify/core

Package

Name
@intlify/core
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/core

Affected ranges

Type
SEMVER
Events
Introduced
10.0.0
Fixed
10.0.8

npm / @intlify/core

Package

Name
@intlify/core
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/core

Affected ranges

Type
SEMVER
Events
Introduced
11.0.0
Fixed
11.1.10

npm / @intlify/core-base

Package

Name
@intlify/core-base
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/core-base

Affected ranges

Type
SEMVER
Events
Introduced
9.0.0
Fixed
9.14.5

npm / @intlify/core-base

Package

Name
@intlify/core-base
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/core-base

Affected ranges

Type
SEMVER
Events
Introduced
10.0.0
Fixed
10.0.8

npm / @intlify/core-base

Package

Name
@intlify/core-base
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/core-base

Affected ranges

Type
SEMVER
Events
Introduced
11.0.0
Fixed
11.1.10

npm / @intlify/vue-i18n-core

Package

Name
@intlify/vue-i18n-core
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/vue-i18n-core

Affected ranges

Type
SEMVER
Events
Introduced
9.2.0
Fixed
9.14.5

npm / @intlify/vue-i18n-core

Package

Name
@intlify/vue-i18n-core
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/vue-i18n-core

Affected ranges

Type
SEMVER
Events
Introduced
10.0.0
Fixed
10.0.8

npm / @intlify/vue-i18n-core

Package

Name
@intlify/vue-i18n-core
View open source insights on deps.dev
Purl
pkg:npm/%40intlify/vue-i18n-core

Affected ranges

Type
SEMVER
Events
Introduced
11.0.0
Fixed
11.1.10

npm / petite-vue-i18n

Package

Affected ranges

Type
SEMVER
Events
Introduced
10.0.0
Fixed
10.0.8

npm / petite-vue-i18n

Package

Affected ranges

Type
SEMVER
Events
Introduced
11.0.0
Fixed
11.1.10