Home

Description

Signal K Server is a server application that runs on a central hub in a boat. Prior to version 2.25.0, the HTTP login endpoints (POST /login and POST /signalk/v1/auth/login) are protected by express-rate-limit (default: 100 attempts per 10-minute window, configurable via HTTP_RATE_LIMITS). The WebSocket login path — sending {login: {username, password}} messages over an established WebSocket connection — calls app.securityStrategy.login() directly without any rate limiting. An attacker can bypass HTTP rate limiting entirely by opening a WebSocket connection and attempting unlimited password guesses at the speed bcrypt allows (~20 attempts/sec with 10 salt rounds). This issue has been patched in version 2.25.0.

PUBLISHED Reserved 2026-04-22 | Published 2026-05-09 | Updated 2026-05-09 | Assigner GitHub_M




HIGH: 8.7CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:H/VA:N/SC:N/SI:N/SA:N

Problem types

CWE-307: Improper Restriction of Excessive Authentication Attempts

Product status

< 2.25.0
affected

References

github.com/...server/security/advisories/GHSA-vmfm-ch9h-5c7g

github.com/SignalK/signalk-server/pull/2568

github.com/...ommit/215d81eb700d5419c3396a0fbf23f2e246dfac2d

github.com/SignalK/signalk-server/releases/tag/v2.25.0

cve.org (CVE-2026-41893)

nvd.nist.gov (CVE-2026-41893)

Download JSON