Open Source Project Security Baseline

Overview

The Open Source Project Security (OSPS) Baseline is a set of security criteria that projects should meet to be considered secure. The criteria are organized by maturity level and category. In the detailed subsections you will find the criteria, objectives, and implementation notes.

For more information on the project and to make contributions, visit the GitHub repo.


Criteria Overview

ID Maturity Level Category Criteria
OSPS-AC-01 1 Access Control The project’s version control system MUST require multi-factor authentication for collaborators modifying the project repository settings or accessing sensitive data.
OSPS-AC-02 1 Access Control The project’s version control system MUST restrict collaborator permissions to the lowest available privileges by default.
OSPS-AC-03 1 Access Control The project’s version control system MUST prevent unintentional direct commits against the primary branch.
OSPS-AC-04 1 Access Control The project’s version control system MUST prevent unintentional deletion of the primary branch.
OSPS-AC-05 2 Access Control The project’s permissions in CI/CD pipelines MUST be configured to the lowest available privileges except when explicitly elevated.
OSPS-AC-07 3 Access Control The project’s version control system MUST require multi-factor authentication that does not include SMS for users when modifying the project repository settings or accessing sensitive data.
OSPS-BR-01 1 Build & Release The project’s build and release pipelines MUST NOT execute arbitrary code that is input from outside of the build script.
OSPS-BR-02 1 Build & Release All releases and released software assets MUST be assigned a unique version identifier for each release intended to be used by users.
OSPS-BR-03 1 Build & Release Any websites, API responses or other services involved in the project development and release MUST be delivered using SSH, HTTPS or other encrypted channels.
OSPS-BR-04 2 Build & Release All released software assets MUST be created with consistent, automated [build and release pipelines].
OSPS-BR-05 2 Build & Release All build and release pipelines MUST use standardized tooling where available to ingest dependencies at build time.
OSPS-BR-06 2 Build & Release All releases MUST provide a descriptive log of functional and security modifications.
OSPS-BR-08 2 Build & Release All released software assets MUST be signed or accounted for in a signed manifest including each asset’s cryptographic hashes.
OSPS-DO-01 1 Documentation The project MUST have one or more mechanisms for public discussions about proposed changes and usage obstacles.
OSPS-DO-02 1 Documentation The project documentation MUST include an explanation of the contribution process.
OSPS-DO-03 2 Documentation The project documentation MUST provide user guides for all basic functionality.
OSPS-DO-04 2 Documentation The project documentation MUST include a policy for coordinated vulnerability reporting, with a clear timeframe for response.
OSPS-DO-05 2 Documentation The project documentation MUST include a mechanism for reporting defects.
OSPS-DO-06 2 Documentation The project documentation MUST include a guide for code contributors that includes requirements for acceptable contributions.
OSPS-DO-07 2 Documentation The project documentation MUST provide design documentation demonstrating all actions and actors within the system.
OSPS-DO-08 3 Documentation The project documentation MUST include a policy that defines a threshold for remediation of SCA findings related to vulnerabilities and licenses.
OSPS-DO-09 3 Documentation The project documentation MUST include descriptions of all external input and output interfaces of the released software assets.
OSPS-DO-10 3 Documentation The project documentation MUST include a policy to address SCA violations prior to any release.
OSPS-DO-11 2 Documentation The project documentation MUST have a policy that code contributors are reviewed prior to granting escalated permissions to sensitive resources.
OSPS-DO-12 2 Documentation The project documentation MUST contain instructions to verify the integrity and authenticity of the release assets, including the expected identity of the person or process authoring the software release.
OSPS-LE-01 2 Legal The version control system MUST require all code contributors to assert that they are legally authorized to commit the associated contributions on every commit.
OSPS-LE-02 1 Legal The license for the source code MUST meet the OSI Open Source Definition or the FSF Free Software Definition.
OSPS-LE-03 1 Legal The license for the source code MUST be maintained in a standard location within the project’s repository.
OSPS-LE-04 1 Legal The license for the released software assets MUST meet the OSI Open Source Definition or the FSF Free Software Definition.
OSPS-QA-01 1 Quality The project’s source code MUST be publicly readable and have a static URL.
OSPS-QA-02 1 Quality The version control system MUST contain a publicly readable record of all changes made, who made the changes, and when the changes were made.
OSPS-QA-03 2 Quality All released software assets MUST be delivered with a machine-readable list of all direct and transitive internal software dependencies with their associated version identifiers.
OSPS-QA-04 2 Quality Any automated status checks for commits MUST pass or require manual acknowledgement prior to merge.
OSPS-QA-05 3 Quality Any additional subproject code repositories produced by the project and compiled into a release MUST enforce security requirements as applicable to the status and intent of the respective codebase.
OSPS-QA-06 2 Quality The version control system MUST NOT contain generated executable artifacts.
OSPS-QA-07 3 Quality All proposed changes to the project’s codebase must be automatically evaluated against a documented policy for known vulnerabilities and blocked in the event of violations except when declared and supressed as non exploitable.

