Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Draft: OQS security response process #124

Draft
wants to merge 9 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -57,3 +57,7 @@ Subscribe and access list archives at [https://lists.pqca.org/g/oqs-tsc](https:/
### Discord

Join the [PQCA Discord server](https://discord.gg/gv8YN5bb) and reach us on the [#oqs-general](https://discordapp.com/channels/1202723482224295936/1203395992003678238) channel.

## Security

OQS responds to security reports following a [coordinated vulnerability disclosure process](security/response-process.md), informed by current Open Source Software Foundation [guidelines](https://github.com/ossf/oss-vulnerability-guide).
106 changes: 106 additions & 0 deletions security/reports/20241220-hqc-decaps.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
# OQS Vulnerability Response Report: 20241220-hqc-decaps

<!--
Copy this template and rename the file following the format YYYYMMDD-vulnerability-name.md format.
The date should be the date that the report was created.

The intent of these reports is to help streamline the vulnerability response process.
No technical details about the vulnerability need to be provided here; those are contained in the security advisories.

For a completed example, see the report 20241220-hqc-decaps.md in this same directory.
-->

## Information

<!--
Provide links to any associated published GitHub Security Advisories.
If there are none, provide (or link to) information about the reported vulnerability.
-->

See https://github.com/open-quantum-safe/liboqs/security/advisories/GHSA-gpf4-vrrw-r8v7

## Process

### 1. Intake

<!--
Briefly summarize how the vulnerability report was received.
Be sure to include the following information:
- intake method (e.g., [email protected], GitHub security report, internal meeting)
- date of report
- initial response time
- initial responder
-->

We received an initial report from Quarkslab researchers Célian Glénaz and Dahmun Goudarzi via GitHub on 17 September 2024.
Due to GitHub configuration issues, we were unaware of the report until 24 October, when the reporters left a follow-up comment.
We did not respond to the reporters until completing the Assessment phase.

### 2. Assessment

<!--
Briefly summarize the assessment process.
Technical details about the vulnerability are not necessary.
Instead, focus on which projects were impacted and
Be sure to include the following information:
- OQS subprojects affected by the vulnerability
- upstream sources notified
- team members identified and assigned to work on a fix
-->

Douglas shared the report with Spencer, who was the team member most familiar with the affected code (the HQC implementation).
Spencer confirmed the report's findings and responded to the reporters on GitHub on 6 November.
The vulnerability was present in upstream code (https://pqc-hqc.org) and pulled into the library via PQClean.
Spencer notified the "main" and "backup" contacts listed on the upstream source's website after coordinating with the reporters.
The only subproject directly affected (by including vulnerable code) was liboqs.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I know this report is closed and dealt with, but re-reading it makes me wonder: If liboqs is affected, wouldn't that imply that at least the language wrappers are also affected automatically? Also oqsprovider makes available HQC code if I'm not mistaken. So in case of a more severe problem with liboqs what would such problem mean for dependent OQS sub projects? Should that be spelled out somewhere?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've fleshed out the main document to specify that oqs-provider and the language wrappers should also have advisories published whenever a liboqs advisory is published.

It was believed that liboqs-rust was also affected; however, this turned out not to be the case.

Douglas and Spencer consulted and decided not to create a dedicated security release for two reasons:
1. The 0.12.0 release of liboqs was imminent, so a patch could be included there.
2. HQC was still an experimental algorithm.

### 3. Patching

<!--
Briefly summarize the patch development process.
Be sure to highlight any friction points.
-->
Spencer created a temporary private fork via the draft GitHub advisory and developed a PR with a fix using the `copy_from_upstream` patch mechanism.
One of the reporters reviewed and approved the PR.
The fix was merged into liboqs main branch on 21 November.
Due to liboqs GitHub settings, the PR from the private fork could not be merged directly.
It was necessary for an administrator (in this case, Ry Jones) to override these settings and commit to main.

### 4. CVE assignment

<!--
Was a CVE assigned?
If not, provide rationale.
-->
GitHub assigned CVE-2024-54137.

### 5. Public disclosure

<!--
Provide details about public disclosures (e.g., release notes, emails) other than the GitHub Security Advisories already included in the "Information" section.
-->
The security advisory was published on 6 December.
Version 0.12.0 of liboqs was released on 9 December, with a note about the vulnerability in its release notes: https://github.com/open-quantum-safe/liboqs/releases/tag/0.12.0

Spencer submitted the fix to PQClean (https://github.com/PQClean/PQClean/pull/578) on 10 December.
This led to a related security advisory being published for the pqcrypto Rust crate: https://github.com/PQClean/PQClean/security/advisories/GHSA-753p-wrj5-g8fj

### 6. Feedback

<!--
Highlight any friction points in the response process.
Feel free to provide suggestions to improve the process.
Additionally, mention any follow-up work related to the vulnerability.
-->

We observed the following obstacles throughout the process:
- Our initial response was very slow due to misconfiguration of GitHub notifications.
This has hopefully been amended.
- Merging the patch required "admin"-level access on GitHub.
Based on GitHub logs, this seems to be due to liboqs settings requiring a pull request for all commits.
Apparently, a PR from a private fork does not count.
72 changes: 72 additions & 0 deletions security/reports/YYYYMMDD-template.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
# OQS Vulnerability Response Report: YYYY-MM-DD-vulnerability-name

<!--
Copy this template and rename the file following the format YYYYMMDD-vulnerability-name.md format.
The date should be the date that the report was created.

The intent of these reports is to help streamline the vulnerability response process.
No technical details about the vulnerability need to be provided here; those are contained in the security advisories.

For a completed example, see the report 20241220-hqc-decaps.md in this same directory.
-->

## Information

<!--
Provide links to any associated published GitHub Security Advisories.
If there are none, provide (or link to) information about the reported vulnerability.
-->

## Process

### 1. Intake

<!--
Briefly summarize how the vulnerability report was received.
Be sure to include the following information:
- intake method (e.g., [email protected], GitHub security report, internal meeting)
- date of report
- initial response time
- initial responder
-->

### 2. Assessment

<!--
Briefly summarize the assessment process.
Technical details about the vulnerability are not necessary.
Instead, focus on which projects were impacted and
Be sure to include the following information:
- OQS subprojects affected by the vulnerability
- upstream sources notified
- team members identified and assigned to work on a fix
-->

### 3. Patching

<!--
Briefly summarize the patch development process.
Be sure to highlight any friction points.
-->

### 4. CVE assignment

<!--
Was a CVE assigned?
If not, provide rationale.
-->

### 5. Public disclosure

<!--
Provide details about public disclosures (e.g., release notes, emails) other than the GitHub Security Advisories already included in the "Information" section.
-->

### 6. Feedback

<!--
Highlight any friction points in the response process.
Feel free to provide suggestions to improve the process.
Additionally, mention any follow-up work related to the vulnerability.
-->

Loading