Action not permitted
Modal body text goes here.
Modal Title
Modal Body
CVE-2026-48525 (GCVE-0-2026-48525)
Vulnerability from cvelistv5 – Published: 2026-05-28 15:11 – Updated: 2026-05-28 15:59- CWE-400 - Uncontrolled Resource Consumption
| URL | Tags |
|---|---|
| https://github.com/jpadilla/pyjwt/security/adviso… | x_refsource_CONFIRM |
{
"containers": {
"adp": [
{
"metrics": [
{
"other": {
"content": {
"id": "CVE-2026-48525",
"options": [
{
"Exploitation": "poc"
},
{
"Automatable": "yes"
},
{
"Technical Impact": "partial"
}
],
"role": "CISA Coordinator",
"timestamp": "2026-05-28T15:58:48.873096Z",
"version": "2.0.3"
},
"type": "ssvc"
}
}
],
"providerMetadata": {
"dateUpdated": "2026-05-28T15:59:19.219Z",
"orgId": "134c704f-9b21-4f2e-91b3-4a467353bcc0",
"shortName": "CISA-ADP"
},
"references": [
{
"tags": [
"exploit"
],
"url": "https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39"
}
],
"title": "CISA ADP Vulnrichment"
}
],
"cna": {
"affected": [
{
"product": "pyjwt",
"vendor": "jpadilla",
"versions": [
{
"status": "affected",
"version": "\u003e= 2.8.0, \u003c 2.13.0"
}
]
}
],
"descriptions": [
{
"lang": "en",
"value": "PyJWT is a JSON Web Token implementation in Python. From 2.8.0 to 2.12.1, when verifying detached JWS tokens using the unencoded-payload option (\"b64\": false, RFC 7797), PyJWT performs Base64URL decoding of the compact-serialization payload segment before enforcing the detached-payload rules. For b64=false, PyJWT later discards that decoded payload and replaces it with the caller-provided detached_payload. In practice, this turns the middle segment into an attacker-controlled \u201cwork amplifier\u201d: a remote client can supply an arbitrarily large Base64URL payload segment that forces CPU work + memory allocations even if the signature is invalid. This creates an unauthenticated DoS vector against any endpoint that verifies detached JWS using PyJWT. This vulnerability is fixed in 2.13.0."
}
],
"metrics": [
{
"cvssV3_1": {
"attackComplexity": "LOW",
"attackVector": "NETWORK",
"availabilityImpact": "LOW",
"baseScore": 5.3,
"baseSeverity": "MEDIUM",
"confidentialityImpact": "NONE",
"integrityImpact": "NONE",
"privilegesRequired": "NONE",
"scope": "UNCHANGED",
"userInteraction": "NONE",
"vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L",
"version": "3.1"
}
}
],
"problemTypes": [
{
"descriptions": [
{
"cweId": "CWE-400",
"description": "CWE-400: Uncontrolled Resource Consumption",
"lang": "en",
"type": "CWE"
}
]
}
],
"providerMetadata": {
"dateUpdated": "2026-05-28T15:11:12.483Z",
"orgId": "a0819718-46f1-4df5-94e2-005712e83aaa",
"shortName": "GitHub_M"
},
"references": [
{
"name": "https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39",
"tags": [
"x_refsource_CONFIRM"
],
"url": "https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39"
}
],
"source": {
"advisory": "GHSA-w7vc-732c-9m39",
"discovery": "UNKNOWN"
},
"title": "PyJWT: Unauthenticated DoS via unbounded Base64URL decoding of unused payload segment in b64=false detached JWS"
}
},
"cveMetadata": {
"assignerOrgId": "a0819718-46f1-4df5-94e2-005712e83aaa",
"assignerShortName": "GitHub_M",
"cveId": "CVE-2026-48525",
"datePublished": "2026-05-28T15:11:12.483Z",
"dateReserved": "2026-05-21T16:18:10.619Z",
"dateUpdated": "2026-05-28T15:59:19.219Z",
"state": "PUBLISHED"
},
"dataType": "CVE_RECORD",
"dataVersion": "5.2",
"vulnerability-lookup:meta": {
"epss": {
"cve": "CVE-2026-48525",
"date": "2026-06-14",
"epss": "0.00054",
"percentile": "0.17334"
},
"nvd": "{\"cve\":{\"id\":\"CVE-2026-48525\",\"sourceIdentifier\":\"security-advisories@github.com\",\"published\":\"2026-05-28T16:16:29.533\",\"lastModified\":\"2026-06-01T17:45:15.763\",\"vulnStatus\":\"Analyzed\",\"cveTags\":[],\"descriptions\":[{\"lang\":\"en\",\"value\":\"PyJWT is a JSON Web Token implementation in Python. From 2.8.0 to 2.12.1, when verifying detached JWS tokens using the unencoded-payload option (\\\"b64\\\": false, RFC 7797), PyJWT performs Base64URL decoding of the compact-serialization payload segment before enforcing the detached-payload rules. For b64=false, PyJWT later discards that decoded payload and replaces it with the caller-provided detached_payload. In practice, this turns the middle segment into an attacker-controlled \u201cwork amplifier\u201d: a remote client can supply an arbitrarily large Base64URL payload segment that forces CPU work + memory allocations even if the signature is invalid. This creates an unauthenticated DoS vector against any endpoint that verifies detached JWS using PyJWT. This vulnerability is fixed in 2.13.0.\"}],\"metrics\":{\"cvssMetricV31\":[{\"source\":\"security-advisories@github.com\",\"type\":\"Secondary\",\"cvssData\":{\"version\":\"3.1\",\"vectorString\":\"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L\",\"baseScore\":5.3,\"baseSeverity\":\"MEDIUM\",\"attackVector\":\"NETWORK\",\"attackComplexity\":\"LOW\",\"privilegesRequired\":\"NONE\",\"userInteraction\":\"NONE\",\"scope\":\"UNCHANGED\",\"confidentialityImpact\":\"NONE\",\"integrityImpact\":\"NONE\",\"availabilityImpact\":\"LOW\"},\"exploitabilityScore\":3.9,\"impactScore\":1.4}]},\"weaknesses\":[{\"source\":\"security-advisories@github.com\",\"type\":\"Secondary\",\"description\":[{\"lang\":\"en\",\"value\":\"CWE-400\"}]}],\"configurations\":[{\"nodes\":[{\"operator\":\"OR\",\"negate\":false,\"cpeMatch\":[{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:pyjwt_project:pyjwt:*:*:*:*:*:*:*:*\",\"versionStartIncluding\":\"2.8.0\",\"versionEndIncluding\":\"2.12.1\",\"matchCriteriaId\":\"71DC0C43-352F-449C-B411-5040A311A35F\"}]}]}],\"references\":[{\"url\":\"https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39\",\"source\":\"security-advisories@github.com\",\"tags\":[\"Exploit\",\"Vendor Advisory\",\"Mitigation\"]},{\"url\":\"https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39\",\"source\":\"134c704f-9b21-4f2e-91b3-4a467353bcc0\",\"tags\":[\"Exploit\",\"Vendor Advisory\",\"Mitigation\"]}]}}"
}
}
FKIE_CVE-2026-48525
Vulnerability from fkie_nvd - Published: 2026-05-28 16:16 - Updated: 2026-06-01 17:45| URL | Tags | ||
|---|---|---|---|
| security-advisories@github.com | https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39 | Exploit, Vendor Advisory, Mitigation | |
| 134c704f-9b21-4f2e-91b3-4a467353bcc0 | https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39 | Exploit, Vendor Advisory, Mitigation |
| Vendor | Product | Version | |
|---|---|---|---|
| pyjwt_project | pyjwt | * |
{
"configurations": [
{
"nodes": [
{
"cpeMatch": [
{
"criteria": "cpe:2.3:a:pyjwt_project:pyjwt:*:*:*:*:*:*:*:*",
"matchCriteriaId": "71DC0C43-352F-449C-B411-5040A311A35F",
"versionEndIncluding": "2.12.1",
"versionStartIncluding": "2.8.0",
"vulnerable": true
}
],
"negate": false,
"operator": "OR"
}
]
}
],
"cveTags": [],
"descriptions": [
{
"lang": "en",
"value": "PyJWT is a JSON Web Token implementation in Python. From 2.8.0 to 2.12.1, when verifying detached JWS tokens using the unencoded-payload option (\"b64\": false, RFC 7797), PyJWT performs Base64URL decoding of the compact-serialization payload segment before enforcing the detached-payload rules. For b64=false, PyJWT later discards that decoded payload and replaces it with the caller-provided detached_payload. In practice, this turns the middle segment into an attacker-controlled \u201cwork amplifier\u201d: a remote client can supply an arbitrarily large Base64URL payload segment that forces CPU work + memory allocations even if the signature is invalid. This creates an unauthenticated DoS vector against any endpoint that verifies detached JWS using PyJWT. This vulnerability is fixed in 2.13.0."
}
],
"id": "CVE-2026-48525",
"lastModified": "2026-06-01T17:45:15.763",
"metrics": {
"cvssMetricV31": [
{
"cvssData": {
"attackComplexity": "LOW",
"attackVector": "NETWORK",
"availabilityImpact": "LOW",
"baseScore": 5.3,
"baseSeverity": "MEDIUM",
"confidentialityImpact": "NONE",
"integrityImpact": "NONE",
"privilegesRequired": "NONE",
"scope": "UNCHANGED",
"userInteraction": "NONE",
"vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L",
"version": "3.1"
},
"exploitabilityScore": 3.9,
"impactScore": 1.4,
"source": "security-advisories@github.com",
"type": "Secondary"
}
]
},
"published": "2026-05-28T16:16:29.533",
"references": [
{
"source": "security-advisories@github.com",
"tags": [
"Exploit",
"Vendor Advisory",
"Mitigation"
],
"url": "https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39"
},
{
"source": "134c704f-9b21-4f2e-91b3-4a467353bcc0",
"tags": [
"Exploit",
"Vendor Advisory",
"Mitigation"
],
"url": "https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39"
}
],
"sourceIdentifier": "security-advisories@github.com",
"vulnStatus": "Analyzed",
"weaknesses": [
{
"description": [
{
"lang": "en",
"value": "CWE-400"
}
],
"source": "security-advisories@github.com",
"type": "Secondary"
}
]
}
OPENSUSE-SU-2026:11024-1
Vulnerability from csaf_opensuse - Published: 2026-06-13 00:00 - Updated: 2026-06-13 00:00| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64 | — |
Vendor Fix
|
{
"document": {
"aggregate_severity": {
"namespace": "https://www.suse.com/support/security/rating/",
"text": "moderate"
},
"category": "csaf_security_advisory",
"csaf_version": "2.0",
"distribution": {
"text": "Copyright 2024 SUSE LLC. All rights reserved.",
"tlp": {
"label": "WHITE",
"url": "https://www.first.org/tlp/"
}
},
"lang": "en",
"notes": [
{
"category": "summary",
"text": "python311-PyJWT-2.13.0-1.1 on GA media",
"title": "Title of the patch"
},
{
"category": "description",
"text": "These are all security issues fixed in the python311-PyJWT-2.13.0-1.1 package on the GA media of openSUSE Tumbleweed.",
"title": "Description of the patch"
},
{
"category": "details",
"text": "openSUSE-Tumbleweed-2026-11024",
"title": "Patchnames"
},
{
"category": "legal_disclaimer",
"text": "CSAF 2.0 data is provided by SUSE under the Creative Commons License 4.0 with Attribution (CC-BY-4.0).",
"title": "Terms of use"
}
],
"publisher": {
"category": "vendor",
"contact_details": "https://www.suse.com/support/security/contact/",
"name": "SUSE Product Security Team",
"namespace": "https://www.suse.com/"
},
"references": [
{
"category": "external",
"summary": "SUSE ratings",
"url": "https://www.suse.com/support/security/rating/"
},
{
"category": "self",
"summary": "URL of this CSAF notice",
"url": "https://ftp.suse.com/pub/projects/security/csaf/opensuse-su-2026_11024-1.json"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-48522 page",
"url": "https://www.suse.com/security/cve/CVE-2026-48522/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-48523 page",
"url": "https://www.suse.com/security/cve/CVE-2026-48523/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-48524 page",
"url": "https://www.suse.com/security/cve/CVE-2026-48524/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-48525 page",
"url": "https://www.suse.com/security/cve/CVE-2026-48525/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-48526 page",
"url": "https://www.suse.com/security/cve/CVE-2026-48526/"
}
],
"title": "python311-PyJWT-2.13.0-1.1 on GA media",
"tracking": {
"current_release_date": "2026-06-13T00:00:00Z",
"generator": {
"date": "2026-06-13T00:00:00Z",
"engine": {
"name": "cve-database.git:bin/generate-csaf.pl",
"version": "1"
}
},
"id": "openSUSE-SU-2026:11024-1",
"initial_release_date": "2026-06-13T00:00:00Z",
"revision_history": [
{
"date": "2026-06-13T00:00:00Z",
"number": "1",
"summary": "Current version"
}
],
"status": "final",
"version": "1"
}
},
"product_tree": {
"branches": [
{
"branches": [
{
"branches": [
{
"category": "product_version",
"name": "python311-PyJWT-2.13.0-1.1.aarch64",
"product": {
"name": "python311-PyJWT-2.13.0-1.1.aarch64",
"product_id": "python311-PyJWT-2.13.0-1.1.aarch64"
}
},
{
"category": "product_version",
"name": "python313-PyJWT-2.13.0-1.1.aarch64",
"product": {
"name": "python313-PyJWT-2.13.0-1.1.aarch64",
"product_id": "python313-PyJWT-2.13.0-1.1.aarch64"
}
},
{
"category": "product_version",
"name": "python314-PyJWT-2.13.0-1.1.aarch64",
"product": {
"name": "python314-PyJWT-2.13.0-1.1.aarch64",
"product_id": "python314-PyJWT-2.13.0-1.1.aarch64"
}
}
],
"category": "architecture",
"name": "aarch64"
},
{
"branches": [
{
"category": "product_version",
"name": "python311-PyJWT-2.13.0-1.1.ppc64le",
"product": {
"name": "python311-PyJWT-2.13.0-1.1.ppc64le",
"product_id": "python311-PyJWT-2.13.0-1.1.ppc64le"
}
},
{
"category": "product_version",
"name": "python313-PyJWT-2.13.0-1.1.ppc64le",
"product": {
"name": "python313-PyJWT-2.13.0-1.1.ppc64le",
"product_id": "python313-PyJWT-2.13.0-1.1.ppc64le"
}
},
{
"category": "product_version",
"name": "python314-PyJWT-2.13.0-1.1.ppc64le",
"product": {
"name": "python314-PyJWT-2.13.0-1.1.ppc64le",
"product_id": "python314-PyJWT-2.13.0-1.1.ppc64le"
}
}
],
"category": "architecture",
"name": "ppc64le"
},
{
"branches": [
{
"category": "product_version",
"name": "python311-PyJWT-2.13.0-1.1.s390x",
"product": {
"name": "python311-PyJWT-2.13.0-1.1.s390x",
"product_id": "python311-PyJWT-2.13.0-1.1.s390x"
}
},
{
"category": "product_version",
"name": "python313-PyJWT-2.13.0-1.1.s390x",
"product": {
"name": "python313-PyJWT-2.13.0-1.1.s390x",
"product_id": "python313-PyJWT-2.13.0-1.1.s390x"
}
},
{
"category": "product_version",
"name": "python314-PyJWT-2.13.0-1.1.s390x",
"product": {
"name": "python314-PyJWT-2.13.0-1.1.s390x",
"product_id": "python314-PyJWT-2.13.0-1.1.s390x"
}
}
],
"category": "architecture",
"name": "s390x"
},
{
"branches": [
{
"category": "product_version",
"name": "python311-PyJWT-2.13.0-1.1.x86_64",
"product": {
"name": "python311-PyJWT-2.13.0-1.1.x86_64",
"product_id": "python311-PyJWT-2.13.0-1.1.x86_64"
}
},
{
"category": "product_version",
"name": "python313-PyJWT-2.13.0-1.1.x86_64",
"product": {
"name": "python313-PyJWT-2.13.0-1.1.x86_64",
"product_id": "python313-PyJWT-2.13.0-1.1.x86_64"
}
},
{
"category": "product_version",
"name": "python314-PyJWT-2.13.0-1.1.x86_64",
"product": {
"name": "python314-PyJWT-2.13.0-1.1.x86_64",
"product_id": "python314-PyJWT-2.13.0-1.1.x86_64"
}
}
],
"category": "architecture",
"name": "x86_64"
},
{
"branches": [
{
"category": "product_name",
"name": "openSUSE Tumbleweed",
"product": {
"name": "openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed",
"product_identification_helper": {
"cpe": "cpe:/o:opensuse:tumbleweed"
}
}
}
],
"category": "product_family",
"name": "SUSE Linux Enterprise"
}
],
"category": "vendor",
"name": "SUSE"
}
],
"relationships": [
{
"category": "default_component_of",
"full_product_name": {
"name": "python311-PyJWT-2.13.0-1.1.aarch64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64"
},
"product_reference": "python311-PyJWT-2.13.0-1.1.aarch64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python311-PyJWT-2.13.0-1.1.ppc64le as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le"
},
"product_reference": "python311-PyJWT-2.13.0-1.1.ppc64le",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python311-PyJWT-2.13.0-1.1.s390x as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x"
},
"product_reference": "python311-PyJWT-2.13.0-1.1.s390x",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python311-PyJWT-2.13.0-1.1.x86_64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64"
},
"product_reference": "python311-PyJWT-2.13.0-1.1.x86_64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python313-PyJWT-2.13.0-1.1.aarch64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64"
},
"product_reference": "python313-PyJWT-2.13.0-1.1.aarch64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python313-PyJWT-2.13.0-1.1.ppc64le as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le"
},
"product_reference": "python313-PyJWT-2.13.0-1.1.ppc64le",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python313-PyJWT-2.13.0-1.1.s390x as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x"
},
"product_reference": "python313-PyJWT-2.13.0-1.1.s390x",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python313-PyJWT-2.13.0-1.1.x86_64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64"
},
"product_reference": "python313-PyJWT-2.13.0-1.1.x86_64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python314-PyJWT-2.13.0-1.1.aarch64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64"
},
"product_reference": "python314-PyJWT-2.13.0-1.1.aarch64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python314-PyJWT-2.13.0-1.1.ppc64le as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le"
},
"product_reference": "python314-PyJWT-2.13.0-1.1.ppc64le",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python314-PyJWT-2.13.0-1.1.s390x as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x"
},
"product_reference": "python314-PyJWT-2.13.0-1.1.s390x",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python314-PyJWT-2.13.0-1.1.x86_64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
},
"product_reference": "python314-PyJWT-2.13.0-1.1.x86_64",
"relates_to_product_reference": "openSUSE Tumbleweed"
}
]
},
"vulnerabilities": [
{
"cve": "CVE-2026-48522",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-48522"
}
],
"notes": [
{
"category": "general",
"text": "PyJWT is a JSON Web Token implementation in Python. Prior to 2.13.0, PyJWKClient passes its uri argument directly to urllib.request.urlopen() which uses Python stdlib\u0027s default OpenerDirector registering HTTPHandler, HTTPSHandler, FTPHandler, FileHandler, and DataHandler. There is currently no documented option to restrict which schemes PyJWKClient will fetch. If an application\u0027s jku URL ingestion path accepts attacker-influenced URLs (e.g., from JWT header, configuration file, OAuth flow parameter), the attacker can cause PyJWKClient to read arbitrary local files via file:// (SSRF on local filesystem), cause PyJWKClient to attempt FTP / data-URI fetches (broader SSRF surface), or forge tokens that PyJWT verifies as valid. The library does not directly return non-HTTP(S) URI contents to the attacker; the chained \"plant a JWKS to forge tokens\" scenario described in the original report requires additional application-layer flaws (attacker write access to a filesystem path, untrusted jku derivation) that this fix does not address. This vulnerability is fixed in 2.13.0.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-48522",
"url": "https://www.suse.com/security/cve/CVE-2026-48522"
},
{
"category": "external",
"summary": "SUSE Bug 1266798 for CVE-2026-48522",
"url": "https://bugzilla.suse.com/1266798"
}
],
"remediations": [
{
"category": "vendor_fix",
"details": "To install this SUSE Security Update use the SUSE recommended installation methods like YaST online_update or \"zypper patch\".\n",
"product_ids": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"scores": [
{
"cvss_v3": {
"baseScore": 4.8,
"baseSeverity": "MEDIUM",
"vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:L/A:N",
"version": "3.1"
},
"products": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-06-13T00:00:00Z",
"details": "moderate"
}
],
"title": "CVE-2026-48522"
},
{
"cve": "CVE-2026-48523",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-48523"
}
],
"notes": [
{
"category": "general",
"text": "PyJWT is a JSON Web Token implementation in Python. From 2.9.0 to 2.12.1, there is a verifier-side algorithm allow-list bypass when jwt.decode() or jwt.decode_complete() are called with a PyJWK key. The token header alg is checked against the caller-supplied algorithms allow-list, but signature verification is performed with the algorithm bound to the PyJWK object instead of the header algorithm. An attacker who controls a registered JWK/JWKS private key can sign with a disallowed algorithm, advertise an allowed algorithm in the JWT header, and still be accepted. The issue affects the documented PyJWKClient.get_signing_key_from_jwt(...) flow. This vulnerability is fixed in 2.13.0.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-48523",
"url": "https://www.suse.com/security/cve/CVE-2026-48523"
},
{
"category": "external",
"summary": "SUSE Bug 1266799 for CVE-2026-48523",
"url": "https://bugzilla.suse.com/1266799"
}
],
"remediations": [
{
"category": "vendor_fix",
"details": "To install this SUSE Security Update use the SUSE recommended installation methods like YaST online_update or \"zypper patch\".\n",
"product_ids": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"scores": [
{
"cvss_v3": {
"baseScore": 5.4,
"baseSeverity": "MEDIUM",
"vectorString": "CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:L/I:L/A:N",
"version": "3.1"
},
"products": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-06-13T00:00:00Z",
"details": "moderate"
}
],
"title": "CVE-2026-48523"
},
{
"cve": "CVE-2026-48524",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-48524"
}
],
"notes": [
{
"category": "general",
"text": "PyJWT is a JSON Web Token implementation in Python. Prior to 2.13.0, PyJWKClient.get_signing_key() forces a fresh HTTP request to the JWKS endpoint for every JWT with an unknown kid value, with no rate limiting. Since kid comes from the unverified token header, an attacker can trigger unlimited outbound requests. The vulnerability surfaces only when a JWKS fetch fails; an attacker can attempt to provoke that with sustained unknown-kid traffic, but the outcome depends on upstream JWKS-endpoint behavior (rate limiting, transient errors) which is beyond the attacker\u0027s control. This vulnerability is fixed in 2.13.0.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-48524",
"url": "https://www.suse.com/security/cve/CVE-2026-48524"
},
{
"category": "external",
"summary": "SUSE Bug 1266800 for CVE-2026-48524",
"url": "https://bugzilla.suse.com/1266800"
}
],
"remediations": [
{
"category": "vendor_fix",
"details": "To install this SUSE Security Update use the SUSE recommended installation methods like YaST online_update or \"zypper patch\".\n",
"product_ids": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"scores": [
{
"cvss_v3": {
"baseScore": 3.7,
"baseSeverity": "LOW",
"vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:L",
"version": "3.1"
},
"products": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-06-13T00:00:00Z",
"details": "low"
}
],
"title": "CVE-2026-48524"
},
{
"cve": "CVE-2026-48525",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-48525"
}
],
"notes": [
{
"category": "general",
"text": "PyJWT is a JSON Web Token implementation in Python. From 2.8.0 to 2.12.1, when verifying detached JWS tokens using the unencoded-payload option (\"b64\": false, RFC 7797), PyJWT performs Base64URL decoding of the compact-serialization payload segment before enforcing the detached-payload rules. For b64=false, PyJWT later discards that decoded payload and replaces it with the caller-provided detached_payload. In practice, this turns the middle segment into an attacker-controlled \u201cwork amplifier\u201d: a remote client can supply an arbitrarily large Base64URL payload segment that forces CPU work + memory allocations even if the signature is invalid. This creates an unauthenticated DoS vector against any endpoint that verifies detached JWS using PyJWT. This vulnerability is fixed in 2.13.0.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-48525",
"url": "https://www.suse.com/security/cve/CVE-2026-48525"
},
{
"category": "external",
"summary": "SUSE Bug 1266801 for CVE-2026-48525",
"url": "https://bugzilla.suse.com/1266801"
}
],
"remediations": [
{
"category": "vendor_fix",
"details": "To install this SUSE Security Update use the SUSE recommended installation methods like YaST online_update or \"zypper patch\".\n",
"product_ids": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"scores": [
{
"cvss_v3": {
"baseScore": 7.5,
"baseSeverity": "HIGH",
"vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H",
"version": "3.1"
},
"products": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-06-13T00:00:00Z",
"details": "important"
}
],
"title": "CVE-2026-48525"
},
{
"cve": "CVE-2026-48526",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-48526"
}
],
"notes": [
{
"category": "general",
"text": "PyJWT is a JSON Web Token implementation in Python. Prior to 2.13.0, when the verifier is decoding JSON Web Tokens, while supporting both asymmetric and HMAC algorithms, the library does not validate use of JSON Web Keys in HMAC algorithm, allowing attacker to use the issuer public key as the secret key for HMAC algorithm. This vulnerability is fixed in 2.13.0.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-48526",
"url": "https://www.suse.com/security/cve/CVE-2026-48526"
},
{
"category": "external",
"summary": "SUSE Bug 1266802 for CVE-2026-48526",
"url": "https://bugzilla.suse.com/1266802"
}
],
"remediations": [
{
"category": "vendor_fix",
"details": "To install this SUSE Security Update use the SUSE recommended installation methods like YaST online_update or \"zypper patch\".\n",
"product_ids": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"scores": [
{
"cvss_v3": {
"baseScore": 7.4,
"baseSeverity": "HIGH",
"vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N",
"version": "3.1"
},
"products": [
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python311-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python313-PyJWT-2.13.0-1.1.x86_64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.aarch64",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.ppc64le",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.s390x",
"openSUSE Tumbleweed:python314-PyJWT-2.13.0-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-06-13T00:00:00Z",
"details": "important"
}
],
"title": "CVE-2026-48526"
}
]
}
PYSEC-2026-178
Vulnerability from pysec - Published: 2026-05-28 16:16 - Updated: 2026-06-02 10:34PyJWT is a JSON Web Token implementation in Python. From 2.8.0 to 2.12.1, when verifying detached JWS tokens using the unencoded-payload option ("b64": false, RFC 7797), PyJWT performs Base64URL decoding of the compact-serialization payload segment before enforcing the detached-payload rules. For b64=false, PyJWT later discards that decoded payload and replaces it with the caller-provided detached_payload. In practice, this turns the middle segment into an attacker-controlled “work amplifier”: a remote client can supply an arbitrarily large Base64URL payload segment that forces CPU work + memory allocations even if the signature is invalid. This creates an unauthenticated DoS vector against any endpoint that verifies detached JWS using PyJWT. This vulnerability is fixed in 2.13.0.
| Name | purl | pyjwt | pkg:pypi/pyjwt |
|---|
{
"affected": [
{
"ecosystem_specific": {},
"package": {
"ecosystem": "PyPI",
"name": "pyjwt",
"purl": "pkg:pypi/pyjwt"
},
"ranges": [
{
"events": [
{
"introduced": "2.8.0"
},
{
"fixed": "2.13.0"
}
],
"type": "ECOSYSTEM"
}
],
"versions": [
"2.10.0",
"2.10.1",
"2.11.0",
"2.12.0",
"2.12.1",
"2.8.0",
"2.9.0"
]
}
],
"aliases": [
"CVE-2026-48525",
"GHSA-w7vc-732c-9m39"
],
"details": "PyJWT is a JSON Web Token implementation in Python. From 2.8.0 to 2.12.1, when verifying detached JWS tokens using the unencoded-payload option (\"b64\": false, RFC 7797), PyJWT performs Base64URL decoding of the compact-serialization payload segment before enforcing the detached-payload rules. For b64=false, PyJWT later discards that decoded payload and replaces it with the caller-provided detached_payload. In practice, this turns the middle segment into an attacker-controlled \u201cwork amplifier\u201d: a remote client can supply an arbitrarily large Base64URL payload segment that forces CPU work + memory allocations even if the signature is invalid. This creates an unauthenticated DoS vector against any endpoint that verifies detached JWS using PyJWT. This vulnerability is fixed in 2.13.0.",
"id": "PYSEC-2026-178",
"modified": "2026-06-02T10:34:21.164106Z",
"published": "2026-05-28T16:16:29.533Z",
"references": [
{
"type": "EVIDENCE",
"url": "https://github.com/jpadilla/pyjwt/security/advisories/GHSA-w7vc-732c-9m39"
}
],
"severity": [
{
"score": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L",
"type": "CVSS_V3"
}
]
}
Sightings
| Author | Source | Type | Date | Other |
|---|
Nomenclature
- Seen: The vulnerability was mentioned, discussed, or observed by the user.
- Confirmed: The vulnerability has been validated from an analyst's perspective.
- Published Proof of Concept: A public proof of concept is available for this vulnerability.
- Exploited: The vulnerability was observed as exploited by the user who reported the sighting.
- Patched: The vulnerability was observed as successfully patched by the user who reported the sighting.
- Not exploited: The vulnerability was not observed as exploited by the user who reported the sighting.
- Not confirmed: The user expressed doubt about the validity of the vulnerability.
- Not patched: The vulnerability was not observed as successfully patched by the user who reported the sighting.