Criteria Details

OSPS-AC-01

Criteria:

The project’s version control system MUST require multi-factor authentication for collaborators modifying the project repository settings or accessing sensitive data.

Objective:

Protect against unauthorized access to sensitive areas of the project’s repository, reducing the risk of account compromise or insider threats. Passwords are often easily captured, either during communication or on servers, so depending solely on passwords is a weaker form of authentication.

Implementation:

Require multi-factor authentication (MFA) for the project’s version control system, requiring collaborators to provide a second form of authentication when accessing sensitive data or modifying repository settings. For purposes of this criterion passkeys are considered implementation mechanism even though some implementations might not strictly meet the [MFA] definition, as they require something have the private key (something you have) and often require some additional mechanism to enable.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-AC-02

Criteria:

The project’s version control system MUST restrict collaborator permissions to the lowest available privileges by default.

Objective:

Reduce the risk of unauthorized access to the project’s repository by limiting the permissions granted to collaborators.

Implementation:

Configure the project’s version control system to assign the lowest available permissions to collaborators by default when added, granting additional permissions only when necessary.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-AC-03

Criteria:

The project’s version control system MUST prevent unintentional direct commits against the primary branch.

Objective:

Reduce the risk of accidental changes to the primary branch of the project’s repository, ensuring that due diligence is done before commits are merged.

Implementation:

Set branch protection on the primary branch in the project’s version control system requiring changes to be made through pull/merge requests or other review mechanisms.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-AC-04

Criteria:

The project’s version control system MUST prevent unintentional deletion of the primary branch.

Objective:

Protect the primary branch of the project’s repository from accidental deletion, ensuring that the project’s history and codebase are preserved.

Implementation:

Set branch protection on the primary branch in the project’s version control system to prevent deletion.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-AC-05

Criteria:

The project’s permissions in CI/CD pipelines MUST be configured to the lowest available privileges except when explicitly elevated.

Objective:

Reduce the risk of unauthorized access to the project’s build and release processes by limiting the permissions granted to steps within the CI/CD pipelines.

Implementation:

Configure the project’s CI/CD pipelines to assign the lowest available permissions to users and services by default, elevating permissions only when necessary for specific tasks. In some version control systems, this may be possible at the organizational or repository level. If not, set permissions at the top level of the pipeline.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-AC-07

Criteria:

The project’s version control system MUST require multi-factor authentication that does not include SMS for users when modifying the project repository settings or accessing sensitive data.

Objective:

Ensure that multi-factor authentication does not allow SMS as a factor, because SMS lacks encryption and may be vulnerable to attacks via Signaling System 7, social engineering, or SIM-swapping.

Implementation:

Require multi-factor authentication methods that do not include SMS for users. Common alternatives include hardware tokens, mobile authenticator apps, or biometric authentication.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-BR-01

Criteria:

The project’s build and release pipelines MUST NOT execute arbitrary code that is input from outside of the build script.

Objective:

Reduce the risk of code injection or other security vulnerabilities in the project’s build and release processes by restricting the execution of external code.

Implementation:

Ensure that the project’s build and release pipelines do not execute arbitrary code provided from external sources.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-BR-02

Criteria:

All releases and released software assets MUST be assigned a unique version identifier for each release intended to be used by users.

Objective:

Ensure that each software asset produced by the project is uniquely identified, enabling users to track changes and updates to the project over time.

Implementation:

Assign a unique version identifier to each release and associated software asset produced by the project, following a consistent naming convention or numbering scheme. Examples include SemVer, CalVer, or git commit id.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-BR-03

Criteria:

Any websites, API responses or other services involved in the project development and release MUST be delivered using SSH, HTTPS or other encrypted channels.

Objective:

Protect the confidentiality and integrity of data transmitted between the project’s services and users, reducing the risk of eavesdropping or data tampering.

Implementation:

