Snyk - Open Source Security

Snyk test report

January 21st 2025, 9:27:37 am (UTC+00:00)

Scanned the following paths:
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master (gradle)
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master/documentation (gradle)
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master/domain-graph-api (gradle)
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master/domain-graph-impl (gradle)
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master/domain-visualizer-d3 (gradle)
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master/json-pep-client (gradle)
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master/json-pep-client-jaxrs (gradle)
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master/json-pep-models (gradle)
  • /mnt/sdb1/buildmaster-agent/workspace/CR_alfa-test-framework_master/plugin-tests (gradle)
1 known vulnerabilities
3 vulnerable dependency paths
281 dependencies

Information Exposure

low severity

  • Package Manager: maven
  • Vulnerable module: org.jetbrains.kotlin:kotlin-stdlib
  • Introduced through: alfa-test-framework/plugin-tests@1.0.40, com.github.docker-java:docker-java-transport-okhttp@3.4.0 and others

Detailed paths

  • Introduced through: alfa-test-framework/plugin-tests@1.0.40 com.github.docker-java:docker-java-transport-okhttp@3.4.0 com.squareup.okhttp3:okhttp@4.12.0 org.jetbrains.kotlin:kotlin-stdlib-jdk8@2.0.21 org.jetbrains.kotlin:kotlin-stdlib@2.0.21
  • Introduced through: alfa-test-framework/plugin-tests@1.0.40 com.github.docker-java:docker-java-transport-okhttp@3.4.0 com.squareup.okhttp3:okhttp@4.12.0 org.jetbrains.kotlin:kotlin-stdlib-jdk8@2.0.21 org.jetbrains.kotlin:kotlin-stdlib-jdk7@2.0.21 org.jetbrains.kotlin:kotlin-stdlib@2.0.21
  • Introduced through: alfa-test-framework/plugin-tests@1.0.40 com.github.docker-java:docker-java-transport-okhttp@3.4.0 com.squareup.okhttp3:okhttp@4.12.0 com.squareup.okio:okio@3.6.0 com.squareup.okio:okio-jvm@3.6.0 org.jetbrains.kotlin:kotlin-stdlib-common@2.0.21 org.jetbrains.kotlin:kotlin-stdlib@2.0.21

Overview

org.jetbrains.kotlin:kotlin-stdlib is a Kotlin Standard Library for JVM.

Affected versions of this package are vulnerable to Information Exposure. A Kotlin application using createTempDir or createTempFile and placing sensitive information within either of these locations would be leaking this information in a read-only way to other users also on this system.

Note: As of version 1.4.21, the vulnerable functions have been marked as deprecated. Due to still being usable, this advisory is kept as "unfixed".

PoC by JLLeitschuh

package org.jlleitschuh.sandbox
        
        import org.junit.jupiter.api.Test
        import java.io.BufferedReader
        import java.io.File
        import java.io.IOException
        import java.io.InputStreamReader
        import java.nio.file.Files
        
        class KotlinTempDirectoryPermissionCheck {
            @Test
            fun `kotlin check default directory permissions`() {
                val dir = createTempDir()
                runLS(dir.parentFile, dir) // Prints drwxr-xr-x
            }
        
            @Test
            fun `Files check default directory permissions`() {
                val dir = Files.createTempDirectory("random-directory")
                runLS(dir.toFile().parentFile, dir.toFile()) // Prints drwx------
            }
        
            @Test
            fun `kotlin check default file permissions`() {
                val file = createTempFile()
                runLS(file.parentFile, file) // Prints -rw-r--r--
            }
        
            @Test
            fun `Files check default file permissions`() {
                val file = Files.createTempFile("random-file", ".txt")
                runLS(file.toFile().parentFile, file.toFile()) // Prints -rw-------
            }
        
            private fun runLS(file: File, lookingFor: File) {
                val processBuilder = ProcessBuilder()
                processBuilder.command("ls", "-l", file.absolutePath)
                try {
                    val process = processBuilder.start()
                    val output = StringBuilder()
                    val reader = BufferedReader(
                        InputStreamReader(process.inputStream)
                    )
                    reader.lines().forEach { line ->
                        if (line.contains("total")) {
                            output.append(line).append('\n')
                        }
                        if (line.contains(lookingFor.name)) {
                            output.append(line).append('\n')
                        }
                    }
                    val exitVal = process.waitFor()
                    if (exitVal == 0) {
                        println("Success!")
                        println(output)
                    } else {
                        //abnormal...
                    }
                } catch (e: IOException) {
                    e.printStackTrace()
                } catch (e: InterruptedException) {
                    e.printStackTrace()
                }
            }
        }
        

Remediation

Upgrade org.jetbrains.kotlin:kotlin-stdlib to version 2.1.0 or higher.

References