Andy Green | a35c86f | 2013-01-31 10:16:44 +0800 | [diff] [blame] | 1 | Changelog |
| 2 | --------- |
| 3 | |
Andy Green | 51cd925 | 2019-08-14 09:22:50 +0100 | [diff] [blame^] | 4 | v3.2.0 |
| 5 | ====== |
| 6 | |
| 7 | - This is the last planned release under LGPLv2+SLE. It's not planned to be |
| 8 | maintained like previous releases, please switch to master for the latest |
| 9 | stuff or continue to use v3.1-stable until the next release under the |
| 10 | new MIT license. |
| 11 | |
| 12 | - NEW: completely refactored scheduler with a unified, sorted us-resolution |
| 13 | linked-list implementation. All polled checks like timeout are migrated |
| 14 | to use the new timers, which also work on the event lib implementations. |
| 15 | Faster operation, us-resolution timeouts and generic scheduled callbacks |
| 16 | from the event loop. |
| 17 | |
| 18 | - NEW: lws_dsh specialized buffer memory allocator that can borrow space |
| 19 | from other cooperating buffers on the same list. |
| 20 | |
| 21 | - NEW: lws_sequencer allows managing multi-connection processes and |
| 22 | retries |
| 23 | |
| 24 | - NEW: memory buffer cert support |
| 25 | |
| 26 | - NEW: LWS_WITH_NETWORK in CMake... can be configured without any network- |
| 27 | related code at all |
| 28 | |
| 29 | - NEW: builds on QNX 6.5 and SmartOS |
| 30 | |
| 31 | - NEW: JOSE / JWK / JWS / JWE support, for all common ciphers and algs, |
| 32 | works on OpenSSL and mbedtls backends |
| 33 | |
| 34 | - NEW: gencrypto now has genaes and genec in addition to genrsa, works |
| 35 | on OpenSSL and mbedtls backends |
| 36 | |
| 37 | - NEW: raw_proxy role |
| 38 | |
| 39 | - NEW: Basic Auth works on ws connections |
| 40 | |
Andy Green | eda102e | 2018-12-13 20:05:12 +0800 | [diff] [blame] | 41 | - CHANGE: REMOVED: LWS_WITH_GENRSA, LWS_WITH_GENHASH, LWS_WITH_GENEC, |
| 42 | LWS_WITH_GENAES have all been removed and combined into LWS_WITH_GENCRYPTO |
| 43 | |
| 44 | - CHANGE: REMOVED: LWS_WITH_JWS, LWS_WITH_JWE have been removed and combined |
| 45 | into LWS_WITH_JOSE |
| 46 | |
Andy Green | ac03254 | 2018-11-16 09:10:41 +0800 | [diff] [blame] | 47 | v3.1.0 |
| 48 | ====== |
| 49 | |
Andy Green | 502130d | 2018-05-10 16:13:26 +0800 | [diff] [blame] | 50 | - CHANGE: REMOVED: lws_client_connect() and lws_client_connect_extended() |
| 51 | compatibility apis for lws_client_connect_via_info() have been marked as |
| 52 | deprecated for several versions and are now removed. Use |
Andy Green | ac03254 | 2018-11-16 09:10:41 +0800 | [diff] [blame] | 53 | lws_client_connect_via_info() directly instead. |
Andy Green | 502130d | 2018-05-10 16:13:26 +0800 | [diff] [blame] | 54 | |
Andy Green | ac03254 | 2018-11-16 09:10:41 +0800 | [diff] [blame] | 55 | - CHANGE: CMAKE: |
| 56 | - LWS_WITH_HTTP2: now defaults ON |
| 57 | |
Andy Green | d9f982a | 2018-11-19 07:40:47 +0800 | [diff] [blame] | 58 | - CHANGE: Minimal examples updated to use Content Security Policy best |
| 59 | practices, using |
| 60 | `LWS_SERVER_OPTION_HTTP_HEADERS_SECURITY_BEST_PRACTICES_ENFORCE` vhost |
Andy Green | 9bed6d6 | 2018-11-23 08:47:56 +0800 | [diff] [blame] | 61 | option flag and disabling of inline style and scripts. A side-effect of |
| 62 | this is that buffers used to marshal headers have to be prepared to take |
| 63 | more content than previously... LWS_RECOMMENDED_MIN_HEADER_SPACE (2048 |
| 64 | currently) is available for user (and internal) use to logically tie the |
| 65 | buffer size to this usecase (and follow future increases). |
Andy Green | d9f982a | 2018-11-19 07:40:47 +0800 | [diff] [blame] | 66 | |
Andy Green | ac03254 | 2018-11-16 09:10:41 +0800 | [diff] [blame] | 67 | - NEW: CMAKE |
| 68 | - LWS_FOR_GITOHASHI: sets various cmake options suitable for gitohashi |
| 69 | - LWS_WITH_ASAN: for Linux, enable build with ASAN |
| 70 | |
| 71 | Don't forget LWS_WITH_DISTRO_RECOMMENDED, which enables a wide range of lws |
| 72 | options suitable for a distro build of the library. |
| 73 | |
| 74 | - NEW: lws threadpool - lightweight pool of pthreads integrated to lws wsi, with |
| 75 | all synchronization to event loop handled internally, queue for excess tasks |
| 76 | [threadpool docs](https://libwebsockets.org/git/libwebsockets/tree/lib/misc/threadpool) |
| 77 | [threadpool minimal example](https://libwebsockets.org/git/libwebsockets/tree/minimal-examples/ws-server/minimal-ws-server-threadpool) |
| 78 | Cmake config: `-DLWS_WITH_THREADPOOL=1` |
| 79 | |
| 80 | - NEW: libdbus support integrated on lws event loop |
| 81 | [lws dbus docs](https://libwebsockets.org/git/libwebsockets/tree/lib/roles/dbus) |
| 82 | [lws dbus client minimal examples](https://libwebsockets.org/git/libwebsockets/tree/minimal-examples/dbus-client) |
| 83 | [lws dbus server minimal examples](https://libwebsockets.org/git/libwebsockets/tree/minimal-examples/dbus-server) |
| 84 | Cmake config: `-DLWS_ROLE_DBUS=1` |
| 85 | |
| 86 | - NEW: lws allocated chunks (lwsac) - helpers for optimized mass allocation of small |
| 87 | objects inside a few larger malloc chunks... if you need to allocate a lot of |
| 88 | inter-related structs for a limited time, this removes per-struct allocation |
| 89 | library overhead completely and removes the need for any destruction handling |
| 90 | [lwsac docs](https://libwebsockets.org/git/libwebsockets/tree/lib/misc/lwsac) |
| 91 | [lwsac minimal example](https://libwebsockets.org/git/libwebsockets/tree/minimal-examples/api-tests/api-test-lwsac) |
| 92 | Cmake Config: `-DLWS_WITH_LWSAC=1` |
| 93 | |
| 94 | - NEW: lws tokenizer - helper api for robustly tokenizing your own strings without |
| 95 | allocating or adding complexity. Configurable by flags for common delimiter |
| 96 | sets and comma-separated-lists in the tokenizer. Detects and reports syntax |
| 97 | errors. |
| 98 | [lws_tokenize docs](https://libwebsockets.org/git/libwebsockets/tree/include/libwebsockets/lws-tokenize.h) |
| 99 | [lws_tokenize minimal example / api test](https://libwebsockets.org/git/libwebsockets/tree/minimal-examples/api-tests/api-test-lws_tokenize) |
| 100 | |
| 101 | - NEW: lws full-text search - optimized trie generation, serialization, |
| 102 | autocomplete suggestion generation and instant global search support extensible |
| 103 | to huge corpuses of UTF-8 text while remaining super lightweight on resources. |
| 104 | [full-text search docs](https://libwebsockets.org/git/libwebsockets/tree/lib/misc/fts) |
| 105 | [full-text search minimal example / api test](https://libwebsockets.org/git/libwebsockets/tree/minimal-examples/api-tests/api-test-fts) |
| 106 | [demo](https://libwebsockets.org/ftsdemo/) |
| 107 | [demo sources](https://libwebsockets.org/git/libwebsockets/tree/plugins/protocol_fulltext_demo.c) |
| 108 | Cmake config: `-DLWS_WITH_FTS=1 -DLWS_WITH_LWSAC=1` |
| 109 | |
| 110 | - NEW: gzip + brotli http server-side compression - h1 and h2 automatic advertising |
| 111 | of server compression and application to files with mimetypes "text/*", |
| 112 | "application/javascript" and "image/svg.xml". |
| 113 | Cmake config: `-DLWS_WITH_HTTP_STREAM_COMPRESSION=1`, `-DLWS_WITH_HTTP_BROTLI=1` |
| 114 | |
| 115 | - NEW: managed disk cache - API for managing a directory containing cached files |
| 116 | with hashed names, and automatic deletion of LRU files once the cache is |
| 117 | above a given limit. |
| 118 | [lws diskcache docs](https://libwebsockets.org/git/libwebsockets/tree/include/libwebsockets/lws-diskcache.h) |
| 119 | Cmake config: `-DLWS_WITH_DISKCACHE=1` |
| 120 | |
| 121 | - NEW: http reverse proxy - lws mounts support proxying h1 or h2 requests to |
| 122 | a local or remote IP, or unix domain socket over h1. This allows microservice |
| 123 | type architectures where parts of the common URL space are actually handled |
| 124 | by external processes which may be remote or on the same machine. |
| 125 | [lws gitohashi serving](https://libwebsockets.org/git/) is handled this way. |
| 126 | CMake config: `-DLWS_WITH_HTTP_PROXY=1` |
| 127 | |
| 128 | - NEW: lws_buflist - internally several types of ad-hoc malloc'd buffer have |
| 129 | been replaced by a new, exported api `struct lws_buflist`. This allows |
| 130 | multiple buffers to be chained and drawn down in strict FIFO order. |
| 131 | |
| 132 | - NEW: In the case of h1 upgrade, the connection header is checked to contain |
| 133 | "upgrade". The vhost flag LWS_SERVER_OPTION_VHOST_UPG_STRICT_HOST_CHECK |
| 134 | also causes the Host: header to be confirmed to match the vhost name and |
| 135 | listen port. |
Andy Green | c027c3d | 2018-11-21 06:46:23 +0800 | [diff] [blame] | 136 | |
| 137 | - NEW: If no 404 redirect for `lws_return_http_status()` is specified for the vhost, |
| 138 | the status page produced will try to bring in a stylesheet `/error.css`. This allows |
| 139 | you to produce styled 404 or other error pages with logos, graphics etc. See |
| 140 | https://libwebsockets.org/git/badrepo for an example of what you can do with it. |
Andy Green | 502130d | 2018-05-10 16:13:26 +0800 | [diff] [blame] | 141 | |
Andy Green | 1c08a96 | 2018-05-04 13:27:12 +0800 | [diff] [blame] | 142 | v3.0.0 |
| 143 | ====== |
| 144 | |
| 145 | - CHANGE: Clients used to call LWS_CALLBACK_CLOSED same as servers... |
| 146 | LWS_CALLBACK_CLIENT_CLOSED has been introduced and is called for clients |
| 147 | now. |
| 148 | |
| 149 | - CHANGE: LWS_CALLBACK_CLIENT_CONNECTION_ERROR used to only be directed at |
| 150 | protocols[0]. However in many cases, the protocol to bind to was provided |
| 151 | at client connection info time and the wsi bound accordingly. In those |
| 152 | cases, CONNECTION_ERROR is directed at the bound protocol, not protcols[0] |
| 153 | any more. |
| 154 | |
| 155 | - CHANGE: CMAKE: the following cmake defaults have changed with this version: |
| 156 | |
| 157 | - LWS_WITH_ZIP_FOPS: now defaults OFF |
| 158 | - LWS_WITH_RANGES: now defaults OFF |
| 159 | - LWS_WITH_ZLIB: now defaults OFF |
| 160 | - LWS_WITHOUT_EXTENSIONS: now defaults ON |
| 161 | |
| 162 | - CHANGE: REMOVED: lws_alloc_vfs_file() (read a file to malloc buffer) |
| 163 | |
| 164 | - CHANGE: REMOVED: lws_read() (no longer useful outside of lws internals) |
| 165 | |
| 166 | - CHANGE: REMOVED: ESP8266... ESP32 is now within the same price range and much |
| 167 | more performant |
| 168 | |
| 169 | - CHANGE: soname bump... don't forget to `ldconfig` |
| 170 | |
| 171 | - NEW: all event libraries support "foreign" loop integration where lws itself |
| 172 | if just a temporary user of the loop unrelated to the actual loop lifecycle. |
| 173 | |
| 174 | See `minimal-http-server-eventlib-foreign` for example code demonstrating |
| 175 | this for all the event libraries. |
| 176 | |
| 177 | Internal loop in lws is also supported and demonstrated by |
| 178 | `minimal-http-server-eventlib`. |
| 179 | |
| 180 | - NEW: ws-over-h2 support. This is a new RFC-on-the-way supported by Chrome |
| 181 | and shortly firefox that allows ws connections to be multiplexed back to the |
| 182 | server on the same tcp + tls wrapper h2 connection that the html and scripts |
| 183 | came in on. This is hugely faster that discrete connections. |
| 184 | |
| 185 | - NEW: UDP socket adoption and related event callbacks |
| 186 | |
| 187 | - NEW: Multi-client connection binding, queuing and pipelining support. |
| 188 | |
| 189 | Lws detects multiple client connections to the same server and port, and |
| 190 | optimizes how it handles them according to the server type and provided |
| 191 | flags. For http/1.0, all occur with individual parallel connections. For |
| 192 | http/1.1, you can enable keepalive pipelining, so the connections occur |
| 193 | sequentially on a single network connection. For http/2, they all occur |
| 194 | as parallel streams within a single h2 network connection. |
| 195 | |
| 196 | See minimal-http-client-multi for example code. |
| 197 | |
| 198 | - NEW: High resolution timer API for wsi, get a callback on your wsi with |
| 199 | LWS_CALLBACK_TIMER, set and reset the timer with lws_set_timer_usecs(wsi, us) |
| 200 | Actual resolution depends on event backend. Works with all backends, poll, |
| 201 | libuv, libevent, and libev. |
| 202 | |
| 203 | - NEW: Protocols can arrange vhost-protocol instance specific callbacks with |
| 204 | second resolution using `lws_timed_callback_vh_protocol()` |
| 205 | |
| 206 | - NEW: ACME client plugin for self-service TLS certificates |
| 207 | |
| 208 | - NEW: RFC7517 JSON Web Keys RFC7638 JWK thumbprint, and RFC7515 JSON Web |
| 209 | signatures support |
| 210 | |
| 211 | - NEW: lws_cancel_service() now provides a generic way to synchronize events |
| 212 | from other threads, which appear as a LWS_CALLBACK_EVENT_WAIT_CANCELLED |
| 213 | callback on all protocols. This is compatible with all the event libraries. |
| 214 | |
| 215 | - NEW: support BSD poll() where changes to the poll wait while waiting are |
| 216 | undone. |
| 217 | |
| 218 | - NEW: Introduce generic hash, hmac and RSA apis that operate the same |
| 219 | regardless of OpenSSL or mbedTLS tls backend |
| 220 | |
| 221 | - NEW: Introduce X509 element query api that works the same regardless of |
| 222 | OpenSSL or mbedTLS tls backend |
| 223 | |
| 224 | - NEW: Introduce over 30 "minimal examples" in ./minimal-examples... these |
| 225 | replace most of the old test servers |
| 226 | |
| 227 | - test-echo -> minimal-ws-server-echo and minimal-ws-client-echo |
| 228 | |
| 229 | - test-server-libuv / -libevent / -libev -> |
| 230 | minimal-https-server-eventlib / -eventlib-foreign / -eventlib-demos |
| 231 | |
| 232 | - test-server-v2.0 -> folded into all the minimal servers |
| 233 | |
| 234 | - test-server direct http serving -> minimal-http-server-dynamic |
| 235 | |
| 236 | The minimal examples allow individual standalone build using their own |
| 237 | small CMakeLists.txt. |
| 238 | |
| 239 | - NEW: lws now detects any back-to-back writes that did not go through the |
| 240 | event loop inbetween and reports them. This will flag any possibility of |
| 241 | failure rather than wait until the problem happens. |
| 242 | |
| 243 | - NEW: CMake has LWS_WITH_DISTRO_RECOMMENDED to select features that are |
| 244 | appropriate for distros |
| 245 | |
| 246 | - NEW: Optional vhost URL `error_document_404` if given causes a redirect there |
| 247 | instead of serve the default 404 page. |
| 248 | |
| 249 | - NEW: lws_strncpy() wrapper guarantees NUL in copied string even if it was |
| 250 | truncated to fit. |
| 251 | |
| 252 | - NEW: for client connections, local protocol binding name can be separated |
| 253 | from the ws subprotocol name if needed, using .local_protocol_name |
| 254 | |
| 255 | - NEW: Automatic detection of time discontiguities |
| 256 | |
| 257 | - NEW: Applies TCP_USER_TIMEOUT for Linux tcp keepalive where available |
| 258 | |
| 259 | - QA: 1600 tests run on each commit in Travis CI, including almost all |
| 260 | Autobahn in client and server mode, various h2load tests, h2spec, attack.sh |
| 261 | the minimal example selftests and others. |
| 262 | |
| 263 | - QA: fix small warnings introduced on gcc8.x (eg, Fedora 28) |
| 264 | |
| 265 | - QA: Add most of -Wextra on gcc (-Wsign-compare, -Wignored-qualifiers, |
| 266 | -Wtype-limits, -Wuninitialized) |
| 267 | |
| 268 | - QA: clean out warnings on windows |
| 269 | |
| 270 | - QA: pass all 146 h2spec tests now on strict |
| 271 | |
| 272 | - QA: introduce 35 selftests that operate different minimal examples against |
| 273 | each other and confirm the results. |
| 274 | |
| 275 | - QA: LWS_WITH_MINIMAL_EXAMPLES allows mass build of all relevant minimal- |
| 276 | examples with the LWS build, for CI and to make all the example binaries |
| 277 | available from the lws build dir ./bin |
| 278 | |
| 279 | - REFACTOR: the lws source directory layout in ./lib has been radically |
| 280 | improved, and there are now README.md files in selected subdirs with extra |
| 281 | documentation of interest to people working on lws itself. |
| 282 | |
| 283 | - REFACTOR: pipelined transactions return to the event loop before starting the |
| 284 | next part. |
| 285 | |
| 286 | - REFACTOR: TLS: replace all TLS library constants with generic LWS ones and |
| 287 | adapt all the TLS library code to translate to these common ones. |
| 288 | |
| 289 | Isolated all the tls-related private stuff in `./lib/tls/private.h`, and all |
| 290 | the mbedTLS stuff in `./lib/tls/mbedtls` + openSSL stuff in |
| 291 | `./lib/tls/openssl` |
| 292 | |
| 293 | - REFACTOR: the various kinds of wsi possible with lws have been extracted |
| 294 | from the main code and isolated into "roles" in `./lib/roles` which |
| 295 | communicate with the core code via an ops struct. Everything related to |
| 296 | ah is migrated to the http role. |
| 297 | |
| 298 | wsi modes are eliminated and replaced by the ops pointer for the role the |
| 299 | wsi is performing. Generic states for wsi are available to control the |
| 300 | lifecycle using core code. |
| 301 | |
| 302 | Adding new "roles" is now much easier with the changes and ops struct to |
| 303 | plug into. |
| 304 | |
| 305 | - REFACTOR: reduce four different kinds of buffer management in lws into a |
| 306 | generic scatter-gather struct lws_buflist. |
| 307 | |
| 308 | - REFACTOR: close notifications go through event loop |
| 309 | |
| 310 | |
Andy Green | fcf5b2c | 2017-10-16 20:09:58 +0800 | [diff] [blame] | 311 | v2.4.0 |
| 312 | ====== |
| 313 | |
| 314 | - HTTP/2 server support is now mature and usable! LWS_WITH_HTTP2=1 enables it. |
| 315 | Uses ALPN to serve HTTP/2, HTTP/1 and ws[s] connections all from the same |
| 316 | listen port seamlessly. (Requires ALPN-capable OpenSSL 1.1 or mbedTLS). |
| 317 | |
| 318 | - LWS_WITH_MBEDTLS=1 at CMake now builds and works against mbedTLS instead of |
| 319 | OpenSSL. Most things work identically, although on common targets where |
| 320 | OpenSSL has acceleration, mbedTLS is many times slower in operation. However |
| 321 | it is a lot smaller codewise. |
| 322 | |
| 323 | - Generic hash apis introduced that work the same on mbedTLS or OpenSSL backend |
| 324 | |
| 325 | - LWS_WITH_PEER_LIMITS tracks IPs across all vhosts and allows restrictions on |
| 326 | both the number of simultaneous connections and wsi in use for any single IP |
| 327 | |
| 328 | - lws_ring apis provide a generic single- or multi-tail ringbuffer... mirror |
| 329 | protocol now uses this. Features include ring elements may be sized to fit |
| 330 | structs in the ringbuffer, callback when no tail any longer needs an element |
| 331 | and it can be deleted, and zerocopy options to write new members directly |
| 332 | into the ringbuffer, and use the ringbuffer element by address too. |
| 333 | |
| 334 | - abstract ssh 2 server plugin included, with both plugin and standalone |
| 335 | demos provided. You can bind the plugin to a vhost and also serve full- |
| 336 | strength ssh from the vhost. IO from the ssh server is controlled by an |
| 337 | "ops" struct of callbacks for tx, rx, auth etc. |
| 338 | |
| 339 | - Many fixes, cleanups, source refactors and other improvements. |
| 340 | |
| 341 | |
Andy Green | e6bd629 | 2017-07-28 14:13:42 +0800 | [diff] [blame] | 342 | v2.3.0 |
| 343 | ====== |
| 344 | |
| 345 | - ESP32 OpenSSL support for client and server |
| 346 | |
| 347 | - ESP32 4 x WLAN credential slots may be configured |
| 348 | |
| 349 | - Libevent event loop support |
| 350 | |
| 351 | - SOCKS5 proxy support |
| 352 | |
| 353 | - lws_meta protocol for websocket connection multiplexing |
| 354 | |
| 355 | - lws_vhost_destroy() added... allows dynamic removal of listening |
| 356 | vhosts. Vhosts with shared listen sockets adopt the listen socket |
| 357 | automatically if the owner is destroyed. |
| 358 | |
| 359 | - IPv6 on Windows |
| 360 | |
| 361 | - Improved CGI handling suitable for general CGI scripting, eg, PHP |
| 362 | |
| 363 | - Convert even the "old style" test servers to use statically included |
| 364 | plugin sources |
| 365 | |
| 366 | - LWS_WITH_STATS cmake option dumps resource usage and timing information |
| 367 | every few seconds to debug log, including latency information about |
| 368 | delay from asking for writeable callback to getting it |
| 369 | |
| 370 | - Large (> 2GB) files may be served |
| 371 | |
| 372 | - LWS_WITH_HTTP_PROXY Cmake option adds proxying mounts |
| 373 | |
| 374 | - Workaround for libev build by disabling -Werror on the test app |
| 375 | |
| 376 | - HTTP2 support disabled since no way to serve websockets on it |
| 377 | |
| 378 | |
Andy Green | 6be573f | 2017-03-06 15:35:45 +0800 | [diff] [blame] | 379 | v2.2.0 |
| 380 | ====== |
| 381 | |
| 382 | Major new features |
| 383 | |
| 384 | - A mount can be protected by Basic Auth... in lwsws it looks like this |
| 385 | |
| 386 | ``` |
| 387 | { |
| 388 | "mountpoint": "/basic-auth", |
| 389 | "origin": "file://_lws_ddir_/libwebsockets-test-server/private", |
| 390 | "basic-auth": "/var/www/balogins-private" |
| 391 | } |
| 392 | ``` |
| 393 | |
| 394 | The text file named in `basic-auth` contains user:password information |
| 395 | one per line. |
| 396 | |
| 397 | See README.lwsws.md for more information. |
| 398 | |
| 399 | - RFC7233 RANGES support in lws server... both single and multipart. |
| 400 | This allows seeking for multimedia file serving and download resume. |
| 401 | It's enabled by default but can be disabled by CMake option. |
| 402 | |
| 403 | - On Linux, lwsws can reload configuration without dropping ongoing |
| 404 | connections, when sent a SIGHUP. The old configuration drops its |
| 405 | listen sockets so the new configuration can listen on them. |
| 406 | New connections connect to the server instance with the new |
| 407 | configuration. When all old connections eventually close, the old |
| 408 | instance automatically exits. This is equivalent to |
| 409 | `systemctl reload apache` |
| 410 | |
| 411 | - New `adopt` api allow adoption including SSL negotiation and |
| 412 | for raw sockets and file descriptors. |
| 413 | |
| 414 | - Chunked transfer encoding supported for client and server |
| 415 | |
| 416 | - Adaptations to allow operations inside OPTEE Secure World |
| 417 | |
| 418 | - ESP32 initial port - able to do all test server functions. See |
| 419 | README.build.md |
| 420 | |
| 421 | - Serving gzipped files from inside a ZIP file is supported... this |
| 422 | includes directly serving the gzipped content if the client |
| 423 | indicated it could accept it (ie, almost all browsers) saving |
| 424 | bandwidth and time. For clients that can't accept it, lws |
| 425 | automatically decompresses and serves the content in memory- |
| 426 | efficient chunks. Only a few hundred bytes of heap are needed |
| 427 | to serve any size file from inside the zip. See README.coding.md |
| 428 | |
| 429 | - RAW file descriptors may now be adopted into the lws event loop, |
| 430 | independent of event backend (including poll service). |
| 431 | See README.coding.md |
| 432 | |
| 433 | - RAW server socket descriptors may now be enabled on the vhost if |
| 434 | the first thing sent on the connection is not a valid http method. |
| 435 | The user code can associate these with a specific protocol per |
| 436 | vhost, and RAW-specific callbacks appear there for creation, rx, |
| 437 | writable and close. See libwebsockets-test-server-v2.0 for an example. |
| 438 | See README.coding.md |
| 439 | |
| 440 | - RAW client connections are now possible using the method "RAW". |
| 441 | After connection, the socket is associated to the protocol |
| 442 | named in the client connection info and RAW-specific callbacks |
| 443 | appear there for creation, rx, writable and close. |
| 444 | See libwebsockets-test-client (with raw://) for an example. |
| 445 | See README.coding.md |
| 446 | |
| 447 | |
Andy Green | 7355750 | 2016-10-06 21:48:20 +0800 | [diff] [blame] | 448 | v2.1.0 |
| 449 | ====== |
| 450 | |
| 451 | Major new features |
| 452 | |
| 453 | - Support POST arguments, including multipart and file attachment |
| 454 | |
| 455 | - Move most of lwsws into lws, make the stub CC0 |
| 456 | |
| 457 | - Add loopback test plugin to confirm client ws / http coexistence |
| 458 | |
| 459 | - Integrate lwsws testing on Appveyor (ie, windows) |
| 460 | |
| 461 | - Introduce helpers for sql, urlencode and urldecode sanitation |
| 462 | |
| 463 | - Introduce LWS_CALLBACK_HTTP_BIND_PROTOCOL / DROP_PROTOCOL that |
| 464 | are compatible with http:/1.1 pipelining and different plugins |
| 465 | owning different parts of the URL space |
| 466 | |
| 467 | - lwsgs - Generic Sessions plugin supports serverside sessions, |
| 468 | cookies, hashed logins, forgot password etc |
| 469 | |
| 470 | - Added APIs for sending email to SMTP servers |
| 471 | |
| 472 | - Messageboard example plugin for lwsgs |
| 473 | |
| 474 | - Automatic PING sending at fixed intervals and close if no response |
| 475 | |
| 476 | - Change default header limit in ah to 4096 (from 1024) |
| 477 | |
| 478 | - Add SNI matching for wildcards if no specific wildcard vhost name match |
| 479 | |
| 480 | - Convert docs to Doxygen |
| 481 | |
| 482 | - ESP8266 support ^^ |
| 483 | |
Enno Boland | 7731a3e | 2016-05-05 22:08:41 +0200 | [diff] [blame] | 484 | Fixes |
| 485 | ----- |
| 486 | |
Andy Green | 7355750 | 2016-10-06 21:48:20 +0800 | [diff] [blame] | 487 | See git log v2.0.0.. |
Enno Boland | 7731a3e | 2016-05-05 22:08:41 +0200 | [diff] [blame] | 488 | |
Andy Green | fb8be05 | 2016-05-12 19:39:29 +0800 | [diff] [blame] | 489 | |
Enno Boland | 7731a3e | 2016-05-05 22:08:41 +0200 | [diff] [blame] | 490 | |
Andy Green | 5500643 | 2016-05-05 09:40:18 +0800 | [diff] [blame] | 491 | v2.0.0 |
| 492 | ====== |
| 493 | |
| 494 | Summary |
| 495 | ------- |
| 496 | |
| 497 | - There are only api additions, the api is compatible with v1.7.x. But |
| 498 | there is necessarily an soname bump to 8. |
| 499 | |
| 500 | - If you are using lws client, you mainly need to be aware the option |
| 501 | LWS_SERVER_OPTION_DO_SSL_GLOBAL_INIT is needed at context-creation time |
| 502 | if you will use SSL. |
| 503 | |
| 504 | - If you are using lws for serving, the above is also true but there are |
| 505 | many new features to simplify your code (and life). There is a |
| 506 | summany online here |
| 507 | |
| 508 | https://libwebsockets.org/lws-2.0-new-features.html |
| 509 | |
| 510 | but basically the keywords are vhosts, mounts and plugins. You can now |
| 511 | do the web serving part from lws without any user callback code at all. |
| 512 | See ./test-server/test-server-v2.0.c for an example, it has no user |
| 513 | code for ws either since it uses the protocol plugins... that one C file |
| 514 | is all that is needed to do the whole test server function. |
| 515 | |
| 516 | You now have the option to use a small generic ws-capable webserver |
| 517 | "lwsws" and write your ws part as a plugin. That eliminates even |
| 518 | cut-and-pasting the test server code and offers more configurable |
| 519 | features like control over http cacheability in JSON. |
| 520 | |
| 521 | |
Andy Green | 0c3cc2e | 2016-02-20 09:12:52 +0800 | [diff] [blame] | 522 | Fixes |
| 523 | ----- |
| 524 | |
Andy Green | 5500643 | 2016-05-05 09:40:18 +0800 | [diff] [blame] | 525 | These are already in 1.7.x series |
| 526 | |
Andy Green | 0c3cc2e | 2016-02-20 09:12:52 +0800 | [diff] [blame] | 527 | 1) MAJOR (Windows-only) fix assert firing |
| 528 | |
| 529 | 2) MAJOR http:/1.1 connections handled by lws_return_http_status() did not |
| 530 | get sent a content-length resulting in the link hanging until the peer closed |
| 531 | it. attack.sh updated to add a test for this. |
| 532 | |
Andy Green | 26d4249 | 2016-02-24 12:40:21 +0800 | [diff] [blame] | 533 | 3) MINOR An error about hdr struct in _lws_ws_related is corrected, it's not |
| 534 | known to affect anything until after it was fixed |
| 535 | |
Andy Green | 5c0bcf4 | 2016-02-24 21:27:46 +0800 | [diff] [blame] | 536 | 4) MINOR During the close shutdown wait state introduced at v1.7, if something |
| 537 | requests callback on writeable for the socket it will busywait until the |
| 538 | socket closes |
| 539 | |
Andy Green | dbfbbb4 | 2016-02-24 20:58:19 +0800 | [diff] [blame] | 540 | 5) MAJOR Although the test server has done it for a few versions already, it |
| 541 | is now required for the user code to explicitly call |
| 542 | |
| 543 | if (lws_http_transaction_completed(wsi)) |
| 544 | return -1; |
| 545 | |
| 546 | when it finishes replying to a transaction in http. Previously the library |
| 547 | did it for you, but that disallowed large, long transfers with multiple |
| 548 | trips around the event loop (and cgi...). |
| 549 | |
Andy Green | 4ba798d | 2016-02-25 21:50:49 +0800 | [diff] [blame] | 550 | 6) MAJOR connections on ah waiting list that closed did not get removed from |
| 551 | the waiting list... |
| 552 | |
Andy Green | 83af28a | 2016-02-28 10:55:31 +0800 | [diff] [blame] | 553 | 7) MAJOR since we added the ability to hold an ah across http keepalive |
| 554 | transactions where more headers had already arrived, we broke the ability |
| 555 | to tell if more headers had arrived. Result was if the browser didn't |
| 556 | close the keepalive, we retained ah for the lifetime of the keepalive, |
| 557 | using up the pool. |
| 558 | |
Andy Green | 442e1c8 | 2016-02-29 10:10:42 +0800 | [diff] [blame] | 559 | 8) MAJOR windows-only-POLLHUP was not coming |
| 560 | |
Andy Green | 4f5ebec | 2016-03-09 23:13:31 +0800 | [diff] [blame] | 561 | 9) Client should not send ext hdr if no exts |
Andy Green | dbfbbb4 | 2016-02-24 20:58:19 +0800 | [diff] [blame] | 562 | |
Andy Green | 0c3cc2e | 2016-02-20 09:12:52 +0800 | [diff] [blame] | 563 | Changes |
| 564 | ------- |
| 565 | |
| 566 | 1) MINOR test-server gained some new switches |
| 567 | |
| 568 | -C <file> use external SSL cert file |
| 569 | -K <file> use external SSL key file |
| 570 | -A <file> use external SSL CA cert file |
| 571 | |
| 572 | -u <uid> set effective uid |
| 573 | -g <gid> set effective gid |
| 574 | |
| 575 | together you can use them like this to have the test-server work with the |
| 576 | usual purchased SSL certs from an official CA. |
| 577 | |
| 578 | --ssl -C your.crt -K your.key -A your.cer -u 99 -g 99 |
| 579 | |
| 580 | 2) MINOR the OpenSSL magic to setup ECDH cipher usage is implemented in the |
| 581 | library, and the ciphers restricted to use ECDH only. |
| 582 | Using this, the lws test server can score an A at SSLLABS test |
| 583 | |
| 584 | 3) MINOR STS (SSL always) header is added to the test server if you use --ssl. With |
| 585 | that, we score A+ at SSLLABS test |
| 586 | |
| 587 | 4) MINOR daemonize function (disabled at cmake by default) is updated to work |
| 588 | with systemd |
| 589 | |
| 590 | 5) MINOR example systemd .service file now provided for test server |
| 591 | (not installed by default) |
| 592 | |
Andy Green | 0ad1a6e | 2016-02-20 14:05:55 +0800 | [diff] [blame] | 593 | 6) test server html is updated with tabs and a new live server monitoring |
| 594 | feature. Input sanitization added to the js. |
| 595 | |
Andy Green | 2d8d35a | 2016-02-29 14:19:16 +0800 | [diff] [blame] | 596 | 7) client connections attempted when no ah is free no longer fail, they are |
| 597 | just deferred until an ah becomes available. |
| 598 | |
Andy Green | a661ee5 | 2016-02-29 13:18:30 +0800 | [diff] [blame] | 599 | 8) The test client pays attention to if you give it an http:/ or https:// |
| 600 | protocol string to its argument in URL format. If so, it stays in http[s] |
| 601 | client mode and doesn't upgrade to ws[s], allowing you to do generic http client |
Andy Green | 5c8906e | 2016-03-13 16:44:19 +0800 | [diff] [blame] | 602 | operations. Receiving transfer-encoding: chunked is supported. |
Andy Green | a661ee5 | 2016-02-29 13:18:30 +0800 | [diff] [blame] | 603 | |
Andy Green | 1e5a9ad | 2016-03-20 11:59:53 +0800 | [diff] [blame] | 604 | 9) If you enable -DLWS_WITH_HTTP_PROXY=1 at cmake, the test server has a |
| 605 | new URI path http://localhost:7681/proxytest If you visit here, a client |
| 606 | connection to http://example.com:80 is spawned, and the results piped on |
| 607 | to your original connection. |
| 608 | |
| 609 | 10) Also with LWS_WITH_HTTP_PROXY enabled at cmake, lws wants to link to an |
| 610 | additional library, "libhubbub". This allows lws to do html rewriting on the |
| 611 | fly, adjusting proxied urls in a lightweight and fast way. |
Andy Green | fb5f33b | 2016-03-01 07:19:01 +0800 | [diff] [blame] | 612 | |
Andy Green | c6fd360 | 2016-03-23 09:22:11 +0800 | [diff] [blame] | 613 | 11) There's a new context creation flag LWS_SERVER_OPTION_DO_SSL_GLOBAL_INIT, |
| 614 | this is included automatically if you give any other SSL-related option flag. |
| 615 | If you give no SSL-related option flag, nor this one directly, then even |
| 616 | though SSL support may be compiled in, it is never initialized nor used for the |
| 617 | whole lifetime of the lws context. |
| 618 | |
| 619 | Conversely in order to prepare the context to use SSL, even though, eg, you |
| 620 | are not listening on SSL but will use SSL client connections later, you must |
| 621 | give this flag explicitly to make sure SSL is initialized. |
| 622 | |
Andy Green | 2d8d35a | 2016-02-29 14:19:16 +0800 | [diff] [blame] | 623 | |
Andy Green | d7fddad | 2016-02-18 20:36:55 +0800 | [diff] [blame] | 624 | User API additions |
| 625 | ------------------ |
| 626 | |
Andy Green | 0c3cc2e | 2016-02-20 09:12:52 +0800 | [diff] [blame] | 627 | 1) MINOR APIBREAK There's a new member in struct lws_context_creation_info, ecdh_curve, |
Andy Green | d7fddad | 2016-02-18 20:36:55 +0800 | [diff] [blame] | 628 | which lets you set the name of the ECDH curve OpenSSL should use. By |
| 629 | default (if you leave ecdh_curve NULL) it will use "prime256v1" |
| 630 | |
Andy Green | 51d9afa | 2016-02-24 11:05:56 +0800 | [diff] [blame] | 631 | 2) MINOR NEWAPI It was already possible to adopt a foreign socket that had not |
| 632 | been read from using lws_adopt_socket() since v1.7. Now you can adopt a |
| 633 | partially-used socket if you don't need SSL, by passing it what you read |
| 634 | so it can drain that before reading from the socket. |
| 635 | |
| 636 | LWS_VISIBLE LWS_EXTERN struct lws * |
| 637 | lws_adopt_socket_readbuf(struct lws_context *context, lws_sockfd_type accept_fd, |
| 638 | const char *readbuf, size_t len); |
Andy Green | d7fddad | 2016-02-18 20:36:55 +0800 | [diff] [blame] | 639 | |
Andy Green | 6a8099b | 2016-02-21 21:25:48 +0800 | [diff] [blame] | 640 | 3) MINOR NEWAPI CGI type "network io" subprocess execution is now possible from |
| 641 | a simple api. |
| 642 | |
| 643 | LWS_VISIBLE LWS_EXTERN int |
Andy Green | 1a13885 | 2016-03-20 11:55:25 +0800 | [diff] [blame] | 644 | lws_cgi(struct lws *wsi, char * const *exec_array, int script_uri_path_len, |
| 645 | int timeout_secs); |
Andy Green | 6a8099b | 2016-02-21 21:25:48 +0800 | [diff] [blame] | 646 | |
| 647 | LWS_VISIBLE LWS_EXTERN int |
| 648 | lws_cgi_kill(struct lws *wsi); |
| 649 | |
| 650 | To use it, you must first set the cmake option |
| 651 | |
| 652 | $ cmake .. -DLWS_WITH_CGI=1 |
| 653 | |
| 654 | See test-server-http.c and test server path |
| 655 | |
| 656 | http://localhost:7681/cgitest |
| 657 | |
| 658 | stdin gets http body, you can test it with wget |
| 659 | |
| 660 | $ echo hello > hello.txt |
| 661 | $ wget http://localhost:7681/cgitest --post-file=hello.txt -O- --quiet |
| 662 | lwstest script |
| 663 | read="hello" |
| 664 | |
Andy Green | 1a13885 | 2016-03-20 11:55:25 +0800 | [diff] [blame] | 665 | The test script returns text/html table showing /proc/meminfo. But the cgi |
| 666 | support is complete enough to run cgit cgi. |
| 667 | |
Andy Green | d61bed3 | 2016-02-25 15:01:55 +0800 | [diff] [blame] | 668 | 4) There is a helper api for forming logging timestamps |
| 669 | |
| 670 | LWS_VISIBLE int |
| 671 | lwsl_timestamp(int level, char *p, int len) |
| 672 | |
| 673 | this generates this kind of timestamp for use as logging preamble |
| 674 | |
| 675 | lwsts[13116]: [2016/01/25 14:52:52:8386] NOTICE: Initial logging level 7 |
| 676 | |
Andy Green | a661ee5 | 2016-02-29 13:18:30 +0800 | [diff] [blame] | 677 | 5) struct lws_client_connect_info has a new member |
| 678 | |
| 679 | const char *method |
| 680 | |
| 681 | If it's NULL, then everything happens as before, lws_client_connect_via_info() |
| 682 | makes a ws or wss connection to the address given. |
| 683 | |
| 684 | If you set method to a valid http method like "GET", though, then this method |
| 685 | is used and the connection remains in http[s], it's not upgraded to ws[s]. |
| 686 | |
| 687 | So with this, you can perform http[s] client operations as well as ws[s] ones. |
| 688 | |
| 689 | There are 4 new related callbacks |
| 690 | |
| 691 | LWS_CALLBACK_ESTABLISHED_CLIENT_HTTP = 44, |
| 692 | LWS_CALLBACK_CLOSED_CLIENT_HTTP = 45, |
| 693 | LWS_CALLBACK_RECEIVE_CLIENT_HTTP = 46, |
| 694 | LWS_CALLBACK_COMPLETED_CLIENT_HTTP = 47, |
Andy Green | 6a8099b | 2016-02-21 21:25:48 +0800 | [diff] [blame] | 695 | |
Andy Green | 494418a | 2016-03-02 09:17:22 +0800 | [diff] [blame] | 696 | 6) struct lws_client_connect_info has a new member |
| 697 | |
| 698 | const char *parent_wsi |
| 699 | |
| 700 | if non-NULL, the client wsi is set to be a child of parent_wsi. This ensures |
| 701 | if parent_wsi closes, then the client child is closed just before. |
| 702 | |
Andy Green | 0f9904f | 2016-03-17 15:26:49 +0800 | [diff] [blame] | 703 | 7) If you're using SSL, there's a new context creation-time option flag |
| 704 | LWS_SERVER_OPTION_REDIRECT_HTTP_TO_HTTPS. If you give this, non-ssl |
| 705 | connections to the server listen port are accepted and receive a 301 |
| 706 | redirect to / on the same host and port using https:// |
| 707 | |
Andy Green | c5376b1 | 2016-04-08 09:45:49 +0800 | [diff] [blame] | 708 | 8) User code may set per-connection extension options now, using a new api |
| 709 | "lws_set_extension_option()". |
| 710 | |
| 711 | This should be called from the ESTABLISHED callback like this |
| 712 | |
| 713 | lws_set_extension_option(wsi, "permessage-deflate", |
| 714 | "rx_buf_size", "12"); /* 1 << 12 */ |
| 715 | |
| 716 | If the extension is not active (missing or not negotiated for the |
| 717 | connection, or extensions are disabled on the library) the call is |
| 718 | just returns -1. Otherwise the connection's extension has its |
| 719 | named option changed. |
| 720 | |
| 721 | The extension may decide to alter or disallow the change, in the |
| 722 | example above permessage-deflate restricts the size of his rx |
| 723 | output buffer also considering the protocol's rx_buf_size member. |
| 724 | |
| 725 | |
Andy Green | cd0c696 | 2016-03-28 10:12:37 +0800 | [diff] [blame] | 726 | New application lwsws |
| 727 | --------------------- |
| 728 | |
| 729 | A libwebsockets-based general webserver is built by default now, lwsws. |
| 730 | |
| 731 | It's configured by JSON, by default in |
| 732 | |
| 733 | /etc/lwsws/conf |
| 734 | |
| 735 | which contains global lws context settings like this |
| 736 | |
| 737 | { |
| 738 | "global": { |
| 739 | "uid": "99", |
| 740 | "gid": "99", |
| 741 | "interface": "eth0", |
| 742 | "count-threads": "1" |
| 743 | } |
| 744 | } |
| 745 | |
| 746 | /etc/lwsws/conf.d/* |
| 747 | |
| 748 | which contains zero or more files describing vhosts, like this |
| 749 | |
| 750 | { |
| 751 | "vhosts": [ |
| 752 | { "name": "warmcat.com", |
| 753 | "port": "443", |
| 754 | "host-ssl-key": "/etc/pki/tls/private/warmcat.com.key", |
| 755 | "host-ssl-cert": "/etc/pki/tls/certs/warmcat.com.crt", |
| 756 | "host-ssl-ca": "/etc/pki/tls/certs/warmcat.com.cer", |
| 757 | "mounts": [ |
| 758 | { "/": [ |
| 759 | { "home": "file:///var/www/warmcat.com" }, |
| 760 | { "default": "index.html" } |
| 761 | ] |
| 762 | } |
| 763 | ] |
| 764 | } |
| 765 | ] |
| 766 | } |
| 767 | |
| 768 | |
Andy Green | 0c3cc2e | 2016-02-20 09:12:52 +0800 | [diff] [blame] | 769 | |
Andy Green | 9c60ed9 | 2016-02-16 12:32:18 +0800 | [diff] [blame] | 770 | v1.7.0 |
| 771 | ====== |
| 772 | |
Andy Green | 6711266 | 2016-01-11 11:34:01 +0800 | [diff] [blame] | 773 | Extension Changes |
| 774 | ----------------- |
| 775 | |
| 776 | 1) There is now a "permessage-deflate" / RFC7692 implementation. It's very |
| 777 | similar to "deflate-frame" we have offered for a long while; deflate-frame is |
| 778 | now provided as an alias of permessage-deflate. |
| 779 | |
| 780 | The main differences are that the new permessage-deflate implementation: |
| 781 | |
| 782 | - properly performs streaming respecting input and output buffer limits. The |
| 783 | old deflate-frame implementation could only work on complete deflate input |
| 784 | and produce complete inflate output for each frame. The new implementation |
| 785 | only mallocs buffers at initialization. |
| 786 | |
| 787 | - goes around the event loop after each input package is processed allowing |
| 788 | interleaved output processing. The RX flow control api can be used to |
| 789 | force compressed input processing to match the rate of compressed output |
| 790 | processing (test--echo shows an example of how to do this). |
| 791 | |
| 792 | - when being "deflate-frame" for compatibility he uses the same default zlib |
| 793 | settings as the old "deflate-frame", but instead of exponentially increasing |
| 794 | malloc allocations until the whole output will fit, he observes the default |
| 795 | input and output chunking buffer sizes of "permessage-deflate", that's |
| 796 | 1024 in and 1024 out at a time. |
| 797 | |
| 798 | 2) deflate-stream has been disabled for many versions (for over a year) and is |
| 799 | now removed. Browsers are now standardizing on "permessage-deflate" / RFC7692 |
| 800 | |
| 801 | 3) struct lws_extension is simplified, and lws extensions now have a public |
| 802 | api (their callback) for use in user code to compose extensions and options |
| 803 | the user code wants. lws_get_internal_exts() is deprecated but kept around |
| 804 | as a NOP. The changes allow one extension implementation to go by different |
| 805 | names and allows the user client code to control option offers per-ext. |
| 806 | |
| 807 | The test client and server are updated to use the new way. If you use |
| 808 | the old way it should still work, but extensions will be disabled until you |
| 809 | update your code. |
| 810 | |
| 811 | Extensions are now responsible for allocating and per-instance private struct |
| 812 | at instance construction time and freeing it when the instance is destroyed. |
| 813 | Not needing to know the size means the extension's struct can be opaque |
| 814 | to user code. |
| 815 | |
| 816 | |
Andy Green | 3df5800 | 2015-12-25 12:44:12 +0800 | [diff] [blame] | 817 | User api additions |
| 818 | ------------------ |
| 819 | |
Andy Green | 200a6a2 | 2016-02-15 20:36:02 +0800 | [diff] [blame] | 820 | 1) The info struct gained three new members |
Andy Green | 3df5800 | 2015-12-25 12:44:12 +0800 | [diff] [blame] | 821 | |
| 822 | - max_http_header_data: 0 for default (1024) or set the maximum amount of known |
| 823 | http header payload that lws can deal with. Payload in unknown http |
| 824 | headers is dropped silently. If for some reason you need to send huge |
| 825 | cookies or other HTTP-level headers, you can now increase this at context- |
| 826 | creation time. |
| 827 | |
| 828 | - max_http_header_pool: 0 for default (16) or set the maximum amount of http |
| 829 | headers that can be tracked by lws in this context. For the server, if |
| 830 | the header pool is completely in use then accepts on the listen socket |
| 831 | are disabled until one becomes free. For the client, if you simultaneously |
| 832 | have pending connects for more than this number of client connections, |
| 833 | additional connects will fail until some of the pending connections timeout |
| 834 | or complete. |
| 835 | |
Andy Green | 200a6a2 | 2016-02-15 20:36:02 +0800 | [diff] [blame] | 836 | - timeout_secs: 0 for default (currently 20s), or set the library's |
| 837 | network activity timeout to the given number of seconds |
| 838 | |
Andy Green | 3df5800 | 2015-12-25 12:44:12 +0800 | [diff] [blame] | 839 | HTTP header processing in lws only exists until just after the first main |
| 840 | callback after the HTTP handshake... for ws connections that is ESTABLISHED and |
| 841 | for HTTP connections the HTTP callback. |
| 842 | |
| 843 | So these settings are not related to the maximum number of simultaneous |
Andy Green | 3246ebb | 2015-12-26 12:03:06 +0800 | [diff] [blame] | 844 | connections, but the number of HTTP handshakes that may be expected or ongoing, |
Andy Green | 3df5800 | 2015-12-25 12:44:12 +0800 | [diff] [blame] | 845 | or have just completed, at one time. The reason it's useful is it changes the |
| 846 | memory allocation for header processing to be one-time at context creation |
| 847 | instead of every time there is a new connection, and gives you control over |
| 848 | the peak allocation. |
| 849 | |
| 850 | Setting max_http_header_pool to 1 is fine it will just queue incoming |
| 851 | connections before the accept as necessary, you can still have as many |
Andy Green | 5b85e39 | 2015-12-26 13:23:11 +0800 | [diff] [blame] | 852 | simultaneous post-header connections as you like. Since the http header |
| 853 | processing is completed and the allocation released after ESTABLISHED or the |
| 854 | HTTP callback, even with a pool of 1 many connections can be handled rapidly. |
| 855 | |
Andy Green | 066a7a1 | 2015-12-26 15:47:06 +0800 | [diff] [blame] | 856 | 2) There is a new callback that allows the user code to get acccess to the |
| 857 | optional close code + aux data that may have been sent by the peer. |
| 858 | |
| 859 | LWS_CALLBACK_WS_PEER_INITIATED_CLOSE: |
| 860 | The peer has sent an unsolicited Close WS packet. @in and |
| 861 | @len are the optional close code (first 2 bytes, network |
| 862 | order) and the optional additional information which is not |
| 863 | defined in the standard, and may be a string or non-human- |
| 864 | readble data. |
| 865 | If you return 0 lws will echo the close and then close the |
Andy Green | 6711266 | 2016-01-11 11:34:01 +0800 | [diff] [blame] | 866 | connection. If you return nonzero lws will just close the |
| 867 | connection. |
Andy Green | 066a7a1 | 2015-12-26 15:47:06 +0800 | [diff] [blame] | 868 | |
| 869 | As usual not handling it does the right thing, if you're not interested in it |
| 870 | just ignore it. |
| 871 | |
| 872 | The test server has "open and close" testing buttons at the bottom, if you |
| 873 | open and close that connection, on close it will send a close code 3000 decimal |
| 874 | and the string "Bye!" as the aux data. |
| 875 | |
| 876 | The test server dumb-increment callback handles this callback reason and prints |
| 877 | |
| 878 | lwsts[15714]: LWS_CALLBACK_WS_PEER_INITIATED_CLOSE: len 6 |
| 879 | lwsts[15714]: 0: 0x0B |
| 880 | lwsts[15714]: 1: 0xB8 |
| 881 | lwsts[15714]: 2: 0x42 |
| 882 | lwsts[15714]: 3: 0x79 |
| 883 | lwsts[15714]: 4: 0x65 |
| 884 | lwsts[15714]: 5: 0x21 |
| 885 | |
Andy Green | 1fb95e8 | 2015-12-26 17:20:34 +0800 | [diff] [blame] | 886 | 3) There is a new API to allow the user code to control the content of the |
| 887 | close frame sent when about to return nonzero from the user callback to |
| 888 | indicate the connection should close. |
| 889 | |
| 890 | /** |
| 891 | * lws_close_reason - Set reason and aux data to send with Close packet |
| 892 | * If you are going to return nonzero from the callback |
| 893 | * requesting the connection to close, you can optionally |
| 894 | * call this to set the reason the peer will be told if |
| 895 | * possible. |
| 896 | * |
| 897 | * @wsi: The websocket connection to set the close reason on |
| 898 | * @status: A valid close status from websocket standard |
| 899 | * @buf: NULL or buffer containing up to 124 bytes of auxiliary data |
| 900 | * @len: Length of data in @buf to send |
| 901 | */ |
| 902 | LWS_VISIBLE LWS_EXTERN void |
| 903 | lws_close_reason(struct lws *wsi, enum lws_close_status status, |
| 904 | unsigned char *buf, size_t len); |
| 905 | |
| 906 | An extra button is added to the "open and close" test server page that requests |
| 907 | that the test server close the connection from his end. |
| 908 | |
| 909 | The test server code will do so by |
| 910 | |
| 911 | lws_close_reason(wsi, LWS_CLOSE_STATUS_GOINGAWAY, |
| 912 | (unsigned char *)"seeya", 5); |
| 913 | return -1; |
| 914 | |
| 915 | The browser shows the close code and reason he received |
| 916 | |
| 917 | websocket connection CLOSED, code: 1001, reason: seeya |
| 918 | |
Vijay Khurdiya | e73d446 | 2016-01-15 16:21:51 +0800 | [diff] [blame] | 919 | 4) There's a new context creation time option flag |
Andy Green | 44a7f65 | 2015-12-29 11:20:09 +0800 | [diff] [blame] | 920 | |
| 921 | LWS_SERVER_OPTION_VALIDATE_UTF8 |
| 922 | |
| 923 | if you set it in info->options, then TEXT and CLOSE frames will get checked to |
| 924 | confirm that they contain valid UTF-8. If they don't, the connection will get |
| 925 | closed by lws. |
| 926 | |
Vijay Khurdiya | e73d446 | 2016-01-15 16:21:51 +0800 | [diff] [blame] | 927 | 5) ECDH Certs are now supported. Enable the CMake option |
| 928 | |
| 929 | cmake .. -DLWS_SSL_SERVER_WITH_ECDH_CERT=1 |
| 930 | |
| 931 | **and** the info->options flag |
| 932 | |
Andy Green | ff69648 | 2016-02-17 07:46:27 +0800 | [diff] [blame] | 933 | LWS_SERVER_OPTION_SSL_ECDH |
Vijay Khurdiya | e73d446 | 2016-01-15 16:21:51 +0800 | [diff] [blame] | 934 | |
| 935 | to build in support and select it at runtime. |
| 936 | |
Andy Green | ff69648 | 2016-02-17 07:46:27 +0800 | [diff] [blame] | 937 | 6) There's a new api lws_parse_uri() that simplifies chopping up |
Andy Green | 809d69a | 2016-01-14 11:37:56 +0800 | [diff] [blame] | 938 | https://xxx:yyy/zzz uris into parts nicely. The test client now uses this |
Andy Green | d3a5505 | 2016-01-19 03:34:24 +0800 | [diff] [blame] | 939 | to allow proper uris as well as the old address style. |
| 940 | |
| 941 | 7) SMP support is integrated into LWS without any internal threading. It's |
| 942 | very simple to use, libwebsockets-test-server-pthread shows how to do it, |
| 943 | use -j <n> argument there to control the number of service threads up to 32. |
| 944 | |
| 945 | Two new members are added to the info struct |
| 946 | |
| 947 | unsigned int count_threads; |
| 948 | unsigned int fd_limit_per_thread; |
| 949 | |
| 950 | leave them at the default 0 to get the normal singlethreaded service loop. |
| 951 | |
| 952 | Set count_threads to n to tell lws you will have n simultaneous service threads |
| 953 | operating on the context. |
| 954 | |
| 955 | There is still a single listen socket on one port, no matter how many |
| 956 | service threads. |
| 957 | |
| 958 | When a connection is made, it is accepted by the service thread with the least |
| 959 | connections active to perform load balancing. |
| 960 | |
| 961 | The user code is responsible for spawning n threads running the service loop |
| 962 | associated to a specific tsi (Thread Service Index, 0 .. n - 1). See |
| 963 | the libwebsockets-test-server-pthread for how to do. |
| 964 | |
| 965 | If you leave fd_limit_per_thread at 0, then the process limit of fds is shared |
| 966 | between the service threads; if you process was allowed 1024 fds overall then |
| 967 | each thread is limited to 1024 / n. |
| 968 | |
| 969 | You can set fd_limit_per_thread to a nonzero number to control this manually, eg |
| 970 | the overall supported fd limit is less than the process allowance. |
| 971 | |
| 972 | You can control the context basic data allocation for multithreading from Cmake |
| 973 | using -DLWS_MAX_SMP=, if not given it's set to 32. The serv_buf allocation |
| 974 | for the threads (currently 4096) is made at runtime only for active threads. |
| 975 | |
| 976 | Because lws will limit the requested number of actual threads supported |
| 977 | according to LWS_MAX_SMP, there is an api lws_get_count_threads(context) to |
| 978 | discover how many threads were actually allowed when the context was created. |
| 979 | |
| 980 | It's required to implement locking in the user code in the same way that |
| 981 | libwebsockets-test-server-pthread does it, for the FD locking callbacks. |
| 982 | |
Andy Green | ba119e9 | 2016-01-26 21:40:32 +0800 | [diff] [blame] | 983 | If LWS_MAX_SMP=1, then there is no code related to pthreads compiled in the |
| 984 | library. If more than 1, a small amount of pthread mutex code is built into |
| 985 | the library. |
Andy Green | 809d69a | 2016-01-14 11:37:56 +0800 | [diff] [blame] | 986 | |
Andy Green | ba119e9 | 2016-01-26 21:40:32 +0800 | [diff] [blame] | 987 | 8) New API |
| 988 | |
| 989 | LWS_VISIBLE struct lws * |
| 990 | lws_adopt_socket(struct lws_context *context, lws_sockfd_type accept_fd) |
| 991 | |
| 992 | allows foreign sockets accepted by non-lws code to be adopted by lws as if they |
| 993 | had just been accepted by lws' own listen socket. |
Andy Green | 3df5800 | 2015-12-25 12:44:12 +0800 | [diff] [blame] | 994 | |
Danomi Czaski | 4e9c7f3 | 2016-01-28 09:40:53 +0800 | [diff] [blame] | 995 | 9) X-Real-IP: header has been added as WSI_TOKEN_HTTP_X_REAL_IP |
| 996 | |
Andy Green | 86ed65f | 2016-02-14 09:27:41 +0800 | [diff] [blame] | 997 | 10) Libuv support is added, there are new related user apis |
| 998 | |
| 999 | typedef void (lws_uv_signal_cb_t)(uv_loop_t *l, uv_signal_t *w, int revents); |
| 1000 | |
| 1001 | LWS_VISIBLE LWS_EXTERN int |
| 1002 | lws_uv_sigint_cfg(struct lws_context *context, int use_uv_sigint, |
| 1003 | lws_uv_signal_cb_t *cb); |
| 1004 | |
| 1005 | LWS_VISIBLE LWS_EXTERN int |
| 1006 | lws_uv_initloop(struct lws_context *context, uv_loop_t *loop, int tsi); |
| 1007 | |
| 1008 | LWS_VISIBLE void |
| 1009 | lws_uv_sigint_cb(uv_loop_t *loop, uv_signal_t *watcher, int revents); |
| 1010 | |
| 1011 | and CMAKE option |
| 1012 | |
| 1013 | LWS_WITH_LIBUV |
| 1014 | |
Danomi Czaski | 4e9c7f3 | 2016-01-28 09:40:53 +0800 | [diff] [blame] | 1015 | |
Andy Green | 3246ebb | 2015-12-26 12:03:06 +0800 | [diff] [blame] | 1016 | User api changes |
| 1017 | ---------------- |
| 1018 | |
| 1019 | 1) LWS_SEND_BUFFER_POST_PADDING is now 0 and deprecated. You can remove it; if |
| 1020 | you still use it, obviously it does nothing. Old binary code with nonzero |
| 1021 | LWS_SEND_BUFFER_POST_PADDING is perfectly compatible, the old code just |
Andy Green | 5b85e39 | 2015-12-26 13:23:11 +0800 | [diff] [blame] | 1022 | allocated a buffer bigger than the library is going to use. |
Andy Green | 3246ebb | 2015-12-26 12:03:06 +0800 | [diff] [blame] | 1023 | |
Andy Green | 5b85e39 | 2015-12-26 13:23:11 +0800 | [diff] [blame] | 1024 | The example apps no longer use LWS_SEND_BUFFER_POST_PADDING. |
Andy Green | 3246ebb | 2015-12-26 12:03:06 +0800 | [diff] [blame] | 1025 | |
Andy Green | 4e2ac76 | 2015-12-26 20:26:11 +0800 | [diff] [blame] | 1026 | The only path who made use of it was sending with LWS_WRITE_CLOSE ---> |
Andy Green | 3246ebb | 2015-12-26 12:03:06 +0800 | [diff] [blame] | 1027 | |
Andy Green | 1fb95e8 | 2015-12-26 17:20:34 +0800 | [diff] [blame] | 1028 | 2) Because of lws_close_reason() formalizing handling close frames, |
| 1029 | LWS_WRITE_CLOSE is removed from libwebsockets.h. It was only of use to send |
| 1030 | close frames...close frame content should be managed using lws_close_reason() |
| 1031 | now. |
| 1032 | |
Andy Green | 44a7f65 | 2015-12-29 11:20:09 +0800 | [diff] [blame] | 1033 | 3) We check for invalid CLOSE codes and complain about protocol violation in |
| 1034 | our close code. But it changes little since we were in the middle of closing |
| 1035 | anyway. |
| 1036 | |
| 1037 | 4) zero-length RX frames and zero length TX frames are now allowed. |
| 1038 | |
| 1039 | 5) Pings and close used to be limited to 124 bytes, the correct limit is 125 |
| 1040 | so that is now also allowed. |
Andy Green | 3246ebb | 2015-12-26 12:03:06 +0800 | [diff] [blame] | 1041 | |
Steffen Vogel | f926717 | 2016-02-09 07:19:15 +0100 | [diff] [blame] | 1042 | 6) LWS_PRE is provided as a synonym for LWS_SEND_BUFFER_PRE_PADDING, either is |
Andy Green | 6711266 | 2016-01-11 11:34:01 +0800 | [diff] [blame] | 1043 | valid to use now. |
| 1044 | |
| 1045 | 7) There's generic support for RFC7462 style extension options built into the |
| 1046 | library now. As a consequence, a field "options" is added to lws_extension. |
| 1047 | It can be NULL if there are no options on the extension. Extension internal |
| 1048 | info is part of the public abi because extensions may be implemented outside |
| 1049 | the library. |
| 1050 | |
Danomi Czaski | 4e9c7f3 | 2016-01-28 09:40:53 +0800 | [diff] [blame] | 1051 | 8) WSI_TOKEN_PROXY enum was accidentally defined to collide with another token |
| 1052 | of value 73. That's now corrected and WSI_TOKEN_PROXY moved to his own place at |
| 1053 | 77. |
| 1054 | |
Andy Green | 86ed65f | 2016-02-14 09:27:41 +0800 | [diff] [blame] | 1055 | 9) With the addition of libuv support, libev is not the only event loop |
| 1056 | library in town and his api names must be elaborated with _ev_ |
| 1057 | |
| 1058 | Callback typedef: lws_signal_cb ---> lws_ev_signal_cb_t |
| 1059 | lws_sigint_cfg --> lws_ev_sigint_cfg |
| 1060 | lws_initloop --> lws_ev_initloop |
| 1061 | lws_sigint_cb --> lws_ev_sigint_cb |
| 1062 | |
| 1063 | 10) Libev support is made compatible with multithreaded service, |
| 1064 | lws_ev_initloop (was lws_initloop) gets an extra argument for the |
| 1065 | thread service index (use 0 if you will just have 1 service thread). |
| 1066 | |
| 1067 | LWS_VISIBLE LWS_EXTERN int |
Andy Green | ff69648 | 2016-02-17 07:46:27 +0800 | [diff] [blame] | 1068 | lws_ev_initloop(struct lws_context *context, ev_loop_t *loop, int tsi); |
Andy Green | 86ed65f | 2016-02-14 09:27:41 +0800 | [diff] [blame] | 1069 | |
Andy Green | 3df5800 | 2015-12-25 12:44:12 +0800 | [diff] [blame] | 1070 | |
Andy Green | aef3dc4 | 2016-05-06 07:45:19 +0800 | [diff] [blame] | 1071 | (for earlier changelogs, see the tagged releases) |