@blamejs/exceptd-skills 0.13.106 → 0.13.107
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +4 -0
- package/data/_indexes/_meta.json +9 -9
- package/data/_indexes/activity-feed.json +2 -2
- package/data/_indexes/catalog-summaries.json +2 -2
- package/data/_indexes/chains.json +816 -0
- package/data/atlas-ttps.json +6 -0
- package/data/attack-techniques.json +6 -0
- package/data/cve-catalog.json +212 -0
- package/data/cwe-catalog.json +2 -0
- package/data/framework-control-gaps.json +18 -0
- package/data/zeroday-lessons.json +100 -0
- package/manifest.json +44 -44
- package/package.json +2 -2
- package/sbom.cdx.json +25 -25
package/data/atlas-ttps.json
CHANGED
|
@@ -152,6 +152,8 @@
|
|
|
152
152
|
"CVE-2024-24590",
|
|
153
153
|
"CVE-2024-24591",
|
|
154
154
|
"CVE-2024-37032",
|
|
155
|
+
"CVE-2024-37052",
|
|
156
|
+
"CVE-2024-37060",
|
|
155
157
|
"CVE-2025-1550",
|
|
156
158
|
"CVE-2025-32434",
|
|
157
159
|
"CVE-2025-33236",
|
|
@@ -1288,6 +1290,8 @@
|
|
|
1288
1290
|
"CVE-2024-11394",
|
|
1289
1291
|
"CVE-2024-21513",
|
|
1290
1292
|
"CVE-2024-24590",
|
|
1293
|
+
"CVE-2024-37052",
|
|
1294
|
+
"CVE-2024-37060",
|
|
1291
1295
|
"CVE-2025-1550",
|
|
1292
1296
|
"CVE-2025-32434",
|
|
1293
1297
|
"CVE-2025-33236",
|
|
@@ -2859,6 +2863,8 @@
|
|
|
2859
2863
|
"CVE-2024-11393",
|
|
2860
2864
|
"CVE-2024-11394",
|
|
2861
2865
|
"CVE-2024-24590",
|
|
2866
|
+
"CVE-2024-37052",
|
|
2867
|
+
"CVE-2024-37060",
|
|
2862
2868
|
"CVE-2025-1550",
|
|
2863
2869
|
"CVE-2025-32434",
|
|
2864
2870
|
"CVE-2025-33236",
|
|
@@ -290,6 +290,8 @@
|
|
|
290
290
|
"CVE-2024-24590",
|
|
291
291
|
"CVE-2024-2912",
|
|
292
292
|
"CVE-2024-37032",
|
|
293
|
+
"CVE-2024-37052",
|
|
294
|
+
"CVE-2024-37060",
|
|
293
295
|
"CVE-2024-42479",
|
|
294
296
|
"CVE-2024-4889",
|
|
295
297
|
"CVE-2024-50050",
|
|
@@ -1149,6 +1151,8 @@
|
|
|
1149
1151
|
"CVE-2024-11394",
|
|
1150
1152
|
"CVE-2024-24590",
|
|
1151
1153
|
"CVE-2024-3094",
|
|
1154
|
+
"CVE-2024-37052",
|
|
1155
|
+
"CVE-2024-37060",
|
|
1152
1156
|
"CVE-2025-1550",
|
|
1153
1157
|
"CVE-2025-32434",
|
|
1154
1158
|
"CVE-2025-33236",
|
|
@@ -4339,6 +4343,8 @@
|
|
|
4339
4343
|
"CVE-2024-11394",
|
|
4340
4344
|
"CVE-2024-24590",
|
|
4341
4345
|
"CVE-2024-24591",
|
|
4346
|
+
"CVE-2024-37052",
|
|
4347
|
+
"CVE-2024-37060",
|
|
4342
4348
|
"CVE-2025-1550",
|
|
4343
4349
|
"CVE-2025-32434",
|
|
4344
4350
|
"CVE-2025-33236",
|
package/data/cve-catalog.json
CHANGED
|
@@ -16672,6 +16672,218 @@
|
|
|
16672
16672
|
"_intake_method": "manual-verified-curation",
|
|
16673
16673
|
"_kev_short_description": "BentoML's serde.py deserializes attacker-supplied serialized objects from requests without validation, giving unauthenticated RCE (CWE-502); fixed in 1.4.3 - the deserialization-RCE class recurred after the 1.2.5 fix."
|
|
16674
16674
|
},
|
|
16675
|
+
"CVE-2024-37052": {
|
|
16676
|
+
"name": "MLflow scikit-learn Model Deserialization Remote Code Execution",
|
|
16677
|
+
"type": "RCE",
|
|
16678
|
+
"cvss_score": 8.8,
|
|
16679
|
+
"cvss_vector": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:U/C:H/I:H/A:H",
|
|
16680
|
+
"cvss_note": "HiddenLayer (CNA) CVSS v3.1 base 8.8 (HIGH); NVD has not published its own assessed score. A maliciously crafted scikit-learn model stored in MLflow runs arbitrary code when a user loads/interacts with it, because the model object is reconstructed through unsafe deserialization (CWE-502).",
|
|
16681
|
+
"cisa_kev": false,
|
|
16682
|
+
"poc_available": true,
|
|
16683
|
+
"poc_description": "HiddenLayer published the analysis: a scikit-learn model stored in MLflow runs code when a user loads/runs it.",
|
|
16684
|
+
"ai_discovered": false,
|
|
16685
|
+
"ai_discovery_source": "human_researcher",
|
|
16686
|
+
"ai_discovery_notes": "Disclosed by HiddenLayer (https://github.com/advisories/GHSA-76cg-cfhx-373f). The abused surface is MLflow, a widely used MLOps / model-registry platform - one of the Protect AI / HiddenLayer model-flavor deserialization findings.",
|
|
16687
|
+
"ai_assisted_weaponization": false,
|
|
16688
|
+
"ai_assisted_notes": "No AI-assisted weaponization; the flaw is that an MLflow scikit-learn model is executable code reconstructed through unsafe deserialization when loaded.",
|
|
16689
|
+
"active_exploitation": "none",
|
|
16690
|
+
"active_exploitation_notes": "Research disclosure with a documented attack chain; no confirmed in-the-wild exploitation reported as of curation. No patched MLflow version is published (loading an untrusted model is inherently unsafe), so exposure persists when untrusted models/recipes are loaded.",
|
|
16691
|
+
"affected": "MLflow 1.1.0 through 2.14.1.",
|
|
16692
|
+
"affected_versions": [
|
|
16693
|
+
"MLflow >= 1.1.0, <= 2.14.1"
|
|
16694
|
+
],
|
|
16695
|
+
"vector": "MLflow stores and loads ML models and Recipes by flavor. A scikit-learn model is reconstructed through an unsafe deserialization path, so loading or running it executes embedded attacker code on the user's system (CWE-502). The model artifact IS executable code. Disclosed by HiddenLayer as part of the MLflow model-flavor deserialization set.",
|
|
16696
|
+
"complexity": "low",
|
|
16697
|
+
"complexity_notes": "HiddenLayer (CNA) AV:N / AC:L / PR:N / UI:R - network-delivered via an uploaded model/recipe, but requires the victim to load/run it (UI:R).",
|
|
16698
|
+
"patch_available": false,
|
|
16699
|
+
"patch_required_reboot": false,
|
|
16700
|
+
"live_patch_available": false,
|
|
16701
|
+
"live_patch_tools": [],
|
|
16702
|
+
"live_patch_notes": "No patched MLflow version is published (the GitHub advisory records 'Patched versions: None'); loading an untrusted model artifact is inherently code execution. Mitigation is provenance verification + sandboxing (see vendor_update_paths).",
|
|
16703
|
+
"vendor_update_paths": [
|
|
16704
|
+
"No fixed MLflow version is published. Only load models and Recipes from trusted sources, verify artifact provenance, run model loading in a sandboxed/least-privilege environment, and prefer safe serialization formats; treat every MLflow model artifact as executable code."
|
|
16705
|
+
],
|
|
16706
|
+
"framework_control_gaps": {
|
|
16707
|
+
"NIST-800-53-SI-2": "Flaw remediation cannot resolve this by patching - loading an untrusted model is inherently code execution; the control must be artifact provenance + sandboxing.",
|
|
16708
|
+
"NIST-800-53-SI-10": "No input validation distinguishes a benign model artifact from one carrying a deserialization payload before MLflow loads it.",
|
|
16709
|
+
"NIST-800-53-SR-3": "Supply-chain controls do not treat MLflow model artifacts / Recipes as untrusted third-party executable content.",
|
|
16710
|
+
"ISO-27001-2022-A.8.28": "Secure-coding expectations do not address loading an untrusted model artifact as host code.",
|
|
16711
|
+
"NIS2-Art21-supply-chain": "Supply-chain-security measures do not reach the MLflow model registry as a channel that delivers executable model artifacts.",
|
|
16712
|
+
"DORA-Art-9": "ICT protection measures do not model untrusted model-artifact loading as an ICT-risk event.",
|
|
16713
|
+
"UK-CAF-B4": "System Security objective has no objective for verifying model-artifact provenance before loading.",
|
|
16714
|
+
"AU-ISM-1546": "Patch-application control does not address a flaw with no patch - the model format is inherently executable.",
|
|
16715
|
+
"ALL-AI-PIPELINE-INTEGRITY": "No framework treats an MLflow model artifact / Recipe as untrusted executable code requiring provenance verification and sandboxed loading."
|
|
16716
|
+
},
|
|
16717
|
+
"atlas_refs": [
|
|
16718
|
+
"AML.T0010",
|
|
16719
|
+
"AML.T0011",
|
|
16720
|
+
"AML.T0011.000"
|
|
16721
|
+
],
|
|
16722
|
+
"attack_refs": [
|
|
16723
|
+
"T1204",
|
|
16724
|
+
"T1059",
|
|
16725
|
+
"T1195.002"
|
|
16726
|
+
],
|
|
16727
|
+
"rwep_score": 42,
|
|
16728
|
+
"rwep_factors": {
|
|
16729
|
+
"cisa_kev": 0,
|
|
16730
|
+
"poc_available": 20,
|
|
16731
|
+
"ai_factor": 0,
|
|
16732
|
+
"active_exploitation": 0,
|
|
16733
|
+
"blast_radius": 22,
|
|
16734
|
+
"patch_available": 0,
|
|
16735
|
+
"live_patch_available": 0,
|
|
16736
|
+
"reboot_required": 0
|
|
16737
|
+
},
|
|
16738
|
+
"rwep_notes": "Elevated (RWEP 42, \"patch within 7 days\" band per lib/scoring.js timeline). Not KEV, no confirmed in-the-wild exploitation, and no patched version exists so no patch credit (Hard Rule #3) - this is a model-artifact-as-code flaw that no patch can close, only provenance + sandboxing. The UI:R requirement (victim must load the model) keeps blast moderate. poc_available=20 + blast_radius=22.",
|
|
16739
|
+
"epss_score": null,
|
|
16740
|
+
"epss_date": "2026-05-25",
|
|
16741
|
+
"epss_note": "EPSS not pulled for this entry; retrieve via FIRST EPSS API in a future refresh.",
|
|
16742
|
+
"epss_source": "https://api.first.org/data/v1/epss?cve=CVE-2024-37052",
|
|
16743
|
+
"cwe_refs": [
|
|
16744
|
+
"CWE-502"
|
|
16745
|
+
],
|
|
16746
|
+
"iocs": {
|
|
16747
|
+
"behavioral": [
|
|
16748
|
+
"MLflow scikit-learn model artifacts whose stored payload contains a deserialization gadget rather than a plain model.",
|
|
16749
|
+
"The MLflow process or client spawning shell, network, or file-system child processes when a model/recipe is loaded or run.",
|
|
16750
|
+
"MLflow 1.1.0-2.14.1 loading scikit-learn models from an untrusted registry/run - the exposed precondition."
|
|
16751
|
+
],
|
|
16752
|
+
"_ioc_source_note": "Behavioral signatures anchored to the HiddenLayer disclosure / GitHub advisory (https://github.com/advisories/GHSA-76cg-cfhx-373f) and NVD CVE-2024-37052 (CWE-502)."
|
|
16753
|
+
},
|
|
16754
|
+
"source_verified": "2026-05-25",
|
|
16755
|
+
"verification_sources": [
|
|
16756
|
+
"https://nvd.nist.gov/vuln/detail/CVE-2024-37052",
|
|
16757
|
+
"https://github.com/advisories/GHSA-76cg-cfhx-373f"
|
|
16758
|
+
],
|
|
16759
|
+
"vendor_advisories": [
|
|
16760
|
+
{
|
|
16761
|
+
"vendor": "GitHub Security Advisory",
|
|
16762
|
+
"advisory_id": "CVE-2024-37052",
|
|
16763
|
+
"url": "https://github.com/advisories/GHSA-76cg-cfhx-373f",
|
|
16764
|
+
"severity": "high",
|
|
16765
|
+
"published_date": "2024-06-04"
|
|
16766
|
+
},
|
|
16767
|
+
{
|
|
16768
|
+
"vendor": "NVD",
|
|
16769
|
+
"advisory_id": "CVE-2024-37052",
|
|
16770
|
+
"url": "https://nvd.nist.gov/vuln/detail/CVE-2024-37052",
|
|
16771
|
+
"severity": "high",
|
|
16772
|
+
"published_date": "2024-06-04"
|
|
16773
|
+
}
|
|
16774
|
+
],
|
|
16775
|
+
"last_updated": "2026-05-25",
|
|
16776
|
+
"discovery_attribution_note": "Manually curated from the HiddenLayer / GitHub Security Advisory (https://github.com/advisories/GHSA-76cg-cfhx-373f, CWE-502) + HiddenLayer (CNA, CVSS v3.1 8.8); NVD has not published its own score. MLflow model-flavor deserialization (Protect AI / HiddenLayer set); reuses the untrusted-model-artifact-loading control NEW-CTRL-091 - a model artifact is executable code, the class shared with Keras / Hugging Face / NeMo / PyTorch / H2O.",
|
|
16777
|
+
"_auto_imported": false,
|
|
16778
|
+
"_intake_method": "manual-verified-curation",
|
|
16779
|
+
"_kev_short_description": "A malicious scikit-learn model in MLflow runs code when loaded (CWE-502 unsafe deserialization); no patched version - treat MLflow models as untrusted code."
|
|
16780
|
+
},
|
|
16781
|
+
"CVE-2024-37060": {
|
|
16782
|
+
"name": "MLflow Recipe Deserialization Remote Code Execution",
|
|
16783
|
+
"type": "RCE",
|
|
16784
|
+
"cvss_score": 8.8,
|
|
16785
|
+
"cvss_vector": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:U/C:H/I:H/A:H",
|
|
16786
|
+
"cvss_note": "HiddenLayer (CNA) CVSS v3.1 base 8.8 (HIGH); NVD has not published its own assessed score. A maliciously crafted MLflow Recipe runs arbitrary code when executed, because it is reconstructed through unsafe deserialization (CWE-502).",
|
|
16787
|
+
"cisa_kev": false,
|
|
16788
|
+
"poc_available": true,
|
|
16789
|
+
"poc_description": "HiddenLayer published the analysis: a malicious MLflow Recipe stored in MLflow runs code when a user loads/runs it.",
|
|
16790
|
+
"ai_discovered": false,
|
|
16791
|
+
"ai_discovery_source": "human_researcher",
|
|
16792
|
+
"ai_discovery_notes": "Disclosed by HiddenLayer (https://github.com/advisories/GHSA-cv6c-7963-wxcg). The abused surface is MLflow, a widely used MLOps / model-registry platform - one of the Protect AI / HiddenLayer model-flavor deserialization findings.",
|
|
16793
|
+
"ai_assisted_weaponization": false,
|
|
16794
|
+
"ai_assisted_notes": "No AI-assisted weaponization; the flaw is that an MLflow Recipe is executable code reconstructed through unsafe deserialization when loaded.",
|
|
16795
|
+
"active_exploitation": "none",
|
|
16796
|
+
"active_exploitation_notes": "Research disclosure with a documented attack chain; no confirmed in-the-wild exploitation reported as of curation. No patched MLflow version is published (loading an untrusted model is inherently unsafe), so exposure persists when untrusted models/recipes are loaded.",
|
|
16797
|
+
"affected": "MLflow 1.27.0 through 2.14.1.",
|
|
16798
|
+
"affected_versions": [
|
|
16799
|
+
"MLflow >= 1.27.0, <= 2.14.1"
|
|
16800
|
+
],
|
|
16801
|
+
"vector": "MLflow stores and loads ML models and Recipes by flavor. A malicious MLflow Recipe is reconstructed through an unsafe deserialization path, so loading or running it executes embedded attacker code on the user's system (CWE-502). The model artifact IS executable code. Disclosed by HiddenLayer as part of the MLflow model-flavor deserialization set.",
|
|
16802
|
+
"complexity": "low",
|
|
16803
|
+
"complexity_notes": "HiddenLayer (CNA) AV:N / AC:L / PR:N / UI:R - network-delivered via an uploaded model/recipe, but requires the victim to load/run it (UI:R).",
|
|
16804
|
+
"patch_available": false,
|
|
16805
|
+
"patch_required_reboot": false,
|
|
16806
|
+
"live_patch_available": false,
|
|
16807
|
+
"live_patch_tools": [],
|
|
16808
|
+
"live_patch_notes": "No patched MLflow version is published (the GitHub advisory records 'Patched versions: None'); loading an untrusted model artifact is inherently code execution. Mitigation is provenance verification + sandboxing (see vendor_update_paths).",
|
|
16809
|
+
"vendor_update_paths": [
|
|
16810
|
+
"No fixed MLflow version is published. Only load models and Recipes from trusted sources, verify artifact provenance, run model loading in a sandboxed/least-privilege environment, and prefer safe serialization formats; treat every MLflow model artifact as executable code."
|
|
16811
|
+
],
|
|
16812
|
+
"framework_control_gaps": {
|
|
16813
|
+
"NIST-800-53-SI-2": "Flaw remediation cannot resolve this by patching - loading an untrusted model is inherently code execution; the control must be artifact provenance + sandboxing.",
|
|
16814
|
+
"NIST-800-53-SI-10": "No input validation distinguishes a benign model artifact from one carrying a deserialization payload before MLflow loads it.",
|
|
16815
|
+
"NIST-800-53-SR-3": "Supply-chain controls do not treat MLflow model artifacts / Recipes as untrusted third-party executable content.",
|
|
16816
|
+
"ISO-27001-2022-A.8.28": "Secure-coding expectations do not address loading an untrusted model artifact as host code.",
|
|
16817
|
+
"NIS2-Art21-supply-chain": "Supply-chain-security measures do not reach the MLflow model registry as a channel that delivers executable model artifacts.",
|
|
16818
|
+
"DORA-Art-9": "ICT protection measures do not model untrusted model-artifact loading as an ICT-risk event.",
|
|
16819
|
+
"UK-CAF-B4": "System Security objective has no objective for verifying model-artifact provenance before loading.",
|
|
16820
|
+
"AU-ISM-1546": "Patch-application control does not address a flaw with no patch - the model format is inherently executable.",
|
|
16821
|
+
"ALL-AI-PIPELINE-INTEGRITY": "No framework treats an MLflow model artifact / Recipe as untrusted executable code requiring provenance verification and sandboxed loading."
|
|
16822
|
+
},
|
|
16823
|
+
"atlas_refs": [
|
|
16824
|
+
"AML.T0010",
|
|
16825
|
+
"AML.T0011",
|
|
16826
|
+
"AML.T0011.000"
|
|
16827
|
+
],
|
|
16828
|
+
"attack_refs": [
|
|
16829
|
+
"T1204",
|
|
16830
|
+
"T1059",
|
|
16831
|
+
"T1195.002"
|
|
16832
|
+
],
|
|
16833
|
+
"rwep_score": 42,
|
|
16834
|
+
"rwep_factors": {
|
|
16835
|
+
"cisa_kev": 0,
|
|
16836
|
+
"poc_available": 20,
|
|
16837
|
+
"ai_factor": 0,
|
|
16838
|
+
"active_exploitation": 0,
|
|
16839
|
+
"blast_radius": 22,
|
|
16840
|
+
"patch_available": 0,
|
|
16841
|
+
"live_patch_available": 0,
|
|
16842
|
+
"reboot_required": 0
|
|
16843
|
+
},
|
|
16844
|
+
"rwep_notes": "Elevated (RWEP 42, \"patch within 7 days\" band per lib/scoring.js timeline). Not KEV, no confirmed in-the-wild exploitation, and no patched version exists so no patch credit (Hard Rule #3) - this is a model-artifact-as-code flaw that no patch can close, only provenance + sandboxing. The UI:R requirement (victim must load the model) keeps blast moderate. poc_available=20 + blast_radius=22.",
|
|
16845
|
+
"epss_score": null,
|
|
16846
|
+
"epss_date": "2026-05-25",
|
|
16847
|
+
"epss_note": "EPSS not pulled for this entry; retrieve via FIRST EPSS API in a future refresh.",
|
|
16848
|
+
"epss_source": "https://api.first.org/data/v1/epss?cve=CVE-2024-37060",
|
|
16849
|
+
"cwe_refs": [
|
|
16850
|
+
"CWE-502"
|
|
16851
|
+
],
|
|
16852
|
+
"iocs": {
|
|
16853
|
+
"behavioral": [
|
|
16854
|
+
"MLflow Recipe artifacts whose stored payload contains a deserialization gadget rather than a plain model.",
|
|
16855
|
+
"The MLflow process or client spawning shell, network, or file-system child processes when a model/recipe is loaded or run.",
|
|
16856
|
+
"MLflow 1.27.0-2.14.1 running Recipes from an untrusted source - the exposed precondition."
|
|
16857
|
+
],
|
|
16858
|
+
"_ioc_source_note": "Behavioral signatures anchored to the HiddenLayer disclosure / GitHub advisory (https://github.com/advisories/GHSA-cv6c-7963-wxcg) and NVD CVE-2024-37060 (CWE-502)."
|
|
16859
|
+
},
|
|
16860
|
+
"source_verified": "2026-05-25",
|
|
16861
|
+
"verification_sources": [
|
|
16862
|
+
"https://nvd.nist.gov/vuln/detail/CVE-2024-37060",
|
|
16863
|
+
"https://github.com/advisories/GHSA-cv6c-7963-wxcg"
|
|
16864
|
+
],
|
|
16865
|
+
"vendor_advisories": [
|
|
16866
|
+
{
|
|
16867
|
+
"vendor": "GitHub Security Advisory",
|
|
16868
|
+
"advisory_id": "CVE-2024-37060",
|
|
16869
|
+
"url": "https://github.com/advisories/GHSA-cv6c-7963-wxcg",
|
|
16870
|
+
"severity": "high",
|
|
16871
|
+
"published_date": "2024-06-04"
|
|
16872
|
+
},
|
|
16873
|
+
{
|
|
16874
|
+
"vendor": "NVD",
|
|
16875
|
+
"advisory_id": "CVE-2024-37060",
|
|
16876
|
+
"url": "https://nvd.nist.gov/vuln/detail/CVE-2024-37060",
|
|
16877
|
+
"severity": "high",
|
|
16878
|
+
"published_date": "2024-06-04"
|
|
16879
|
+
}
|
|
16880
|
+
],
|
|
16881
|
+
"last_updated": "2026-05-25",
|
|
16882
|
+
"discovery_attribution_note": "Manually curated from the HiddenLayer / GitHub Security Advisory (https://github.com/advisories/GHSA-cv6c-7963-wxcg, CWE-502) + HiddenLayer (CNA, CVSS v3.1 8.8); NVD has not published its own score. MLflow model-flavor deserialization (Protect AI / HiddenLayer set); reuses the untrusted-model-artifact-loading control NEW-CTRL-091 - a model artifact is executable code, the class shared with Keras / Hugging Face / NeMo / PyTorch / H2O.",
|
|
16883
|
+
"_auto_imported": false,
|
|
16884
|
+
"_intake_method": "manual-verified-curation",
|
|
16885
|
+
"_kev_short_description": "A malicious MLflow Recipe runs code when executed (CWE-502 unsafe deserialization); no patched version - treat MLflow artifacts as untrusted code."
|
|
16886
|
+
},
|
|
16675
16887
|
"CVE-2026-41091": {
|
|
16676
16888
|
"name": "Microsoft Defender (Malware Protection Engine) Link-Following LPE to SYSTEM",
|
|
16677
16889
|
"type": "LPE",
|
package/data/cwe-catalog.json
CHANGED
|
@@ -57,6 +57,8 @@
|
|
|
57
57
|
"CVE-2024-27132",
|
|
58
58
|
"CVE-2024-2912",
|
|
59
59
|
"CVE-2024-37032",
|
|
60
|
+
"CVE-2024-37052",
|
|
61
|
+
"CVE-2024-37060",
|
|
60
62
|
"CVE-2024-39722",
|
|
61
63
|
"CVE-2024-42478",
|
|
62
64
|
"CVE-2024-42479",
|
|
@@ -1276,6 +1278,8 @@
|
|
|
1276
1278
|
"CVE-2024-24590",
|
|
1277
1279
|
"CVE-2024-24591",
|
|
1278
1280
|
"CVE-2024-2912",
|
|
1281
|
+
"CVE-2024-37052",
|
|
1282
|
+
"CVE-2024-37060",
|
|
1279
1283
|
"CVE-2024-5565",
|
|
1280
1284
|
"CVE-2025-0133",
|
|
1281
1285
|
"CVE-2025-1094",
|
|
@@ -2352,6 +2356,8 @@
|
|
|
2352
2356
|
"CVE-2024-27132",
|
|
2353
2357
|
"CVE-2024-2912",
|
|
2354
2358
|
"CVE-2024-37032",
|
|
2359
|
+
"CVE-2024-37052",
|
|
2360
|
+
"CVE-2024-37060",
|
|
2355
2361
|
"CVE-2024-39722",
|
|
2356
2362
|
"CVE-2024-50050",
|
|
2357
2363
|
"CVE-2024-5565",
|
|
@@ -2534,6 +2540,8 @@
|
|
|
2534
2540
|
"CVE-2024-27199",
|
|
2535
2541
|
"CVE-2024-27443",
|
|
2536
2542
|
"CVE-2024-37032",
|
|
2543
|
+
"CVE-2024-37052",
|
|
2544
|
+
"CVE-2024-37060",
|
|
2537
2545
|
"CVE-2024-37079",
|
|
2538
2546
|
"CVE-2024-39722",
|
|
2539
2547
|
"CVE-2024-42009",
|
|
@@ -2857,6 +2865,8 @@
|
|
|
2857
2865
|
"CVE-2024-24590",
|
|
2858
2866
|
"CVE-2024-24591",
|
|
2859
2867
|
"CVE-2024-3094",
|
|
2868
|
+
"CVE-2024-37052",
|
|
2869
|
+
"CVE-2024-37060",
|
|
2860
2870
|
"MAL-2026-SHAI-HULUD-OSS"
|
|
2861
2871
|
],
|
|
2862
2872
|
"atlas_refs": [
|
|
@@ -5067,6 +5077,8 @@
|
|
|
5067
5077
|
"CVE-2024-27132",
|
|
5068
5078
|
"CVE-2024-2912",
|
|
5069
5079
|
"CVE-2024-37032",
|
|
5080
|
+
"CVE-2024-37052",
|
|
5081
|
+
"CVE-2024-37060",
|
|
5070
5082
|
"CVE-2024-39722",
|
|
5071
5083
|
"CVE-2024-42478",
|
|
5072
5084
|
"CVE-2024-42479",
|
|
@@ -5634,6 +5646,8 @@
|
|
|
5634
5646
|
"CVE-2024-27132",
|
|
5635
5647
|
"CVE-2024-2912",
|
|
5636
5648
|
"CVE-2024-37032",
|
|
5649
|
+
"CVE-2024-37052",
|
|
5650
|
+
"CVE-2024-37060",
|
|
5637
5651
|
"CVE-2024-39722",
|
|
5638
5652
|
"CVE-2024-42478",
|
|
5639
5653
|
"CVE-2024-42479",
|
|
@@ -5736,6 +5750,8 @@
|
|
|
5736
5750
|
"CVE-2024-27132",
|
|
5737
5751
|
"CVE-2024-2912",
|
|
5738
5752
|
"CVE-2024-37032",
|
|
5753
|
+
"CVE-2024-37052",
|
|
5754
|
+
"CVE-2024-37060",
|
|
5739
5755
|
"CVE-2024-39722",
|
|
5740
5756
|
"CVE-2024-42478",
|
|
5741
5757
|
"CVE-2024-42479",
|
|
@@ -5855,6 +5871,8 @@
|
|
|
5855
5871
|
"CVE-2024-24590",
|
|
5856
5872
|
"CVE-2024-24591",
|
|
5857
5873
|
"CVE-2024-3154",
|
|
5874
|
+
"CVE-2024-37052",
|
|
5875
|
+
"CVE-2024-37060",
|
|
5858
5876
|
"MAL-2026-NODE-IPC-STEALER",
|
|
5859
5877
|
"MAL-2026-RUBYGEMS-BUFFERZONECORP-SLEEPER",
|
|
5860
5878
|
"MAL-2026-SHAI-HULUD-OSS",
|
|
@@ -4511,6 +4511,106 @@
|
|
|
4511
4511
|
"_auto_imported": false,
|
|
4512
4512
|
"_intake_method": "manual-verified-curation"
|
|
4513
4513
|
},
|
|
4514
|
+
"CVE-2024-37052": {
|
|
4515
|
+
"name": "MLflow scikit-learn Model Deserialization Remote Code Execution",
|
|
4516
|
+
"lesson_date": "2026-05-25",
|
|
4517
|
+
"attack_vector": {
|
|
4518
|
+
"description": "A maliciously crafted scikit-learn model stored in MLflow (1.1.0-2.14.1) runs arbitrary code when a user loads or interacts with it, because the model object is reconstructed through unsafe deserialization.",
|
|
4519
|
+
"privileges_required": "low-to-none (upload to a registry the victim uses; victim must load/run the artifact - UI:R)",
|
|
4520
|
+
"complexity": "low",
|
|
4521
|
+
"ai_factor": "The abused surface is MLflow, an MLOps / model-registry platform. The lesson: an MLflow model artifact or Recipe is executable code - loading an untrusted one is code execution, so there is no patch, only provenance verification and sandboxed loading. One of the Protect AI / HiddenLayer model-flavor deserialization findings."
|
|
4522
|
+
},
|
|
4523
|
+
"framework_coverage": {
|
|
4524
|
+
"NIST-800-53-SI-2": {
|
|
4525
|
+
"covered": true,
|
|
4526
|
+
"adequate": false,
|
|
4527
|
+
"gap": "Flaw remediation cannot patch this - loading an untrusted model is inherently code execution; the control is artifact provenance + sandboxing."
|
|
4528
|
+
},
|
|
4529
|
+
"NIST-800-53-SI-10": {
|
|
4530
|
+
"covered": true,
|
|
4531
|
+
"adequate": false,
|
|
4532
|
+
"gap": "No input validation distinguishes a benign model artifact from a deserialization payload before MLflow loads it."
|
|
4533
|
+
},
|
|
4534
|
+
"ALL-AI-PIPELINE-INTEGRITY": {
|
|
4535
|
+
"covered": false,
|
|
4536
|
+
"adequate": false,
|
|
4537
|
+
"gap": "No framework treats an MLflow model artifact / Recipe as untrusted executable code requiring provenance verification and sandboxed loading."
|
|
4538
|
+
}
|
|
4539
|
+
},
|
|
4540
|
+
"compliance_exposure_score": {
|
|
4541
|
+
"percent_audit_passing_orgs_still_exposed": 82,
|
|
4542
|
+
"basis": "MLflow model registries are shared across teams on trusted-collaborator assumptions; model artifacts are loaded without provenance verification or sandboxing, and no patch exists because the format is inherently executable.",
|
|
4543
|
+
"theater_pattern": "untrusted_model_artifact_as_code"
|
|
4544
|
+
},
|
|
4545
|
+
"ai_discovered_zeroday": false,
|
|
4546
|
+
"ai_discovery_source": "human_researcher",
|
|
4547
|
+
"ai_assist_factor": "none",
|
|
4548
|
+
"new_control_requirements": [
|
|
4549
|
+
{
|
|
4550
|
+
"id": "NEW-CTRL-091",
|
|
4551
|
+
"name": "UNTRUSTED-MODEL-ARTIFACT-LOADING",
|
|
4552
|
+
"description": "Treat ML model artifacts as untrusted code: never load .keras / pickle-based models from untrusted sources, verify provenance, prefer safe formats (e.g. safetensors), and load untrusted models only in a sandboxed, network-isolated, least-privilege environment. Upgrade Keras to the fixed release (>= 3.8.0 for CVE-2025-1550; past 3.10.0 for the CVE-2025-8747 safe_mode bypass) and do not rely on safe_mode alone — it was bypassable. The distinguishing test: load an attacker-crafted .keras archive with safe_mode enabled on a sandboxed instance and confirm no code executes.",
|
|
4553
|
+
"evidence": "https://nvd.nist.gov/vuln/detail/CVE-2025-1550",
|
|
4554
|
+
"gap_closes": [
|
|
4555
|
+
"NIST-800-53-SI-2",
|
|
4556
|
+
"NIST-800-53-SI-10",
|
|
4557
|
+
"ALL-AI-PIPELINE-INTEGRITY"
|
|
4558
|
+
]
|
|
4559
|
+
}
|
|
4560
|
+
],
|
|
4561
|
+
"_auto_imported": false,
|
|
4562
|
+
"_intake_method": "manual-verified-curation"
|
|
4563
|
+
},
|
|
4564
|
+
"CVE-2024-37060": {
|
|
4565
|
+
"name": "MLflow Recipe Deserialization Remote Code Execution",
|
|
4566
|
+
"lesson_date": "2026-05-25",
|
|
4567
|
+
"attack_vector": {
|
|
4568
|
+
"description": "A maliciously crafted MLflow Recipe (1.27.0-2.14.1) runs arbitrary code when executed, because it is reconstructed through unsafe deserialization.",
|
|
4569
|
+
"privileges_required": "low-to-none (upload to a registry the victim uses; victim must load/run the artifact - UI:R)",
|
|
4570
|
+
"complexity": "low",
|
|
4571
|
+
"ai_factor": "The abused surface is MLflow, an MLOps / model-registry platform. The lesson: an MLflow model artifact or Recipe is executable code - loading an untrusted one is code execution, so there is no patch, only provenance verification and sandboxed loading. One of the Protect AI / HiddenLayer model-flavor deserialization findings."
|
|
4572
|
+
},
|
|
4573
|
+
"framework_coverage": {
|
|
4574
|
+
"NIST-800-53-SI-2": {
|
|
4575
|
+
"covered": true,
|
|
4576
|
+
"adequate": false,
|
|
4577
|
+
"gap": "Flaw remediation cannot patch this - loading an untrusted model is inherently code execution; the control is artifact provenance + sandboxing."
|
|
4578
|
+
},
|
|
4579
|
+
"NIST-800-53-SI-10": {
|
|
4580
|
+
"covered": true,
|
|
4581
|
+
"adequate": false,
|
|
4582
|
+
"gap": "No input validation distinguishes a benign model artifact from a deserialization payload before MLflow loads it."
|
|
4583
|
+
},
|
|
4584
|
+
"ALL-AI-PIPELINE-INTEGRITY": {
|
|
4585
|
+
"covered": false,
|
|
4586
|
+
"adequate": false,
|
|
4587
|
+
"gap": "No framework treats an MLflow model artifact / Recipe as untrusted executable code requiring provenance verification and sandboxed loading."
|
|
4588
|
+
}
|
|
4589
|
+
},
|
|
4590
|
+
"compliance_exposure_score": {
|
|
4591
|
+
"percent_audit_passing_orgs_still_exposed": 82,
|
|
4592
|
+
"basis": "MLflow model registries are shared across teams on trusted-collaborator assumptions; model artifacts are loaded without provenance verification or sandboxing, and no patch exists because the format is inherently executable.",
|
|
4593
|
+
"theater_pattern": "untrusted_model_artifact_as_code"
|
|
4594
|
+
},
|
|
4595
|
+
"ai_discovered_zeroday": false,
|
|
4596
|
+
"ai_discovery_source": "human_researcher",
|
|
4597
|
+
"ai_assist_factor": "none",
|
|
4598
|
+
"new_control_requirements": [
|
|
4599
|
+
{
|
|
4600
|
+
"id": "NEW-CTRL-091",
|
|
4601
|
+
"name": "UNTRUSTED-MODEL-ARTIFACT-LOADING",
|
|
4602
|
+
"description": "Treat ML model artifacts as untrusted code: never load .keras / pickle-based models from untrusted sources, verify provenance, prefer safe formats (e.g. safetensors), and load untrusted models only in a sandboxed, network-isolated, least-privilege environment. Upgrade Keras to the fixed release (>= 3.8.0 for CVE-2025-1550; past 3.10.0 for the CVE-2025-8747 safe_mode bypass) and do not rely on safe_mode alone — it was bypassable. The distinguishing test: load an attacker-crafted .keras archive with safe_mode enabled on a sandboxed instance and confirm no code executes.",
|
|
4603
|
+
"evidence": "https://nvd.nist.gov/vuln/detail/CVE-2025-1550",
|
|
4604
|
+
"gap_closes": [
|
|
4605
|
+
"NIST-800-53-SI-2",
|
|
4606
|
+
"NIST-800-53-SI-10",
|
|
4607
|
+
"ALL-AI-PIPELINE-INTEGRITY"
|
|
4608
|
+
]
|
|
4609
|
+
}
|
|
4610
|
+
],
|
|
4611
|
+
"_auto_imported": false,
|
|
4612
|
+
"_intake_method": "manual-verified-curation"
|
|
4613
|
+
},
|
|
4514
4614
|
"CVE-2025-27520": {
|
|
4515
4615
|
"name": "BentoML serde.py Insecure Deserialization Unauthenticated Remote Code Execution",
|
|
4516
4616
|
"lesson_date": "2026-05-25",
|