mirror of
https://github.com/ysoftdevs/DependencyCheck.git
synced 2026-03-23 01:29:43 +01:00
Ruby Bundler: Successfully adding vulnerability into report, though all displayed info not looking great.
This commit is contained in:
@@ -22,6 +22,7 @@ import org.owasp.dependencycheck.Engine;
|
|||||||
import org.owasp.dependencycheck.analyzer.exception.AnalysisException;
|
import org.owasp.dependencycheck.analyzer.exception.AnalysisException;
|
||||||
import org.owasp.dependencycheck.dependency.Confidence;
|
import org.owasp.dependencycheck.dependency.Confidence;
|
||||||
import org.owasp.dependencycheck.dependency.Dependency;
|
import org.owasp.dependencycheck.dependency.Dependency;
|
||||||
|
import org.owasp.dependencycheck.dependency.Vulnerability;
|
||||||
import org.owasp.dependencycheck.utils.FileFilterBuilder;
|
import org.owasp.dependencycheck.utils.FileFilterBuilder;
|
||||||
import org.owasp.dependencycheck.utils.Settings;
|
import org.owasp.dependencycheck.utils.Settings;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
@@ -188,12 +189,14 @@ public class RubyBundleAuditAnalyzer extends AbstractFileTypeAnalyzer {
|
|||||||
final String parentName = original.getActualFile().getParentFile().getName();
|
final String parentName = original.getActualFile().getParentFile().getName();
|
||||||
final String fileName = original.getFileName();
|
final String fileName = original.getFileName();
|
||||||
Dependency dependency = null;
|
Dependency dependency = null;
|
||||||
|
Vulnerability vulnerability= null;
|
||||||
|
String gem = null;
|
||||||
while (rdr.ready()) {
|
while (rdr.ready()) {
|
||||||
final String nextLine = rdr.readLine();
|
final String nextLine = rdr.readLine();
|
||||||
if (null == nextLine) {
|
if (null == nextLine) {
|
||||||
break;
|
break;
|
||||||
} else if (nextLine.startsWith(NAME)) {
|
} else if (nextLine.startsWith(NAME)) {
|
||||||
final String gem = nextLine.substring(NAME.length());
|
gem = nextLine.substring(NAME.length());
|
||||||
final File tempFile = File.createTempFile("Gemfile-" + gem, ".lock", Settings.getTempDirectory());
|
final File tempFile = File.createTempFile("Gemfile-" + gem, ".lock", Settings.getTempDirectory());
|
||||||
final String displayFileName = String.format("%s%c%s:%s", parentName, File.separatorChar, fileName, gem);
|
final String displayFileName = String.format("%s%c%s:%s", parentName, File.separatorChar, fileName, gem);
|
||||||
FileUtils.write(tempFile, displayFileName); // unique contents to avoid dependency bundling
|
FileUtils.write(tempFile, displayFileName); // unique contents to avoid dependency bundling
|
||||||
@@ -201,16 +204,27 @@ public class RubyBundleAuditAnalyzer extends AbstractFileTypeAnalyzer {
|
|||||||
engine.getDependencies().add(dependency);
|
engine.getDependencies().add(dependency);
|
||||||
dependency.setDisplayFileName(displayFileName);
|
dependency.setDisplayFileName(displayFileName);
|
||||||
dependency.getProductEvidence().addEvidence("bundler-audit", "Name", gem, Confidence.HIGHEST);
|
dependency.getProductEvidence().addEvidence("bundler-audit", "Name", gem, Confidence.HIGHEST);
|
||||||
|
vulnerability = new Vulnerability();
|
||||||
|
vulnerability.setName(gem);
|
||||||
|
dependency.getVulnerabilities().add(vulnerability);
|
||||||
LOGGER.info(String.format("bundle-audit (%s): %s", parentName, nextLine));
|
LOGGER.info(String.format("bundle-audit (%s): %s", parentName, nextLine));
|
||||||
} else if (nextLine.startsWith(VERSION)) {
|
} else if (nextLine.startsWith(VERSION)) {
|
||||||
if (null != dependency) {
|
if (null != dependency) {
|
||||||
|
final String version = nextLine.substring(VERSION.length());
|
||||||
dependency.getVersionEvidence().addEvidence(
|
dependency.getVersionEvidence().addEvidence(
|
||||||
"bundler-audit",
|
"bundler-audit",
|
||||||
"Version",
|
"Version",
|
||||||
nextLine.substring(VERSION.length()),
|
version,
|
||||||
Confidence.HIGHEST);
|
Confidence.HIGHEST);
|
||||||
|
vulnerability.setMatchedCPE(
|
||||||
|
String.format("cpe:/a:%1$s_project:%1$s:%2$s::~~~ruby~~", gem, version),
|
||||||
|
null);
|
||||||
}
|
}
|
||||||
LOGGER.info(String.format("bundle-audit (%s): %s", parentName, nextLine));
|
LOGGER.info(String.format("bundle-audit (%s): %s", parentName, nextLine));
|
||||||
|
} else if (nextLine.startsWith("Advisory: ")){
|
||||||
|
final String advisory = nextLine.substring(("Advisory: ".length()));
|
||||||
|
vulnerability.setName(advisory);
|
||||||
|
LOGGER.info(String.format("bundle-audit (%s): %s", parentName, nextLine));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user