Vulnerability Management
Manual for the vulnerability management using Ketryx Software Supply Chain Management
1. Introduction
Vulnerability management is the process of identifying, evaluating, treating, and reporting on security vulnerabilities in systems and the software that runs on them. The process is a continuous cycle of discovery, prioritization, and remediation. Vulnerability management is integral to computer security and network security.
When developing medical devices following IEC 62304, vulnerability management becomes even more crucial. Medical devices often rely on Software of Unknown Provenance (SOUP) and Off-the-shelf (OTS) software components and dependencies, making them vulnerable to security risks. Proper vulnerability management ensures that potential vulnerabilities are identified and addressed, reducing the risk of security breaches and ensuring the safety and effectiveness of the medical devices.
Ketryx Software Supply Chain Management offers a vulnerability management module designed to assist users in monitoring vulnerabilities within their software supply chain. This module presents a centralized view of all vulnerabilities in the software supply chain, aiding users in prioritizing and remedying them.
1.1. Purpose
The purpose of this document instruct users on how to use the Vulnerability management module in Ketryx Software Supply Chain Management to manage vulnerabilities in the software supply chain.
1.2. Scope
This document describes the features and functionality of the Vulnerability management module in Ketryx Software Supply Chain Management.
2. Terms and definitions
The definitions of this document conform to the ones of ISO/IEC 27001, ANSI/AAMI SW96:2023, and AAMI TIR57:2016/(R)2019.
GHSA
GitHub Security Advisory
OTS
Off-the-shelf
SBOM
Software Bill of Materials
SOUP
Software of Unknown Provenance
SPDX
Software Package Data Exchange
3. Project setup
To use the Vulnerability management module, you need to have a project set up in Ketryx Software Supply Chain Management. If you don't have a project set up, follow the instructions in MAN-03, section 3.
Once you have a project set up, you can start using the Vulnerability management module. The module is available in the SBOM > Vulnerabilities section of the project.
4. Manage vulnerabilities
The Manage vulnerabilities (available in the SBOM > Vulnerabilities section of the project) screen displays a list of all identified vulnerabilities in the software supply chain of the project. It is also possible to create, edit, and manage vulnerability impact assessments on this screen, as well as to create, edit, and manage manual vulnerabilities.
If the project contains transitive dependencies, the vulnerabilities of the transitive dependencies are also displayed. The vulnerabilities of the transitive dependencies can be expanded to view more information. For transitive dependency support, please refer to MAN-03, section 12, as well as the manual on Working with SPDX or Working with CycloneDX.
The vulnerabilities list displays the following information for each identified vulnerability:
Title: The title of the vulnerability. Below the title, the vulnerable SOUP or OTS component is displayed. Clicking on the SOUP/OTS component will take you to the detail screen, where you can view more information about the component.
Reported on: The date the vulnerability was reported.
Severity: The severity of the vulnerability and its score.
Risks: The number of risks associated with the vulnerability, if any.
Mitigations: The number of mitigations associated with the vulnerability, if any.
Resolution: The resolution status of the vulnerability impact assessment.
Status: The status of the vulnerability.
Expand: Clicking on the expand icon will display more information about the vulnerability, such as the description, the affected version, etc. and if available, the vulnerability impact assessment.
Columns can be sorted, filtered, resized and rearranged to suit your needs.
When hovering over a column header, an arrow icon will appear. Clicking on the arrow will sort the column in ascending or descending order.
To rearrange columns, click and drag the column header to the desired position.
To resize a column, hover over the right edge of the column header until the resize icon appears, then click and drag the edge to the desired width. Double-clicking on the edge will automatically resize the column to fit the content.
To filter, hide, or pin a column, hover over a column click on the three-dot (︙) icon in the column header and select the desired options.
5. Manual vulnerabilities
For many ecosystems, Ketryx can automatically detect vulnerabilities by leveraging the GHSA (GitHub Security Advisory). However, for the product itself or certain OTS (Off-The-Shelf) software, Ketryx allows users to create and manage their own vulnerabilities.
5.1. Creating a manual vulnerability
To create a manual vulnerability, click on the Add vulnerability button on the manage vulnerabilities screen above the table.
Clicking on the Add vulnerability button opens the manual vulnerability dialog.
Manual vulnerabilities can be created by populating the vulnerability details and then clicking the Add vulnerability button. The following fields are available:
Title
Introduced in Version
Obsolete in Version
Description
CVE ID
External URL
Reported On
Severity (Severity level and/or Severity CVSS Vector string)
Additional fields for assessing the vulnerability impact (see section 6)
5.1.1. Manual vulnerability severity
Manual vulnerability severity is set by a severity level dropdown with an option to assess severity using a CVSS vector string. Currently, CVSS vectors of version 3.0, 3.1, and 4.0 are supported.
5.2. Editing a manual vulnerability
To edit a manual vulnerability, select a vulnerability from the Vulnerabilities list and click on the Edit vulnerability impact assessment button.
This will open the Edit item page where you can edit the manual vulnerability fields alongside its impact assessment. Clicking the Save changes button saves the new version.
6. Vulnerability impact assessment
The Vulnerability impact assessment is a detailed analysis of the impact of a vulnerability on the product. It includes information about the affected components, the potential risks, and the mitigations that can be taken to reduce the impact of the vulnerability.
It is available for each identified vulnerability (including manual vulnerabilities). To view the Vulnerability impact assessment, click on the expand icon in the Vulnerabilities list.
The Vulnerability impact assessment functionality is only available to users with the necessary permissions and approval rules. If you don't have the necessary permissions, contact your organization's administrator.
The required permission is Edit dependency which can be found on the page Settings > Permissions of a project.
Approval rules can be set up on the page Settings > Approval rules of a project.
6.1. Creating a vulnerability impact assessment
To create a vulnerability impact assessment, select one or more vulnerabilities from the Vulnerabilities list and click on the Create impact assessment button. This will open a dialog where you can fill in the details of the impact assessment.
For manual vulnerabilities, the Edit vulnerability impact assessment button is available instead of the Create vulnerability impact assessment button.
In the dialog, details of the impact assessment, such as rationales, justifications, potential risks, and mitigations that can be taken to reduce the impact of the vulnerability, can be filled in. By default, the following fields are available:
Severity: This section can be used to modify the severity of the selected vulnerabilities.
CVSS vectors of version 3.0, 3.1, and 4.0 are supported.
During impact assessment creation, leaving the severity field empty will keep the severity of the vulnerability unchanged.
When creating an impact assessment for multiple vulnerabilities in batch, the modifying severity will be applied to all selected vulnerabilities.
Resolution: The resolution status of the vulnerability impact assessment. This field serves to quickly identify the status of the impact assessment, e.g. if a vulnerability is not relevant or exploitable.
Justification for resolution: A justification for the resolution status.
Introduced risks: A list of risks connected to the vulnerability. New risks can be added by using the Risk management module, see MAN-08 Risk Management.
Rationale for connecting risks: A rationale for connecting the risks.
Mitigations: A list of mitigations connected to the vulnerability. By default, any item type but the Risk item type are available. The available item types can be changed in the advanced project settings.
Rationale for connecting mitigations: A rationale for connecting the mitigations.
The vulnerability impact assessment dialog allows customization of all fields to align with your organization's requirements via the advanced project settings. This can be archived either with the advanced settings for the vulnerability impact assessment module, or using the more generic custom item fields configuration.
6.2. Editing a vulnerability impact assessment
To edit a vulnerability impact assessment, select a vulnerability with an existing assessment in the Vulnerabilities list. Then, click on the Edit vulnerability impact assessment button. This will open the Edit item page where you can edit the details of the impact assessment.
Currently, impact assessments can only be edited one-by-one.
7. Download the vulnerability report
The Vulnerability Report can either be generated and downloaded as a release document (as described in MAN-02 Software Release Process, Section 3.9), or generated on demand for a selected version on the page SBOM > Vulnerabilities. The document will be generated an Excel file and will contain the following data:
Title: The title of the vulnerability.
Severity: The severity of the vulnerability.
Score: The score of the vulnerability.
Ecosystem: The ecosystem of the vulnerability.
Dependency: The dependency which is affected by the vulnerability.
Affected versions: The affected versions of the dependency.
Used dependency versions: The versions of the dependency used in the project.
Introduced in version (applicable only for manual vulnerabilities, empty otherwise): The first version of the product this vulnerability is effective in. If empty, the vulnerability is considered effective from the initial version of the product.
Obsolete in version (applicable only for manual vulnerabilities, empty otherwise): The version of the product the vulnerability is becoming obsolete in, i.e., the first version for which this vulnerability is not effective anymore.
Reported on: The date the vulnerability was reported.
CVE ID: The Common Vulnerabilities and Exposures (CVE) ID of the vulnerability.
Description: The description of the vulnerability.
URLs: The URLs related to the vulnerability.
Status: The status of the vulnerability.
Connected risks: URLs to the connected risks.
Connected mitigations: URLs to the connected mitigations.
Resolution: The resolution status of the vulnerability impact assessment.
Justification for resolution: A justification for the resolution status.
Rationale for connecting risks: A rationale for connecting the risks.
Rationale for connecting mitigations: A rationale for connecting the mitigations.
The generated document aims to replicate the Manage vulnerabilities page content as closely as possible as the format permits. This includes any additional, removed or renamed fields configured for the vulnerability impact assessment.
In case a cell exceeds the limit of characters for a single cell in Excel (32,767 characters), the content will be split into multiple cells, spanning multiple rows.
8. Vulnerability management of an individual SOUP/OTS component/dependency
To manage the vulnerabilities of an individual SOUP/OTS component/dependency, navigate to the SBOM page of the project and click the dependency you want to manage. On its details page, click on the Vulnerabilities tab. There, the same functionality as on the Vulnerabilities page is available, but only for the selected dependency, listing only the vulnerabilities of the selected dependency.
Similarly, on the page SBOM > Vulnerabilities, the dependency details page can be reached by clicking on the dependency name below the vulnerability title in the Vulnerabilities list.
9. Vulnerability notifications
New vulnerabilities are discovered daily. To keep you informed about the latest vulnerabilities in your project, Ketryx sends daily and weekly vulnerability notifications via email. Daily notifications include vulnerabilities of critical severity, while weekly notifications cover all new vulnerabilities regardless of the severity level. You will receive notifications for all dependencies in your current version and all active releases (as described in Monitoring). Notifications are sent to all users configured in the approval rules for dependencies, according to MAN-11 Approval Rules.
Ketryx updates its vulnerability database periodically and scans all your dependencies for known vulnerabilities. This includes dependencies reported via dependency manifest files, as well as CycloneDX or SPDX files using the Builds API.
Last updated