<?xml version="1.0" encoding="UTF-8"?><rss xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title><![CDATA[[gelöst] iob diag: Checking for nodejs vulnerability]]></title><description><![CDATA[<p dir="auto">... in der Nacht gab es einen Stromausfall ... ;-((</p>
<p dir="auto">Der iobroker läuft (wieder) in einer VM auf einem QNAP NAS aber ... iob diag bringt diesen "Fehler":</p>
<pre><code>Checking for nodejs vulnerability:


██████   █████  ███    ██  ██████  ███████ ███████
██   ██ ██   ██ ████   ██ ██       ██      ██   ██
██   ██ ███████ ██ ██  ██ ██   ███ █████   ███████
██   ██ ██   ██ ██  ██ ██ ██    ██ ██      ██   ██
██████  ██   ██ ██   ████  ██████  ███████ ██   ██


The current Node.js version (v22.22.0) is vulnerable to the following CVEs:

CVE-2026-21637(high): A flaw in Node.js TLS error handling leaves `SNICallback` invocations unprotected against synchronous exceptions, while the equivalent ALPN and PSK callbacks were already addressed in CVE-2026-21637. This represents an incomplete fix of that prior vulnerability.

When an `SNICallback` throws synchronously on unexpected input the exception bypasses TLS error handlers and propagates as an uncaught exception, crashing the Node.js process.

* This vulnerability affects all Node.js versions that received the CVE-2026-21637 fix, including **20.x, 22.x, 24.x, and 25.x**, on any TLS server where `SNICallback` may throw on unexpected `servername` input.
Patched versions: ^20.20.2 || ^22.22.2 || ^24.14.1 || ^25.8.2
=

CVE-2026-21710(high): A flaw in Node.js HTTP request handling causes an uncaught `TypeError` when a request is received with a header named `__proto__` and the application accesses `req.headersDistinct`.

When this occurs, `dest["__proto__"]` resolves to `Object.prototype` rather than `undefined`, causing `.push()` to be called on a non-array. This exception is thrown synchronously inside a property getter and cannot be intercepted by `error` event listeners, meaning it cannot be handled without wrapping every `req.headersDistinct` access in a `try/catch`.

* This vulnerability affects all Node.js HTTP servers on **20.x, 22.x, 24.x, and v25.x**
Patched versions: ^20.20.2 || ^22.22.2 || ^24.14.1 || ^25.8.2
=

CVE-2026-21713(medium): A flaw in Node.js HMAC verification uses a non-constant-time comparison when validating user-provided signatures, potentially leaking timing information proportional to the number of matching bytes. Under certain threat models where high-resolution timing measurements are possible, this behavior could be exploited as a timing oracle to infer HMAC values.

Node.js already provides timing-safe comparison primitives used elsewhere in the codebase, indicating this is an oversight rather than an intentional design decision.

This vulnerability affects **20.x, 22.x, 24.x, and 25.x**.
Patched versions: ^20.20.2 || ^22.22.2 || ^24.14.1 || ^25.8.2
=

CVE-2026-21714(medium): A memory leak occurs in Node.js HTTP/2 servers when a client sends WINDOW_UPDATE frames on stream 0 (connection-level) that cause the flow control window to exceed the maximum value of 2³¹-1. The server correctly sends a GOAWAY frame, but the Http2Session object is never cleaned up.

This vulnerability affects HTTP2 users on Node.js 20, 22, 24 and 25.
Patched versions: ^20.20.2 || ^22.22.2 || ^24.14.1 || ^25.8.2
=

CVE-2026-21715(low): A flaw in Node.js Permission Model filesystem enforcement leaves `fs.realpathSync.native()` without the required read permission checks, while all comparable filesystem functions correctly enforce them.

As a result, code running under `--permission` with restricted `--allow-fs-read` can still use `fs.realpathSync.native()` to check file existence, resolve symlink targets, and enumerate filesystem paths outside of permitted directories.

This vulnerability affects **20.x, 22.x, 24.x, and 25.x** processes using the Permission Model where `--allow-fs-read` is intentionally restricted.
Patched versions: ^20.20.2 || ^22.22.2 || ^24.14.1 || ^25.8.2
=

CVE-2026-21716(low): An incomplete fix for CVE-2024-36137 leaves `FileHandle.chmod()` and `FileHandle.chown()` in the promises API without the required permission checks, while their callback-based equivalents (`fs.fchmod()`, `fs.fchown()`) were correctly patched.

As a result, code running under `--permission` with restricted `--allow-fs-write` can still use promise-based `FileHandle` methods to modify file permissions and ownership on already-open file descriptors, bypassing the intended write restrictions.

This vulnerability affects **20.x, 22.x, 24.x, and 25.x** processes using the Permission Model where `--allow-fs-write` is intentionally restricted.
Patched versions: ^20.20.2 || ^22.22.2 || ^24.14.1 || ^25.8.2
=

CVE-2026-21717(medium): A flaw in V8's string hashing mechanism causes integer-like strings to be hashed to their numeric value, making hash collisions trivially predictable. By crafting a request that causes many such collisions in V8's internal string table, an attacker can significantly degrade performance of the Node.js process.

The most common trigger is any endpoint that calls `JSON.parse()` on attacker-controlled input, as JSON parsing automatically internalizes short strings into the affected hash table.

This vulnerability affects **20.x, 22.x, 24.x, and 25.x**.
Patched versions: ^20.20.2 || ^22.22.2 || ^24.14.1 || ^25.8.2
=

</code></pre>
<p dir="auto">Alle anderen Prüfungen sind "grün" ... Was muss ich tun damit da wieder GOOD steht ?!</p>
<p dir="auto">Danke für die Hilfe.</p>
]]></description><link>https://forum.iobroker.net/topic/84308/gelöst-iob-diag-checking-for-nodejs-vulnerability</link><generator>RSS for Node</generator><lastBuildDate>Tue, 14 Apr 2026 14:46:00 GMT</lastBuildDate><atom:link href="https://forum.iobroker.net/topic/84308.rss" rel="self" type="application/rss+xml"/><pubDate>Tue, 14 Apr 2026 06:30:03 GMT</pubDate><ttl>60</ttl><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 09:17:04 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334570">sagte</a>:</p>
<p dir="auto">In meinem Alter lerne ich langsam aber vergesse schnell ...</p>
</blockquote>
<p dir="auto">Aber lesen kannst du noch? 😉</p>
<p dir="auto">Wenn du das Warning nicht verstehst, dann frag doch.<br />
Dafür sind wir ja da.</p>
<p dir="auto">Ignorieren ist keine Option.</p>
]]></description><link>https://forum.iobroker.net/post/1334574</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334574</guid><dc:creator><![CDATA[Homoran]]></dc:creator><pubDate>Tue, 14 Apr 2026 09:17:04 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 08:55:20 GMT]]></title><description><![CDATA[<p dir="auto">... interessant, aber für mich als <em>einfachster User</em> kann ich da nicht mit halten.<br />
In meinem Alter lerne ich langsam aber vergesse schnell ...<br />
Ich bin immer wieder froh wenn hier im Forum Wissende helfen (auch bei "einfachen" Problemen)</p>
<p dir="auto">Nochmal Danke !!</p>
]]></description><link>https://forum.iobroker.net/post/1334570</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334570</guid><dc:creator><![CDATA[RaspiUser]]></dc:creator><pubDate>Tue, 14 Apr 2026 08:55:20 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 08:41:37 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334549">sagte</a>:</p>
<p dir="auto">Den hatte ich geklickt und dann passierte (scheinbar) nix .... warum ?</p>
</blockquote>
<p dir="auto">Weil der Klick im Hintergrund auch nichts anderes tut als ein</p>
<pre><code>apt upgrade nodejs
</code></pre>
<p dir="auto">auszuführen. Leider wird da aber auch wirklich apt verwendet und nicht apt-get, was an der Stelle sinnvoller wäre, weil apt keine stabile Schnittstelle liefert und für das Handling in Skripten nicht geeignet ist. Ich muss mal suchen in welchem Adapter an welcher Stelle das programmiert worden ist und mach einen PR das wieder zurückzustellen.</p>
]]></description><link>https://forum.iobroker.net/post/1334564</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334564</guid><dc:creator><![CDATA[Thomas Braun]]></dc:creator><pubDate>Tue, 14 Apr 2026 08:41:37 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 08:36:40 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/thomas-braun" aria-label="Profile: Thomas-Braun">@<bdi>Thomas-Braun</bdi></a> <a href="/post/1334561">sagte</a>:</p>
<p dir="auto">wenn</p>
</blockquote>
<p dir="auto">Si!<br />
Deswegen die Nachfrage nach den Warnings bei apt</p>
]]></description><link>https://forum.iobroker.net/post/1334562</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334562</guid><dc:creator><![CDATA[Homoran]]></dc:creator><pubDate>Tue, 14 Apr 2026 08:36:40 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 08:34:54 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334549">sagte</a>:</p>
</blockquote>
<blockquote>
<p dir="auto">... ich habe jetzt "iob nodejs-update" ausgeführt und jetzt ist "iob diag" VERY GOOD ... Danke für eure Hilfe.</p>
</blockquote>
<p dir="auto">Das ist nicht notwendig, wenn das nodesource-Repository richtig angelegt ist. Dann schwimmt auch ein Update von nodejs mit dem allgemeinen Systemupgrade-Zweisprung aus 'apt update &amp;&amp; apt upgrade' mit.<br />
Der 'iob nodejs-update'-Befehlt ist in erster Linie dazu gedacht das nodesource-Repository richtig anzulegen oder falsche Installationen zu reparieren. Dazu wird relativ agressiv vorgegangen. Mit 'apt' ist das ganze etwas sanfter.</p>
]]></description><link>https://forum.iobroker.net/post/1334561</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334561</guid><dc:creator><![CDATA[Thomas Braun]]></dc:creator><pubDate>Tue, 14 Apr 2026 08:34:54 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 08:10:30 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334553">sagte</a>:</p>
<pre><code>das nächste Mal achte ich darauf ...
</code></pre>
</blockquote>
<p dir="auto">Solche Warnings kommen ja nicht ohne Grund.<br />
Die soll man natürlich <strong>IMMER</strong> beachten!</p>
]]></description><link>https://forum.iobroker.net/post/1334555</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334555</guid><dc:creator><![CDATA[Homoran]]></dc:creator><pubDate>Tue, 14 Apr 2026 08:10:30 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 08:02:40 GMT]]></title><description><![CDATA[<p dir="auto">OK ... das nächste Mal achte ich darauf ...</p>
<p dir="auto">Danke</p>
]]></description><link>https://forum.iobroker.net/post/1334553</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334553</guid><dc:creator><![CDATA[RaspiUser]]></dc:creator><pubDate>Tue, 14 Apr 2026 08:02:40 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 07:59:25 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334551">sagte</a>:</p>
<p dir="auto">warum hat der "Update-Kringel" nicht funktioniert ?</p>
</blockquote>
<p dir="auto">Das wird da</p>
<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334551">sagte</a>:</p>
<p dir="auto">ich glaube mich an einige "<strong>Warnings</strong>" zu erinner</p>
</blockquote>
<p dir="auto">Gestanden haben</p>
]]></description><link>https://forum.iobroker.net/post/1334552</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334552</guid><dc:creator><![CDATA[Homoran]]></dc:creator><pubDate>Tue, 14 Apr 2026 07:59:25 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 07:49:10 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/homoran" aria-label="Profile: Homoran">@<bdi>Homoran</bdi></a> <a href="/post/1334550">sagte</a>:</p>
<p dir="auto">Und da kam keine Error/warn Meldung?</p>
</blockquote>
<p dir="auto">... ich glaube mich an einige "Warnings" zu erinnern ... ;-(</p>
<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/homoran" aria-label="Profile: Homoran">@<bdi>Homoran</bdi></a> <a href="/post/1334550">sagte</a>:</p>
<p dir="auto">Einfach so</p>
</blockquote>
<p dir="auto">ja</p>
<p dir="auto">EDIT: Aber warum hat der "Update-Kringel" nicht funktioniert ?</p>
]]></description><link>https://forum.iobroker.net/post/1334551</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334551</guid><dc:creator><![CDATA[RaspiUser]]></dc:creator><pubDate>Tue, 14 Apr 2026 07:49:10 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 07:41:18 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334549">sagte</a>:</p>
<p dir="auto">Hat bisher immer gut funktioniert.</p>
</blockquote>
<p dir="auto">Und da kam keine Error/warn Meldung?</p>
<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334549">sagte</a>:</p>
<p dir="auto">ich habe jetzt "iob nodejs-update" ausgeführt</p>
</blockquote>
<p dir="auto">Einfach so oder noch mit '22' dahinter?</p>
<p dir="auto">Letzteres hätte ich dir sonst geraten, um das vermutlich entgleiste nodesource Repo wieder in die Spur zu bringen</p>
]]></description><link>https://forum.iobroker.net/post/1334550</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334550</guid><dc:creator><![CDATA[Homoran]]></dc:creator><pubDate>Tue, 14 Apr 2026 07:41:18 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 07:38:11 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/thomas-braun" aria-label="Profile: Thomas-Braun">@<bdi>Thomas-Braun</bdi></a> <a href="/post/1334532">sagte</a>:</p>
<p dir="auto">Dein System auf den aktuellen Stand bringen.</p>
</blockquote>
<p dir="auto">... mache ich alle 2 Wochen: "iob stop, sudo apt update, sudo apt full-upgrade, reboot". Hat bisher immer gut funktioniert.</p>
<p dir="auto">... ich habe jetzt "iob nodejs-update" ausgeführt und jetzt ist "iob diag" VERY GOOD ... Danke für eure Hilfe.</p>
<p dir="auto">Aber ... Verständnisfrage:<br />
In der Übersicht <img src="/assets/uploads/files/1776151876548-node.jpg" alt="node.jpg" class=" img-fluid img-markdown" /><br />
konnte ich hier <strong>zuvor</strong> v22.22.0 mit einem Update-Kringel sehen. Den hatte ich geklickt und dann passierte (scheinbar) nix .... warum ?</p>
]]></description><link>https://forum.iobroker.net/post/1334549</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334549</guid><dc:creator><![CDATA[RaspiUser]]></dc:creator><pubDate>Tue, 14 Apr 2026 07:38:11 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 06:46:58 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334526">sagte</a>:</p>
<p dir="auto">Was muss ich tun damit da wieder GOOD steht ?!</p>
</blockquote>
<p dir="auto">Dein System auf den aktuellen Stand bringen.<br />
Sollte man eigentlich ohnehin machen, bevor man ein Forumsposting absetzt. Es ist oft so einfach.</p>
<p dir="auto">Edit: Der Punkt 'Pending Updates' war nämlich nicht grün, da muss mindestens 1 Update angezeigt worden sein.</p>
]]></description><link>https://forum.iobroker.net/post/1334532</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334532</guid><dc:creator><![CDATA[Thomas Braun]]></dc:creator><pubDate>Tue, 14 Apr 2026 06:46:58 GMT</pubDate></item><item><title><![CDATA[Reply to [gelöst] iob diag: Checking for nodejs vulnerability on Tue, 14 Apr 2026 06:35:08 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334526">sagte</a>:</p>
<p dir="auto">Was muss ich tun damit da wieder GOOD steht ?!</p>
</blockquote>
<p dir="auto">Updaten!</p>
<p dir="auto">Auf</p>
<blockquote>
<p dir="auto"><a class="plugin-mentions-user plugin-mentions-a" href="/user/raspiuser" aria-label="Profile: RaspiUser">@<bdi>RaspiUser</bdi></a> <a href="/post/1334526">sagte</a>:</p>
<p dir="auto">Patched versions: ^20.20.2 || ^22.22.2 || ^24.14.1 || ^25.8.2</p>
</blockquote>
]]></description><link>https://forum.iobroker.net/post/1334529</link><guid isPermaLink="true">https://forum.iobroker.net/post/1334529</guid><dc:creator><![CDATA[Homoran]]></dc:creator><pubDate>Tue, 14 Apr 2026 06:35:08 GMT</pubDate></item></channel></rss>