CVE-2026-58371
NiskieCVSS 3.1Prawdopodobieństwo exploitacji (EPSS)
Niskie ryzykoPercentyl 11 — wyżej niż 11% wszystkich znanych CVE
Streszczenie
Podatność w SeaweedFS przed wersją 4.30 powoduje, że parametr wywołania zwrotnego (callback) jest odbijany bez walidacji w odpowiedziach JSON z typem MIME application/javascript. Brak nagłówka X-Content-Type-Options: nosniff oraz listy dozwolonych domen CORS umożliwia atakującemu wczytanie odpowiedzi z dowolnego punktu końcowego JSON (w tym nieuwierzytelnionych) za pomocą znacznika <script> z zewnętrznej strony.
Ocena ryzyka
Organizacja narażona jest na wyciek wrażliwych informacji, takich jak topologia klastra, adresy serwerów woluminów, porty gRPC, identyfikatory plików oraz listy katalogów. Atakujący z zewnętrznej strony internetowej może odczytać te dane, co może prowadzić do dalszych ataków na infrastrukturę.
Rekomendacja
Należy niezwłocznie zaktualizować SeaweedFS do wersji 4.30 lub nowszej. Dodatkowo, w konfiguracji należy włączyć listę dozwolonych domen CORS, ustawić nagłówek X-Content-Type-Options: nosniff oraz ograniczyć dostęp do punktów końcowych za pomocą parametru -whiteList lub pliku security.toml.
Oryginalny opis (angielski, źródło NVD)
SeaweedFS before 4.30 reflects the callback query parameter verbatim into responses served with Content-Type application/javascript in the shared writeJson helper (weed/server/common.go), with no callback-name validation, no X-Content-Type-Options: nosniff header, and no CORS allow-list. Every JSON endpoint that uses writeJson - including the unauthenticated master endpoints /dir/status, /dir/lookup and /cluster/status, the volume server /status, and the filer directory listing, all reachable in the default configuration (no -whiteList, no security.toml, bound to 0.0.0.0) - can therefore be loaded cross-origin via a script tag with a chosen callback, letting a third-party web page read cluster topology, volume server URLs and gRPC ports, file identifiers, and directory listings. Because the callback string is reflected at the start of the body and no nosniff header is sent, MIME-sniffing clients may also interpret the reflected content as HTML.

