-
Notifications
You must be signed in to change notification settings - Fork 580
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #11335 from zainasir/feat/security-badge
add security status badge
- Loading branch information
Showing
3 changed files
with
67 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -458,11 +458,65 @@ jobs: | |
echo "Individual reports for master and pr have been saved under the Artifacts tab." | ||
exit 0 | ||
fi | ||
- persist_to_workspace: | ||
root: /tmp/repos | ||
paths: | ||
- master_report.sbom | ||
- store_artifacts: | ||
path: /tmp/repos/master_report.sbom | ||
- store_artifacts: | ||
path: /tmp/repos/pr_report.sbom | ||
|
||
update_security_status_badge: | ||
machine: | ||
image: ubuntu-2204:2024.08.1 | ||
resource_class: medium | ||
working_directory: /tmp/repos | ||
environment: | ||
SUCCESS_MESSAGE: 'passing' | ||
SUCCESS_COLOR: 'brightgreen' | ||
FAILURE_MESSAGE: 'failing' | ||
FAILURE_COLOR: 'FF0A0A' | ||
SEVERITY_THRESHOLD: 'CRITICAL' | ||
TEST_REPO_URL: '[email protected]:cBioPortal/cbioportal-test.git' | ||
steps: | ||
- attach_workspace: | ||
at: /tmp/repos | ||
- add_ssh_keys: | ||
fingerprints: | ||
- "SHA256:vtzpWrYBLQAMgZIsEv3Nuc1HeINJXFFtUB+IpSY/AK4" | ||
- run: | ||
name: Set up git user | ||
command: | | ||
git config --global user.name "CircleCI Bot" | ||
git config --global user.email "[email protected]" | ||
- run: | ||
name: Clone test repo using ssh url | ||
command: | | ||
rm -rf cbioportal-test | ||
git clone $TEST_REPO_URL | ||
- run: | ||
name: Count vulnerabilities and update status badge | ||
command: | | ||
COUNT=$(jq '[.[] | select(.severity == "$SEVERITY_THRESHOLD")] | length' master_report.sbom) | ||
cd cbioportal-test | ||
if [ $COUNT -eq 0 ]; then | ||
jq --arg msg "$SUCCESS_MESSAGE" --arg col "$SUCCESS_COLOR" '.message = $msg | .color = $col' security-status.json > temp.json | ||
else | ||
jq --arg msg "$FAILURE_MESSAGE" --arg col "$FAILURE_COLOR" '.message = $msg | .color = $col' security-status.json > temp.json | ||
fi | ||
mv temp.json security-status.json | ||
echo "security-status.json has been updated:" | ||
cat security-status.json | jq | ||
- run: | ||
name: Push new security status to cbioportal/cbioportal-test | ||
command: | | ||
cd cbioportal-test | ||
git diff | ||
git add security-status.json | ||
git commit -m "Update security status" | ||
git push | ||
workflows: | ||
end_to_end_tests: | ||
jobs: | ||
|
@@ -501,4 +555,11 @@ workflows: | |
context: | ||
- docker-scout | ||
requires: | ||
- build_image | ||
- build_image | ||
- update_security_status_badge: | ||
requires: | ||
- run_security_tests | ||
filters: | ||
branches: | ||
only: | ||
- master |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,29 +1,28 @@ | ||
# Security | ||
We are committed to maintaining a secure and reliable platform by integrating proactive vulnerability detection and mitigation strategies into our development and release workflows. Here's how we address security concerns at each stage of our development process. | ||
|
||
--- | ||
## Current Vulnerability Status | ||
We provide a [status badge](https://github.com/cBioPortal/cbioportal?tab=readme-ov-file#cbioportal) that displays the current vulnerability status of the cBioPortal application. Additionally, we maintain a Software Bill of Materials (SBOM) integrated with our Github Dependabot Security system. | ||
|
||
## Vulnerability Detection in Pull Requests | ||
We utilize **SonarCloud** to ensure the integrity and security of our codebase. SonarCloud is configured to automatically analyze all pull requests and merged code. This enables us to: | ||
- Detect security vulnerabilities, bugs, and code smells during the review process. | ||
- Generate detailed reports that identify specific issues, such as potential injections, insecure code patterns, or other security risks. | ||
- Enforce quality gates that prevent merging unsafe code into the main branch. | ||
The results of the analysis are presented as part of the Github pull request checks, allowing contributors and maintainers to address issues early in the development lifecycle. | ||
--- | ||
|
||
## Container Image Security with Docker Scout | ||
As part of our release process, we integrate **Docker Scout** to ensure the security of container images published to our public DockerHub repository. Key steps include: | ||
- **Automated Scanning:** Every time a Docker image is built and pushed, Docker scout performs an in-depth analysis of all base layers and dependencies. | ||
- **Detailed Reports:** Vulnerabilities are categorized by severity, and actionable remediation steps are provided. This ensures maintainers can quickly patch or replace vulnerable components. | ||
- **Image Maintenance:** We montior and rebuild images when new vulnerabilities are detected in upstream dependencies, ensuring our images remain secure. | ||
Docker Scout is a critical step in the release pipeline, ensuring that the container images used by our users are secure and free from known vulnerabilities. | ||
--- | ||
|
||
## Continuous Monitoring and Updates | ||
SonarCloud and Docker Scout work seamlessly within our development and release workflows: | ||
- **SonarCloud** safeguards the integrity of the codebase during pull requests and merges. | ||
- **Docker Scout** validates the security of container images as part of our weekly release cycle. | ||
This dual-layered approach ensures that vulnerabilities are addressed both at the source code and container levels, offering comprehensive security coverage for the cBioPortal platform. | ||
--- | ||
|
||
## Feedback and Contributions | ||
We encourage the community to provide feedback and suggestions to enhance our security processes. If you have any questions or ideas, please contact us or submit an issue on our [Github repository](https://github.com/cBioPortal/cbioportal/security/policy). |