MAL-2026-5692

See a problem?
Import Source
https://github.com/ossf/malicious-packages/blob/main/osv/malicious/npm/ecto-win-flag-q2m7/MAL-2026-5692.json
JSON Data
https://api.osv.dev/v1/vulns/MAL-2026-5692
Aliases
  • GHSA-22wq-6mfh-69qv
Published
2026-06-12T14:32:51Z
Modified
2026-06-12T20:01:50.794463918Z
Summary
Malicious code in ecto-win-flag-q2m7 (npm)
Details

-= Per source details. Do not edit below this line.=-

Source: amazon-inspector (a6344042aff547b32cf30bc456be25e1229f921217ec0d6777f470174df10792)

On npm install, postinstall.js executes a harvest-and-exfiltrate chain against the installer's machine. It reads files under /app, /root, and /flag.txt, shells out via execFileSync('/bin/sh', ['-c',...]) to recursively grep the filesystem for HTB{...} flag patterns and collect git history, gathers host identifiers (uid, cwd, hostname), and transmits the collected data via HTTP PUT to a hardcoded attacker endpoint at http://154.57.164.82:31250/api/modules/ECT-*. The script includes sandbox-evasion gating that exits cleanly when cwd contains /tmp/npm-safe or /tmp/pkg, or when hostname matches nijin, hetzner, or ec2.internal — ensuring the malicious path only fires on real installer machines. The combination of unconditional filesystem read, hardcoded non-registry IP destination, and scanner-evasion logic is an unambiguous supply-chain attack.

Source: ghsa-malware (572f6a0b3a14892c3b86a30ede324f314a1f933c49e8376090756050a8e7a891)

Any computer that has this package installed or running should be considered fully compromised. All secrets and keys stored on that computer should be rotated immediately from a different computer. The package should be removed, but as full control of the computer may have been given to an outside entity, there is no guarantee that removing the package will remove all malicious software resulting from installing it.

Database specific
{
    "malicious-packages-origins": [
        {
            "id": "GHSA-22wq-6mfh-69qv",
            "import_time": "2026-06-12T15:23:25.115478956Z",
            "source": "ghsa-malware",
            "ranges": [
                {
                    "type": "SEMVER",
                    "events": [
                        {
                            "introduced": "0"
                        }
                    ]
                }
            ],
            "modified_time": "2026-06-12T14:32:52Z",
            "sha256": "572f6a0b3a14892c3b86a30ede324f314a1f933c49e8376090756050a8e7a891"
        },
        {
            "id": "IN-MAL-2026-005846",
            "import_time": "2026-06-12T19:43:39.612397103Z",
            "versions": [
                "1.0.0"
            ],
            "source": "amazon-inspector",
            "sha256": "a6344042aff547b32cf30bc456be25e1229f921217ec0d6777f470174df10792",
            "modified_time": "2026-06-12T19:03:10Z"
        },
        {
            "id": "IN-MAL-2026-005847",
            "import_time": "2026-06-12T19:43:39.722252575Z",
            "versions": [
                "1.0.1"
            ],
            "source": "amazon-inspector",
            "modified_time": "2026-06-12T19:03:12Z",
            "sha256": "23b7d4877162c6de01e19ee9d8aeafba981b2c4e08a6c1404f6b0cc5333cd508"
        }
    ]
}
References
Credits

Affected packages

npm / ecto-win-flag-q2m7

Package

Affected ranges

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

Affected versions

1.*
1.0.0
1.0.1

Database specific

cwes
[
    {
        "name": "Embedded Malicious Code",
        "description": "The product contains code that appears to be malicious in nature.",
        "cweId": "CWE-506"
    },
    {
        "name": "Embedded Malicious Code",
        "description": "The product contains code that appears to be malicious in nature.",
        "cweId": "CWE-506"
    },
    {
        "name": "Embedded Malicious Code",
        "description": "The product contains code that appears to be malicious in nature.",
        "cweId": "CWE-506"
    }
]
source
"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/npm/ecto-win-flag-q2m7/MAL-2026-5692.json"
indicators
{
    "evidence_files": [
        {
            "path": "postinstall.js",
            "sha256": "5c1aba57213b8d06660ee5c3c4f644e6497c00c5ccf83bcd9f12e2e6ae6c1610",
            "tlsh": "9061c8e4a7f5643403e3b4ed696b6106f66ba493304ae8d0b74d02992f4c0bd02f31cc"
        }
    ]
}