Lookup for vulnerable packages by Package URL.

Purlpkg:npm/exiftool-vendored@14.3.0
Typenpm
Namespace
Nameexiftool-vendored
Version14.3.0
Qualifiers
Subpath
Is_vulnerabletrue
Next_non_vulnerable_version35.19.0
Latest_non_vulnerable_version35.19.0
Affected_by_vulnerabilities
0
url VCID-58kk-kzpt-m7ez
vulnerability_id VCID-58kk-kzpt-m7ez
summary
exiftool-vendored vulnerable to argument injection via newline characters in tag names
### Impact

`exiftool-vendored` starts ExifTool in `-stay_open True -@ -` mode, where arguments are read from stdin one per line. In affected versions, several caller-supplied strings were interpolated into ExifTool arguments without rejecting line delimiters. A newline or carriage return inside one of those strings could split a single intended argument into multiple ExifTool arguments, allowing argument injection. The fix also rejects NUL bytes as unsafe control characters.

Applications that pass attacker-controlled strings to affected APIs may allow an attacker to make ExifTool read files accessible to the ExifTool process, or write output to attacker-chosen file system paths accessible to that process. No remote code execution has been demonstrated.

The reported write-path issue is caused by unsanitized tag **keys**. Tag **values** passed to `ExifTool#write` are not affected, because `WriteTask` already encodes whitespace characters in values (e.g. `\n` -> `
`) before transmission.

Confirmed affected inputs:

- **Tag-name arguments / tag keys** — keys of the `tags` object passed to `ExifTool#write`; entries of the `retain` option to `ExifTool#deleteAllTags`; entries of the `numericTags` option to `ExifTool#read`; the `tagname` argument to `ExifTool#extractBinaryTag` and `#extractBinaryTagToBuffer`.
- **Filename / path arguments** to `ExifTool#write`, `#read`, `#readRaw`, `#deleteAllTags`, `#rewriteAllTags`, `#extractBinaryTag`, `#extractBinaryTagToBuffer`, and the binary-extraction convenience methods `#extractJpgFromRaw`, `#extractPreview`, and `#extractThumbnail`. `path.resolve()` does not strip newlines, so an application that accepts attacker-controlled filenames containing newline characters was vulnerable.
- **The `imageHashType` option** to `ExifTool#read`. TypeScript types restrict this to a literal union, but JS callers or callers with weakened type checking could reach the sink.

Applications that only pass hardcoded strings for tag names, options, and filenames are not affected.

### Patches

Fixed in **v35.19.0**. Two layers of defense:

1. **Per-site input validation.** A new `validateTagName` helper rejects any tag-name string containing characters outside the ExifTool tag grammar (letters, digits, `:`, `-`, `_`, and the ExifTool modifiers `*`, `?`, `+`, `#`). Applied at every tag-name interpolation site.
2. **Defense-in-depth at the command renderer.** `ExifToolTask.renderCommand` now rejects _any_ argument containing `\r`, `\n`, or `\0` before it is sent to the ExifTool process. This catches injection via filename arguments, option values, and any future interpolation site that forgets the per-site validator.

### Workarounds

Upgrade to v35.19.0 or later.

If upgrading immediately is not possible, reject untrusted strings containing control characters before passing them to the affected APIs. Conservative guard:

```ts
function assertSafeForExifTool(s: string): void {
  if (typeof s !== "string" || /[\x00-\x20=<>]/.test(s)) {
    throw new Error("Rejected unsafe string for ExifTool");
  }
}
```

Apply to tag names, `retain` / `numericTags` entries, binary-extraction tag names, filenames, and the `imageHashType` option. This is a denylist and is strictly weaker than the library's internal validator; it is sufficient to block the known PoCs but will accept strings that the library itself now rejects.

### Resources

- ExifTool `-stay_open` / argument-file documentation: https://exiftool.org/exiftool_pod.html#stay_open-FLAG
- ExifTool tag-name reference: https://exiftool.org/TagNames/
- CWE-88: Improper Neutralization of Argument Delimiters in a Command ('Argument Injection') — https://cwe.mitre.org/data/definitions/88.html

### Credit

