Implementing the Auto-refreshing Official Kubernetes CVE Feed

Author: Pushkar Joglekar (VMware)

Accompanying the release of Kubernetes v1.25, we announced availability of an official CVE feed as an alpha feature. This blog will cover how we implemented this feature.

Implementation Details

An auto-refreshing CVE feed allows users and implementers to programmatically fetch the list of CVEs announced by the Kubernetes SRC (Security Response Committee).

To ensure freshness and minimal maintainer overhead, the feed updates automatically by fetching the CVE related information from the CVE announcement GitHub Issues. Creating these issues is already part of the existing Security Response Committee (SRC) workflow.

Pre-requisites

Until December 2021, it was not possible to filter for issues or PRs that are tied to CVEs announced by Kubernetes SRC. We added a new label, official-cve-feed to address that, and SIG-Security labelled relevant issues with it. The in-scope issues are closed issues for which there is a CVE ID(s) and is officially announced as a Kubernetes security vulnerability by SRC. You can now filter on all of these issues and find them here .

For future security vulnerabilities, we added the label to the SRC playbook so that all the future in-scope issues will automatically have this label.

Building on existing tooling

For the next step, we created a prow job in order to periodically query the GitHub REST API and pull the relevant issues. The job runs every two hours and pushes the CVE related information fetched from GitHub into a Google Cloud Bucket.

For every website build (at least twice a day), Netlify data templates make a call to this Google Cloud Bucket to pull the CVE information and then parses into fields that are JSON Feed v1.1 compliant. The JSON file is available for programmatic consumption by automated security tools. For humans, the JSON also gets transformed into a Markdown table for easy viewing.

Design Considerations

Building trust and ensuring that the feed is not stale were our main priorities when designing this feature for success and widespread adoption.

Integrity and Access Control Protections

Changes to any of the four artifacts used to build this feed could lead to feed tampering, broken JSON, and inconsistent or stale data.

Let’s look at how access is controlled for them one by one:

GitHub Issues for Publicly Announced CVEs

Adding the official-cve-feed label is restricted to limited number of trusted community members. Access to add this label is defined in this configuration file . Any updates to this configuration file require the changes to go through the existing code review and approval process

Prow Configuration

The Prow job is defined in a kubernetes/infra configuration file The shell script to push and pull the data in Google Cloud Bucket is defined in a kubernetes/sig-security file under sig-security-tooling sub-project. Both of these files go through the same code review and approval process mentioned earlier.

Google Cloud Bucket

Write access to Google Cloud bucket is configured to be restricted to a set of trusted community members managed via an invite-only Google Groups Membership under the kubernetes.io domain.

Website Data templates

Website data templates that fetch and parse the stored JSON blob are managed under kubernetes/website and have to follow the same code review and approval process as mentioned earlier.

Freshness Guarantees

The feed is updated everytime new CVE data is available by periodically verifying if generated data is not the same as the stored data in the feed.

The prow job runs every two hours and compares the sha256 checksum of the existing contents of the bucket with checksum of the latest JSON file generated through GitHub issues. If the there is new data available, the hashes do not match (typically because of a newly announced CVE) and the updated JSON file is pushed onto the bucket replacing the old file and old hash checksum.

If the hashes match, the write to bucket operation is skipped to reduce redundant updates to the cloud bucket. This also sets us up for more frequent runs of the prow job if needed in the future.

What’s Next?

If you would like to get involved in future iterations of this feed or other security relevant work, please consider joining Kubernetes SIG Security by joining our bi-weekly meetings or hanging out with us on our Slack Channel.

A special shout out and massive thanks to Neha Lohia (@nehalohia27) and Tim Bannister (@sftim) for their stellar collaboration for many months from “ideation to implementation” of this feature.