Configure the project’s websites, API responses, and other services to use encrypted channels such as SSH or HTTPS for data transmission.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-BR-04

Criteria:

All released software assets MUST be created with consistent, automated build and release pipelines.

Objective:

Ensure that the project’s software assets are built and released using consistent and automated processes, reducing the risk of errors or inconsistencies in the deployment and distribution of the software.

Implementation:

VCS-integrated pipelines are recommended to ensure consistency and automation in the build and release processes.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-BR-05

Criteria:

All build and release pipelines MUST use standardized tooling where available to ingest dependencies at build time.

Objective:

Ensure that the project’s build and release pipelines use standardized tools and processes to manage dependencies, reducing the risk of compatibility issues or security vulnerabilities in the software.

Implementation:

Use a common tooling for your ecosystem, such as package managers or dependency management tools to ingest dependencies at build time. This may include using a dependency file, lock file, or manifest to specify the required dependencies, which are then pulled in by the build system.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-BR-06

Criteria:

All releases MUST provide a descriptive log of functional and security modifications.

Objective:

Provide transparency and accountability for changes made to the project’s software releases, enabling users to understand the modifications and improvements included in each release.

Implementation:

Ensure that all releases include a descriptive change log.

It is recommended to ensure that the change log is human-readable and includes details beyond commit messages, such as descriptions of the security impact or relevance to different use cases.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-BR-08

Criteria:

All released software assets MUST be signed or accounted for in a signed manifest including each asset’s cryptographic hashes.

Objective:

Provide users with a mechanism to verify the authenticity and integrity of released software assets, reducing the risk of tampering or unauthorized modifications.

Implementation:

Sign all released software assets at build time with a cryptographic signature or attestations, such as GPG or PGP signature, Sigstore signatures, SLSA provenance, or SLSA VSAs. Include the cryptographic hashes of each asset in a signed manifest or metadata file.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-01

Criteria:

The project MUST have one or more mechanisms for public discussions about proposed changes and usage obstacles.

Objective:

Encourages open communication and collaboration within the project community, enabling users to provide feedback and discuss proposed changes or usage challenges.

Implementation:

Establish one or more mechanisms for public discussions within the project, such as mailing lists, instant messaging, or issue trackers, to facilitate open communication and feedback.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-02

Criteria:

The project documentation MUST include an explanation of the contribution process.

Objective:

Provide guidance to new contributors on how to participate in the project, outlining the steps required to submit changes or enhancements to the project’s codebase.

Implementation:

Create a CONTRIBUTING.md or CONTRIBUTING/ directory to outline the contribution process including the steps for submitting changes, and engaging with the project maintainers.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-03

Criteria:

The project documentation MUST provide user guides for all basic functionality.

Objective:

Ensure that users have a clear and comprehensive understanding of the project’s current features in order to prevent damage from misuse or misconfiguration.

Implementation:

Create user guides or documentation for all basic functionality of the project, explaining how to install, configure, and use the project’s features. If there are any known dangerous or destructive actions available, include highly-visible warnings.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-04

Criteria:

The project documentation MUST include a policy for coordinated vulnerability reporting, with a clear timeframe for response.

Objective:

Establish a process for reporting and addressing vulnerabilities in the project, ensuring that security issues are handled promptly and transparently.

Implementation:

Create a SECURITY.md file at the root of the directory, outlining the project’s policy for coordinated vulnerability reporting. Include a method for reporting vulnerabilities. Set expectations for the how the project will respond and address reported issues.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-DO-05

Criteria:

The project documentation MUST include a mechanism for reporting defects.

Objective:

Enable users and contributors to report defects or issues with the released software assets, facilitating communication and collaboration on defect fixes and improvements.

Implementation:

It is recommended that projects use their VCS default issue tracker. If an extarnal source is used, ensure that the project documentation and contributing guide clearly and visibly explain how to use the reporting system.

It is recommended that project documentation also sets expectations for how defects will be triaged and resolved.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-06

Criteria:

The project documentation MUST include a guide for code contributors that includes requirements for acceptable contributions.

Objective:

Provide guidance to code contributors on how to submit changes and enhancements to the project’s codebase, outlining the standards and expectations for acceptable contributions.

Implementation:

Extend the CONTRIBUTING.md or CONTRIBUTING/ contents in the project documentation to outline the requirements for acceptable contributions, including coding standards, testing requirements, and submission guidelines for code contributors.

It is recommended that this guide is the source of truth for both contributors and approvers.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-07

