Project

General

Profile

Actions

Security process » History » Revision 1

Revision 1/11 | Next »
Dominic Cleal, 09/18/2015 06:04 AM
today's security process


Security process

If you need to report a potential security issue, please email (a private address) immediately so we can help investigate it.

Please see http://theforeman.org/security.html for up to date information on known vulnerabilities and fixes. This page is a development/triage resource only.

foreman-security list

The foreman-security mailing list is an invite-only group of Foreman developers, distribution maintainers and security response experts. At the time of writing, it has nine members, which for obvious reasons, we try to keep at a minimum.

The responsibility of the group is to triage incoming notifications from the public and other Foreman developers, analyse and write up the issue, assign a CVE identifier, and to ensure the fix is shipped correctly. It isn't the responsibility of the security team to write the fix/patch.

Vulnerability process

When an issue is reported, the following process should be followed by one or more people on the foreman-security list.

  1. Reporter emails with information about the issue.
  2. Security team member replies to the reporter, CCing the list to acknowledge the report.
  3. Security team member investigates the issue and if invalid, replies to the reporter and list to reject it.
  4. If the report is valid, the security team member should judge the severity or email the list to decide on it.
    • Higher/critical severity issues will be embargoed.
    • Lower/medium severity issues will be handled in public as regular bug reports, but with a CVE assigned.
  5. Determine the affected versions of Foreman through code analysis, if possible.

For unembargoed/public issues:

  1. Security team files a Redmine issue with all relevant details and reproducer information.
    • Set Category to Security
    • Set Release to the next minor/major depending on severity.
  2. Reply to the reporter and list to provide the ticket URL and inform them on how it's being handled.
  3. The Redmine ticket can be picked up and worked as usual.
    • Consider emailing foreman-dev to help get a developer assigned to the ticket.
  4. Email (Red Hat Security Response Team), CCing foreman-security, providing all relevant details and requesting a CVE identifier. Expect a response within 48 working hours.
  5. On receiving a CVE identifier:
    1. Update the security webpage with details.
    2. Prefix the Redmine ticket title with the CVE identifier.

For embargoed issues, handle in a similar way with these exceptions:

  1. Take extreme care to make no public comments, emails, pull requests or IRC conversations on the subject. Ensure anybody working on the issue follows the same.
  2. Decide a suitable unembargo date (often ~2 weeks) when it would also be suitable to make a release of Foreman.
  3. File a Redmine issue, but set the Private flag which makes the ticket visible to security team members and Redmine administrators.
  4. Attach proposed patches to the Redmine issue, review in comments preferably.
  5. On unembargo, change the Private flag of the Redmine ticket to false. Submit the patch as a pull request and/or merge if tests are green.
  6. Have the release manager of the current stable branch(es) make a patch release.

Updated by Dominic Cleal over 8 years ago · 1 revisions