- Reporter: Hank Tam
- Affiliation: Independent
references
0
reference_url https://api.first.org/data/v1/epss?cve=CVE-2026-43893
reference_id
reference_type
scores
0
value 0.00139
scoring_system epss
scoring_elements 0.33798
published_at 2026-06-05T12:55:00Z
1
value 0.00139
scoring_system epss
scoring_elements 0.33814
published_at 2026-06-06T12:55:00Z
url https://api.first.org/data/v1/epss?cve=CVE-2026-43893
1
reference_url https://exiftool.org/exiftool_pod.html#stay_open-FLAG
reference_id
reference_type
scores
0
value 8.2
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:H/A:N
1
value HIGH
scoring_system generic_textual
scoring_elements
url https://exiftool.org/exiftool_pod.html#stay_open-FLAG
2
reference_url https://exiftool.org/TagNames
reference_id
reference_type
scores
0
value 8.2
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:H/A:N
1
value HIGH
scoring_system generic_textual
scoring_elements
url https://exiftool.org/TagNames
3
reference_url https://github.com/photostructure/exiftool-vendored.js
reference_id
reference_type
scores
0
value 8.2
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:H/A:N
1
value HIGH
scoring_system generic_textual
scoring_elements
url https://github.com/photostructure/exiftool-vendored.js
4
reference_url https://github.com/photostructure/exiftool-vendored.js/security/advisories/GHSA-cw26-7653-2rp5
reference_id
reference_type
scores
0
value 8.2
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:H/A:N
1
value HIGH
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-05-12T12:54:33Z/
url https://github.com/photostructure/exiftool-vendored.js/security/advisories/GHSA-cw26-7653-2rp5
5
reference_url https://nvd.nist.gov/vuln/detail/CVE-2026-43893
reference_id
reference_type
scores
0
value 8.2
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:H/A:N
1
value HIGH
scoring_system generic_textual
scoring_elements
url https://nvd.nist.gov/vuln/detail/CVE-2026-43893
6
reference_url https://github.com/advisories/GHSA-cw26-7653-2rp5
reference_id GHSA-cw26-7653-2rp5
reference_type
scores
url https://github.com/advisories/GHSA-cw26-7653-2rp5
fixed_packages
0
url pkg:npm/exiftool-vendored@35.19.0
purl pkg:npm/exiftool-vendored@35.19.0
is_vulnerable false
affected_by_vulnerabilities
resource_url http://public2.vulnerablecode.io/packages/pkg:npm/exiftool-vendored@35.19.0
aliases CVE-2026-43893, GHSA-cw26-7653-2rp5
risk_score 4.0
exploitability 0.5
weighted_severity 8.0
resource_url http://public2.vulnerablecode.io/vulnerabilities/VCID-58kk-kzpt-m7ez
Fixing_vulnerabilities
0
url VCID-12ty-91ab-4ygg
vulnerability_id VCID-12ty-91ab-4ygg
summary Improper Neutralization of Special Elements used in an OS Command ('OS Command Injection') in exiftool-vendored.
references
0
reference_url https://github.com/photostructure/exiftool-vendored.js
reference_id
reference_type
scores
0
value 7.8
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
1
value HIGH
scoring_system generic_textual
scoring_elements
url https://github.com/photostructure/exiftool-vendored.js
1
reference_url https://github.com/advisories/GHSA-4whq-r978-2x68
reference_id GHSA-4whq-r978-2x68
reference_type
scores
url https://github.com/advisories/GHSA-4whq-r978-2x68
2
reference_url https://github.com/photostructure/exiftool-vendored.js/security/advisories/GHSA-4whq-r978-2x68
reference_id GHSA-4whq-r978-2x68
reference_type
scores
0
value 7.8
scoring_system cvssv3.1
scoring_elements CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
1
value HIGH
scoring_system generic_textual
scoring_elements
url https://github.com/photostructure/exiftool-vendored.js/security/advisories/GHSA-4whq-r978-2x68
fixed_packages
0
url pkg:npm/exiftool-vendored@14.3.0
purl pkg:npm/exiftool-vendored@14.3.0
is_vulnerable true
affected_by_vulnerabilities
0
vulnerability VCID-58kk-kzpt-m7ez
resource_url http://public2.vulnerablecode.io/packages/pkg:npm/exiftool-vendored@14.3.0
aliases GHSA-4whq-r978-2x68, GMS-2021-35
risk_score 4.0
exploitability 0.5
weighted_severity 8.0
resource_url http://public2.vulnerablecode.io/vulnerabilities/VCID-12ty-91ab-4ygg
Risk_score4.0
Resource_urlhttp://public2.vulnerablecode.io/packages/pkg:npm/exiftool-vendored@14.3.0