Class NodeAuditAnalyzer

  • All Implemented Interfaces:
    java.io.FileFilter, Analyzer, FileTypeAnalyzer

    @ThreadSafe
    public class NodeAuditAnalyzer
    extends AbstractNpmAnalyzer
    Used to analyze Node Package Manager (npm) package-lock.json and npm-shrinkwrap.json files via NPM Audit API.
    Author:
    Steve Springett
    • Field Detail

      • DEFAULT_URL

        public static final java.lang.String DEFAULT_URL
        The default URL to the NPM Audit API.
        See Also:
        Constant Field Values
      • DEPENDENCY_ECOSYSTEM

        public static final java.lang.String DEPENDENCY_ECOSYSTEM
        A descriptor for the type of dependencies processed or added by this analyzer.
        See Also:
        Constant Field Values
      • PACKAGE_LOCK_JSON

        public static final java.lang.String PACKAGE_LOCK_JSON
        The file name to scan.
        See Also:
        Constant Field Values
      • SHRINKWRAP_JSON

        public static final java.lang.String SHRINKWRAP_JSON
        The file name to scan.
        See Also:
        Constant Field Values
    • Constructor Detail

      • NodeAuditAnalyzer

        public NodeAuditAnalyzer()
    • Method Detail

      • getName

        public java.lang.String getName()
        Returns the name of the analyzer.
        Returns:
        the name of the analyzer.
      • getAnalysisPhase

        public AnalysisPhase getAnalysisPhase()
        Returns the phase that the analyzer is intended to run in.
        Returns:
        the phase that the analyzer is intended to run in.
      • getAnalyzerEnabledSettingKey

        protected java.lang.String getAnalyzerEnabledSettingKey()
        Returns the key used in the properties file to determine if the analyzer is enabled.
        Specified by:
        getAnalyzerEnabledSettingKey in class AbstractAnalyzer
        Returns:
        the enabled property setting key for the analyzer
      • analyzeDependency

        protected void analyzeDependency​(Dependency dependency,
                                         Engine engine)
                                  throws AnalysisException
        Description copied from class: AbstractAnalyzer
        Analyzes a given dependency. If the dependency is an archive, such as a WAR or EAR, the contents are extracted, scanned, and added to the list of dependencies within the engine.
        Specified by:
        analyzeDependency in class AbstractAnalyzer
        Parameters:
        dependency - the dependency to analyze
        engine - the engine scanning
        Throws:
        AnalysisException - thrown if there is an analysis exception