bitmath

遵循以下最佳实践的项目将能够自愿的自我认证,并显示他们已经实现了核心基础设施计划(OpenSSF)徽章。

没有一套可以保证软件永远不会有缺陷或漏洞的做法;如果规范或假设是错误的,即使合适的方法也可能失败。也没有哪些做法可以保证一个项目能够维持健康和运作良好的开发者社区。但是,遵循最佳做法可以帮助改善项目的成果。例如,一些做法可以在发布之前进行多人评估,这可以帮助您找到其他难以找到的技术漏洞,并帮助建立信任,并希望不同公司的开发人员之间进行重复的交互。要获得徽章,必须满足所有“必须”和“禁止”的条款,满足所有“应该”条款或有合适的理由,所有“建议”条款必须满足或未满足(至少希望考虑)。欢迎通过 GitHub网站创建问题或提出请求进行反馈。另外还有一个一般讨论邮件列表

如果这是您的项目,请在项目页面上显示您的基准徽章状态!基准徽章状态如下所示: 项目12749的基准徽章等级为baseline-2 以下是如何嵌入基准徽章:
您可以通过将其嵌入到Markdown文件中来显示您的基准徽章状态:
[![OpenSSF Baseline](https://www.bestpractices.dev/projects/12749/baseline)](https://www.bestpractices.dev/projects/12749)
或者将其嵌入到HTML中:
<a href="https://www.bestpractices.dev/projects/12749"><img src="https://www.bestpractices.dev/projects/12749/baseline"></a>


这些是基准等级2的标准。 这些标准来自基准版本 v2025.10.10,并包含来自版本 v2026.02.19 的更新标准文本。版本 v2026.02.19 中新增的标准标记为"未来",将从 2026-06-01 开始强制执行。请在该日期之前提供对"未来"标准的回答。

Baseline Series: 基准等级1 基准等级2 基准等级3

        

 基本

  • 常规

    请注意,其他项目可能使用相同的名称。

    Python module to work with file sizes like numbers - convert, compare, sort, and format across any prefix unit

    请使用 SPDX许可证表达格式;例子包括“Apache-2.0”,“BSD-2-Clause”,“BSD-3-Clause”,“GPL-2.0+”,“LGPL-3.0 +”,“MIT”和“(BSD-2-Clause OR Ruby)”。
    如果有多种语言,请将它们列为逗号分隔值(可选空格),并将它们从最多到最少使用。如果有长列表,请至少列出前三个最常见的列表。如果没有语言(例如,这是仅文档或仅测试项目),请使用单个字符“ - ”。请使用每种语言的常规大小写,例如“JavaScript”。
    通用平台枚举(CPE)是用于信息技术系统,软件和软件包的结构化命名方案。在报告漏洞时,它可用于多个系统和数据库。

 控制 19/19

  • 控制


    当执行CI/CD任务且未指定权限时,CI/CD系统必须将任务的权限默认为管道中授予的最低权限。 [OSPS-AC-04.01]
    配置项目的设置,默认情况下为新管道分配最低可用权限,仅在特定任务需要时才授予额外权限。

    Every workflow in .github/workflows/ declares permissions: read-all at the top level, so any task without an explicit permission block runs read-only. Elevated permissions (security-events: write, id-token: write) are scoped to specific jobs only where required. Verifiable at https://github.com/timlnx/bitmath/tree/master/.github/workflows



    当创建正式发布时,该发布必须分配一个唯一的版本标识符。 [OSPS-BR-02.01]
    为项目生成的每个发布分配一个唯一的版本标识符,遵循一致的命名约定或编号方案。示例包括SemVer、CalVer或git提交id。

    Releases follow Semantic Versioning. The single source of truth is the VERSION file (https://github.com/timlnx/bitmath/blob/master/VERSION), which pyproject.toml reads dynamically via [tool.hatch.version]. Each release is tagged in git and published to PyPI under its SemVer identifier: https://github.com/timlnx/bitmath/releases



    当创建正式发布时,该发布必须包含功能和安全修改的描述性日志。 [OSPS-BR-04.01]
    确保所有发布都包含描述性的变更日志。建议确保变更日志是人类可读的,并且包含超出提交消息的详细信息,例如安全影响的描述或与不同用例的相关性。为确保机器可读性,请将内容放在markdown标题下,例如"## Changelog"。

    Every release has a corresponding section in NEWS.rst (https://github.com/timlnx/bitmath/blob/master/NEWS.rst) describing functional changes, breaking changes, and security-relevant modifications in human-readable prose well beyond commit-message granularity. The same content is also published to GitHub Releases: https://github.com/timlnx/bitmath/releases



    当构建和发布管道摄取依赖项时,它必须使用标准化工具(如果可用)。 [OSPS-BR-05.01]
    为您的生态系统使用通用工具,例如包管理器或依赖项管理工具,以在构建时摄取依赖项。这可能包括使用依赖项文件、锁文件或清单来指定所需的依赖项,然后由构建系统拉入。

    Dependencies are managed through the standard Python packaging stack: pyproject.toml declares build and project metadata per PEP 517/518/621 (https://github.com/timlnx/bitmath/blob/master/pyproject.toml), Hatchling is the build backend, and requirements.txt (https://github.com/timlnx/bitmath/blob/master/requirements.txt) pins the development dependency set. Runtime dependencies are intentionally zero.



    当创建正式发布时,该发布必须进行签名或在包含每个资产加密哈希值的签名清单中进行说明。 [OSPS-BR-06.01]
    在构建时使用加密签名或证明(例如GPG或PGP签名、Sigstore签名、SLSA来源或SLSA VSA)对所有发布的软件资产进行签名。在签名清单或元数据文件中包含每个资产的加密哈希值。

    Releases are published to PyPI via PyPI Trusted Publishing (OIDC), which produces sigstore-backed PEP 740 attestations attached to every artifact. PyPI also publishes a SHA-256 hash for each released file. The publish workflow is at https://github.com/timlnx/bitmath/blob/master/.github/workflows/publish.yml and trust-publisher metadata is visible on the PyPI project page: https://pypi.org/project/bitmath/



    当项目发布版本后,项目文档必须包含项目如何选择、获取和跟踪其依赖项的描述。 [OSPS-DO-06.01]
    建议在可公开查看的资源(如源代码存储库、项目网站或其他渠道)上与项目的技术和设计文档一起发布此信息。

    The "Components" section of the contributing guide (https://bitmath.readthedocs.io/en/latest/contributing.html#components) enumerates every development dependency with its purpose and rationale. The zero-runtime-dependency policy and the use of pyproject.toml + requirements.txt for tracking are documented in CLAUDE.md (https://github.com/timlnx/bitmath/blob/master/CLAUDE.md) and visible in pyproject.toml directly.



    (未来条款) 项目文档必须包含如何构建软件的说明,包括所需的库、框架、SDK 和依赖项。 [OSPS-DO-07.01]
    建议将此信息与项目的贡献者文档一起发布,例如在 CONTRIBUTING.md 或其他开发者任务文档中。也可以使用 Makefile 目标或其他自动化脚本来记录此信息。

    The contributing guide's "Makefile Targets" section (https://bitmath.readthedocs.io/en/latest/contributing.html#makefile-targets) documents make ci, make build, make docs, and make clean, including their behavior and when to use each. The README also includes a quick-start. The Makefile itself (https://github.com/timlnx/bitmath/blob/master/Makefile) is the authoritative build automation.



    在活动期间,项目文档必须包含有权访问敏感资源的项目成员列表。 [OSPS-GV-01.01]
    通过项目源代码存储库中的members.md、governance.md、maintainers.md或类似文件等工件记录项目参与者及其角色。这可以简单到在维护者列表中包含姓名或账户句柄,或者根据项目的治理更复杂。

    MAINTAINERS.md (https://github.com/timlnx/bitmath/blob/master/MAINTAINERS.md) lists the current maintainer (Tim Case / @timlnx) and explicitly enumerates every sensitive resource that person has access to: the GitHub repository (admin), the PyPI project (via OIDC), the Read The Docs project, and the security-reporting email address.



    在活动期间,项目文档必须包含项目成员的角色和责任的描述。 [OSPS-GV-01.02]
    通过项目源代码存储库中的members.md、governance.md、maintainers.md或类似文件等工件记录项目参与者及其角色。

    MAINTAINERS.md (https://github.com/timlnx/bitmath/blob/master/MAINTAINERS.md) describes the maintainer role, responsibilities (PR review, releases, security triage, Code of Conduct enforcement, dependency surface oversight), the decision-making process, and a standing open request for a Debian/Ubuntu co-maintainer (tracked in https://github.com/timlnx/bitmath/issues/117).



    在活动期间,项目文档必须包含代码贡献者指南,其中包括可接受贡献的要求。 [OSPS-GV-03.02]
    扩展项目文档中的CONTRIBUTING.md或CONTRIBUTING/的内容,以概述可接受的贡献要求,包括编码标准、测试要求和代码贡献者的提交指南。建议将该指南作为贡献者和批准者的真实来源。

    The contributing guide (https://bitmath.readthedocs.io/en/latest/contributing.html) documents the requirements for acceptable contributions including: code style (pycodestyle PEP 8 + pylint 10.00/10 target), commit message conventions, the pull request workflow with required CI status checks, testing expectations (unit tests for new functionality), the supported Python version policy, and the Makefile targets contributors should run locally before submitting.



    处于活跃状态时,版本控制系统必须要求所有代码贡献者在每次提交时断言他们有合法授权提交相关的贡献。 [OSPS-LE-01.01]
    在项目的代码库中包含一个DCO,要求代码贡献者在每次提交时断言他们有合法授权提交相关贡献。使用状态检查以确保完成此断言。CLA也满足此要求。某些版本控制系统(例如GitHub)可能会在平台服务条款中包含此项。

    bitmath is hosted on GitHub. Per the GitHub Terms of Service, §D.6 "Contributions Under Repository License," every contributor pushing to a public repository licenses their contribution under the repository's license by the act of pushing. The OSPS criterion text itself acknowledges: "Some version control systems, such as GitHub, may include this in the platform terms of service." This control is satisfied via that mechanism.



    当向主分支提交时,必须通过或手动绕过提交的任何自动化状态检查。 [OSPS-QA-03.01]
    配置项目的版本控制系统,要求所有自动化状态检查通过或在提交合并到主分支之前需要手动确认。建议不要将任何可选状态检查配置为批准者可能会绕过的通过或失败要求。

    Branch protection on master requires 17 status checks to pass before any commit can be merged: the full Python 3.9–3.13 × {macOS, Ubuntu, Windows} test matrix plus CodeQL and Bandit. enforce_admins: true so even the repo owner cannot bypass these checks.



    在接受提交之前,项目的CI/CD管道必须运行至少一个自动化测试套件,以确保更改符合预期。 [OSPS-QA-06.01]
    应在每次合并到主分支之前运行自动化测试。测试套件应在CI/CD管道中运行,结果应对所有贡献者可见。测试套件应在一致的环境中运行,并应以允许贡献者在本地运行测试的方式运行。测试套件的示例包括单元测试、集成测试和端到端测试。

    The .github/workflows/python.yml workflow (https://github.com/timlnx/bitmath/blob/master/.github/workflows/python.yml) runs the full pytest suite on every push and pull request, across Python 3.9, 3.10, 3.11, 3.12, and 3.13 on macOS, Ubuntu, and Windows. Test results are publicly visible on every PR, and the same tests can be run locally via make ci.



    当项目发布版本时,项目文档必须包括设计文档,展示系统中的所有操作和参与者。 [OSPS-SA-01.01]
    在项目文档中包括说明操作和参与者的设计。参与者包括可以影响系统中另一段的任何子系统或实体。确保为新功能或重大更改更新此文档。

    ARCHITECTURE.md (https://github.com/timlnx/bitmath/blob/master/ARCHITECTURE.md) at the repository root documents the system as actors and actions across two scopes: the runtime library (user code → public API → class hierarchy → OS abstraction layer) and the build/release pipeline (PyPI flow plus the parallel Packit-driven Fedora/EPEL RPM flow). The Maintenance section establishes an update contract tied to public API, build pipeline, and trust boundary changes, with review at every minor release.



    当项目发布版本时,项目文档必须包括对已发布软件资产的所有外部软件接口的描述。 [OSPS-SA-02.01]
    记录已发布软件资产的所有软件接口(API),解释用户如何与软件交互以及期望或产生什么数据。确保为新功能或重大更改更新此文档。

    Every public class, method, and module-level function in bitmath has reference documentation at https://bitmath.readthedocs.io/ covering inputs, outputs, exceptions, and usage examples. The documentation source is in docsite/source/ and is regenerated from the codebase on every release.



    当项目发布版本时,项目必须执行安全评估,以了解软件中可能发生的最可能和最具影响力的潜在安全问题。 [OSPS-SA-03.01]
    执行安全评估可以告知项目成员和下游消费者,项目了解软件中可能出现的问题。了解可能实现的威胁有助于项目管理和应对风险。此信息对下游消费者很有用,可以证明项目的安全敏锐度和实践。确保为新功能或重大更改更新此文档。

    SECURITY_ASSESSMENT.md (https://github.com/timlnx/bitmath/blob/master/SECURITY_ASSESSMENT.md) is a standing threat model that describes: what bitmath does and deliberately does not do (no network, no eval, no subprocess, zero runtime dependencies); the realistic attack surfaces ranked by concern (parse_string, filesystem helpers, query_device_capacity, the build/release pipeline); the mitigations in place for each; and the automated security tooling continuously assessing the project (Bandit, CodeQL, OSSF Scorecard, Dependabot, GitHub secret scanning). It is committed to revisit at every minor release.



    处于活跃状态时,项目文档必须包括协调漏洞披露(CVD)的政策,并有明确的响应时间框架。 [OSPS-VM-01.01]
    在目录根目录创建一个SECURITY.md文件,概述项目的协调漏洞披露政策。包括报告漏洞的方法。设定项目将如何响应和处理报告问题的期望。

    SECURITY.md (https://github.com/timlnx/bitmath/blob/master/SECURITY.md) documents the coordinated vulnerability disclosure process with explicit response timeframes: acknowledgement of receipt within 72 hours, initial triage assessment within 7 days, and coordinated disclosure synchronized with the patch release that contains the fix. Backup contact channels are provided in case the primary email path fails.



    处于活跃状态时,项目文档必须提供一种方法,用于直接向项目内的安全联系人私下报告漏洞。 [OSPS-VM-03.01]
    为安全研究人员提供一种方式,以私下向项目报告漏洞。这可能是专用电子邮件地址、Web表单、VCS专用工具、安全联系人的电子邮件地址或其他方法。

    Two private reporting channels are available, both documented in SECURITY.md (https://github.com/timlnx/bitmath/blob/master/SECURITY.md): GitHub's native Private Vulnerability Reporting (enabled on the repository, accessible via the Security tab), and direct email to bitmath@lnx.cx. Bluesky and Instagram are listed as emergency backup channels if both primary methods fail.



    处于活跃状态时,项目文档必须公开发布有关已发现漏洞的数据。 [OSPS-VM-04.01]
    在可预测的公共渠道(例如CVE条目、博客文章或其他媒体)中提供有关已知漏洞的信息。在可能的情况下,此信息应包括受影响的版本、消费者如何确定他们是否容易受到攻击以及缓解或修复的说明。

    The project publishes vulnerability information through GitHub Security Advisories (https://github.com/timlnx/bitmath/security/advisories) with CVE numbers when applicable, and through the relevant version's section in NEWS.rst. As of submission, zero vulnerabilities have been reported or confirmed against bitmath, so no advisories exist yet, but the publication channel is configured and operational.



该数据可在社区数据许可协议 – 许可性,版本 2.0 (CDLA-Permissive-2.0)下获取。这意味着数据接收方可以共享数据,无论是否经过修改,只要数据接收方在共享数据时提供本协议文本。请注明Tim Case和OpenSSF最佳实践徽章贡献者。

项目徽章条目拥有者: Tim Case.
最后更新于 2026-05-04 23:07:38 UTC, 最后更新于 2026-05-24 07:07:48 UTC。 最后在 2026-05-24 04:07:11 UTC 获得通过徽章。