OSS-RISK-6 追跡されていない依存関係 (Untracked Dependencies)
説明:
プロジェクト開発者はコンポーネントへの依存関係を全く認識していない可能性があります。たとえば、アップストリームコンポーネントの SBOM の一部ではない、SCA ツールが実行されていないか検出されていない、依存関係がパッケージマネージャを使用して確立されていない、などの理由です。
誰も認識していないため、それぞれのコンポーネントに何か他の欠陥がないかチェックしたり監視することはできません。
事例:
アップストリームコンポーネントとして受け取ったり、SCA ツールによって生成された不完全な SBOM
管理された (追跡された) 依存関係にサードパーティのコードの包含。例を以下に示します。
コードスニペット
ソースコードファイル (依存関係のソースにそのままコピーされ、"vendored" とも呼ばれます)
コンパイルされたコード (プラットフォーム固有のバイナリや、Java アーカイブ/クラスファイル、rebundling とも呼ばれます)
PIP や Maven などのパッケージマネージャのマニフェストファイルを通じて確立されていない依存関係。たとえば、brew や apt-get を通じて手動またはスクリプトでインストールしています。
IDE プラグイン、ビルドスクリプト、テスト依存関係、その他の開発者ツールは、依存ソフトウェア自体には含まれていませんが、依然としてセキュリティと運用上のリスクをもたらします。
対応:
粗い粒度レベル (Maven や npm などのパッケージマネジメントツールの助けを借りて宣言された依存関係など) と細かい粒度レベル (「帯域外」つまりパッケージマネージャを使用せずに含まれる単一ファイルなどのアーティファクトなど) の両方で、正確な部品表を作成する機能に関して SCA ツールを評価及び比較します。
参照:
OWASP Software Component Versification Standard (SCVS) V1 Inventory and V2 Software Bills of Materials
rebundling の研究
Seth Larson: Patching the libwebp vulnerability across the Python ecosystem (2023)
A Dann, et al.: Identifying Challenges for OSS Vulnerability Scanners - A Study & Test Suite (2021)
Anand Sawant: Dependency Resolution in Python: Beware The Phantom Dependency (2023)
Last updated