title | layout | sidebar | permalink | folder |
---|---|---|---|---|
Managing Open-source security and license with Mend (formerly WhiteSource) |
page |
vsts2 |
/labs/vstsextend/whitesource/ |
/labs/vstsextend/whitesource/ |
Mend (formerly WhiteSource){:target="_blank"} is the leader in continuous open source software security and compliance management. Mend integrates into your build process, irrespective of your programming languages, build tools, or development environments. It works automatically, continuously, and silently in the background, checking the security, licensing, and quality of your open source components against WhiteSource constantly-updated definitive database of open source repositories.
Mend provides Mend Bolt, a lightweight open source security and management solution developed specifically for integration with Azure DevOps and Azure DevOps Server. It works per project and does not offer real-time alert capabilities like the Full platform which is generally recommended for larger development teams, wanting to automate their open source management throughout the entire software development lifecycle (from the repositories to post-deployment stages) and across all projects and products.
This lab shows how you can use Mend Bolt with Azure DevOps to automatically detect alerts on vulnerable open source components, outdated libraries, and license compliance issues in your code. You will be using WebGoat, a deliberately insecure web application, maintained by OWASP designed to teach web application security lessons.
Azure DevOps integration with Mend Bolt will enable you to:
- Detect and remedy vulnerable open source components.
- Generate comprehensive open source inventory reports per project or build.
- Enforce open source license compliance, including dependencies’ licenses.
- Identify outdated open source libraries with recommendations to update.
-
Refer the Getting Started page before you follow the exercises.
-
Use Azure DevOps Demo Generator{:target="_blank"} to provision the WhiteSource project on your Azure DevOps Organization.
Ensure the following:
-
Your Azure DevOps organization is connected to an Azure AD via Organization Settings > Azure Active Directory.
-
In your Azure DevOps navigate to Organization Settings and select Mend under Extensions. Provide your Work Email, Company Name and other details and click Create Account button to start using the Free version.
You have a Java code provisioned by the Azure DevOps demo generator. You will use Mend Bolt extension to check the vulnerable components present in this code.
-
Go to Pipelines section under Pipelines tab, select the build definition WhiteSourceBolt and click on Run pipeline to trigger a build. Click Run (leave defaults).
{% include note.html content= "We also have a YAML build pipeline if that's something you're interested in. To proceed through the YAML pipeline, choose WhiteSourceBolt-YAML and click Edit to view the YAML pipeline." %}
-
To view the build in progress status, click on job named Phase 1.
-
While the build is in progress, let's explore the build definition. The tasks that are used in the build definition are listed in the table below.
-
Once the build is completed, click back navigation to see the summary which shows Test results, Build artifacts etc. as shown below.
-
Navigate to WhiteSource Bolt Build Report tab and wait for the report generation of the completed build to see the vulnerability report. This report shows the list of all vulnerable open source components with Vulnerability Score, Vulnerable Libraries, Severity Distribution
Mend bolt automatically detects OpenSource components in the software including transitive dependencies and their respective licenses.
The security vulnerability section shows vulnerabilty, name of the library, description and Top Fix
You can see the opensource license distribution and a detailed view of all components and links to their metadata and licensed references.
With Azure DevOps and Mend Bolt integration, you can shift-left your open source management. The integration allows you to have alerts in real time, on vulnerabilities and other issues to help you take immediate action.