This plugin allows Jenkins builds to scan the resulting build artifacts with Synopsys Black Duck Binary Analysis tool (formerly known as Protecode SC).
More information of Synopsys Protecode SC is available from https://www.synopsys.com/software-integrity/security-testing/software-composition-analysis.html
- Install the Protecode SC Jenkins plugin via the Plugin Manager and restart Jenkins.
- Configure system wide Protecode SC server address.
- Manage Jenkins > Configure System
- Protecode SC: Server address
- Specify the HTTP address of the Protecode SC installation here, such as https://protecode-sc.mydomain.com/.
- Protecode SC: Disable certificate validation
- Allow connections to Protecode SC server without certificate validation. It is not recommended to use this option. Instead you should consider getting a valid certificate for your server.
- Protecode SC: Server address
- Manage Jenkins > Configure System
Configure a build step as follows:
-
Protecode SC
- Credentials (new) Add - Select "Global" and "Username with password" - Enter your user Protecode SC user details
- (existing) Select suitable credentials
- Group ID
- Specify the Protecode SC Group ID where the artifacts should be uploaded to. The group id is only the number of the group. Group ID can be found from the Protecode SC service by looking at the URL when browsing an individual group: https://protecode-sc.mydomain.com/group/1234/ or with Groups API https://protecode-sc.mydomain.com/api/groups/.
- Using environment variable is also supported, e.g $MY_GROUP_ID which contains the group ID number.
- Fail build if vulnerabilities
- Trigger build failure if Protecode SC finds vulnerabilities from the artifacts.
- Directory for files to scan
- The directory to scan. There is no automatic scanning of artifacts yet (as of 0.15.1)
- Using environment variable is also supported, e.g $MY_SCAN_DIR which contains the path or URL to scan.
- Include subdirectories. Please see help for warnings.
- Include all files in a directory structure. Please notice that this can send massive amounts of files if the "directory to scan" is set incorrectly.
- Regular expression for including files
- A Java 8 type regexp pattern. Please see https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html for more information.
- Scanning timeout (minutes)
- The timeout for the scanning build step. If the scan operation in protecode lasts longer than the given value, the build step will exit.
- Convert results to Summary plugin format
- Set to
true
- The summary can be shown using Summary Display Plugin of Jenkins. The report file name to publish is protecodesc.xml.
- Set to
- Credentials (new) Add - Select "Global" and "Username with password" - Enter your user Protecode SC user details
-
Publish XML Summary Reports (requires Summary Display Plugin)
- Files to parse
- Set to
**/protecodesc.xml
- Set to
- Show on Project page
- Set to
true
- Set to
- Files to parse
-
If you use Summar****y Display Plugin the results of all files scanned in the whole history of the build on the right side of the builds main page.
-
Please notice that the results shown on are all the results ever produced by the build.
-
If you wish to see only the latest results you can manually delete the reports directory. This is most conveniently done in a "Execute shell" step. A new directory is created in place of the deleted one automatically.
-
If no summary plugin is used the build will only fail if vulnerabilities are found (as of 0.15)
- A more detailed UI to show vulnerabilities and history is being planned currently, but no release date has been set yet (as of 7.2.2018).
Simple example, more to be added:
node {
stage ("Scan files") {
protecodesc credentialsId: 'PR2', directoryToScan: 'target', includeSubdirectories: true, protecodeScGroup: '<number>', scanTimeout: 40
}
}
When you encounter problems while using the plugin, please provide the following information:
- What you were doing when the problem occurred.
- The error message
- The Jenkins server log file (the location is dependent on the container you use)
- The content of ‘Manage Jenkins > System Information’ (Jenkins root/systemInfo)
- The configuration file for the job (Jenkins root/jobs/job name/config.xml)
- The global configuration file for Jenkins (Jenkins root/config.xml)
- In case of problems while saving the job configuration, a screenshot before submitting, and the browser you are using.
- Fixed a bug causing scans done via URL fetch to always pass.
- Updated to Java 11
- Updated dependencies to later versions
- Moved documentation to Github
- Support using environment variables for Group ID and Scan Directory / URL
- Support for using docker-registry-http and docker-registry-https protocols in scan URL
- Fixed crash if no custom header was given when scanning URL
- Support API key
- Has texts changed to Black Duck Binary Analysis to reflect naming changes in tool.
- Added possiblity to never zip provided the plugin is run against a privately hosted appliance
- removed some waiting from results checking
- removed some waiting from sending files to Protecode SC
- Fixed a possible corner case nullpointer
- Updated okHttp libraries to latest
- Added retryOnFail to okHttp
- Added Header(Connection, close) to connection
- Added logic to make sure that the result is binded to the correct response always.
- Added possiblity to only upload files to Protecode SC and not wait for results
- Added some more logging
- Pipeline fix due to Jenkins change.
- Loggin fixes
- Logic made more robust
- Files are zipped only if there are 10 or more files. If there are 9 or less files, they are sent in parallel.
- It is now possible to define the zip name (thus the Protecode SC analysis job name)
- Clarifications to jenkins build console logging.
- Robustness improvements.
-
Files are zipped before being sent to Protecode SC to avoid massive overhead for large amounts of files.
-
Results are shown for files individualy
-
File result has build number indicator to specify from which build the result is from.
-
Many minor improvements
- Fixed: Plugin looses configuration and throws exception for missing fields in configuration when updating from earlier versions
-
Limited parallel file uploads to four due to Protecode SC cloud limit.
- Files are now queued until free connections are available. This slows builds down, but avoids errors when the service is at low capacity.
-
Plugin now logs less useless info into jenkins log.
-
Fixed no name showing in lists when the file is hidden.
- Advanced file options.
- Regexp support and include subfolders added as build configuration options.
- Removed some legacy options (safe to transfer old build configurations to new release).
- Various bugfixes and logging improvements.
- Improved jenkins logging.
- Plugin uses latest API now. (this could break scan requests sometimes)
- Fixed: File Input stream for a file to be scanned could not be read multiple times.
- Fixed bug caused builds not to fail when required.
- Added a warning that this breaks the configuration of builds before 0.15.1
- Minor bug fixes
- Complete overhaul
- Basic pipeline and snippet support
- Compatibility break
- Fixed an issue with file paths in distributed executor setup
- Added ability to define scanning timeout
- Fixed an issue that prevented uploading larger files
- Improved API exception handling to show proper error messages
- Upload build artifacts even when additional artifact directory is not defined
- Increase polling interval
- Initial release
The plugin works with Jenkins 2.60.1 or newer and it is written to be Java 1.8 compatible.
The plugin is built with Maven 3.x. The command to create the package to be deployed, simply issue
mvn package
This will compile, test and package the plugin into an Jenkins plugin installation package to target/protecode-sc-plugin.hpi
.
- Install dependencies
- Credentials plugin for storing Protecode SC credentials
- Optional: Summary Display plugin for rendering reports from Protecode SC scans
- Upload and install Protecode SC Plugin
protecode-sc-plugin.hpi
- Restart Jenkins
See https://plugins.jenkins.io/protecode-sc
- https://plugins.jenkins.io/confluence-publisher
- https://plugins.jenkins.io/mock-slave
- https://plugins.jenkins.io/http-post
- https://plugins.jenkins.io/http_request
- https://plugins.jenkins.io/publish-over-ssh
- https://plugins.jenkins.io/hudson-pview-plugin
- https://plugins.jenkins.io/device-watcher
- https://plugins.jenkins.io/hipchat
- https://plugins.jenkins.io/coverity
- https://plugins.jenkins.io/disk-usage
- https://plugins.jenkins.io/findbugs
- https://plugins.jenkins.io/robot
- https://plugins.jenkins.io/copyartifact
- https://plugins.jenkins.io/text-file-operations
- https://plugins.jenkins.io/build-timeout
- https://plugins.jenkins.io/exclusive-execution
- https://plugins.jenkins.io/versionnumber
- https://plugins.jenkins.io/files-found-trigger
- https://plugins.jenkins.io/artifact-diff-plugin
- https://plugins.jenkins.io/blackduck-detect
- https://plugins.jenkins.io/blackduck-hub
- https://plugins.jenkins.io/downstream-buildview
- https://plugins.jenkins.io/project-inheritance
- https://plugins.jenkins.io/build-monitor-plugin
- https://plugins.jenkins.io/htmlresource
All rights reserved. This program and the accompanying materials are made available under the terms of the Eclipse Public License v1.0 which accompanies this distribution, and is available at http://www.eclipse.org/legal/epl-v10.html