OSS-RISK-3 : Name Confusion Attacks

Description:

Attackers may create components whose names resemble names of legitimate open-source or system components (typo-squatting), suggest trustworthy authors (brand-jacking) or play with common naming patterns in different languages or ecosystems.

Malicious code can be executed on end-user systems or on systems belonging to the organization that develops and/or operates the dependent software (e.g., build systems or developer workstations). The confidentiality, integrity and availability of systems and the data processed/stored thereon is at risk.

Examples:

  1. Colourama (PyPI, 2018): Typo-squatting attack on the legitimate Python package “colorama”, redirecting Bitcoin transfers to an attacker-controlled wallet.

Actions:

Prior to installing/using a component:

  1. Check code characteristics (pre/post installation hooks, encoded payloads, etc.) and project characteristics (source code repository, maintainer accounts, release frequency, number of downstream users, etc.) for leading risk indicators.

    Note that some component metadata is not verified by package repositories, thus, can easily be forged by attackers.

  2. Verify that the component carries a signature from a trusted party (for ecosystems that support/require signatures)

References:

  1. Secure Supply Chain Consumption Framework (S2C2F)
  2. Risk Explorer for Software Supply Chains Create Name Confusion with Legitimate Package (AV-200)
  3. Supply chain Levels for Software Artifacts (SLSA)
  4. MITRE ATT&CK T1195.001 Compromise Software Dependencies and Development Tools