Skip to content

Commit

Permalink
DOC Update security issues docs (#371)
Browse files Browse the repository at this point in the history
  • Loading branch information
GuySartorelli authored Oct 12, 2023
1 parent 863cf99 commit 631274c
Showing 1 changed file with 71 additions and 58 deletions.
129 changes: 71 additions & 58 deletions en/05_Contributing/17_Managing_Security_Issues.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: Managing Security Issues
title: Managing security issues
summary: This document highlights how the Silverstripe CMS security team handles security issues.
iconBrand: shield-alt
---
Expand All @@ -10,7 +10,7 @@ This document aims to provide a high level overview of how the Silverstripe CMS

## Broad approach

While the process for handling security issues is publicly visible, only a limited number of participants are privy to the internal pre-disclosure discussions around specific vulnerabilities.
While the process for handling security issues is publicly visible, only a limited number of participants are privy to the internal pre-disclosure discussions around specific vulnerabilities.

We aim to release security fixes with our regularly scheduled minor releases to minimise disruption to Silverstripe CMS projects. This allows security releases to go through our regular regression testing. We will usually hold back security fixes for a few weeks or months while we wait for the next scheduled release.

Expand All @@ -20,87 +20,99 @@ If there's indication that a vulnerability is actively exploited in the wild or

Silverstripe staff are granted access to review undisclosed security issues on a need-to-know basis and are bound by their employment contracts. Core committers not currently employed by Silverstripe are allowed to review undisclosed security issues after signing a non-disclosure agreement.

## Handling security issues confidentially
## Handling security issues confidentially

This process is relevant when a potential vulnerability is reported confidentially and the Silverstripe CMS development team is in a position to prepare a patch prior to the public disclosure of the vulnerability.

This process is usually started once someone [reports a security issue](issues_and_bugs/#reporting-security-issues).

### When receiving a report

[hint]
Ensure the reporter is given a justification for all issues we conclude are not security vulnerabilities.
[/hint]

1. An automated response is sent back to the reporter to acknowledge receipt of their vulnerability report.
2. Perform an initial assessment of the report.
3. [Create a issue in our private security repository](https://github.com/silverstripe-security/security-issues/issues/new) unless the report is obviously invalid. e.g. SPAM.
4. Clarify who picks up and owns the issue (assign in Github).
The owner can be separate from the developer resolving the issue,
their primary responsibility is to ensure the issue keeps moving through the process correctly.
5. If encrypted information or attachments are provided, attach them to the private security issue.
6. Reply to [[email protected]](mailto:[email protected]) ONLY (i.e. do not include the reporter in this reply) and provide a link to the private security issue. Keep most of the discussion on GitHub.
7. Perform a criticality assessment to determine how severe the issue is and if it can be replicated.
1. Perform an initial assessment of the report. If the report does not qualify as a security issue, reply to the reporter thanking them for their efforts and explaining that we won't be handling this as a security issue.
- If what was raised is a valid bug but not a valid security report, advise them to raise an issue on GitHub.
- If the report was spam, see [spam](#spam) below.
1. If the report is valid, [create a issue in our private security repository](https://github.com/silverstripe-security/security-issues/issues/new).
- Prefix the issue name with "[NO CVE REQUESTED YET]".
- If encrypted information or attachments are provided, attach them to the private security issue.
- Add the new issue to the "Triage" column on the [project board](https://github.com/silverstripe-security/security-issues/projects/1).
1. Reply to [[email protected]](mailto:[email protected]) ONLY (i.e. do not include the reporter in this reply) and provide a link to the private security issue. Keep most of the discussion on GitHub.
1. Clarify who picks up the issue (assign in GitHub).
- This is the person responsible for communicating with the reporter and applying for the CVE, etc. Usually this is whoever creates the issue.
- The person who implements a fix for the issue does not have to be the person initially assigned in GitHub.
1. Perform an assessment to determine how severe the issue is and if it can be replicated.
- You may need to seek additional information from the reporter before completing the criticality assessment.
- Validate the assessment with at least one other member of the security team before replying to the reporter with your conclusion.
8. Use the [CVSS Calculator](https://nvd.nist.gov/vuln-metrics/cvss/v3-calculator) to determine the issue severity.
9. Ensure the reporter is given a justification for all issues we conclude are not security vulnerabilities.
10. Add the new issue in the "Backlog" on the [project board](https://github.com/silverstripe-security/security-issues/projects/1).
11. Once the issue is confirmed, [create a draft security advisory](#creating-a-github-security-advisory) against the relevant GitHub repository. This will allow you to request a CVE.
12. Once a CVE has been assigned, add it to the Github issue and respond to the issue reporter.
- Add a comment to the GitHub issue with your findings, replications steps, and any suggested solutions.
1. Use the [CVSS Calculator](https://nvd.nist.gov/vuln-metrics/cvss/v3-calculator) to determine the issue severity.
1. Move the issue to the "Backlog" column on the [project board](https://github.com/silverstripe-security/security-issues/projects/1).
1. Once the issue is confirmed, [create a draft security advisory](#creating-a-github-security-advisory) against the relevant GitHub repository.
1. If the CVSS score is higher than 0.0, and it is not directly caused by an upstream dependency, request a CVE via the GitHub advisory UI.
1. Once a CVE has been assigned, add it to the GitHub issue and respond to the issue reporter.
- Ask the reporter if they want to be credited for the disclosure and under what name.

[warning]
Make sure you read the [special circumstances](#special-circumstances) section below in case there are more or different steps you need to follow.
[/warning]

### Creating a GitHub security advisory

GitHub security advisories allow you to request a CVE and attached them a CVSS score. A draft security advisory should be created against the repository where the vulnerability will be patched. If a vulnerability requires patches against multiple modules, aim to create the advisory against the module most directly affected.

In the GitHub _draft security advisory_, we follow certain conventions on fields:

- **Affected product** should have one entry for each composer package affected by the vulnerability. If the patch is backported to older release lines, there should be entries for those older releases.
- **Ecosystem** should always be `composer`.
- **Package name** must match the package name in Packagist.
- **Affected versions** must be a string representing a range of versions affected by the vulnerability.
- **Patched versions** must list the versions where the vulnerability was/will be patched.
- **Severity** must be set to _Assess severity using CVSS_ and the CVSS option must be specified in the calculator.
- **Common weakness enumerator (CWE)** should be left blank if no suitable option can be found in the list.
- **CVE identifier** must be set to "Request CVE ID later" until we have had a CVE assigned.
- **Title** and **Description** should be descriptive enough that people can evaluate the risk without being so specific that would-be-hackers can start exploiting them right away.

These settings can be changed later, so if you are missing information when you first create the draft you can come back to add the information later.

### Developing a fix

- Move the issue into "In Progress" on the [project board](https://github.com/silverstripe-security/security-issues/projects/1)
- If the silverstripe-security GitHub organisation doesn't have a pre-existing private repo for the module that needs to be fixed, create one and push the public git history to it. You can not do a private fork of a public repo.
- Identify the oldest supported minor release where the vulnerability should be patched for each major release line. (see [Supported Versions](release_process/#supported-versions))
- If the silverstripe-security GitHub organisation doesn't have a pre-existing private repo for the module that needs to be fixed, do not create a fork because you cannot create a private fork of a public repo. Instead create a new repo on the silverstripe-security account and push the public git history to it.
- Identify the oldest supported minor release where the vulnerability should be patched for each major release line. (see [minor release support timeline](/project_governance/minor_release_policy/#minor-release-support-timeline)).
- Make sure the target branches on the private repo are up-to-date with the public repo branches.
- Create a fix for each supported major release line and open PRs against the appropriate branches on the private repo.
- Create a fix for each supported major release line and open PRs against the appropriate branches on the private repo.
- Ensure that all security commit messages are prefixed with the CVE. E.g. "[CVE-2019-001] Fixed invalid XSS"
- If there is no CVE assigned yet, use "[CVE-????-???]" for the prefix, and update it once a CVE is assigned.
- If we are not assigning a CVE for this issue, use the `SS-` style identifier (e.g. "[SS-2019-001]") as the prefix.
- Once peer review is completed on the private PRs, do **not** merge it. The PRs should remain open until the fix is released publicly.

### Before release

- For issues rated "high" or "critical" (CVSS of >=7.0), post a pre-announcement to the [security pre-announcement list](https://groups.google.com/a/silverstripe.com/forum/#!forum/security-preannounce).
It should include a basic "preannouncement description" which doesn't give away too much,
the CVSS score, and the CVE identifier.
- Create a draft page under [Open Source > Download > Security Releases](https://www.silverstripe.org/admin/pages/edit/show/794).
Populate it with the information from the [Github project board](https://github.com/silverstripe-security/security-issues/projects/1).
- Link to the individual silverstripe.org security advisory pages in the changelog.
It should include a basic "preannouncement description" which doesn't give away too much, the CVSS score, and the CVE identifier.
- Create a draft page under `Open Source > Download > Security Releases` on silverstripe.org. Populate it with the information from the security issue.
- Update the _draft security advisory_ on GitHub to use the latest wording and link to the advisory on silverstripe.org.
- Move the issue to "Awaiting Release" in the [project board](https://github.com/silverstripe-security/security-issues/projects/1)

### After release

- Publish the security advisory release page on silverstripe.org.
- Publish the security advisory on GitHub. This will also publish the CVE.
- Respond to the issue reporter with a link to the security advisory on the same discussion thread (cc [email protected]).
- Open a pull request to [https://github.com/FriendsOfPHP/security-advisories/tree/master/silverstripe](https://github.com/FriendsOfPHP/security-advisories/tree/master/silverstripe) repository.
- Respond to the issue reporter with a link to the security advisory on the same discussion thread (cc <[email protected]>).
- Open a pull request to the [FriendsOfPHP/security-advisories](https://github.com/FriendsOfPHP/security-advisories/tree/master/silverstripe) repository.
- Move the issue to "Done" in the [project board](https://github.com/silverstripe-security/security-issues/projects/1)

### Creating a GitHub security advisory

GitHub security advisories allow you to request a CVE and attached them a CVSS score. A draft security advisory should be created against the repository where the vulnerability will be patched. If a vulnerability requires patches against multiple modules, aim to create the advisory against the module most directly affected.

In the GitHub _draft security advisory_, we follow certain conventions on fields:
- **Affected product** should have one entry for each composer package affected by the vulnerability. If the patch is backported to older release lines, there should be entries for those older releases.
- **Ecosystem** should always be `composer`.
- **Package name** must match the package name in Packagist.
- **Affected versions** must be a string representing a range of versions affected by the vulnerability.
- **Patched versions** must list the versions where the vulnerability was/will be patched.
- **Severity** must be set to *Assess severity using CVSS* and the CVSS option must be specified in the calculator.
- **Common weakness enumerator (CWE)** should be left blank if no suitable option can be found in the list.
- **CVE identifier** must be set to "Request CVE ID later" until we have had a CVE assigned.
- **Title** and **Description** should be descriptive enough that people can evaluate the risk without being so specific that would-be-hackers can start exploiting them right away.

These settings can be changed later, so if you are missing information when you first create the draft you can come back to add the information later.
- Close the private pull request(s) and issue.

## Special circumstances

### An issue has been reported publicly on GitHub

Occasionally, some developers will open a public issue on GitHub reporting a vulnerability, either because they are unaware of the proper process or because they did not immediately grasp the security implication of the bug being reported.

In those situations, the security team will assess how likely it was that the vulnerability was widely noticed based on how long the issue was opened on GitHub, whether there were any interactions from other GitHub users, and how explicit the description was. If the risk of the vulnerability having been noticed is small, an owner on the Silverstripe GitHub organisation will delete the public facing issue and create a private one instead.
In those situations, the security team will assess how likely it was that the vulnerability was widely noticed based on how long the issue was opened on GitHub, whether there were any interactions from other GitHub users, and how explicit the description was. If the risk of the vulnerability having been noticed is small, an owner on the Silverstripe GitHub organisation will delete the public facing issue and create a private one instead - and attempt to contact the reporter to advise them of the correct procedure to follow in the future.

If it's likely that the issue was noticed publicly, it should be handle as a zero-day vulnerability and patched as soon as possible.

Expand All @@ -112,46 +124,47 @@ If it's likely that the issue was noticed publicly, it should be handle as a zer
- People reporting vulnerabilities via Huntr are not always familiar with Silverstripe CMS. Don't assume that they have much context on what Silverstripe CMS is used for.
- Take some time to review the reporter's profile to see how serious and reliable they are.
- Validate what CVSS score the reporter has suggested for the issue.
- Once we "confirm" an issue in Huntr, it means that we agree the bug exists and that it's a vulnerability. Only confirm an issue if you have concluded that it is a valid security vulnerability that we will fix through the normal security process and have validated this conclusion with at least one other member of the security team. Security _enhancements_ should not be confirmed.
- By default, Huntr will issue CVEs for issues reported through their platform. We've disabled this functionality.
- Marked the issue as "fixed" in hunter once a patched has been released.
- Once we "confirm" an issue in Huntr, it means that we agree the bug exists and that it's a vulnerability. Only confirm an issue if you have concluded that it is a valid security vulnerability that we will fix through the normal security process and have validated this conclusion with at least one other member of the security team. Security _enhancements_ should not be marked as confirmed.
- By default, Huntr will issue CVEs for issues reported through their platform. We've disabled this functionality - follow the process in [when receiving a report](#when-receiving-a-report) to request a CVE.
- Mark the issue as "fixed" in hunter once a patched has been released.

### A vulnerability has been reported against a dependency of Silverstripe CMS

Silverstripe CMS relies on many other dependencies which are outside of our control. Those dependencies will occasionally have vulnerabilities reported and patched against them.

When a vulnerability is disclosed against a Silverstripe CMS dependency, we generally do not consider this a vulnerability in Silverstripe CMS and will not issue a CVE for it.
When a vulnerability is disclosed against a downstream dependency of Silverstripe CMS, we generally do not consider this a vulnerability in Silverstripe CMS and will not issue a CVE for it.

We will consider taking actions if:

- the vulnerability is compounded by the specific way the dependency is used within Silverstripe CMS or
- a Silverstripe CMS constraint prevents the installation of a patched version of the dependency.

As a general principle, Silverstripe CMS composer constraints do not preclude the installation of dependencies with known vulnerabilities. It is the responsibility of Silverstripe CMS project owners to regularly update these constraints and to review the risk posed by specific vulnerabilities.

### SPAM vulnerability report
## SPAM

We receive a substantial amount of SPAM at our security email address. Those fall into 3 broad categories.

#### Straight up untargeted SPAM
### Straight up untargeted SPAM

Simply ignore these emails and mark them as SPAM in your email client.
Simply ignore these emails and mark them as SPAM in the mailing list.

#### Non-security requests
### Email that is not reporting a security vulnerability

Our security email is the only email address bots can find on our website. We get a lot of generic requests. e.g. _Your site is awesome, would you like me to contribute a guest post?_
Bots can our security email address by crawling this documentation. As a result, we get a lot of generic requests. e.g. _Your site is awesome, would you like me to contribute a guest post?_

Provide a cursory response such as:

> This email address is only used to report potential security issues with Silverstripe CMS.
> This email address is only used to report potential security issues with Silverstripe CMS. Please do not send additional unrelated emails or your email address will be marked as spam.
If more invalid requests are received from that sender, they should be blocked from the mailing list.

#### Low quality security reports
### Low quality security reports

We get a lot of boiler plate vulnerability reports from individuals hoping to collect bounties. These requests are usually crafted to obscure their non-sensical nature.

When dealing with this kind of request, provide a brief response explaining why the request is invalid and include some boiler plate language such as:

> Silverstripe does not operate a bug bounty program.
> Silverstripe does not operate a bug bounty program. Please do not send additional low quality security reports or your email address will be marked as spam.
Consider blocking repeat offenders from the the mailing list.
Consider blocking repeat offenders from the the mailing list.

0 comments on commit 631274c

Please sign in to comment.