Releases: uNetworking/uWebSockets
v20.67.0
v20.66.0
Minor HTTP corrections
- Emit 431 on too many headers (not just too long headers)
- Don't emit 505 on fragmented request line (regression since 505 was introduced)
v20.65.0
- Always put a reason message on 1006 close events
- Template refactors needed for coming HTTP cache; it should be entirely backwards compatible for your app
v20.64.0
- uWebSockets is now 22% faster than simdutf in validating [mostly English] UTF-8.
v20.63.0
- Make use of ERR_INVALID_CLOSE_PAYLOAD to better explain such closures.
- Remove C-API as it is no longer maintained here, but rather over at the Bun repo.
- It's invalid to pass nullptr to memcpy even with 0 size according to UndefinedBehaviorSanitizer, so this is now fixed.
v20.62.0
RFC 9110 fix part trois
- DQUOTE is not a valid field name char
- "431 Request Header Fields Too Large" will be emitted more strictly
- Reminder: you can set the environment variable UWS_HTTP_MAX_HEADERS_SIZE higher if you need to
v20.61.0
RFC 9110 fix part deux
Previous release did not fix all problems with, for instance, underscores in HTTP field names. This release properly fixes such cases and also makes the HTTP server 14% faster in user space.
A new benchmarking project has been added for reliably benchmarking the entire user space portion of the server by overriding epoll syscalls with traffic producing alternatives. This is a similar approach to how we currently fuzz the user space.
v20.60.0
RFC 9110 fix
A misinterpretation of the spec. has been fixed re. HTTP field names. If you rely on field names that aren't just alphanum + hyphen, this release should fix your use.
v20.59.0
v20.58.0
Parameter routing fixes
Having multiple URL routes with differently named parameter segments at the same depth in the routing tree would cause the order of matching to be potentially different from what the documentation stated.
This release fixes that, and adds more testing for this scenario.