Lookup for vulnerable packages by Package URL.

Purlpkg:npm/%40vendure/core@3.1.0-next.2
Typenpm
Namespace@vendure
Namecore
Version3.1.0-next.2
Qualifiers
Subpath
Is_vulnerabletrue
Next_non_vulnerable_version3.5.7
Latest_non_vulnerable_version3.6.2
Affected_by_vulnerabilities
0
url VCID-k1vr-fgbd-v7gb
vulnerability_id VCID-k1vr-fgbd-v7gb
summary
@vendure/core has a SQL Injection vulnerability
## Summary

An unauthenticated SQL injection vulnerability exists in the Vendure Shop API. A user-controlled query string parameter is interpolated directly into a raw SQL expression without parameterization or validation, allowing an attacker to execute arbitrary SQL against the database. This affects all supported database backends (PostgreSQL, MySQL/MariaDB, SQLite).

The Admin API is also affected, though exploitation there requires authentication.

## Affected versions

- `@vendure/core` < 2.3.4
- `@vendure/core` >= 3.0.0, < 3.5.7
- `@vendure/core` >= 3.6.0, < 3.6.2

Note: versions 2.3.4 and above in the 2.x line are patched. There were no 2.4.x or 2.x releases between 2.3.x and 3.0.0.

## Patched versions

- `@vendure/core` 2.3.4
- `@vendure/core` 3.5.7
- `@vendure/core` 3.6.2

## Details

In `ProductService.findOneBySlug`, the request context's `languageCode` value is interpolated into a SQL `CASE` expression via a JavaScript template literal:

```ts
.addSelect(
    `CASE translation.languageCode WHEN '${ctx.languageCode}' THEN 2 WHEN '${ctx.channel.defaultLanguageCode}' THEN 1 ELSE 0 END`,
    'sort_order',
)
```

TypeORM has no opportunity to parameterize this value because it is embedded directly into the SQL string before being passed to the query builder.

The `languageCode` value can originate from the HTTP query string and is set on the request context for every incoming API request. The value is cast to the `LanguageCode` TypeScript type at compile time, but no runtime validation is performed -- the raw query string value is used as-is.

## Attack vector

An unauthenticated attacker can append a crafted `languageCode` query parameter to any Shop API request to inject arbitrary SQL into the query. No user interaction is required. The vulnerable endpoint is exposed on every default Vendure installation.

## Mitigation

**Upgrade to a patched version immediately.**

If you cannot upgrade right away, apply the following hotfix to `RequestContextService.getLanguageCode` to validate the `languageCode` input at the boundary. This blocks injection payloads before they can reach any query:

```ts
private getLanguageCode(req: Request, channel: Channel): LanguageCode | undefined {
    const queryLanguageCode = req.query?.languageCode as string | undefined;
    const isValidFormat = queryLanguageCode && /^[a-zA-Z0-9_-]+$/.test(queryLanguageCode);
    return (
        (isValidFormat ? (queryLanguageCode as LanguageCode) : undefined) ??
        channel.defaultLanguageCode ??
        this.configService.defaultLanguageCode
    );
}
```

This replaces the existing `getLanguageCode` method in `packages/core/src/service/helpers/request-context/request-context.service.ts`. Invalid values are silently dropped and the channel's default language is used instead.

