Lookup for vulnerable packages by Package URL.
| Purl | pkg:maven/gov.nsa.emissary/emissary@8.38.0 |
| Type | maven |
| Namespace | gov.nsa.emissary |
| Name | emissary |
| Version | 8.38.0 |
| Qualifiers |
|
| Subpath | |
| Is_vulnerable | true |
| Next_non_vulnerable_version | 8.39.0 |
| Latest_non_vulnerable_version | 8.43.0 |
| Affected_by_vulnerabilities |
| 0 |
| url |
VCID-d1zn-ry4s-cbff |
| vulnerability_id |
VCID-d1zn-ry4s-cbff |
| summary |
Emissary has Stored XSS via Navigation Template Link Injection
## Summary
Mustache navigation templates interpolated configuration-controlled link values
directly into `href` attributes without URL scheme validation. An administrator
who could modify the `navItems` configuration could inject `javascript:` URIs,
enabling stored cross-site scripting (XSS) against other authenticated users
viewing the Emissary web interface.
## Details
### Vulnerable code — `nav.mustache` (line 10)
```html
{{#navItems}}
<li class="nav-item">
<a class="nav-link" href="{{link}}">{{display}}</a>
</li>
{{/navItems}}
```
The `{{link}}` value was rendered without any scheme validation. Mustache's
default HTML escaping protects against injection of new HTML tags but does
**not** prevent `javascript:` URIs in `href` attributes, since `javascript:`
contains no characters that HTML-escaping would alter.
### Attack vector
An administrator sets a navigation item's link to:
```
javascript:alert(document.cookie)
```
Any authenticated user who clicks the navigation link executes the script in
their browser context.
### Impact
- Session hijacking via cookie theft
- Actions performed on behalf of the victim user
- Requires administrative access to modify navigation configuration
- Requires user interaction (clicking the malicious link)
### Mitigating factors
- Exploitation requires administrative access to modify the `navItems`
configuration
- User interaction (clicking the link) is required
- The Emissary web interface is typically accessed only by authenticated
operators within a trusted network
## Remediation
Fixed in [PR #1293](https://github.com/NationalSecurityAgency/emissary/pull/1293),
merged into release 8.39.0.
### Server-side link validation — `NavAction.java`
An allowlist regex was added that only permits `http://`, `https://`, or
site-relative (`/`) URLs:
```java
private static final Pattern VALID_LINK = Pattern.compile("^(https?:/)?/.*");
private static boolean isValidLink(String link) {
if (!VALID_LINK.matcher(link).matches()) {
logger.warn("Skipping invalid navigation link '{}'", link);
return false;
}
return true;
}
```
Invalid links are logged and silently dropped from the rendered navigation.
### Template hardening — `nav.mustache`
Added `rel="noopener noreferrer"` to all navigation link anchor tags as a
defense-in-depth measure:
```html
<a class="nav-link" href="{{link}}" rel="noopener noreferrer">{{display}}</a>
```
Tests were added to verify that `javascript:` and `ftp://` URIs are rejected
while `http://`, `https://`, and site-relative (`/path`) links are accepted.
## Workarounds
If upgrading is not immediately possible, audit the navigation configuration
to ensure all `navItems` link values use only `http://`, `https://`, or
relative (`/`) URL schemes.
## References
- [PR #1293 — validate nav links](https://github.com/NationalSecurityAgency/emissary/pull/1293)
- Original report: GHSA-wjqm-p579-x3ww |
| references |
| 0 |
| reference_url |
https://api.first.org/data/v1/epss?cve=CVE-2026-35571 |
| reference_id |
|
| reference_type |
|
| scores |
| 0 |
| value |
0.00027 |
| scoring_system |
epss |
| scoring_elements |
0.07471 |
| published_at |
2026-04-08T12:55:00Z |
|
| 1 |
| value |
0.00027 |
| scoring_system |
epss |
| scoring_elements |
0.07477 |
| published_at |
2026-04-12T12:55:00Z |
|
| 2 |
| value |
0.00027 |
| scoring_system |
epss |
| scoring_elements |
0.07489 |
| published_at |
2026-04-11T12:55:00Z |
|
| 3 |
| value |
0.00027 |
| scoring_system |
epss |
| scoring_elements |
0.07495 |
| published_at |
2026-04-09T12:55:00Z |
|
| 4 |
| value |
0.00029 |
| scoring_system |
epss |
| scoring_elements |
0.08192 |
| published_at |
2026-04-13T12:55:00Z |
|
| 5 |
| value |
0.00029 |
| scoring_system |
epss |
| scoring_elements |
0.08237 |
| published_at |
2026-04-21T12:55:00Z |
|
| 6 |
| value |
0.00029 |
| scoring_system |
epss |
| scoring_elements |
0.08076 |
| published_at |
2026-04-18T12:55:00Z |
|
| 7 |
| value |
0.00029 |
| scoring_system |
epss |
| scoring_elements |
0.08089 |
| published_at |
2026-04-16T12:55:00Z |
|
|
| url |
https://api.first.org/data/v1/epss?cve=CVE-2026-35571 |
|
| 1 |
|
| 2 |
|
| 3 |
|
| 4 |
|
| 5 |
|
| 6 |
|
|
| fixed_packages |
|
| aliases |
CVE-2026-35571, GHSA-cpm7-cfpx-3hvp
|
| risk_score |
3.1 |
| exploitability |
0.5 |
| weighted_severity |
6.2 |
| resource_url |
http://public2.vulnerablecode.io/vulnerabilities/VCID-d1zn-ry4s-cbff |
|
|
| Fixing_vulnerabilities |
|
| Risk_score | 3.1 |
| Resource_url | http://public2.vulnerablecode.io/packages/pkg:maven/gov.nsa.emissary/emissary@8.38.0 |