Criteria:

The project documentation MUST provide design documentation demonstrating all actions and actors within the system.

Objective:

Provide an overview of the project’s design and architecture, illustrating the interactions and components of the system to help contributors and security reviewers understand the internal logic of the released software assets.

Implementation:

Include designs in the project documentation that explains the actions and actors. Actors include any subsystem or entity that can influence another segment in the system.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-08

Criteria:

The project documentation MUST include a policy that defines a threshold for remediation of SCA findings related to vulnerabilities and licenses.

Objective:

Ensure that the project clearly communicates the threshold for remediation of SCA findings, including vulnerabilities and license issues in software dependencies.

Implementation:

Document a policy in the project that defines a threshold for remediation of SCA findings related to vulnerabilities and licenses. Include the process for identifying, prioritizing, and remediating these findings.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-09

Criteria:

The project documentation MUST include descriptions of all external input and output interfaces of the released software assets.

Objective:

Provide users and developers with an understanding of how to interact with the project’s software and integrate it with other systems, enabling them to use the software effectively.

Implementation:

Document all input and output interfaces of the released software assets, explaining how users can interact with the software and what data is expected or produced.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-10

Criteria:

The project documentation MUST include a policy to address SCA violations prior to any release.

Objective:

Ensure that violations of your SCA policy are addressed before software releases, reducing the risk of shipping insecure or non-compliant software.

Implementation:

Document a policy in the project to address applicable Software Composition Analysis results before any release, and add status checks that verify compliance with that policy prior to release.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-11

Criteria:

The project documentation MUST have a policy that code contributors are reviewed prior to granting escalated permissions to sensitive resources.

Objective:

Ensure that code contributors are vetted and reviewed before being granted elevated permissions to sensitive resources within the project, reducing the risk of unauthorized access or misuse.

Implementation:

Publish an enforceable policy in the project documentation that requires code contributors to be reviewed and approved before being granted escalated permissions to sensitive resources, such as merge approval or access to secrets.

It is recommended that vetting includes establishing a justifiable lineage of identity such as confirming the contributor’s association with a known trusted organization.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-DO-12

Criteria:

The project documentation MUST contain instructions to verify the integrity and authenticity of the release assets, including the expected identity of the person or process authoring the software release.

Objective:

Enable users to verify the authenticity and integrity of the project’s released software assets, reducing the risk of using tampered or unauthorized versions of the software.

Implementation:

Instructions in the project should contain information about the technology used, the commands to run, and the expected output. The expected identity may be in the form of key IDs used to sign, issuer and identity from a sigstore certificate, or other similar forms.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-LE-01

Criteria:

The version control system MUST require all code contributors to assert that they are legally authorized to commit the associated contributions on every commit.

Objective:

Ensure that code contributors are aware of and acknowledge their legal responsibility for the contributions they make to the project, reducing the risk of intellectual property disputes.

Implementation:

Include a DCO or CLA in the project’s repository, requiring code contributors to assert that they are legally authorized to commit the associated contributions on every commit. Use a status check to ensure the assertion is made.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-LE-02

Criteria:

The license for the source code MUST meet the OSI Open Source Definition or the FSF Free Software Definition.

Objective:

Ensure that the project’s source code is distributed under a recognized and legally enforceable open source software license, providing clarity on how the code can be used and shared by others.

Implementation:

Add a LICENSE file to the project’s repo with a license that is an approved license by the Open Source Initiative (OSI), or a free license as approved by the Free Software Foundation (FSF). Examples of such licenses include the MIT, BSD 2-clause, BSD 3-clause revised, Apache 2.0, Lesser GNU General Public License (LGPL), and the GNU General Public License (GPL). Releasing to the public domain (e.g., CC0) meets this criterion if there are no other encumbrances (e.g., patents).

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-LE-03

Criteria:

The license for the source code MUST be maintained in a standard location within the project’s repository.

Objective:

Ensure that the project’s source code is distributed with the appropriate license terms, making it clear to users and contributors how the code can be used and shared.

Implementation:

Include the project’s source code license in the project’s LICENSE file, COPYING file, or LICENSE/ directory to provide visibility and clarity on the licensing terms. The filename MAY have an extension.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-LE-04

Criteria:

The license for the released software assets MUST meet the OSI Open Source Definition or the FSF Free Software Definition.

Objective:

Ensure that the project’s source code is distributed under a recognized and legally enforceable open source software license, providing clarity on how the code can be used and shared by others.

