CVE-2026-41893 PUBLISHED

Signal K Server's WebSocket Login Endpoint Lacks Rate Limiting (Credential Brute-Force)

Assigner: GitHub_M
Reserved: 22.04.2026 Published: 09.05.2026 Updated: 09.05.2026

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.

Metrics

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

Product Status

Vendor SignalK
Product signalk-server
Versions
  • Version < 2.25.0 is affected

References

Problem Types

  • CWE-307: Improper Restriction of Excessive Authentication Attempts CWE