THREATPKG
SYNC STALE

Supply-chain threat intelligence

Incident detail

criticalnpm·maintainer compromise·osv

Malicious code in swagger-express-routes (npm)

swagger-express-routes

Risk score

92

AI summary

Indexed incident for swagger-express-routes (npm).

Description

On require('swagger-express-routes'), the package's main entry transitively loads src/utils/lib.min.js through src/connector/index.js (line 1: require('../utils/lib.min.js')). lib.min.js stashes Node's require and module onto global (global['r']=require), then uses a permutation-cipher routine (YWG) to deobfuscate a string blob, passes it to the Function constructor, and immediately invokes the resulting function. This is dynamic execution of an opaque payload reconstructed at runtime — the canonical anti-analysis pattern of an embedded supply-chain payload. Re-exposing require via a global alias lets the deobfuscated code pull in child_process, http, fs, etc. without those references being statically visible. None of this is documented in the README, and there is no legitimate reason for a small Express/OpenAPI helper to ship a permutation-deobfuscated Function-eval blob on its import path. Any consumer of this package executes the payload at require time.

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.

Technical details

Affected versions

=1.0.1>=0

Indicators

  • Advisory IDs
    90%
  • affected version=1.0.175%
  • affected version>=075%

Timeline

  1. Advisory published
  2. Indexed by ThreatPkg

Related incidents