Skip to content

Commit

Permalink
Introduce OpenSSF Best Practices Badge rule (#243)
Browse files Browse the repository at this point in the history
Add a rule that ensures that the project has an OpenSSF Best Practices
badge at the specified level (defaulting to: "passing"). This is driven
by the OpenSSF Best Practices data source, which queries
bestpractices.dev.

Add the new rule type to the OpenSSF Scorecard profile.
  • Loading branch information
ethomson authored Jan 17, 2025
1 parent 498ada1 commit bf15c91
Show file tree
Hide file tree
Showing 3 changed files with 96 additions and 1 deletion.
17 changes: 17 additions & 0 deletions data-sources/openssf_bestpractices.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
---
version: v1
type: data-source
name: openssf_bestpractices
context: {}
rest:
def:
lookup:
endpoint: 'https://www.bestpractices.dev/projects/{id}.json'
parse: json
input_schema:
properties:
id:
type: string
description: The project ID to lookup
required:
- id
3 changes: 2 additions & 1 deletion profiles/github/openssf_scorecard.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,8 @@ repository:
# CI-Tests
- type: workflow_pull_request
def: {}
# CII-Best-Practices
- type: openssf_bestpractices # CII-Best-Practices
def: {}
- type: branch_protection_require_pull_request_approving_review_count # Code-Review
def:
required_approving_review_count: 1
Expand Down
77 changes: 77 additions & 0 deletions rule-types/github/openssf_bestpractices.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
---
version: v1
release_phase: alpha
type: rule-type
name: openssf_bestpractices
display_name: Verifies the project has earned an OpenSSF Best Practices Badge
short_failure_message: OpenSSF Best Practices Badge is missing
severity:
value: low
context:
provider: github
description: |
Verifies that a repository contains an OpenSSF Best Practices badge at
the specified level.
This rule type checks for the existence of a image declared in Markdown,
referencing the project's badge on the Best Practices badge site.
guidance: |
Add your project to [OpenSSF Best Practices](https://www.bestpractices.dev/en)
to get a Best Practices badge, then add the badge to your project's README to
show your certification.
def:
in_entity: repository
# Defines the schema for writing a rule with this rule being checked
# In this case there are no settings that need to be configured
rule_schema:
type: object
properties:
filename:
type: string
description: |
The path to the README that links to the badge
default: README.md
level:
type: string
description: |
The required achievement level.
enum:
- in_progress
- passing
- silver
- gold
default: passing
# Defines the configuration for ingesting data relevant for the rule
ingest:
type: git
git: {}
eval:
type: rego
data_sources:
- name: openssf_bestpractices
rego:
type: deny-by-default
def: |
package minder
import rego.v1
default allow := false
default message := "OpenSSF Best Practices Badge is missing"
levels := { "in_progress": 1, "passing": 2, "silver": 3, "gold": 4 }
allow if {
file.exists(input.profile.filename)
readme := file.read(input.profile.filename)
badge := regex.find_all_string_submatch_n(`\[[^\]]+\]\(https:\/\/www\.bestpractices\.dev\/projects\/([\d]+)\/badge\)`, readme, 1)
project_id := badge[0][1]
badge_data := minder.datasource.openssf_bestpractices.lookup({"id": project_id })
levels[badge_data.body.badge_level] >= levels[input.profile.level]
}
# Defines the configuration for alerting on the rule
alert:
type: security_advisory
security_advisory: {}

0 comments on commit bf15c91

Please sign in to comment.