The rise of open-source software (OSS) development and DevOps practices has unleashed a paradigm shift in OSS security. As traditional approaches to OSS security have proven inadequate in the face of rapid development cycles, the Software Bill of Materials (SBOM) has re-made OSS vulnerability management in the era of DevSecOps.
This blog post zooms in on two best practices from our introductory article on OSS security and the software supply chain:
- Maintain a Software Dependency Inventory
- Implement Vulnerability Scanning
These two best practices are set apart from the rest because they are a natural pair. We’ll cover how this novel approach,
- Scaled OSS vulnerability management under the pressure of rapid software delivery
- Is set apart from legacy SCAs
- Unlocks new use-cases in software supply chain security, OSS risk management, etc.
- Benefits software engineering orgs
- Benefits an organization’s overall security posture
- Has measurably impacted modern enterprises, such as, NVIDIA, Infoblox, etc.
Whether you’re a seasoned DevSecOps professional or just beginning to tackle the challenges of securing your software supply chain, this blog post offers insights into how SBOMs and vulnerability management can transform your approach to OSS security.
Learn about the role that SBOMs for the security of your organization in this white paper.
Why do I need SBOMs for OSS vulnerability management?
The TL;DR is SBOMs enabled DevSecOps teams to scale OSS vulnerability management programs in a modern, cloud native environment. Legacy security tools (i.e., SCA platforms) weren’t built to handle the pace of software delivery after a DevOps face lift.
Answering this question in full requires some historical context. Below is a speed-run of how we got to a place where SBOMs became the clear solution for vulnerability management after the rise of DevOps and OSS; the original longform is found on our blog.
If you’re not interested in a history lesson, skip to the next section, “What new use-cases are unlocked with a software dependency inventory?” to get straight to the impact of this evolution on software supply chain security (SSCS).
A short history on software composition analysis (SCA)
- SCAs were originally designed to solve the problem of OSS licensing risk
- Remember that Microsoft made a big fuss about the dangers of OSS at the turn of the millennium
- Vulnerability scanning and management was tacked-on later
- These legacy SCAs worked well enough until DevOps and OSS popularity hit critical mass
How the rise of OSS and DevOps principles broke legacy SCAs
- DevOps and OSS movements hit traction in the 2010s
- Software development and delivery transitioned from major updates with long development times to incremental updates with frequent releases
- Modern engineering organizations are measured and optimized for delivery speed
- Legacy SCAs were designed to scan a golden image once and take as much as needed to do it; upwards of weeks in some cases
- This wasn’t compatible with the DevOps promise and created friction between engineering and security
- This meant not all software could be scanned and much was scanned after release increasing the risk of a security breach
SBOMs as the solution
- SBOMs were introduced as a standardized data structure that comprised a complete list of all software dependencies (OSS or otherwise)
- These lightweight files created a reliable way to scan software for vulnerabilities without the slow performance of scanning the entire application—soup to nuts
- Modern SCAs utilize SBOMs as the foundational layer to power vulnerability scanning in DevSecOps pipelines
- SBOMs + SCAs deliver on the performance of DevOps without compromising security
What is the difference between SBOMs and legacy SCA scanning?
SBOMs offer two functional innovations over the legacy model:
- Deeper visibility into an organization’s application inventory and;
- A record of changes to applications over-time.
The deeper visibility comes from the fact that modern SCA scanners identify software dependencies recursively and build a complete software dependency tree (both direct and transitive). The record of changes comes from the fact that the OSS ecosystem has begun to standardize the contents of SBOMs to allow interoperability between OSS consumers and producers.
Legacy SCAs typically only scan for direct software dependencies and don’t recursively scan for dependencies of dependencies. Also, legacy SCAs don’t generate standardized scans that can then be used to track changes over time.
What new use-cases are unlocked with an SBOM inventory?
The innovations brought by SBOMs (see above) have unlocked new use-cases that benefit both the software supply chain security niche and the greater DevSecOps world. See the list below:
OSS Dependency Drift Detection
Ideally software dependencies are only injected in source code but the reality is that CI/CD pipelines are leaky and both automated and one-off modifications are made at all stages of development. Plugging 100% of the leaks is a strategy with diminishing returns. Application drift detection is a scalable solution to this challenge.
SBOMs unlocks drift detection by creating a point-in-time record on the composition of an application at each stage of the development process. This creates an auditable record of when software builds are modified; how they are changed and who changed it.
Software Supply Chain Attack Detection
Not all dependency injections are performed by benevolent 1st-party developers. Malicious threat actors who gain access to your organization’s DevSecOps pipeline or the pipeline of one of your OSS suppliers can inject malicious code into your applications.
An SBOM inventory creates the historical record that can identify anomalous behavior and catch these security breaches before organizational damage is done. This is a particularly important strategy for dealing with advanced persistent threats (APTs) that are expert at infiltration and stealth. For a real-world example, see our blog on the recent XZ supply chain attack.
OSS Licensing Risk Management
OSS licenses are currently undergoing the beginning of a new transformation. The highly permissive licenses that came into fashion over the last 20 years are proving to be unsustainable. As prominent open source startups amend their licenses (e.g., Hashicorp, Elastic, Redis, etc.), organizations need to evaluate these changes and how it impacts their OSS supply chain strategy.
Similar to the benefits during a security incident, an SBOM inventory acts as the source of truth for OSS licensing risk. As licenses are amended, an organization can quickly evaluate their risk by querying their inventory and identifying who their “critical” OSS suppliers are.
Domain Expertise Risk Management
Another emerging use-case of software dependency inventories is the management of domain expertise of developers in your organization. A comprehensive inventory of software dependencies allows organization’s to map critical software to individual employee’s domain knowledge. This creates a measurement of how well resourced your engineering organization is and who owns the knowledge that could impact business operations.
While losing an employee with a particular set of skills might not have the same urgency as a security incident, over time this gap can create instability. An SBOM inventory allows organizations to maintain a list of critical OSS suppliers and get ahead of any structural risks in their organization.
What are the benefits of a software dependency inventory?
SBOM inventories create a number of benefits for tangential domains, such as, software supply chain security, risk management, etc. but there is one big benefit for the core practices of software development.
Reduced engineering and QA time for debugging
A software dependency inventory stores metadata about applications and their OSS dependencies over-time in a centralized repository. This datastore is a simple and efficient way to search and answer critical questions about the state of an organization’s software development pipeline.
Previously, engineering and QA teams had to manually search codebases and commits in order to determine the source of a rogue dependency being added to an application. A software dependency inventory combines a centralized repository of SBOMs with an intuitive search interface. Now, these time consuming investigations can be accomplished in minutes versus hours.
What are the benefits of scanning SBOMs for vulnerabilities?
There are a number of security benefits that can be achieved by integrating SBOMs and vulnerability scanning. We’ve highlighted the most important below:
Reduce risk by scaling vulnerability scanning for complete coverage
One of the side effects of transitioning to DevOps practices was that legacy SCAs couldn’t keep up with the software output of modern engineering orgs. This meant that not all applications were scanned before being deployed to production—a risky security practice!
Modern SCAs solved this problem by scanning SBOMs rather than applications or codebases. These lightweight SBOM scans are so efficient that they can keep up with the pace of DevOps output. Scanning 100% of applications reduces risk by preventing unscanned software from being deployed into vulnerable environments.
Prevent delays in software delivery
Overall organizational productivity can be increased by adopting modern, SBOM-powered SCAs that allow organizations to shift security left. When vulnerabilities are uncovered during application design, developers can make informed decisions about the OSS dependencies that they choose.
This prevents the situation where engineering creates a new application or feature but right before it is deployed into production the security team scans the dependencies and finds a critical vulnerability. These last minute security scans can delay a release and create frustration across the organization. Scanning early and often prevents this productivity drain from occurring at the worst possible time.
Reduced financial risk during a security incident
The faster a security incident is resolved the less risk that an organization is exposed to. The primary metric that organizations track is called mean-time-to-recovery (MTTR). SBOM inventories are utilized to significantly reduce this metric and improve incident outcomes.
An application inventory with full details on the software dependencies is a prerequisite for rapid security response in the event of an incident. A single SQL query to an SBOM inventory will return a list of all applications that have exploitable dependencies installed. Recent examples include Log4j and XZ. This prevents the need for manual scanning of codebases or production containers. This is the difference between a zero-day incident lasting a few hours versus weeks.
Reduce hours spent on compliance with automation
Compliance certifications are powerful growth levers for organizations; they open up new market opportunities. The downside is that they create a lot of work for organizations. Manually confirming that each compliance control is met and providing evidence for the compliance officer to review discourages organizations from pursuing these certifications.
Providing automated vulnerability scans from DevSecOps pipelines that integrate SBOM inventories and vulnerability scanners significantly reduces the hours needed to generate and collect evidence for compliance audits.
How impactful are these benefits?
Many modern enterprises are adopting SBOM-powered SCAs and reaping the benefits outlined above. The quantifiable benefits to any organization are unique to that enterprise but anecdotal evidence is still helpful when weighing how to prioritize a software supply chain security initiative, like the adoption of an SBOM-powered SCA against other organizational priorities.
As a leading SBOM-powered SCA, Anchore has helped numerous organizations achieve the benefits of this evolution in the software industry. To get an estimate of what your organization can expect, see the case studies below:
NVIDIA
- Reduced time to production by scanning SBOMs instead of full applications
- Scaled vulnerability scanning and management program to 100% coverage across 1000s of containerized applications and 100,000s of containers
Read the full NVIDIA case study here >>
Infoblox
- 75% reduction in engineering hours spent performing manual vulnerability detection
- 55% reduction in hours allocated to retroactive remediation of vulnerabilities
- 60% reduction in hours spent on manual compliance discovery and documentation
Read the full Infoblox case study here >>
DreamFactory
- 75% reduction in engineering hours spent on vulnerability management and compliance
- 70% faster production deployments with automated vulnerability scanning and management
Read the full DreamFactory case study here >>
Next Steps
Hopefully you now have a better understanding of the power of integrating an SBOM inventory into OSS vulnerability management. This “one-two” combo has unlocked novel use-cases, numerous benefits and measurable results for modern enterprises.
If you’re interested in learning more about how Anchore can help your organization achieve similar results, reach out to our team.
Learn the container security best practices to reduce the risk of software supply chain attacks.