Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[FP]: vulnerability in date-and-time (NPM) dependencies being flagged in kotlinx-datetime dependencies #6864

Closed
volkert-fastned opened this issue Jul 22, 2024 · 8 comments

Comments

@volkert-fastned
Copy link
Contributor

volkert-fastned commented Jul 22, 2024

Package URl

pkg:maven/org.jetbrains.kotlinx/kotlinx-datetime*

CPE

cpe:2.3:a:date-and-time_project:date-and-time:0.6.0:*:*:*:*:*:*:*

CVE

CVE-2020-26289

ODC Integration

{"label"=>"Gradle Plugin"}

ODC Version

10.0.3

Description

This NPM-specific CPE is apparently being erroneously applied to multiple Kotlin dependencies:

kotlinx-datetime-0.6.0-sources.jar	cpe:2.3:a:date-and-time_project:date-and-time:0.6.0:*:*:*:*:*:*:*	pkg:maven/org.jetbrains.kotlinx/[email protected]
kotlinx-datetime-js-0.6.0-sources.jar	cpe:2.3:a:date-and-time_project:date-and-time:0.6.0:*:*:*:*:*:*:*	pkg:maven/org.jetbrains.kotlinx/[email protected]
kotlinx-datetime-jvm-0.6.0-sources.jar	cpe:2.3:a:date-and-time_project:date-and-time:0.6.0:*:*:*:*:*:*:*	pkg:maven/org.jetbrains.kotlinx/[email protected]
kotlinx-datetime-macosarm64-0.6.0-sources.jar	cpe:2.3:a:date-and-time_project:date-and-time:0.6.0:*:*:*:*:*:*:*	pkg:maven/org.jetbrains.kotlinx/[email protected]

Since kotlinx-datetime is a Kotlin Multiplatform (KMP) library, the JS-specific dependencies of that library, such as kotlinx-datetime-js, could at least in theory be affected by this vulnerability if they depend on affected versions of the date-and-time NPM dependency, but it doesn't look like that's the reason why this vulnerability is getting flagged. (Even if it did, it should only flag it on the applicable -js dependencies of the library.)

Copy link
Contributor

Failed to automatically evaluate the false positive. See: https://github.com/jeremylong/DependencyCheck/actions/runs/10040271163

Copy link
Contributor

Failed to automatically evaluate the false positive. See: https://github.com/jeremylong/DependencyCheck/actions/runs/10040275711

Copy link
Contributor

Failed to automatically evaluate the false positive. See: https://github.com/jeremylong/DependencyCheck/actions/runs/10040307470

@volkert-fastned
Copy link
Contributor Author

The likely reason why github-actions couldn't automatically evaluate the false positives was probably because I suffixed the Maven package with an asterisk (*), to make it clear that all packages that start with pkg:maven/org.jetbrains.kotlinx/kotlinx-datetime are apparently flagged by this FP.

@volkert-fastned
Copy link
Contributor Author

This broader CVE-level suppression worked for me, but it does assume that the JS-specific dependencies of this KMP library don't actually depend on the affected JS library:

    <suppress>
        <notes><![CDATA[
        FP per issue #6864
        ]]></notes>
        <packageUrl regex="true">^pkg:maven/org\.jetbrains\.kotlinx/kotlinx-datetime.*$</packageUrl>
        <cve>CVE-2020-26289</cve>
    </suppress>

@aikebah
Copy link
Collaborator

aikebah commented Oct 16, 2024

@volkert-fastned do you still get these FPs? I tried locally to reproduce it using

plugins {
    kotlin("jvm") version "1.8.0"
}

buildscript {
  repositories {
      mavenLocal()
        maven {
            url = uri("https://plugins.gradle.org/m2/")
        }

      mavenCentral()
  }
  dependencies {
    classpath("org.owasp:dependency-check-gradle:10.0.4")
  }
}

apply(plugin = "org.owasp.dependencycheck")

group = "com.example"
version = "1.0-SNAPSHOT"

repositories {
    mavenLocal()
    mavenCentral()
}

dependencies {
    implementation("org.jetbrains.kotlinx", "kotlinx-datetime", "0.6.0")
    implementation("org.jetbrains.kotlinx", "kotlinx-datetime-js", "0.6.0")
    implementation("org.jetbrains.kotlinx", "kotlinx-datetime-jvm", "0.6.0")
    implementation("org.jetbrains.kotlinx", "kotlinx-datetime-macosarm64", "0.6.0")
}

but the false positives do not show up

@nhumblot
Copy link
Collaborator

Closing as unable to reproduce and no additional information from the author.

@nhumblot nhumblot reopened this Dec 30, 2024
@nhumblot nhumblot closed this as not planned Won't fix, can't repro, duplicate, stale Dec 30, 2024
Copy link
Contributor

Failed to automatically evaluate the false positive. See: https://github.com/jeremylong/DependencyCheck/actions/runs/12547552832

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants