Skip to content

An application for retrieving and viewing success metrics from Sonatype Nexus IQ

License

Notifications You must be signed in to change notification settings

moneeraden/nexusiq-successmetrics

 
 

Repository files navigation

Success Metrics Application for IQ Server

IQ Server has a number of REST APIs which can be used to extract policy evaluation, violation and remediation data. The Success Metrics get-metrics application extracts common metrics using this API and the view-metrics application aggregates the data into web or text reports.

Using the Success Metrics application is a two step process:

  1. Extract metrics from IQ server via REST API (get-metrics)
  2. Run the Success Metrics application against the success metrics csv (view-metrics)

Installation

  1. From the Releases pane on the right side of this page select the latest release

  2. Click on the nexusiq-successmetrics-[releasenumber].zip file on the assets page to download and save to your machine

  3. Unzip the contents into a directory of your choice

    unzip nexusiq-successmetrics-[releasenumber].zip
  4. Navigate to the successmetrics-[releasenumber] directory (this will be the working directory for the rest of the commands given in this README)

    cd nexusiq-successmetrics-[releasenumber.zip]

Fetch metrics from the IQ Server (get-metrics)

The get-metrics script extract metrics from an IQ server and stores the result in the ./iqmetrics directory.

get-metrics can be executed using a Java 1.8 jar or Docker image.

⚠ For large installations/datasets, the extract should be limited to a shorter period (e.g. previous 6 months or weeks) or subset of organisations and/or applications.

Get-Metrics Configuration

The configuration for get-metrics is stored in ./get-metrics/config/application.properties.

Metrics

To fetch associated metrics from Nexus IQ the following properties may be set to true.

metrics.successmetrics
metrics.applicationsevaluations
metrics.waivers
metrics.policyviolations
metrics.firewall

⚠ success-metrics should always be set to true.

Nexus IQ server details

These parameters should be updated with the details of the Nexus IQ instance.

iq.url
iq.user
iq.passwd

⚠ If you are using the get-metrics Docker image on the Nexus IQ machine then you cannot use 127.0.0.1 in the iq.url. You should instead use host.docker.internal.

Error validating the security certificate

If you receive an error saying "There was a problem validating the security certificate provided by IQ. Aborting..." when running the script then there is an option to disable checking of the Nexus IQ security certificate by setting the insecure.ssl parameter to true. This setting will make the connection to the Nexus IQ server less secure by bypassing the following checks that the get-metrics script performs on every connection to the Nexus IQ server:

  • check that the server certificate is signed by a trusted authority
  • check that the server certificate contains the correct domain name of the Nexus IQ server
  • check that the server certificate has, and has not expired

This option is provided for convenience. The more correct is to resolve the underlying issue, whether by adding the server certificate to your machine, using the servers name rather than IP address in the iq.url parameter or by confirming that the server certificate has not expired. How to perform these changes and checks is outside the scope of this application and varies by operating system.

Time period for which data should be fetched

Data may be collected in monthly or weekly periods by setting the iq.api.sm.period to either month or week.

The first period that we should collect data from is controlled by the iq.api.sm.payload.timeperiod.first parameter. This is a mandatory parameter. The format of this parameter is 2022-01 if iq.api.sm.period is set to month or 2022-W01 if iq.api.sm.period is set to week.

The last period that we should collect data from is controlled by the iq.api.sm.payload.timeperiod.last parameter. This is an optional parameter. The format of this parameter is 2022-04 if iq.api.sm.period is set to month or 2022-W04 if iq.api.sm.period is set to week.

Limit extracted data to given organisations or applications

To limit data extraction by organisation set iq.api.sm.payload.organisation.name to a list of comma separated organisation names. This is an optional parameter.

To limit data extraction by application set iq.api.sm.payload.application.name to a list of comma separated application names. This is an optional parameter.

If neither of these parameters are set then all organisations and applications will be fetched from Nexus IQ.

If both of these parameter are set then the organistaion setting will be used and application setting will be ignored.

Running get-metrics using Java

Get-metrics using Java on Linux/Mac machines

cd get-metrics
sh runapp.sh

Get-metrics using Java on Windows machines

cd get-metrics
runapp.bat

Running get-metrics using Docker

⚠ You must be in the get-metrics directory for the runapp-docker script to work.

Get-metrics using Docker on Linux/Mac machines

cd get-metrics
sh runapp-docker.sh

Get-metrics using Docker on Windows machines

cd get-metrics
runapp-docker.bat

view-metrics

There are two modes to the application.

  1. Web mode (interactive)
  2. Data extract mode (non-interactive)

The view-metrics script processes metrics stored in the ./nexusiq directory and presents them as detailed aggregated charts in a web view or in data files in the ./datafiles directory.

⚠ In order to aggregate and process success metrics a minimum of three data points (weeks or months) are needed.

⚠ Only fully completed months (or weeks) are included in the success metrics data extract.

View-metrics configuration

View-metrics configuration is stored in the ./successmetrics-[releasenumber]/view-metrics/application.properties file.

To configure which mode the view-metrics application should run in set the spring.profiles.active parameter to web for web (interactive) mode or data for data extract (non-interactive) mode.

Running the view-metrics application

Running view-metrics using Java

View-metrics using Java on Linux/Mac machines

cd view-metrics
sh runapp.sh

View-metrics using Java on Windows machines

cd view-metrics
runapp.bat

Running view-metrics using Docker

⚠ You must be in the get-metrics directory for the runapp-docker script to work.

View-metrics using Docker on Linux/Mac machines

cd view-metrics
sh runapp-docker.sh

View-metrics using Docker on Windows machines

cd view-metrics
runapp-docker.bat

Web (interactive) mode

When running in this mode a web UI for the Success Metrics application is available on the localhost http://localhost:4040

Data extract (non-interactive) mode

The Success Metrics application will perform calculations on the provided metrics, output files representing this and then close. Three output files can then be found in the ./successmetrics-[releasenumber]/output directory.

  1. Metrics Summary PDF
  2. Insights CSV
  3. Data Extract CSV

The Fine Print

For large datasets we recommend running extracts for small periods of time and for sets of organisations instead of the full system.

This application is NOT SUPPORTED by Sonatype, and is a contribution of ours to the open source community (read: you!)

Don't worry, using this community item does not "void your warranty". In a worst case scenario, you may be asked by the Sonatype Support team to remove the community item in order to determine the root cause of any issues.

Please remember:

  • Use this contribution at the risk tolerance that you have
  • Do NOT file Sonatype support tickets related to iq-success-metrics
  • DO file issues here on GitHub, so that the community can pitch in
  • Phew, that was easier than I thought. Last but not least of all, have fun creating and using this application and the Nexus platform, we are glad to have you here!

About

An application for retrieving and viewing success metrics from Sonatype Nexus IQ

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 72.5%
  • HTML 23.6%
  • CSS 3.5%
  • Other 0.4%