Implementation:

If a different license is included with released software assets, ensure it is an approved license by the Open Source Initiative (OSI), or a free license as approved by the Free Software Foundation (FSF). Examples of such licenses include the MIT, BSD 2-clause, BSD 3-clause revised, Apache 2.0, Lesser GNU General Public License (LGPL), and the GNU General Public License (GPL). Note that the license for the released software assets may be different than the source code.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-QA-01

Criteria:

The project’s source code MUST be publicly readable and have a static URL.

Objective:

Enable users to access and review the project’s source code and history, promoting transparency and collaboration within the project community.

Implementation:

Use a common VCS such as GitHub, GitLab, or Bitbucket. Ensure the repository is publicly readable. Avoid duplication or mirroring of repositories unless highly visible documentation clarifies the primary source. Avoid frequent changes to the repository that would impact the repository URL.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-QA-02

Criteria:

The version control system MUST contain a publicly readable record of all changes made, who made the changes, and when the changes were made.

Objective:

Provide transparency and accountability for changes made to the project’s codebase, enabling users to track modifications and understand the history of the project.

Implementation:

Use a common VCS such as GitHub, GitLab, or Bitbucket to maintain a publicly readable commit history. Avoid squashing or rewriting commits in a way that would obscure the author of any commits.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-QA-03

Criteria:

All released software assets MUST be delivered with a machine-readable list of all direct and transitive internal software dependencies with their associated version identifiers.

Objective:

Provide transparency and accountability for the project’s dependencies, enabling users and contributors to understand the software’s dependencies and versions.

Implementation:

This may take the form of a software bill of materials (SBOM) or a dependency file that lists all direct and transitive dependencies such as package.json, Gemfile.lock, or go.sum.

It is recommended to use a CycloneDX or SPDX file that is auto-generated at build time by a tool that has been vetted for accuracy. This enables users to ingest this data in a standardized approach alongside other projects in their environment.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-QA-04

Criteria:

Any automated status checks for commits MUST pass or require manual acknowledgement prior to merge.

Objective:

Ensure that the project’s approvers do not become accustomed to tolerating failing status checks, even if arbitrary, because it increases the risk of overlooking security vulnerabilities or defects identified by automated checks.

Implementation:

Configure the project’s version control system to require that all automated status checks pass or require manual acknowledgement before a commit can be merged into the primary branch.

It is recommended that any optional status checks are NOT configured as a pass or fail requirement that approvers may be tempted to bypass.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-QA-05

Criteria:

Any additional subproject code repositories produced by the project and compiled into a release MUST enforce security requirements as applicable to the status and intent of the respective codebase.

Objective:

Ensure that additional code repositories or subprojects produced by the project are held to a standard that clear and appropriate for that codebase.

Implementation:

The parent project should maintain a list of any codebases that are considered subprojects or additional repositories. Collaborators on those repositories should identify the proper maturity level and apply the Open Source Project Security Baseline to the codebase. Any subproject or repository from the project which is compiled into the primary project must be held to the same standard as the primary project. Others may be held to a lower standard if they have lower levels of adoption or are not intended for general use.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


OSPS-QA-06

Criteria:

The version control system MUST NOT contain generated executable artifacts.

Objective:

Reduce the risk of including generated executable artifacts in the project’s version control system, ensuring that only source code and necessary files are stored in the repository.

Implementation:

Remove generated executable artifacts in the project’s version control system.

It is recommended that any scenario where a generated executable artifact appears critical to a process such as testing, it should be instead be generated at build time or stored separately and fetched during a specific well-documented pipeline step.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):


OSPS-QA-07

Criteria:

All proposed changes to the project’s codebase must be automatically evaluated against a documented policy for known vulnerabilities and blocked in the event of violations except when declared and supressed as non exploitable.

Objective:

Identify and address defects and security weaknesses in the project’s codebase early in the development process, reducing the risk of shipping insecure software.

Implementation:

Create a status check in the project’s version control system that runs a Static Application Security Testing (SAST) tool on all changes to the codebase. Require that the status check passes before changes can be merged.

Control Mappings:

No control mappings identified.

Security Insights Value:

No security insights identified.

Scorecard Probe(s):

No scorecard probe identified.


Lexicon

Arbitrary Code

Code provided by an external source that is executed by a system without validation or restriction.

Build and Release Pipeline