The patched versions additionally convert the vulnerable SQL interpolation to a parameterized query as defense in depth.
references
0
reference_url https://api.first.org/data/v1/epss?cve=CVE-2026-40887
reference_id
reference_type
scores
0
value 0.07704
scoring_system epss
scoring_elements 0.92087
published_at 2026-06-09T12:55:00Z
1
value 0.07704
scoring_system epss
scoring_elements 0.92076
published_at 2026-06-05T12:55:00Z
2
value 0.07704
scoring_system epss
scoring_elements 0.92073
published_at 2026-06-06T12:55:00Z
3
value 0.07704
scoring_system epss
scoring_elements 0.92071
published_at 2026-06-07T12:55:00Z
4
value 0.07704
scoring_system epss
scoring_elements 0.92072
published_at 2026-06-08T12:55:00Z
url https://api.first.org/data/v1/epss?cve=CVE-2026-40887
1
reference_url https://github.com/vendurehq/vendure
reference_id
reference_type
scores
0
value 9.1
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:H
1
value CRITICAL
scoring_system generic_textual
scoring_elements
url https://github.com/vendurehq/vendure
2
reference_url https://github.com/vendurehq/vendure/security/advisories/GHSA-9pp3-53p2-ww9v
reference_id
reference_type
scores
0
value 9.1
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:H
1
value CRITICAL
scoring_system cvssv3.1_qr
scoring_elements
2
value CRITICAL
scoring_system generic_textual
scoring_elements
3
value Track
scoring_system ssvc
scoring_elements SSVCv2/E:N/A:Y/T:P/P:M/B:A/M:M/D:T/2026-04-22T13:40:47Z/
url https://github.com/vendurehq/vendure/security/advisories/GHSA-9pp3-53p2-ww9v
3
reference_url https://nvd.nist.gov/vuln/detail/CVE-2026-40887
reference_id
reference_type
scores
0
value 9.1
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:H
1
value CRITICAL
scoring_system generic_textual
scoring_elements
url https://nvd.nist.gov/vuln/detail/CVE-2026-40887
4
reference_url https://github.com/advisories/GHSA-9pp3-53p2-ww9v
reference_id GHSA-9pp3-53p2-ww9v
reference_type
scores
0
value CRITICAL
scoring_system cvssv3.1_qr
scoring_elements
url https://github.com/advisories/GHSA-9pp3-53p2-ww9v
fixed_packages
0
url pkg:npm/%40vendure/core@3.5.7
purl pkg:npm/%40vendure/core@3.5.7
is_vulnerable false
affected_by_vulnerabilities
resource_url http://public2.vulnerablecode.io/packages/pkg:npm/%2540vendure/core@3.5.7
1
url pkg:npm/%40vendure/core@3.6.2
purl pkg:npm/%40vendure/core@3.6.2
is_vulnerable false
affected_by_vulnerabilities
resource_url http://public2.vulnerablecode.io/packages/pkg:npm/%2540vendure/core@3.6.2
aliases CVE-2026-40887, GHSA-9pp3-53p2-ww9v
risk_score 4.5
exploitability 0.5
weighted_severity 9.0
resource_url http://public2.vulnerablecode.io/vulnerabilities/VCID-k1vr-fgbd-v7gb
1
url VCID-mvja-dec5-6qf2
vulnerability_id VCID-mvja-dec5-6qf2
summary
Vendure vulnerable to timing attack that enables user enumeration in NativeAuthenticationStrategy
The `NativeAuthenticationStrategy.authenticate()` method is vulnerable to a timing attack that allows attackers to enumerate valid usernames (email addresses).
references
0
reference_url https://api.first.org/data/v1/epss?cve=CVE-2026-25050
reference_id
reference_type
scores
0
value 0.00021
scoring_system epss
scoring_elements 0.0612
published_at 2026-06-06T12:55:00Z
1
value 0.00021
scoring_system epss
scoring_elements 0.06092
published_at 2026-06-09T12:55:00Z
2
value 0.00021
scoring_system epss
scoring_elements 0.06069
published_at 2026-06-08T12:55:00Z
3
value 0.00021
scoring_system epss
scoring_elements 0.06116
published_at 2026-06-07T12:55:00Z
4
value 0.00021
scoring_system epss
scoring_elements 0.06133
published_at 2026-06-05T12:55:00Z
url https://api.first.org/data/v1/epss?cve=CVE-2026-25050
1
reference_url https://github.com/vendurehq/vendure
reference_id
reference_type
scores
0
value 2.7
scoring_system cvssv4
scoring_elements CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:L/VI:N/VA:N/SC:N/SI:N/SA:N/E:U
1
value LOW
scoring_system generic_textual
scoring_elements
url https://github.com/vendurehq/vendure
2
reference_url https://github.com/vendurehq/vendure/commit/7f0c5556ecddb44a5d5208677a45fdd5923b0cc9
reference_id
reference_type
scores
0
value 2.7
scoring_system cvssv4
scoring_elements CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:L/VI:N/VA:N/SC:N/SI:N/SA:N/E:U
1
value LOW
scoring_system generic_textual
scoring_elements
url https://github.com/vendurehq/vendure/commit/7f0c5556ecddb44a5d5208677a45fdd5923b0cc9
3
reference_url https://github.com/vendurehq/vendure/releases/tag/v3.5.3
reference_id
reference_type
scores
0
value 2.7
scoring_system cvssv4
scoring_elements CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:L/VI:N/VA:N/SC:N/SI:N/SA:N/E:U
1
value LOW
scoring_system generic_textual
scoring_elements
2
value Track
scoring_system ssvc
scoring_elements SSVCv2/E:N/A:Y/T:P/P:M/B:A/M:M/D:T/2026-01-30T15:45:23Z/
url https://github.com/vendurehq/vendure/releases/tag/v3.5.3
4
reference_url https://nvd.nist.gov/vuln/detail/CVE-2026-25050
reference_id CVE-2026-25050
reference_type
scores
0
value 2.7
scoring_system cvssv4
scoring_elements CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:L/VI:N/VA:N/SC:N/SI:N/SA:N/E:U
1
value LOW
scoring_system generic_textual
scoring_elements
url https://nvd.nist.gov/vuln/detail/CVE-2026-25050
5
reference_url https://github.com/advisories/GHSA-6f65-4fv2-wwch
reference_id GHSA-6f65-4fv2-wwch
reference_type
scores
0
value LOW
scoring_system cvssv3.1_qr
scoring_elements
url https://github.com/advisories/GHSA-6f65-4fv2-wwch
6
reference_url https://github.com/vendurehq/vendure/security/advisories/GHSA-6f65-4fv2-wwch
reference_id GHSA-6f65-4fv2-wwch
reference_type
scores
0
value LOW
scoring_system cvssv3.1_qr
scoring_elements
1
value 2.7
scoring_system cvssv4
scoring_elements CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:L/VI:N/VA:N/SC:N/SI:N/SA:N/E:U
2
value LOW
scoring_system generic_textual
scoring_elements
3
value Track
scoring_system ssvc
scoring_elements SSVCv2/E:N/A:Y/T:P/P:M/B:A/M:M/D:T/2026-01-30T15:45:23Z/
url https://github.com/vendurehq/vendure/security/advisories/GHSA-6f65-4fv2-wwch
fixed_packages
0
url pkg:npm/%40vendure/core@3.5.3
purl pkg:npm/%40vendure/core@3.5.3
is_vulnerable true
affected_by_vulnerabilities
0
vulnerability VCID-k1vr-fgbd-v7gb
resource_url http://public2.vulnerablecode.io/packages/pkg:npm/%2540vendure/core@3.5.3
1
url pkg:npm/%40vendure/core@3.6.0-minor-202511061550
purl pkg:npm/%40vendure/core@3.6.0-minor-202511061550
is_vulnerable false
affected_by_vulnerabilities
resource_url http://public2.vulnerablecode.io/packages/pkg:npm/%2540vendure/core@3.6.0-minor-202511061550
aliases CVE-2026-25050, GHSA-6f65-4fv2-wwch
risk_score 1.4
exploitability 0.5
weighted_severity 2.7
resource_url http://public2.vulnerablecode.io/vulnerabilities/VCID-mvja-dec5-6qf2
Fixing_vulnerabilities
Risk_score4.5
Resource_urlhttp://public2.vulnerablecode.io/packages/pkg:npm/%2540vendure/core@3.1.0-next.2