製品・ソフトウェアに関する情報
Snorkel AI, Inc.のSnorkelにおける信頼できないデータのデシリアライゼーションに関する脆弱性
Title Snorkel AI, Inc.のSnorkelにおける信頼できないデータのデシリアライゼーションに関する脆弱性
Summary

snorkelライブラリのv0.10.0までには、TrainerクラスのTrainer.load()メソッドにおいて、安全でない逆シリアル化の脆弱性(CWE-502)が存在しています。このメソッドはtorch.load()を使用してモデルのチェックポイントファイルを読み込みますが、セキュリティを強化するためのweights_only=Trueパラメータを有効にしていません。このデフォルトの動作により、Pickleモジュールを介して任意のPythonオブジェクトの逆シリアル化が許可されてしまいます。リモートの攻撃者は、マルウェアが仕込まれたモデルファイルを提供することで、この脆弱なメソッドでファイルが読み込まれた際に任意のコードを実行させる攻撃を行うことが可能です。

Possible impacts 当該ソフトウェアが扱う全ての情報が外部に漏れる可能性があります。 また、当該ソフトウェアが扱う全ての情報が書き換えられる可能性があります。 さらに、当該ソフトウェアが完全に停止する可能性があります。 そして、この脆弱性を悪用した攻撃の影響は、他のソフトウェアには及びません。 
Solution

正式な対策が公開されています。ベンダ情報を参照して適切な対策を実施してください。

Publication Date May 12, 2026, midnight
Registration Date May 15, 2026, 10:54 a.m.
Last Update May 15, 2026, 10:54 a.m.
CVSS3.0 : 重要
Score 8.8
Vector CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:U/C:H/I:H/A:H
Affected System
Snorkel AI, Inc.
Snorkel 0.10.0 およびそれ以前
CVE (情報セキュリティ 共通脆弱性識別子)
CWE (共通脆弱性タイプ一覧)
その他
Change Log
No Changed Details Date of change
1 [2026年05月15日]
  掲載
May 15, 2026, 10:54 a.m.

NVD Vulnerability Information
CVE-2026-31222
Summary

The snorkel library thru v0.10.0 contains an insecure deserialization vulnerability (CWE-502) in the Trainer.load() method of the Trainer class. The method loads model checkpoint files using torch.load() without enabling the security-restrictive weights_only=True parameter. This default behavior allows the deserialization of arbitrary Python objects via the Pickle module. A remote attacker can exploit this by providing a maliciously crafted model file, leading to arbitrary code execution on the victim's system when the file is loaded via the vulnerable method.

Publication Date May 13, 2026, 1:16 a.m.
Registration Date May 13, 2026, 4:12 a.m.
Last Update May 14, 2026, 12:47 a.m.
Affected software configurations
Configuration1 or higher or less more than less than
cpe:2.3:a:snorkel:snorkel:*:*:*:*:*:*:*:* 0.10.0
Related information, measures and tools
Common Vulnerabilities List