A series of automated processes that compile and deploy software. Similar to the generic term CI/CD Pipelines, but this term excludes some pipelines, such as pre-merge status checks.

Change

Any alteration of the project’s codebase, CI/CD Pipelines, or documentation. This may include addition, deletion, or modification of content.

CI/CD Pipeline

Automated pipelines for Continuous Integration and Continuous Delivery. Responsible for building, testing, and delivering changes. These pipelines integrate contributions frequently, enabling rapid and reliable software delivery. CI focuses on testing and building code, while CD delivers software to location such as a package registry.

In the context of the Open Source Project Security Baseline, CD refers only to continuous delivery, not to continuous deployment, as sometimes used elsewhere.

Contributor

Entities who commit code or documentation to the project. Code contributors include collaborators or external participants who submit changes.

In the context of the Open Source Project Security Baseline, code contributors does not address non-code contributions such as designing, triaging, reviewing, or testing.

Codebase

The collection of source code and related assets that make up the project. The codebase includes all files necessary to build and test the software. Lives in the repository, sometimes alongside documentation and CI/CD pipelines. The contents of the codebase are the primary deliverable in a release.

Collaborator

A user with a role on the project’s version control system who can approve changes or manage the repository settings. Collaborators may have varying permission levels based on their role in the project. This does not include contributors whose changes only originate through a request from a repository fork.

Commit

A record of a single change submitted to the version control system. Each commit includes details such as the modifications made, the contributor who made them, and the timestamp of the change.

Defect

Errors or flaws in the software that cause it to produce incorrect or unintended results, or to behave in an unintended way. Defects can include bugs, vulnerabilities, or other issues that impact the software’s functionality or security. Defects may have originally been intentional, but a change in environment or understanding has made them undesirable.

Exploitable Vulnerabilities

Defects in the software that can be leveraged by attackers to gain unauthorized access, execute arbitrary code, or cause other undesired outcomes.

License

A legal document that defines the terms under which the software can be used, modified, and distributed. May be stored at the top level of the repository in a file named LICENSE or within files in a directory named LICENSE/. The license applies to repository contents and any released software assets, unless otherwise stated.

Known Vulnerabilities

Publicly acknowledged exploitable vulnerabilities that have been identified within the software. These vulnerabilities often have associated advisories, patches, or recommended mitigations.

All proposed changes to the project’s codebase must be automatically evaluated against a documented policy for known vulnerabilities and blocked in the event of violations.

Multi-factor Authentication

An authentication method that requires two or more verification factors (e.g., a password and a token) to gain access to a resource. This method strengthens security by requiring multiple forms of identification.

Primary Branch

The main development branch in the version control system, representing the latest stable codebase. Releases are typically made from this branch. Commonly named main or master. In some situations where branches are not featured, a repository with forked repositories will have the original repo acting as an equivalent to the primary branch.

Project Documentation

Written materials related to the project, such as user guides, developer guides, and contribution guidelines. These documents help users and developers understand, contribute to, and interact with the software. At release time, this may include provenance information, licensing details, and other metadata.

Software Provenance

Information about the origin and history of the released software assets. This may include details about its development, dependencies, vulnerabilities, contributors, and licensing.

Release

Released Software Asset

Deliverables provided to users as part of a release. These assets can include binaries, libraries, or containers.

Repository

A storage location managed by a version control system where the project’s code, documentation, and other resources are stored. It tracks changes, manages collaborator permissions, and includes configuration options such as branch protection and access controls.

Software Composition Analysis

The process of identifying and cataloging all components and dependencies in a software codebase. SCA is essential for managing security vulnerabilities and ensuring compliance with organizational policies.

Status Check

Automated tests or validations that run on commits before they are merged. Status checks ensure that any changes meet the project’s quality and security standards.

Subproject

A codebase that is part of the project but maintained in a separate repository. Subprojects may be compiled into the primary project or used as standalone components.

Version Identifier

A label assigned to a specific release of the software, such as v1.2.3. Commonly recommended formats are Semantic Versioning or Calendar Versioning.

Version Control System

A tool that tracks changes to files over time and facilitates collaboration among contributors. Examples of version control systems include Git, Subversion, and Mercurial.

Vulnerability Reporting

The act of identifying and documenting exploitable vulnerabilities in released software assets. This may include privately or openly reporting vulnerabilities to maintainers, security teams, or the public, as well as tracking the resolution of these vulnerabilities.


Acknowledgments

This baseline was created by community leaders from across the Linux Foundation, including: