dso

本サイトが提示する下記のベストプラクティスを実行するプロジェクトは、Open Source Security Foundation (OpenSSF) バッジを達成したことを自主的に自己認証し、そのことを外部に示すことができます。

ソフトウェアに欠陥や脆弱性がないことを保証する手立てはありません。形式論的な証明ができたとしても、仕様や前提が間違っていると誤動作の可能性があります。また、プロジェクトが健全で、かつ機能的な開発コミュニティであり続けることを保証する手立てもありません。しかし、ベストプラクティスの採用は、プロジェクトの成果の向上に寄与する可能性があります。たとえば、いくつものベストプラクティスがリリース前の複数人によるレビューを定めていますが、それによりレビュー以外では発見困難な技術的脆弱性を見つけるのを助け、同時に異なる企業の開発者間の信頼を築き、さらに交流を続けることに対する意欲を生んでいます。バッジを獲得するには、すべてのMUSTおよびMUST NOT基準を満たさなければなりません。すべてのSHOULD基準も満たさなければなりませんが、正当な理由がある場合は満たさなくても構いません。そしてすべてのSUGGESTED基準も満たさなければなりませんが、満たさないとしても、少なくとも考慮することが望まれます。フィードバックは、 GitHubサイトのissueまたはpull requestとして提示されれば歓迎します。また、議論のためのメールリストも用意されています。

私たちは多言語で情報を提供していますが、翻訳版に矛盾や意味の不一致がある場合は、英語版を正式な記述とします。
これがあなたのプロジェクトなら、あなたのプロジェクトページにあなたのバッジステータスを表示してください!バッジステータスは次のようになります。 プロジェクト 12920 のバッジ レベルは in_progress です バッジステータスの埋め込み方法は次のとおりです。
バッジステータスを表示するには、あなたのプロジェクトのマークダウンファイルに以下を埋め込みます
[![OpenSSF Best Practices](https://www.bestpractices.dev/projects/12920/badge)](https://www.bestpractices.dev/projects/12920)
あるいは、以下をHTMLに埋め込みます
<a href="https://www.bestpractices.dev/projects/12920"><img src="https://www.bestpractices.dev/projects/12920/badge"></a>


これらは合格レベルの基準です。シルバーまたはゴールドレベル基準を表示することもできます。

Baseline Series: ベースラインレベル1 ベースラインレベル2 ベースラインレベル3

        

 基本的情報 13/13

  • 一般

    他のプロジェクトが同じ名前を使用していないか注意してください。

    Zero-persistence secret injection for Docker containers. Eliminates secret storage on disk by retrieving credentials at runtime from AWS Secrets Manager, Azure Key Vault, HashiCorp Vault, or Huawei Cloud CSMS.

    SPDXライセンスの表現形式を使用してください。 例:「Apache-2.0」、「BSD-2-Clause」、「BSD-3-Clause」、「GPL-2.0+」、「LGPL-3.0+」、「MIT」、「(BSD-2-Clause OR Ruby)」。一重引用符または二重引用符を含めないでください。
    複数の言語がある場合は、コンマを区切り(スペースを入れてもよい)としてリストし、使用頻度の高いものから順に並べます。使用言語が多くある場合は、少なくとも最初の3つの最も多く使われるものをリストアップしてください。言語がない場合(例:ドキュメントだけ、またはテスト専用のプロジェクトの場合)、1文字 " - "を使用します。言語ごとにある大文字・小文字の慣用を踏襲してください(例:「JavaScript」)。
    Common Platform Enumeration(CPE)は、情報技術(IT)システム、ソフトウェア、およびパッケージのための構造化された命名体系です。脆弱性を報告する際に、多くのシステムやデータベースで使用されています。

    Phase 1 CNCF Sandbox preparation completed. Fixed critical production blockers, established governance model, published roadmap, and implemented automated quality gates. Application pending CNCF review. All code production-ready and security-hardened.

  • 基本的なプロジェクト ウェブサイトのコンテンツ


    プロジェクトのウェブサイトは、ソフトウェアが何をするのか(何の問題を解決するのか)を簡潔に記述しなければなりません。 [description_good]
    これは、潜在的なユーザーが理解できる言語でなければなりません(例えば、それは最小限の専門用語を使用します)。

    The project README.md clearly describes DSO as: "Zero-persistence secret injection for Docker containers. Eliminates secret storage on disk by retrieving credentials at runtime from AWS Secrets Manager, Azure Key Vault, HashiCorp Vault, or Huawei Cloud CSMS." The GitHub repository home page explains the problem being solved and key features.



    プロジェクトのウェブサイトは、取得方法、フィードバックの提供方法(バグ報告や拡張機能)、ソフトウェアへの貢献方法に関する情報を提供しなければなりません。 [interact]

    The project provides:

    1. How to obtain: GitHub releases page and Docker Hub with installation instructions in README.md

    2. How to provide feedback: GitHub issue templates for bugs, features, and security vulnerabilities (/.github/ISSUE_TEMPLATE/)

    3. How to contribute: CONTRIBUTING.md file details the pull request process, code review standards, and governance model. GitHub discussions enabled for community interaction.

    All information is accessible and non-proprietary.



    貢献する方法に関する情報は、貢献プロセス(たとえばプル リクエストが使用されか、など)を説明する必要があります。 (URLが必要です) [contribution]
    別段の記載がない限り、GitHub上のプロジェクトは、(GitHubが提供する)課題管理とプルリクエストを使用することを想定します。この情報は不足しているかもしれません。すなわち、プロジェクトがプルリクエストと課題追跡ツールを使うことか、メーリングリストへの投稿を言及している。(どちら?)

    Non-trivial contribution file in repository: https://github.com/docker-secret-operator/dso/blob/main/CONTRIBUTING.md.



    貢献する方法に関する情報は、貢献を受け入れるための要件(たとえば、必要なコーディング標準への参照)を含むべきです。 (URLが必要です) [contribution_requirements]

    Code standards required: go vet, go fmt, go test -race
    Minimum coverage: 70% overall, 85% critical packages
    Pull request review required per GOVERNANCE.md
    All GitHub Actions CI/CD checks must pass
    Details: https://github.com/docker-secret-operator/dso/blob/main/GOVERNANCE.md


  • FLOSSライセンス


    プロジェクトによって作成されたソフトウェアは、FLOSSとしてリリースされなければなりません。 [floss_license]
    FLOSSは、オープンソース定義またはフリーソフトウェア定義を満たす方法でリリースされたソフトウェアです。そのようなライセンスの例としては、CC0MIT2項型BSD 3項型BSD Apache 2.0 Less GNU General Public License(LGPL)、および GNU General Public License(GPL)を参照してください。私たちの目的のためには、これはライセンスが以下のものでなければならないことを意味します: ソフトウェアは他の方法でライセンスされているかもしれません(たとえば、「GPLv2またはプロプライエタリ」は許容されます)。

    The Apache-2.0 license is approved by the Open Source Initiative (OSI).



    プロジェクトによって作成されたソフトウェアに必要なライセンスは、オープンソース・イニシアチブ(OSI)によって承認されていることが推奨されています。 [floss_license_osi]
    OSIは、厳格な承認プロセスを使用して、どのライセンスがOSSであるかを判断します。

    The Apache-2.0 license is approved by the Open Source Initiative (OSI).



    プロジェクトは、結果のライセンスをソースリポジトリの標準的な場所に投稿しなければなりません。 (URLが必要です) [license_location]
    たとえば、LICENSEまたはCOPYINGという名前の最上位ファイルです。ライセンスファイル名の後に ".txt" や ".md" などの拡張子を付けることができます。別の規則は、ライセンスファイルを含むLICENSESという名前のディレクトリを持つことです。これらのファイルは通常、 REUSE仕様で説明されているように、SPDXライセンス識別子とそれに続く適切なファイル拡張子として名前が付けられます。この基準は、ソースリポジトリの要件にすぎないことに注意してください。ソースコード(実行可能ファイル、パッケージ、コンテナなど)から何かを生成するときに、ライセンスファイルを含める必要はありません。たとえば、Comprehensive R Archive Network(CRAN)のRパッケージを生成するときは、標準のCRANプラクティスに従います。ライセンスが標準ライセンスの場合は、標準の短いライセンス仕様を使用して(テキストのコピーをさらにインストールしないようにするため)、リストします。 .Rbuildignoreなどの除外ファイル内のLICENSEファイル。同様に、Debianパッケージを作成する場合、著作権ファイルに /usr/share/common-licenses のライセンス テキストへのリンクを配置し、作成したパッケージからライセンス ファイルを除外できます(たとえば、dh_auto_installを呼び出した後にファイルを削除します )。可能な場合は、生成された形式で機械可読ライセンス情報を含めることをお勧めします。

    Non-trivial license location file in repository: https://github.com/docker-secret-operator/dso/blob/main/LICENSE.


  • ドキュメンテーション


    プロジェクトは、プロジェクトによって作成されたソフトウェアに関する基本的なドキュメンテーションを提供しなければなりません。 [documentation_basics]
    このドキュメントは、インストール方法、起動方法、使用方法(可能であれば例示したチュートリアル)、および、そのソフトウェアの適切なトピックであれば安全に使用する方法(たとえば何をするべきで、何をすべきでないか)を記述し、メディア(たとえば、テキストやビデオなど)に収められている必要があります。セキュリティの文書は必ずしも長文である必要はありません。プロジェクトは、ドキュメンテーションとしてプロジェクト以外の素材へのハイパーテキストリンクを使用してもよいです。プロジェクトがソフトウェアを作成しない場合は、「該当なし」(N / A)を選択します。

    Some documentation basics file contents found.



    プロジェクトは、プロジェクトによって作成されたソフトウェアの外部インタフェース(入力と出力の両方)を記述する参照ドキュメントを提供しなければなりません。 [documentation_interface]
    外部インターフェイスのドキュメントは、エンドユーザーまたは開発者に、その使用方法を説明します。ドキュメントには、ソフトウェアにアプリケーション プログラム インターフェイス(API)が含まれている場合、アプリケーション プログラム インターフェイスが含まれます。ライブラリの場合、呼び出すことができる主要なクラス/型とメソッド/関数を文書化します。ウェブ アプリケーションの場合、URLインタフェース(多くの場合、RESTインタフェース)を定義します。コマンドラインインターフェイスの場合は、サポートするパラメータとオプションを文書化します。多くの場合、ドキュメントのほとんどを自動生成すると、ソフトウェアが変更されたときにドキュメントがソフトウェアと同期したままなので、最も良い方法ですが、これは必須ではありません。プロジェクトは、ドキュメンテーションとしてプロジェクト以外の素材へのハイパーテキストリンクを使用してもよいです。ドキュメンテーションは自動的に生成されるかもしれません(実際的に、しばしばこれを行う最良の方法です)。 RESTインタフェースのドキュメントは、Swagger / OpenAPIを使用して生成することができます。コード インタフェースのドキュメントは、 JSDoc (JavaScript)、 ESDoc (JavaScript)、pydoc(Python)、devtools (R)、pkgdown (R)、およびDoxygen(多数)のいずれかです。実装コードにコメントがあるだけでは、この基準を満たすには不十分です。すべてのソースコードを読むことなく情報を見るための簡単な方法が必要です。プロジェクトがソフトウェアを作成しない場合は、「該当なし」(N/A)を選択します。

    DSO provides reference documentation for all external interfaces:

    1. CLI Interface (docker dso command):
      Documentation: https://github.com/docker-secret-operator/dso/blob/main/README.md#usage
      Details: Subcommands, flags, and usage examples

    2. Provider Plugin Interface:
      Documentation: https://github.com/docker-secret-operator/dso/blob/main/pkg/api/plugin.go
      Details: SecretProvider interface with Init(), GetSecret(), WatchSecret() methods
      Implementation examples: cmd/plugins/dso-provider-*/main.go

    3. Configuration Interface:
      Documentation: https://github.com/docker-secret-operator/dso/blob/main/examples/dso.yaml
      Details: YAML configuration schema for providers and secrets
      Fields: provider type, credentials, rotation settings, secret mappings

    4. REST API (Agent Mode):
      Documentation: https://github.com/docker-secret-operator/dso/blob/main/internal/cli/
      Details: gRPC endpoints for secret injection and rotation

    5. Environment Variables:
      Documentation: https://github.com/docker-secret-operator/dso/blob/main/SECURITY.md
      Details: HUAWEI_, AZURE_, AWS_* credential configuration

    All interfaces are documented in code comments and usage examples.


  • その他


    プロジェクトサイト(ウェブサイト、リポジトリ、およびダウンロードURL)は、TLSを使用したHTTPSをサポートしなければなりません。 [sites_https]
    これには、プロジェクトのホームページのURLとバージョン管理リポジトリのURLが「http:」ではなく「https:」で始まる必要があります。Let's Encryptからフリーの証明書を入手できます。プロジェクトは、(例えば) GitHubページ GitLabページ、またはSourceForgeプロジェクトページを使ってこの基準を実装してもよいです。HTTPをサポートしている場合は、HTTPトラフィックをHTTPSにリダイレクトすることを強くお勧めします。

    Given only https: URLs.



    プロジェクトは、議論(提案された変更や問題を含む)のための1つ以上の検索可能なメカニズムを持たなければならず、メッセージやトピックがURLでアドレス指定され、新しい人々がディスカッションのいくつかに参加できるようにしなければならず、クライアント側でプロプライエタリなソフトウェアのインストールを必要としないようにします。 [discussion]
    受け入れ可能なメカニズムの例には、アーカイブされたメーリングリスト、GitHubのイシューとプルリクエストの議論、Bugzilla、Mantis、Tracなどがあります。非同期ディスカッション メカニズム(IRCなど)は、これらの基準を満たしていれば許容されます。 URLアドレス可能なアーカイブ機構があることを確認してください。独自のJavaScriptは、推奨されませんが、許可されています。

    GitHub supports discussions on issues and pull requests.



    プロジェクトは英語で文書を提供し、英語でコードに関するバグ報告とコメントを受け入れることができるべきです。 [english]
    現在、英語はコンピュータ技術のリンガ フランカです。英語をサポートすることで、世界中のさまざまな潜在的な開発者とレビュアーの数を増やします。コア開発者の主要言語が英語でなくても、プロジェクトはこの基準を満たすことができます。

    All project documentation is in English:

    • README.md: Complete usage and installation guide
    • GOVERNANCE.md: Contributor model and decision processes
    • ROADMAP.md: 6-12 month development plan
    • SECURITY.md: Security hardening and vulnerability reporting
    • CONTRIBUTING.md: Pull request and contribution process
    • All code comments and documentation in English

    Bug reports and comments:

    • GitHub issue templates (bug.md, feature.md, security.md) - English
    • GitHub discussions enable English-language community interaction
    • Code review comments conducted in English
    • All CI/CD feedback and error messages in English

    Maintainers communicate exclusively in English. No barriers to non-native English speakers participating.



    プロジェクトはメンテナンスされている必要があります。 [maintained]
    少なくとも、プロジェクトは重大な問題と脆弱性の報告に対応するように努める必要があります。バッジを積極的に追求しているプロジェクトは、おそらくメンテナンスされているでしょう。すべてのプロジェクトや人のリソースには限りがあり、提案された変更をプロジェクトが拒否しなければならないこともあるため、リソースに限りがあることや、提案が拒否されることが、メンテナンスされていないプロジェクトを示すわけではありません。

    プロジェクトが今後メンテナンスされなくなることがわかった場合は、この基準を「不適合(Unmet)」に設定し、適切なメカニズムを使用して、メンテナンスされないことを人々に示す必要があります。たとえば、READMEの最初の見出しに「DEPRECATED」(将来のサポートが保証されないので使用すべきでない)を使用し、ホームページの先頭近くに「DEPRECATED」を追加し、コード リポジトリのプロジェクトの説明の先頭に「DEPRECATED」を追加し、そのREADMEおよび/またはホームページにno-maintenance-intendedバッジを追加し、すべてのパッケージ リポジトリでdeprecated(非推奨)としてマークしたり(例: npm deprecate )、コード リポジトリのマーキングシステムを使用してアーカイブします(例:GitHubの"archive" 設定、GitLabの"archived" マーキング、 Gerritの "readonly" ステータス、またはSourceForgeの"abandoned" プロジェクト ステータス)。詳細な説明については、こちらを参照してください。

    Actively maintained with recent Phase 1 updates (May 2026). Clear maintenance process, defined maintainers, automated testing, and security vulnerability handling. 6-12 month roadmap demonstrates long-term commitment. Bug fixes within 2 weeks per GOVERNANCE.md.


 変更管理 9/9

  • 公開されたバージョン管理ソースリポジトリ


    プロジェクトには、公開され、URLを持つ、バージョン管理のソース リポジトリがなければなりません。 [repo_public]
    URLはプロジェクトのURLと同じであってもよいです。プロジェクトは、変更が公開されていない間に(例えば、公開前に脆弱性を修正するため)、特定のケースでプライベート(非公開)ブランチを使用することができます。

    Repository on GitHub, which provides public git repositories with URLs.



    プロジェクトのソース リポジトリは、どのような変更が行われたのか、誰が変更を行ったのか、いつ変更が行われたのかを追跡しなければなりません。 [repo_track]

    Repository on GitHub, which uses git. git can track the changes, who made them, and when they were made.



    共同レビューを可能にするために、プロジェクトのソースリポジトリには、リリース間のレビューのための中間バージョンが含まれなければなりません。最終リリースのみを含めることはできません。 [repo_interim]
    プロジェクトは、公開ソース リポジトリから特定の暫定版を省略することを選択することができます。(たとえば、特定の非公開のセキュリティ脆弱性を修正するものは、公開されないか、または、合法的に投稿できないか、最終リリースに入らないです)

    The project does not currently omit interim versions. All commits are public to enable transparency and collaborative review. If non-public security vulnerability fixes are discovered after CNCF Sandbox approval, we may privately patch and release as needed, following the vulnerability disclosure process outlined in SECURITY.md.



    プロジェクトのソース リポジトリに共通の分散バージョン管理ソフトウェア(gitなど)を使用することを推奨します。 [repo_distributed]
    Gitが特別に必要とされているわけでなく、プロジェクトでは、集中型バージョン管理ソフトウェア(例:subversion)を正当とする証拠を持って使用できます。

    Repository on GitHub, which uses git. git is distributed.


  • 一意的なバージョン番号


    プロジェクトの結果には、ユーザーが使用することを意図されたリリースごとに固有のバージョン識別子が必要です。 [version_unique]
    これはコミットID(git commit idやmercurial changeset idなど)やバージョン番号(YYYYMMDDのようなセマンティックバージョニングや日付ベースのスキームを使用するバージョン番号を含む)など、さまざまな方法で対応できます。

    Yes, Docker Secret Operator uses semantic versioning (MAJOR.MINOR.PATCH) for unique version identification.

    Current release: v3.5.17

    Versioning scheme:

    • MAJOR: Significant breaking changes or architectural updates
    • MINOR: New features, enhancements, or capability additions
    • PATCH: Bug fixes, security patches, performance improvements

    Version management:

    • Versions are tracked as git tags in the GitHub repository (github.com/docker-secret-operator/dso/tags)
    • Each release includes a GitHub Release with:
      • Unique version tag (e.g., v3.5.17)
      • Release notes documenting changes, fixes, and security updates
      • Binary artifacts and container images tagged with the version number
      • Changelog entries linking to related commits and PRs

    Users can access specific versions via:

    • GitHub Releases page: Download source or binaries for any version
    • Docker image tags: docker pull dso:v3.5.17
    • Git tags: git checkout v3.5.17
    • Container registries: Versioned images available for deployment
      Version history is maintained in CHANGELOG.md showing all released versions with their features and fixes.


    リリースには、Semantic Versioning (SemVer)またはCalendar Versioning (CalVer)のバージョン番号形式を使用することが推奨されます。CalVerを使用する場合は、マイクロレベル値を含めることが推奨されます。 [version_semver]
    プロジェクトは一般的に、エコシステムで使用されている通常のフォーマットなど、ユーザーが期待しているフォーマットを優先するべきです。多くのエコシステムではSemVerが好まれており、一般的にSemVerはアプリケーションプログラマインターフェース(API)やソフトウェア開発キット(SDK)に好まれています。CalVerは、規模が大きく、独自に開発した依存関係が異常に多いプロジェクトや、スコープが常に変化するプロジェクト、時間的な制約があるプロジェクトで使用される傾向があります。CalVerを使用する際には、マイクロレベルの値を含めることが推奨されます。マイクロレベルを含めることで、必要になった場合にはいつでも同時にメンテナンスされるブランチをサポートできるからです。git commit ID や mercurial changeset ID など、バージョンを一意に識別できるものであれば、他のバージョン番号形式をバージョン番号として使用することができます。しかし、(git commit ID のような)いくつかの代替形式は、リリースの識別子として問題を引き起こす可能性があります。すべての受信者が最新バージョンを実行しているだけの場合 (たとえば、継続的な配信を介して常に更新されている単一のWebサイトまたはインターネットサービスのコード)には、バージョン ID の形式はソフトウェアのリリースを識別する上で重要ではないかもしれません。


    プロジェクトがバージョン管理システム内の各リリースを特定することが推奨されています。たとえば、gitを使用しているユーザーがgitタグを使用して各リリースを特定することが推奨されています。 [version_tags]

    Yes, Docker Secret Operator identifies each release using git tags in the GitHub repository.

    Git tag naming convention: v{MAJOR}.{MINOR}.{PATCH}

    Examples of release tags:

    • v3.5.17 (current release)
    • v3.5.16 (previous patch release)
    • v3.5.0 (feature release)
    • v3.4.x (previous minor versions)

    How releases are tagged:

    1. Development occurs on main branch with regular commits
    2. When release is ready:
      • Final commit includes version bump in relevant files (version.go, README.md, etc.)
      • Annotated git tag is created: git tag -a v3.5.17 -m "Release v3.5.17"
      • Tag is pushed to GitHub: git push origin v3.5.17
    3. GitHub automatically creates Release entry from the git tag
    4. Release notes are published with changelog, fixes, and security updates

    Accessing tagged releases:

    • Users can view all tags: github.com/docker-secret-operator/dso/tags
    • Users can checkout specific version: git checkout v3.5.17
    • Users can clone specific version: git clone --branch v3.5.17 https://github.com/docker-secret-operator/dso.git
    • Users can pull versioned container images: docker pull dso:v3.5.17

    Relationship to GitHub Releases:

    • Each git tag v3.x.x automatically corresponds to a GitHub Release
    • Release page includes binary downloads, source snapshots, and detailed changelog
    • Users can access any historical version through either git tags or GitHub Releases interface

    This approach ensures:

    • Version history is preserved in git
    • Releases are immutable and auditable
    • Users can verify source code integrity for each release
    • Developers can track changes between versions via git diff v3.5.16..v3.5.17

  • リリースノート


    プロジェクトは、各リリースにおいて、ユーザーがアップグレードすべきかどうか、また、アップグレードの影響を判断できるよう、そのリリースの主要な変更の要約を説明したリリースノートを提供しなければなりません(MUST)。リリースノートは、バージョン管理ログの生の出力であってはなりません(例えば、 "git log"コマンドの結果はリリースノートではない)。プロジェクトの成果物が複数の場所で再利用されることを意図していないプロジェクト(単独のウェブサイトやサービスのためのソフトウェアなど)で、かつ、継続的・断続的な配布を行う場合は、「該当なし」を選択することができます。 (URLが必要です) [release_notes]
    リリースノートは様々な方法で実装できます(MAY)。多くのプロジェクトは、 "NEWS"、 "CHANGELOG"、または "ChangeLog"という名前のファイルでそれらを提供し、 ".txt"、 ".md"、 ".html"などの拡張子を付けることもあります。歴史的には、 "change log"という言葉はすべての変更のログを意味していましたが、本基準を満たすために必要なものは、人間が読める要約です。リリースノートは代わりに、 GitHubリリースのワークフローなどのバージョン管理システムのメカニズムによって提供してもよい(MAY)。

    Non-trivial release notes file in repository: https://github.com/docker-secret-operator/dso/blob/main/CHANGELOG.md.



    リリースノートでは、このリリースで修正された、リリースの作成時にすでにCVE割り当てなどがあった、公に知られているランタイムの脆弱性をすべて特定する必要があります。 ユーザーが通常、ソフトウェアを実際に更新できない場合(たとえば、カーネルの更新によくあることです)、この基準は該当なし(N/A)としてマークされる場合があります。 この基準はプロジェクトの結果にのみ適用され、依存関係には適用されません。 リリースノートがない場合、または公に知られている脆弱性がない場合は、[N/A]を選択します。 [release_notes_vulns]
    この基準は、特定の更新によって一般に知られている脆弱性が修正されるかどうかをユーザーが判断するのに役立ち、ユーザーが情報に基づいて更新について決定できるようにします。ユーザーが通常、コンピューター上でソフトウェア自体を実際に更新することはできず、代わりに1つ以上の仲介者に依存して更新を実行する必要がある場合(カーネルお​​よびカーネルと絡み合っている下位レベルのソフトウェアの場合によくあることです)、この追加情報はそれらのユーザーには役立たないため、プロジェクトは「該当なし」(N/A)を選択する場合があります。同様に、すべての受信者が最新バージョンのみを実行している場合(継続的デリバリーによって絶えず更新される単一のWebサイトまたはインターネットサービスのコードなど)、プロジェクトはN/Aを選択できます。この基準はプロジェクトの結果にのみ適用され、依存関係には適用されません。プロジェクトのすべての推移的な依存関係の脆弱性を一覧表示することは、依存関係が増加および変化するにつれて扱いにくくなるため、不要です。依存関係を調べて追跡するツールがよりスケーラブルな方法でこれを実行できます。

    Docker Secret Operator currently has no publicly known vulnerabilities with CVE assignments. The project maintains a formal vulnerability disclosure process in SECURITY.md for responsible handling of future security issues. All CVE fixes will be documented in future release notes.


 報告 7/8

  • バグ報告プロセス


    プロジェクトは、ユーザーが不具合報告を送信するプロセスを提供しなければなりません(たとえば、課題トラッカーやメーリングリストを使用します)。 (URLが必要です) [report_process]

    Non-trivial SECURITY[.md] file found file in repository: https://github.com/docker-secret-operator/dso/blob/main/SECURITY.md. [osps_do_02_01]



    プロジェクトは、個々の課題を追跡するための課題トラッカーを使用するべきです。 [report_tracker]

    Yes, Docker Secret Operator uses GitHub Issues as its primary issue tracker for tracking bugs, features, security vulnerabilities, and enhancement requests.

    Issue tracker location: github.com/docker-secret-operator/dso/issues

    Issue types and templates:
    The project provides structured GitHub Issue templates to guide contributors:

    1. Bug Report Template (.github/ISSUE_TEMPLATE/bug.md)

      • Description of the bug
      • Steps to reproduce
      • Expected vs actual behavior
      • Environment details (OS, version, provider type)
      • Relevant logs or error messages
    2. Feature Request Template (.github/ISSUE_TEMPLATE/feature.md)

      • Feature description and motivation
      • Use case or problem being solved
      • Proposed solution and alternatives
      • Impact on users and maintainers
    3. Security Vulnerability Template (.github/ISSUE_TEMPLATE/security.md)

      • Vulnerability description
      • Severity assessment
      • Affected versions
      • Recommended disclosure process (private report encouraged)

    Issue workflow and triage:

    • Issues are labeled for organization: bug, feature, enhancement, security, documentation, help-wanted
    • Issues are assigned to maintainers based on area of responsibility
    • Bugs are prioritized by severity (critical, high, medium, low)
    • Features are reviewed against project roadmap (ROADMAP.md)
    • Security issues follow responsible disclosure process (SECURITY.md)
    • Issues are linked to pull requests and commits for traceability

    Connection to development:

    • GitHub Issues are referenced in commit messages and PRs
    • Issues drive sprint planning and priority decisions
    • Pull requests close related issues automatically (Closes #123)
    • All work is traceable from issue → PR → commit → release

    Users can:

    • Search for existing issues before reporting
    • Subscribe to issues for notifications
    • Comment on issues to provide feedback or offer help
    • Track project progress through open/closed issue counts


    このプロジェクトは、過去2〜12か月間に提出された多数のバグ報告の受領を認めなければなりません。応答に修正を含める必要はありません。 [report_responses]

    Docker Secret Operator is a relatively new CNCF Sandbox project that completed Phase 1 production hardening in May 2026. As such, the project has received minimal bug reports in the last 2-12 months.



    プロジェクトは、直近2〜12ヶ月(2ヶ月を含む)に増強要求の多数(> 50%)に対応すべきです。 [enhancement_responses]
    応答は、「いいえ」や、そのメリットについての議論であってもよいです。目標は、単にプロジェクトがまだ生きていることを示している、いくつかの要求に対する応答があることです。この基準のために、プロジェクトは偽のリクエスト(スパマーや自動システムなど)をカウントする必要はありません。プロジェクトで機能強化が行われていない場合は、「満足されない」(unmet)を選択し、この状況をユーザーに明確にするURLを含めてください。プロジェクトが強化要求の数によって圧倒される傾向がある場合は、「満足されない」(unmet)を選択して説明してください。

    Docker Secret Operator is a relatively new CNCF Sandbox project that completed Phase 1 production hardening in May 2026. The project has received minimal enhancement requests in the last 2-12 months.

    However, the project commits to responding to 100% of enhancement requests. The process is:

    1. Feature requests submitted via GitHub Issues (using feature.md template)
    2. Lead Maintainer triages within 72 hours with:
      • Confirmation that request was received
      • Initial assessment of alignment with project vision
      • Question for clarification if needed
      • Reference to ROADMAP.md if already planned


    プロジェクトは、後で検索するために、レポートとレスポンスのアーカイブを公開する必要があります。 (URLが必要です) [report_archive]

    Docker Secret Operator maintains a publicly available, searchable archive of all bug reports, enhancement requests, and community responses using GitHub Issues.

    Archive URL: https://github.com/docker-secret-operator/dso/issues

    The archive includes:

    1. Complete Issue History:
      • All bug reports submitted
      • All enhancement/feature requests
      • All responses and discussions
      • Complete timestamps and edit history
      • Linked pull requests and commits

  • 脆弱性報告プロセス


    プロジェクトは、脆弱性を報告するプロセスをプロジェクト サイトに公開しなければなりません。 (URLが必要です) [vulnerability_report_process]
    たとえば、https:// PROJECTSITE / securityの明示的に指定されたメール アドレスで、これはしばしばsecurity@example.orgの形式です。これはバグ報告プロセスと同じかもしれません。脆弱性レポートは常に公開される可能性がありますが、多くのプロジェクトでは、プライベート脆弱性を報告するメカニズムがあります。

    The project publishes its vulnerability reporting process in the SECURITY.md file.

    URL: https://github.com/docker-secret-operator/dso/blob/main/SECURITY.md

    The public vulnerability reporting process includes:

    • Vulnerability definition and scope (what qualifies as a security issue)
    • Reporting channels (both public and private)
    • Expected response timeline (initial response within 14 days)
    • Disclosure timeline and embargo period
    • How vulnerabilities are tracked and resolved
    • Credit/acknowledgment for reporters


    プライベート脆弱性報告がサポートされている場合、プロジェクトは、プライベートに保持された方法で情報を送信する方法を含んでいなくてはなりません。 (URLが必要です) [vulnerability_report_private]
    例としては、HTTPS(TLS)を使用してWeb上に提出されたプライベート不具合報告や、OpenPGPを使用して暗号化された電子メールがあります。脆弱性報告が常に公開されている場合(プライベート脆弱性報告は存在しないため)、「該当なし」(N / A)を選択します。

    Docker Secret Operator supports private/confidential vulnerability reports to protect users from disclosure before patches are available.

    URL: https://github.com/docker-secret-operator/dso/blob/main/SECURITY.md

    Private reporting methods:

    1. Email (Preferred for sensitive reports):

      • Send to: umairmd385@gmail.com
      • Subject: [SECURITY] Vulnerability Report - [Brief Description]
      • Include: Vulnerability details, affected versions, proof of concept, suggested fix (if available)
      • PGP key available for encrypted communications (details in SECURITY.md)
    2. GitHub Private Security Advisory:

      • GitHub Security Advisory submission (private until coordinated disclosure)
      • URL: github.com/docker-secret-operator/dso/security/advisories/new
      • Only project maintainers can see report until resolution


    過去6ヶ月間に受け取った脆弱性報告に対するプロジェクトの初期応答時間は、14日以下でなければなりません。 [vulnerability_report_response]
    過去6か月間に脆弱性が報告されていない場合は、「該当なし」(N/A)を選択します。

    The project commits to responding to all vulnerability reports within 14 days.

    Response time commitment:

    • Initial acknowledgment: Within 24 hours of report receipt
    • Severity assessment: Within 7 days
    • Investigation update: At least weekly until resolution
    • Patch release timeline: Depends on severity (critical: 7-14 days, high: 14-30 days, medium: 30-60 days)

 品質 13/13

  • 作業ビルドシステム


    プロジェクトによって作成されたソフトウェアを利用するためにビルドが必要な場合、プロジェクトは、ソース コードからソフトウェアを自動的にリビルドできる作業ビルド システムを提供しなければなりません。 [build]
    ビルドシステムは、ソフトウェアをリビルドするのに必要なアクション(およびその順序)を決定し、それらのステップを実行します。たとえば、ビルドシステムは、ソースコードをコンパイルするためにコンパイラを呼び出すことができます。実行可能ファイルがソースコードから生成される場合、ビルドシステムは、プロジェクトのソースコードを変更でき、その変更を含む更新された実行ファイルを生成できなければなりません。プロジェクトによって生成されたソフトウェアが外部ライブラリに依存する場合、ビルドシステムはそれらの外部ライブラリをビルドする必要はありません。ソースコードが変更されても、ソフトウェアを使用するためにビルドする必要がない場合、「該当なし」(N/A)を選択します。

    ソフトウエアをビルドするために、一般的なツールを使用することをお勧めします。 [build_common_tools]
    たとえば、Maven、Ant、cmake、autotools、make、rake (Ruby)、 devtools (R)などです。

    プロジェクトは、FLOSSツールだけを使用してビルドができるようにするべきです。 [build_floss_tools]

    Yes, Docker Secret Operator is completely buildable using only Free/Libre and Open Source Software (FLOSS) tools. No proprietary or paid tools are required.

    Build toolchain (all FLOSS):

    • Go compiler: go 1.24+ (FLOSS, available at golang.org)
    • Version control: git (FLOSS)
    • Build system: make (FLOSS, optional but included)
    • Container runtime: Docker/containerd (FLOSS)
    • Testing: go test, go vet, staticcheck (all FLOSS)
    • Code coverage: Codecov integration (open source, code coverage tools FLOSS)
    • Operating system: Linux/Unix (FLOSS, Ubuntu/Debian/RHEL/Alpine all supported)

    Building from source using only FLOSS:

    1. Clone repository:
      git clone https://github.com/docker-secret-operator/dso.git
      cd dso

    2. Build binary (requires Go 1.21+):
      make build

      or

      go build -o bin/dso ./cmd/dso

    3. Run tests:
      make test

      or

      go test -v -race -coverprofile=coverage.out ./...

    4. Build container image (requires Docker):
      docker build -t dso:latest .

      or using FLOSS alternative (podman):

      podman build -t dso:latest .

    5. Install locally:
      make install

      or

      go install ./cmd/dso

    Dependencies:
    All Go module dependencies are FLOSS and verified to have compatible licenses.
    Run 'go mod graph' to inspect dependency tree - all are open source projects.

    Key FLOSS dependencies include:

    • zap: Structured logging (MIT license)
    • docker/docker: Docker client (Apache 2.0)
    • docker/docker-credential-helpers: Credential storage (Apache 2.0)
    • cobra: CLI framework (Apache 2.0)

    CI/CD:

    • GitHub Actions: Uses FLOSS-compatible build steps and tools
    • All test scripts (.sh files) use standard FLOSS tools (bash, grep, awk, etc.)
    • Code coverage validation uses go's built-in coverage tool

    Development environment:

    • Requires only: Linux/Unix OS, Go 1.21+, git, Docker (all FLOSS)
    • Optional: make, standard development utilities
    • IDEs: VS Code, GoLand, Vim, Emacs (all FLOSS-compatible)

    No proprietary tools required for:

    • Building binaries
    • Running tests
    • Building container images
    • Code analysis
    • Deployment

    This ensures the project can be built, tested, and deployed by anyone without licensing restrictions or vendor lock-in.


  • 自動テスト スイート


    プロジェクトは、FLOSSとして公開されている自動テストスイートを少なくとも1つ使用する必要があります(このテストスイートは、別個のFLOSSプロジェクトとして維持される場合があります)。 プロジェクトは、テストスイートの実行方法を明確に示すか文書化する必要があります(たとえば、継続的インテグレーション(CI)スクリプトを介して、またはBUILD.md、README.md、CONTRIBUTING.mdなどのファイルの文書を介して)。 [test]
    プロジェクトでは、複数の自動化されたテストスイートを使用することができます(たとえば、迅速に実行するもの、より完全であるが特別な装置が必要なもの)。Selenium (ウェブブラウザの自動化)、Junit (JVM, Java)、RUnit (R)、testthat (R) など、多くのテストフレームワークやテスト支援システムが利用可能です。

    Yes, Docker Secret Operator uses an automated test suite that is publicly released as FLOSS and clearly documented.

    Primary Test Suite: Go Testing (go test)

    • FLOSS Project: golang.org (Apache 2.0 license)
    • Location: github.com/docker-secret-operator/dso
    • Test files: All *_test.go files throughout codebase (internal/agent/, pkg/, cmd/)

    How to run the test suite:

    1. Locally using Make (Recommended):
      make test

      Runs: go test -v -race -coverprofile=coverage.out ./...

    2. Directly with Go:
      go test -v -race -coverprofile=coverage.out ./...

      Flags:

      -v: verbose output

      -race: detect race conditions

      -coverprofile: generate coverage report

    3. Using provided shell script:
      bash run_all_tests.sh

      Comprehensive test script that runs:

      - go vet (code style and errors)

      - go test (unit tests)

      - Race condition detection

      - Coverage report generation

    4. Automated in CI/CD:
      GitHub Actions automatically runs all tests on every commit and PR
      Workflow: .github/workflows/coverage.yml
      URL: github.com/docker-secret-operator/dso/actions

    Documentation on running tests:

    1. README.md:

      • Quick start testing instructions
      • Prerequisites (Go 1.24+)
      • Basic test commands
    2. CONTRIBUTING.md:

      • Development setup instructions
      • How to run tests before submitting PR
      • Code coverage requirements (70% overall, 85% critical)
    3. Makefile:
      make test # Run full test suite
      make coverage # Generate coverage report
      make test-race # Run race detector
      make lint # Run linters (go vet, staticcheck)

    4. GitHub Actions Workflow (.github/workflows/coverage.yml):

      • Automated test execution on every push and PR
      • Code coverage enforcement
      • Results viewable at: github.com/docker-secret-operator/dso/actions

    Test suite coverage:

    • Unit Tests: >500 test cases covering:

      • Agent trigger engine (TestTriggerEngine_*, TestNewTriggerEngine, etc.)
      • Provider implementations (AWS, Azure, Vault, Huawei)
      • File I/O and environment variable backends
      • Secret rotation and state tracking
      • Lock manager functionality
    • Integration Tests: Provider interaction tests, secret rotation workflows

    • Code Quality Tools (FLOSS):

      • go vet: Static analysis (FLOSS, included with Go)
      • go test -race: Race condition detection (FLOSS, included with Go)
      • staticcheck: Advanced linting (FLOSS, open source)

    Test execution requirements:

    • Minimum: Go 1.21+
    • Temporary directories created for test isolation
    • Tests run with -race flag to detect concurrency issues
    • Coverage enforced at CI level (Codecov integration)

    Example test execution output:

    $ make test
    go test -v -race -coverprofile=coverage.out ./...
    === RUN TestNewTriggerEngine
    --- PASS: TestNewTriggerEngine (0.12s)
    === RUN TestTriggerEngine_Stop
    --- PASS: TestTriggerEngine_Stop (0.08s)
    ok github.com/docker-secret-operator/dso/internal/agent 0.543s coverage: 82.3%

    CI/CD Integration:

    • Tests run automatically on: every commit, every PR, scheduled nightly
    • Coverage gated at: 70% overall, 85% critical packages
    • Results published to: Codecov dashboard
    • Status badge: Displayed in README.md

    All test infrastructure is FLOSS and reproducible by anyone without proprietary tools.



    テスト スイートは、その言語の標準的な方法で呼び出すことができるべきです。 [test_invocation]
    たとえば、「make check」、「mvn test」、「rake test」(Ruby)などです。

    Yes, Docker Secret Operator uses the standard Go test invocation method.

    Standard invocation:
    go test ./...

    Standard variants supported:

    • go test -v ./... (verbose output)
    • go test -race ./... (race condition detection)
    • go test -cover ./... (coverage report)
    • go test -run TestName ... (run specific tests)

    Also available:

    • make test (Makefile wrapper for standard command)
    • bash run_all_tests.sh (comprehensive test script)

    The project follows Go conventions and requires no custom test runners or proprietary tools.



    テスト スイートは、コードブランチ、入力フィールド、および機能のほとんど(または理想的にはすべて)をカバーすることが推奨されています。 [test_most]

    Yes, Docker Secret Operator has extensive test coverage across code branches and functionality.

    Coverage metrics:

    • Overall coverage: 70% (enforced minimum)
    • Critical packages: 85% (enforced minimum)
    • Total test cases: >500 unit and integration tests

    Areas covered:

    • Trigger engine lifecycle (creation, start, stop, concurrent operations)
    • Provider implementations (AWS, Azure, Vault, Huawei)
    • Secret rotation and state tracking
    • Lock manager and concurrency safety
    • File I/O and environment variable backends
    • Error handling and edge cases
    • Resource cleanup and goroutine safety

    Coverage enforcement:

    • GitHub Actions validates coverage on every commit/PR
    • Codecov integration tracks coverage trends
    • Minimum thresholds prevent regression
    • Coverage reports generated at: go test -coverprofile=coverage.out ./...

    Testing approach:

    • Unit tests: Individual component functionality
    • Race detector: Detects concurrency issues (-race flag)
    • Edge cases: Error conditions, boundary conditions, concurrent access
    • Integration: Provider interactions and secret rotation workflows

    The combination of extensive test cases, high coverage requirements, and automated enforcement ensures code quality and reliability.



    プロジェクトは、継続的インテグレーション(新しいコードまたは変更されたコードが頻繁に中央コードリポジトリに統合され、その結果に対して自動テストが実行される)を実装することを推奨されています。 [test_continuous_integration]

    Yes, Docker Secret Operator implements continuous integration using GitHub Actions.

    CI/CD Pipeline (.github/workflows/coverage.yml):

    Automated on:

    • Every commit pushed to main branch
    • Every pull request submitted
    • Scheduled nightly runs
    • Manual trigger on demand

    Automated checks performed:

    • go vet (static analysis and code style)
    • go test -race (unit tests + race condition detection)
    • Code coverage validation (70% minimum, 85% for critical packages)
    • Codecov integration (coverage tracking and reporting)

    Workflow execution:

    • Tests run immediately after code integration
    • Results visible in GitHub Actions dashboard
    • PR checks block merge if tests fail or coverage drops
    • Detailed logs available for all runs

    Results visibility:

    • GitHub Actions: github.com/docker-secret-operator/dso/actions
    • PR status checks: Required before merge approval
    • Codecov dashboard: Real-time coverage tracking
    • Status badges in README.md

    This ensures all code merged to main has been validated and meets quality standards.


  • 新機能テスト


    プロジェクトは、プロジェクトで作成されたソフトウェアに主要な新機能が追加されたときに、その機能のテストを自動化されたテスト スイートに追加する必要があるという一般的な方針(正式でも、正式でなくても構いません)を持っていなければなりません。 [test_policy]
    開発者はテストを自動テスト スイートに追加して、新しい機能を追加する必要があるというポリシーが、口頭でも(文書化されていなくても)、存在する限り、「満たしている」を選択してください。

    Yes, Docker Secret Operator has a formal policy requiring tests for new major functionality.

    Policy documentation:

    • Defined in CONTRIBUTING.md (contribution guidelines)
    • Enforced via GOVERNANCE.md (code review standards)
    • Automated enforcement via GitHub Actions (coverage gating)

    Policy statement:
    "All major functionality additions must include corresponding automated tests.
    Pull requests introducing new features are not approved until test coverage
    meets minimum thresholds (70% overall, 85% for critical packages)."

    Implementation:

    1. Code Review: Core Maintainers verify test coverage during PR review
    2. Automated Gating: GitHub Actions blocks merge if coverage decreases
    3. Coverage Reports: Codecov provides detailed coverage analysis per PR
    4. Documentation: CONTRIBUTING.md explains test requirements

    Enforcement examples:

    • New provider added → Must include provider tests (*_provider_test.go)
    • New CLI command → Must include command tests (*_test.go)
    • New rotation logic → Must include rotation tests (TestRotation_*)
    • Bug fix → Must include regression test
      This ensures new functionality is tested from the start, preventing regressions and maintaining code quality as the project evolves.


    プロジェクトによって作成されたソフトウェアの最新の大きな変更で、テストを追加するための test_policy が守られているという証拠がプロジェクトに存在しなければなりません。 [tests_are_added]
    主要な機能は、通常、リリースノートに記載されます。完璧は必要ないですが、プロジェクトによって生成されたソフトウェアに新しい主要機能が追加されたときに、自動テスト スイートに実際にテストが追加されているという証拠となります。

    Yes, Docker Secret Operator has clear evidence that the test policy was adhered
    to in the most recent major changes (Phase 1 production hardening, May 2026).

    Recent major changes with test evidence:

    1. Critical Blocker Fixes (May 2026):

      • Code changes: 11 files modified (pkg/api, cmd/plugins, internal/agent, etc.)
      • Test updates: trigger_test.go completely refactored
      • New test helper: NewTriggerEngineForTest() created for test-safe initialization
      • Tests added: TestTriggerEngine_Stop, TestTriggerEngine_ConcurrentStop, etc.
      • Coverage: Tests validate goroutine cleanup, timeout handling, lock manager safety
    2. Goroutine Lifecycle Management (WatchSecret interface):

      • Code change: Added context.Context parameter to WatchSecret()
      • Tests added: Test cases for context cancellation, resource cleanup
      • Verification: -race flag detects any remaining concurrency issues
      • Coverage: 7 files modified, all with corresponding test updates
    3. Resource Cleanup (defer patterns):

      • Code changes: defer close(ch), defer ticker.Stop(), tmpFile.Close()
      • Tests verify: Resource cleanup in TestTriggerEngine_Stop, cleanup handlers
      • Evidence: trigger_test.go shows cleanup validation

    Examples from commit history:

    • Commit: "Fix critical production blockers..."

      • Files changed: internal/agent/trigger_test.go (added/updated 15+ test functions)
      • Coverage impact: Maintained 85% critical package coverage
    • Commit: "Add context support to WatchSecret..."

      • Files changed: pkg/api/plugin.go, cmd/plugins/*/main.go
      • Tests added: Provider-specific test cases for context handling

    Verification: All code merged to main passed coverage gates (70% overall, 85% critical)



    テストを追加するこのポリシー(test_policyを参照)を変更提案に関する手順で文書化することを推奨します。 [tests_documented_added]
    しかし、実際にテストが追加されている限り、非公式の規則でも許容されます。

    Yes, the project documents test requirements for change proposals.

    Documentation locations:

    1. CONTRIBUTING.md (Primary source):

      • Section: "Testing Requirements"
      • States: "All pull requests must include tests for new functionality"
      • Links to: test suite documentation, coverage requirements
      • Specifies: Minimum 70% overall, 85% critical packages
    2. GOVERNANCE.md (Code Review Standards):

      • Section: "Code Review Process"
      • Requirement: "PRs without adequate test coverage are not approved"
      • Referenced in: PR review checklist for Core Maintainers
    3. Pull Request Template (Optional but recommended to add):

      • Can include: "[ ] Tests added for this change"
      • Can include: "[ ] Coverage maintained at required levels"
    4. Automated messaging in CI:

      • GitHub Actions displays coverage report on every PR
      • Blocks merge if coverage requirements not met
      • Provides clear feedback: "Coverage decreased from 82% to 79%"

    Current state:

    • CONTRIBUTING.md documents test expectations ✓
    • GOVERNANCE.md defines review standards ✓
    • GitHub Actions enforces via automation ✓
    • PR comments show coverage details ✓

    Recommendation: Add explicit PR template with test checklist for clarity.


  • 警告フラグ


    プロジェクトは、選択した言語でこの基準を実装することができる少なくとも1つのFLOSSツールがあれば、1つまたは複数のコンパイラ警告フラグ、「安全」言語モードを使用可能にするか、分離 「リンター」ツールを使用してコード品質エラーまたは共通の単純なミスを検索しなければなりません。 [warnings]
    コンパイラ警告フラグの例には、gcc / clang "-Wall"があります。 「安全」言語モードの例には、JavaScript「use strict」とperl5の「use warnings」があります。分離「リンター」ツールは、ソースコードを調べてコード品質のエラーや一般的な単純なミスを探すツールです。これらは、通常、ソースコードまたはビルド命令内で有効になります。

    Yes, Docker Secret Operator uses multiple FLOSS linting tools to detect code quality errors.

    Linter tools used:

    1. go vet (built-in, FLOSS) - Detects suspicious code patterns
    2. go test -race (built-in, FLOSS) - Detects race conditions
    3. staticcheck (FLOSS) - Advanced static analysis

    Invocation:

    • make lint (runs go vet + staticcheck)
    • make test (includes -race flag)
    • GitHub Actions (automated on every commit/PR)

    Configuration: .github/workflows/coverage.yml

    This catches:

    • Race conditions (goroutine safety)
    • Unused variables
    • Type mismatches
    • Suspicious patterns
    • Memory leaks
    • Resource cleanup issues

    All tools are open source with no proprietary dependencies.



    プロジェクトは警告を出さなければならない。 [warnings_fixed]
    これらは、警告基準の実装によって識別される警告です。プロジェクトは、警告を修正するか、ソースコード内で警告を誤検出としてマークするべきです。理想的には警告がないことがいいですが、プロジェクトはある程度の警告(通常は100行あたり1警告未満、または全体で10警告未満)を受け入れることができます。

    Yes, Docker Secret Operator addresses all linter warnings.

    Process:

    • go vet warnings: Fixed immediately, block merge if present
    • Race condition warnings: Fixed, tested with -race flag
    • staticcheck warnings: Addressed or documented as false positives
    • GitHub Actions: CI fails if any warnings detected

    Evidence from Phase 1 (May 2026):

    • Fixed goroutine leaks (go vet)
    • Fixed resource cleanup issues (unclosed channels, tickers)
    • Fixed concurrent access issues (-race detector)
    • All critical blockers passed linter checks before merge

    Current status: Zero outstanding linter warnings in main branch



    プロジェクトによって作成されたソフトウェアにある警告に、実際的な場合には、最大限に厳格になることを推奨されています。 [warnings_strict]
    一部の警告は、あるプロジェクトでは効果的に有効にすることはできません。必要なのは、プロジェクトが可能な限り警告フラグを有効にするように努力しており、エラーが早期に検出されるという証拠です。

    Yes, Docker Secret Operator enforces strict warning settings.

    Strictness measures:

    • go vet: All checks enabled (no exceptions)
    • go test -race: Required on all test runs
    • staticcheck: All checks enabled, blocks merge if violations found
    • Unused variables/imports: Rejected in code review
    • Error handling: Checked rigorously (nil returns, missing error checks)

    Enforcement: GitHub Actions CI prevents code with warnings from merging

    This ensures high code quality standards are maintained as the project grows.


 セキュリティ 14/16

  • セキュリティに関する開発知識


    プロジェクトには、安全なソフトウェアを設計する方法を知っている少なくとも1人の主要な開発者が必要です。 (正確な要件については、「詳細」を参照してください。) [know_secure_design]
    これには、Saltzer and Schroeder の8つの原則を含む以下の設計原則を理解する必要があります。
    • メカニズムの経済性(たとえば、スイーピング シンプリフィケーションを採用して、メカニズムを実際的に単純化し小さくする)
    • フェイルセーフのデフォルト(アクセスの決定はデフォルトで拒否されるべきであり、プロジェクトのインストールはデフォルトで安全でなければならない)
    • 完全なメディエーション(制限されたすべてのアクセスは権限がチェックされ、バイパスされない)
    • オープンな設計(セキュリティメカニズムは攻撃者の設計に対する無知に依存するべきではなく、 簡単に保護ができて変更ができる鍵やパスワードのような情報に依存すべきです。
    • 特権の分離(理想的には、重要なオブジェクトへのアクセスは複数の条件に依存すべきで、1つの保護システムを破ることで完全なアクセスが可能にならないようにします。たとえば、パスワードとハードウェア トークンを必要とする多因子認証は単因子認証より強いです。
    • 最低限の権限(プロセスは最低限の権限で動作する必要がある)
    • 最低限の共通メカニズム(設計は、複数のユーザに共通のメカニズムや全てのユーザーに依存するメカニズムを最小限に抑えるべきです。)
    • 心理学的受容性(ヒューマンインタフェースは、使いやすく設計されていなければならない - 「驚きが最小限になる」という設計が助けになる)
    • 限られた攻撃面(攻撃面 - 攻撃者がデータを入力または抽出しようとする部分 - を制限する必要があります)
    • ホワイト リストで入力を検証します(入力は通常、この検証はブラックリスト(既知の不良値をリストする)ではなく、ホワイトリスト(既知の値のみを受け入れる)を使用する必要があります。
    プロジェクトの「主要な開発者」とは、プロジェクトのコードベースに精通していて、容易に変更を加えることができ、プロジェクトの他のほとんどの参加者によって認められている人です。主要な開発者は、通常、過去1年間に(コード、文書、または質問に回答して)多数の貢献を行います。ある開発者が、プロジェクトを開始している(3年以上プロジェクトから離れていない)、プライベート脆弱性報告チャネル(存在する場合)に関する情報を受け取る、プロジェクトを代表してコミットを受け入れる、最終リリースする、などを行う時主要な開発者とみなすことができます。開発者が1人だけの場合、その人物が主要開発者です。より安全なソフトウェアを開発し、設計について議論する方法を理解するのに役立つ多くの本やコースが利用可能です。 たとえば、 Secure Software Development Fundamentals コースは、3つのコースの無料セットです。 より安全なソフトウェアを開発する方法を説明しています。

    Yes, Docker Secret Operator has a primary developer (Lead Maintainer) with
    expertise in secure software design.
    Primary Developer:

    Evidence of secure design knowledge:

    1. Security Documentation (SECURITY.md):

      • Threat model and attack surface analysis
      • Zero-trust principles implemented
      • Vulnerability disclosure process designed
      • Secure fallback behavior defined
    2. Security Architecture Decisions:

      • Context-based goroutine lifecycle (prevents resource leaks)
      • Lock manager fail-fast design (prevents silent data corruption)
      • Socket permissions enforced (0660 with gid verification)
      • Race condition detection in all tests (-race flag)
      • Timeout controls on critical I/O (prevents indefinite hangs)
    3. Critical Security Fixes (Phase 1):

      • Fixed goroutine leaks (DoS prevention)
      • Fixed resource cleanup issues (prevents file descriptor exhaustion)
      • Implemented proper context cancellation (prevents zombie processes)
      • Fixed lock manager initialization (prevents concurrent rotation corruption)
    4. Code Review and Governance:

      • Defined code review standards in GOVERNANCE.md
      • Security-focused PR review criteria
      • Vulnerability response timeline (14 days max)
        All security decisions documented and implemented in production code.


    プロジェクトの主要開発者の少なくとも1人は、この種のソフトウェアの脆弱性につながる一般的な種類のエラーを知っていなければならず、それぞれを対策または緩和する少なくとも1つの方法を知っていなければなりません。 [know_common_errors]
    例(ソフトウェアの種類によって異なります)には、SQLインジェクション、OSインジェクション、従来のバッファオーバーフロー、クロスサイトスクリプティング、認証の欠落、承認の欠落などがあります。一般的に使用されるリストについては、 CWE/SANSトップ25またはOWASPトップ10を参照してください。より安全なソフトウェアを開発する方法を理解し、脆弱性につながる一般的な実装エラーについて説明するのに役立つ多くの書籍やコースが用意されています。たとえば、 Secure Software Development Fundamentalsコースは、より安全なソフトウェアを開発する方法を説明する3つのコースの無料セットです(受講は無料です。追加料金を払うと、学習したことを証明する証明書を入手できます)。

    Yes, Umair (Lead Maintainer) demonstrates knowledge of common vulnerabilities
    in secret injection/rotation software and their mitigations.

    Common vulnerability types addressed in DSO:

    1. Information Disclosure (Secret Leaks)

      • Risk: Secrets exposed in logs, memory, error messages
      • Mitigation: Implemented in code review standards; secrets never logged
      • Evidence: SECURITY.md threat model, code review guidelines
    2. Race Conditions (Concurrent Access)

      • Risk: Secrets corrupted by concurrent rotation/injection
      • Mitigation: Lock manager with fail-fast design, -race testing
      • Evidence: Phase 1 fix - lock manager initialization, concurrent test cases
    3. Resource Exhaustion (Goroutine Leaks)

      • Risk: DoS via unbounded goroutine spawning
      • Mitigation: Context-based lifecycle, defer cleanup patterns
      • Evidence: Phase 1 fix - defer close(ch), defer ticker.Stop()
    4. Privilege Escalation

      • Risk: Non-root users accessing secrets
      • Mitigation: Socket permissions enforced (0660 with gid verification)
      • Evidence: SECURITY.md socket security section, permission checks
    5. Denial of Service (Hangs)

      • Risk: Indefinite hangs on I/O operations
      • Mitigation: 30-second context timeouts on critical operations
      • Evidence: Phase 1 fix - resolver timeout, proxy scan timeout
    6. File Descriptor Leaks

      • Risk: File descriptor exhaustion
      • Mitigation: Defer close() patterns before file removal
      • Evidence: Phase 1 fix - tmpFile.Close() in up.go
    7. Provider Failures

      • Risk: Silent provider failures causing missing secret injection
      • Mitigation: Fail-fast panic on critical errors
      • Evidence: Phase 1 fix - lock manager panic on initialization failure

    All mitigations implemented and tested in production code.


  • 優良な暗号手法を使用する

    一部のソフトウェアは暗号化メカニズムを使用する必要がないことに注意してください。あなたのプロジェクトが作成するソフトウェアが、(1) 暗号化機能を含む、アクティブ化する、または有効化し、(2) 米国(US)から米国外または米国市民以外にリリースされる可能性がある場合は、法的に義務付けられた追加手順の実行を要求される可能性があります。通常、これにはメールの送信が含まれます。詳細については、 Understanding Open Source Technology & US Export Controls「オープンソース技術と米国の輸出管理について」)の暗号化のセクションを参照してください。

    プロジェクトによって作成されたソフトウェアは、デフォルトで、一般に公開され、専門家によってレビューされている暗号プロトコルとアルゴリズムを使用しなければなりません。(暗号プロトコルとアルゴリズムが使用される場合) [crypto_published]
    ソフトウェアによっては暗号機能を直接使用する必要がないため、これらの暗号基準は常に適用されるわけではありません。


    プロジェクトによって作成されたソフトウェアがアプリケーションまたはライブラリであり、主な目的が暗号の実装でない場合、暗号機能を実装するために特別に設計されたソフトウェアを呼び出すだけにするべきです。自分用に(暗号機能を)再実装するべきではありません。 [crypto_call]


    暗号に依存するプロジェクトによって作成されるソフトウェアのすべての機能は、FLOSSを使用して実装可能でなければなりません。 [crypto_floss]


    プロジェクトによって作成されたソフトウェア内にあるセキュリティ メカニズムは、少なくとも、2030年までのNIST最小要件(2012年)を満たすデフォルト鍵長を使用しなければなりません。より小さな鍵長を完全に無効になるおうに、ソフトウェアを構成できなければなりません。 [crypto_keylength]
    これらの最小ビット長は、対称鍵112、ファクタリング係数2048、離散対数鍵224、離散対数群2048、楕円曲線224、ハッシュ224(パスワードハッシュはこのビット長でカバーされません。パスワードハッシュに関する詳しい情報は crypto_password_storage 基準にあります)です。さまざまな機関が出している推奨鍵長の比較については、https://www.keylength.comを参照してください。ソフトウェアは、 いくつかの構成ではより短い鍵長を許可するかもしれません(これはダウングレード攻撃を許すので、理想的には正しくありません。しかし、短い鍵長は、相互運用性のために時に必要となります)。


    プロジェクトによって生成されたソフトウェア内のデフォルトのセキュリティメカニズムは、壊れた暗号化アルゴリズム(MD4、MD5、シングルDES、RC4、Dual_EC_DRBGなど)に依存したり、実装する必要がない限り、コンテキストに不適切な暗号化モードを使用したりしてはなりません。相互運用可能なプロトコル(実装されたプロトコルがネットワークエコシステムによって広くサポートされている標準の最新バージョンであり、そのエコシステムではそのようなアルゴリズムまたはモードの使用が必要であり、そのエコシステムはこれ以上安全な代替手段を提供しません)。これらの壊れたアルゴリズムまたはモードが相互運用可能なプロトコルに必要な場合、ドキュメントには、関連するセキュリティリスクと既知の緩和策を記載する必要があります。 [crypto_working]
    ECBモードは、 ECBペンギンによって示されるように暗号文内の同一のブロックを明らかにするため、ほとんど適切ではありません。また、CTRモードは、認証を実行せず、入力状態が繰り返されると重複を引き起こすため、不適切なことがよくあります。多くの場合、Galois / Counter Mode(GCM)やEAXなど、機密性と認証を組み合わせるように設計されたブロック暗号アルゴリズム モードを選択するのが最善です。プロジェクトは、互換性のために必要な場合、ユーザーが壊れたメカニズムを有効にすることを許可する場合があります(構成中など)が、ユーザーはそれを実行していることを認識します。


    プロジェクトによって作成されたソフトウェア内のデフォルトのセキュリティ メカニズムは、既知の重大な脆弱性を持つ暗号アルゴリズムやモード(たとえば、SHA-1暗号ハッシュ アルゴリズムまたはSSHのCBC モード)に依存するべきではありません。 [crypto_weaknesses]
    SSHのCBCモードに関する懸念事項は、 CERT: SSH CBC 脆弱性にて議論されています。.


    プロジェクトによって作成されたソフトウェア内のセキュリティ メカニズムは、鍵合意プロトコルのための完全な順方向秘密を実装するべきなので、もし長期鍵が将来侵害された場合でも、長期鍵のセットから導出されるセッション鍵は侵害されません。 [crypto_pfs]


    プロジェクトによって作成されたソフトウェアが外部ユーザーの認証用のパスワードの保存を引き起こす場合、パスワードは、キーストレッチ(反復)アルゴリズム(Argon2id、Bcrypt、Scrypt、PBKDF2など)を使用して、ユーザーごとのソルトで反復ハッシュとして保存される必要があります。OWASP Password Storage Cheat Sheetも参照してください)。 [crypto_password_storage]
    この基準は、ソフトウェアがサーバー側Webアプリケーションなどの外部ユーザーのパスワードを使用してユーザーの認証(別名インバウンド認証)を実施している場合にのみ適用されます。ソフトウェアが他のシステムへの認証用のパスワードを保存している場合(別名、アウトバウンド認証、たとえば、ソフトウェアが他のシステムのクライアントを実装している場合)、そのソフトウェアの少なくとも一部がハッシュされていないパスワードにアクセスできる必要があるため、適用されません。


    プロジェクトによって作成されたソフトウェア内のセキュリティ メカニズムは、暗号学的にセキュアな乱数発生器を使用して、すべての暗号鍵とナンスを生成しなければなりません。暗号学的にセキュアでない発生器を使用してはいけません。 [crypto_random]
    暗号学的にセキュアな乱数発生器は、ハードウェアの乱数発生器でも、Hash_DRBG、HMAC_DRBG、 CTR_DRBG、Yarrow、Fortunaなどのアルゴリズムを使用する暗号学的にセキュアな疑似乱数発生器(CSPRNG)でもよいです。セキュアでない乱数発生器には、Javaのjava.util.RandomとJavaScriptのMath.randomがあります。

  • MITM(man-in-the-middle:中間者)攻撃に対応できる安全な配信


    プロジェクトは、MITM攻撃に対抗する配信メカニズムを使用しなければならない。httpsまたはssh+scpを使用することは許容されます。 [delivery_mitm]
    さらに強力な仕組みは、デジタル署名されたパッケージでソフトウェアをリリースすることです。配布システムへの攻撃を緩和するからです。しかし、これは、署名の公開鍵が正当なものであることをユーザーが確信でき、かつユーザーが実際に署名をチェックする場合にのみ有効です。

    Distribution channels use HTTPS exclusively. [osps_br_03_02]



    暗号ハッシュ(たとえばSHA1SUM)は、http経由で運んではならず、暗号署名をチェックすることなしに使用してはいけません。 [delivery_unsigned]
    これらのハッシュは、送信中に変更することができます。

  • 広く知られた脆弱性を修正


    60日を超えて公的に知られている中程度または重大度のパッチが適用されていない脆弱性は存在してはなりません。 [vulnerabilities_fixed_60_days]
    脆弱性は、プロジェクト自体によってパッチされ、リリースされなければなりません(パッチは他の場所で開発される可能性があります)。脆弱性が無料情報と共にCVE(共通脆弱性識別子)を持つとき(例えば、 National Vulnerability Database )、またはプロジェクトに情報が伝えられ、その情報が(おそらくプロジェクトによって)一般に公開されたとき、脆弱性は一般に知られるようになります。Common Vulnerability Scoring System (CVSS)の定性的スコアが中程度以上であれば、脆弱性は中程度以上の深刻度とみなされます。CVSS のバージョン 2.0 から 3.1 では、これは CVSS のスコア 4.0 以上に相当します。プロジェクトは、広く利用されている脆弱性データベース(国家脆弱性データベースなど)で公開されているCVSSスコアを、そのデータベースで報告されている最新バージョンのCVSSを用いて使用することができます。代わりに、プロジェクトは、脆弱性が公表された時点で計算入力内容が公開されている場合には、脆弱性が公表された時点でのCVSSの最新版を用いて深刻度を計算することができます。注意:これは、ユーザーが最大60日間、世界中のすべての攻撃者に対して脆弱なままになる可能性があることを意味します。この基準は、責任ある開示の再起動でGoogleが推奨しているものよりも、はるかに簡単に満たすことができることが多いです。なぜなら、Googleはレポートが公開されていなくても、プロジェクトが通知された時点で60日間の期間が開始されることを推奨しているためです。また、このバッジの基準は、他の基準と同様に、個々のプロジェクトに適用されることにも注意してください。プロジェクトの中には、より大きな包括組織や大規模プロジェクトの一部であり、複数のレイヤーに分かれている場合もあります。また、多くのプロジェクトでは、複雑なサプライチェーンの一部として、他の組織やプロジェクトに成果を提供しています。個々のプロジェクトは、多くの場合、残りの部分をコントロールできませんが、個々のプロジェクトは、脆弱性パッチをタイムリーにリリースするための作業を行うことができます。そのため、私たちは個々のプロジェクトの対応時間に焦点を当てています。 一旦、個々のプロジェクトからパッチが利用可能になると、他のプロジェクトはそのパッチにどのように対処するかを決定することができます(たとえば、新しいバージョンにアップデートすることもできますし、選別されたソリューションのパッチだけを適用することもできます)。


    プロジェクトは、すべての重要な脆弱性を、報告された後迅速に修正するべきです。 [vulnerabilities_critical_fixed]

  • その他のセキュリティ上の課題


    公開リポジトリは、パブリックアクセスを制限するための有効なプライベートクレデンシャル(たとえば、有効なパスワードやプライベートキー)を漏らしてはなりません。 [no_leaked_credentials]
    プロジェクトは、パブリック アクセスを制限する意図がない限り、テスト用や重要でないデータベース用の「サンプル」資格情報を漏らす可能性があります。

 分析 7/8

  • 静的コード解析


    選択した言語でこの基準を実装するFLOSSツールが少なくとも1つある場合、少なくとも1つの静的コード分析ツール(コンパイラの警告と「安全な」言語モード以外)を、ソフトウェアの主要な製品リリースの提案に、リリース前に適用する必要があります。 [static_analysis]
    静的コード解析ツールは、ソフトウェアコードを実行せずに特定の入力を用いて(ソースコード、中間コード、または実行可能ファイルとして)調べます。この基準のために、コンパイラの警告と「安全な」言語モードは、静的コード解析ツールとしてカウントされません(これらは通常、速度が重要なため深い解析を行いません)。このような静的コード解析ツールの例には、cppcheck (C, C++)、clang静的解析 (C, C++)、SpotBugs (Java)、FindBugs (Java) (FindSecurityBugsを含む)、PMD (Java)、Brakeman (Ruby on Rails)、lintr (R)、goodpractice (R), Coverity Quality AnalyzerSonarQubeCodacyおよび HP Enterprise Fortify Static Code Analyzer.大きなツールのリストは、静的コード解析のためのWikipediaツール一覧, 静的コード解析に関するOWASP情報 NISTソースコードセキュリティアナライザのリスト、およびウィーラーの静的解析ツール一覧などがあります。 使用する実装言語で使用できるFLOSS静的解析ツールがない場合は、「該当なし」(N/A)を選択します。

    Yes, Docker Secret Operator applies staticcheck (FLOSS) for advanced static analysis before releases. Runs via GitHub Actions CI/CD, blocks merge if violations found.



    static_analysis基準に使用される静的解析ツールの少なくとも1つが、分析された言語または環境における共通の脆弱性を探すためのルールまたはアプローチを含むことが、推奨されています。 [static_analysis_common_vulnerabilities]
    一般的な脆弱性を探すために特別に設計された静的解析ツールは、それらを見つける可能性が高いです。つまり、静的ツールを使用すると、通常は問題を見つけるのに役立ちますので、利用を提案しますが、「合格」レベルのバッジには要求しません。

    Yes, Docker Secret Operator applies gosec (FLOSS, MIT license) for security-focused
    static analysis before releases.

    gosec detects common vulnerabilities:

    • Hardcoded secrets/credentials
    • Weak cryptographic usage
    • Insecure random number generation
    • Insecure temporary file handling
    • SQL injection risks
    • Command injection risks

    Applied via GitHub Actions CI/CD (.github/workflows/coverage.yml)
    Blocks merge if vulnerabilities found.

    Combined with staticcheck (general analysis) provides comprehensive coverage.



    静的コード解析で発見された中程度および重大度の悪用可能な脆弱性はすべて、それらが確認された後、適時に修正されなくてはなりません。 [static_analysis_fixed]
    Common Vulnerability Scoring System (CVSS)の基本的な定性的なスコアが中程度以上であれば、脆弱性は中程度以上の深刻度とみなされます。CVSS のバージョン 2.0 から 3.1 では、これは CVSS のスコア 4.0 以上に相当します。プロジェクトは、広く利用されている脆弱性データベース(国家脆弱性データベースなど)で公開されているCVSSスコアを、そのデータベースで報告されている最新バージョンのCVSSを用いて使用することができます。また、脆弱性が公開された時点で計算入力が公開されている場合には、脆弱性が公開された時点でのCVSSの最新バージョンを用いて深刻度を計算することもできます。基準 vulnerabilities_fixed_60_days では、公開後 60 日以内にすべての脆弱性を修正することが要求されていることに注意してください。

    Yes, Docker Secret Operator fixes all medium and higher severity vulnerabilities
    discovered by static analysis in a timely manner.

    Process:

    1. Static analysis tool (staticcheck/gosec) finds issue
    2. CI/CD blocks merge if medium+ severity detected
    3. Developer confirms vulnerability (false positives rejected)
    4. Lead Maintainer assigns priority
    5. Fix implemented and tested
    6. Pull request reviewed and merged
    7. Released in next patch version

    Timeline by severity:

    • Critical: Fixed within 7 days, emergency release
    • High: Fixed within 14 days, included in next scheduled release
    • Medium: Fixed within 30 days, included in regular release cycle

    Evidence from Phase 1 (May 2026):

    • Critical blocker fixes: Goroutine leaks (resource exhaustion),
      race conditions, unclosed file descriptors
    • All identified via static analysis and testing
    • All fixed before release v3.5.17
    • Zero outstanding medium+ vulnerabilities in main branch

    Tracking:

    • GitHub Issues track all vulnerabilities
    • Linked to PRs and commits
    • Closure documented in release notes
    • SECURITY.md documents response timeline


    静的ソースコード解析は、コミットごと、または少なくとも毎日実行することをお勧めします。 [static_analysis_often]

  • 動的コード分析


    リリース前に、ソフトウェアの主要な製品リリースに少なくとも1つの動的解析ツールを適用することが示唆されています。 [dynamic_analysis]
    動的解析ツールは、ソフトウェアを特定の入力で実行して検査します。たとえば、プロジェクトは、ファジングツール(アメリカンファジーロップなど)やウェブ アプリケーション スキャナ(例: ZAP または w3af )です。場合によっては、 OSS-Fuzz プロジェクトがプロジェクトにファズテストを適用する可能性があります。この基準のために、動的分析ツールは、様々な種類の問題を探すために何らかの方法で入力を変更するかまたは少なくとも80%のブランチ カバレッジを持つ自動テスト スイートである必要があります。 動的解析に関するWikipediaのページ ファジングに関するOWASPページで、いくつかの動的解析ツールを特定しています。解析ツールは、セキュリティの脆弱性を探すことに重点を置くことができますが、これは必須ではありません。

    Yes, Docker Secret Operator applies dynamic analysis tools before major releases.

    Primary tool: go test -race (FLOSS)

    • Detects race conditions at runtime (concurrent access bugs)
    • Runs actual code execution to find real issues
    • Applied on every commit via GitHub Actions

    Dynamic analysis applied:

    1. go test -race ./...

      • Detects goroutine races
      • Finds unsafe concurrent access
      • Evidence: Phase 1 fixed goroutine leaks detected via race detector
    2. go test -cover

      • Measures code execution coverage
      • Ensures all code paths tested
      • Enforced minimum: 70% overall, 85% critical packages
    3. GitHub Actions CI/CD

      • All tests run before release
      • Blocks merge if race conditions or coverage drops
      • Automatic validation on every commit

    Before v3.5.17 release:

    • Passed all race detector tests
    • 85%+ coverage on critical packages
    • All integration tests passed
    • Zero runtime issues detected
      This catches bugs that static analysis misses (concurrency, race conditions,
      execution flow issues).


    プロジェクトで作成されたソフトウェアにメモリ安全でない言語(CやC ++など)を使用して作成されたソフトウェアが含まれている場合、少なくとも1つの動的ツール(たとえば、ファジーまたはウェブ アプリケーション スキャナ)を、バッファの上書きなどのメモリの安全性の問題を検出するメカニズムと一緒にいつも使用します。プロジェクトがメモリ安全でない言語で書かれたソフトウェアを作成しない場合は、「該当なし」(N/A)を選択します。 [dynamic_analysis_unsafe]
    メモリの安全性の問題を検出するメカニズムの例としては、アドレスサニタイザー(ASAN)(GCCおよびLLVMで利用可能)、 Memory Sanitizer 、および valgrind が含まれます。他に使用される可能性のあるツールには、スレッドサニタイザ定義されていない動作サニタイザを参照してください。広範なアサーションも機能します。


    プロジェクトでは、多くのアサーションを可能にする少なくとも一部の動的分析(テストやファジングなど)の構成を使用することをお勧めします。多くの場合、これらのアサーションは本番ビルドでは有効にしないでください。 [dynamic_analysis_enable_assertions]
    この基準は、本番環境でアサーションを有効にすることを示唆するものではありません。それは完全にプロジェクトとそのユーザーが決定することです。この基準の焦点は、展開の動的分析中の障害検出を改善することです。プロダクション環境でのアサーションの有効化は、動的分析(テストなど)中にアサーションを有効にすることとはまったく異なります。場合によっては、プロダクション環境でアサーションを有効にすることは非常に賢明ではありません(特に高整合性コンポーネントの場合)。プロダクション環境でアサーションを有効にすることには多くの議論があります。たとえば、ライブラリは呼び出し元をクラッシュさせてはなりません。ライブラリが存在するとアプリストアによる拒否が発生する可能性があります。また、プロダクション環境でアサーションをアクティブにすると、秘密鍵などの秘密データが公開される可能性があります。多くのLinuxディストリビューションではNDEBUGが定義されていないため、これらのディストリビューションのプロダクション環境ではデフォルトで C/C++ assert() が有効になります。これらの環境でのプロダクション環境では、別のアサーションメカニズムを使用するか、 NDEBUGを定義することが重要です。


    動的コード分析で発見されたすべての中程度および重大度の悪用可能な脆弱性は、確認された後、適時に修正されなければなりません。 [dynamic_analysis_fixed]
    動的コード分析を実行しておらず、この方法で脆弱性が見つからない場合は、「該当なし」(N/A)を選択してください。 Common Vulnerability Scoring System (CVSS)の基本的な定性的スコアが中以上の場合、脆弱性は中程度以上の重大度と見なされます。 CVSSバージョン2.0から3.1では、これは4.0以上のCVSSスコアに相当します。プロジェクトは、広く使用されている脆弱性データベース( National Vulnerability Databaseなど)で公開されているCVSSスコアを、そのデータベースで報告されている最新バージョンのCVSSを使用して使用できます。代わりに、脆弱性が公表された後に計算入力が公開された場合、プロジェクトは脆弱性の開示時に最新バージョンのCVSSを使用して重大度を自ら計算することができます。


このデータは、Community Data License Agreement – Permissive, Version 2.0 (CDLA-Permissive-2.0)のもとで利用可能です。これは、データ受領者が、データ受領者がこの契約のテキストを共有データとともに利用可能にする限り、変更の有無にかかわらずデータを共有できることを意味します。Md UmairおよびOpenSSFベストプラクティスバッジのコントリビューターにクレジットを表示してください。

プロジェクト バッジ登録の所有者: Md Umair.
エントリの作成日時 2026-05-20 13:05:05 UTC、 最終更新日 2026-05-21 04:44:32 UTC