Skip to main content

An implementation of the WebSocket Protocol (RFC 6455 & 7692)

Project description

vtece4564-websockets

This is a fork of the excellent websockets library, created to facilitate use of a patched version that properly supports the threaded WebSocketServer implementation on Windows. A pull request has been submitted to the main project to incorporate the fix in the official distribution.

Unless you're a student of Virginia Tech's ECE 4564 Network Applications Design course in Spring 2023, you almost certainly want to use the official websockets distribution. This distribution will be removed from PyPI in May 2023.

Background

For a senior-level university network apps design course, my students are using the threaded version of WebSocketServer as part of their final project. While the project required their work to run successfully in containers on Linux, many of them use Windows for their development workstation.

We discovered that serve_forever throws an error at startup on Windows due to the use of select.poll as the means to block while waiting for incoming socket connections. The documentation for pollindicates that it is not supported on all platforms, and apparently Windows is one such platform.

We patched WebSocketServer to instead use selectors.DefaultSelector which determines the best supported mechanism for I/O multiplexing on the runtime platform. The functionality is the same, but it works on a wider range of platforms.

After switching to selectors.DefaultSelector, we discovered that Windows also doesn't support I/O multiplexing using pipes or files -- only sockets. we removed the use of os.pipe for the shutdown mechanism. It was redundant anyway -- simply closing the listener socket in the shutdown method is sufficient to cause the selector to return. Subsequently, the call to socket.accept (on the closed listener socket) causes the loop in serve_forever to terminate as expected.

We tested the change on Windows, Mac OS X, and a Linux container, and it seems that it correctly supports all three platforms.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vtece4564-websockets-11.0.2.post2.tar.gz (102.1 kB view hashes)

Uploaded Source

Built Distributions

vtece4564_websockets-11.0.2.post2-py3-none-any.whl (116.0 kB view hashes)

Uploaded Python 3

vtece4564_websockets-11.0.2.post2-pp39-pypy39_pp73-win_amd64.whl (122.7 kB view hashes)

Uploaded PyPy Windows x86-64

vtece4564_websockets-11.0.2.post2-pp39-pypy39_pp73-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (120.6 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

vtece4564_websockets-11.0.2.post2-pp39-pypy39_pp73-macosx_10_9_x86_64.whl (118.8 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

vtece4564_websockets-11.0.2.post2-pp38-pypy38_pp73-win_amd64.whl (122.7 kB view hashes)

Uploaded PyPy Windows x86-64

vtece4564_websockets-11.0.2.post2-pp38-pypy38_pp73-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (120.5 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

vtece4564_websockets-11.0.2.post2-pp38-pypy38_pp73-macosx_10_9_x86_64.whl (118.8 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

vtece4564_websockets-11.0.2.post2-cp311-cp311-win_amd64.whl (122.6 kB view hashes)

Uploaded CPython 3.11 Windows x86-64

vtece4564_websockets-11.0.2.post2-cp311-cp311-win32.whl (122.1 kB view hashes)

Uploaded CPython 3.11 Windows x86

vtece4564_websockets-11.0.2.post2-cp311-cp311-musllinux_1_1_x86_64.whl (133.9 kB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ x86-64

vtece4564_websockets-11.0.2.post2-cp311-cp311-musllinux_1_1_i686.whl (133.3 kB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ i686

vtece4564_websockets-11.0.2.post2-cp311-cp311-musllinux_1_1_aarch64.whl (134.0 kB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ ARM64

vtece4564_websockets-11.0.2.post2-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (129.2 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ ARM64

vtece4564_websockets-11.0.2.post2-cp311-cp311-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (128.6 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.5+ x86-64

vtece4564_websockets-11.0.2.post2-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (128.2 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

vtece4564_websockets-11.0.2.post2-cp311-cp311-macosx_11_0_arm64.whl (119.0 kB view hashes)

Uploaded CPython 3.11 macOS 11.0+ ARM64

vtece4564_websockets-11.0.2.post2-cp311-cp311-macosx_10_9_x86_64.whl (119.0 kB view hashes)

Uploaded CPython 3.11 macOS 10.9+ x86-64

vtece4564_websockets-11.0.2.post2-cp311-cp311-macosx_10_9_universal2.whl (121.7 kB view hashes)

Uploaded CPython 3.11 macOS 10.9+ universal2 (ARM64, x86-64)

vtece4564_websockets-11.0.2.post2-cp310-cp310-win_amd64.whl (122.6 kB view hashes)

Uploaded CPython 3.10 Windows x86-64

vtece4564_websockets-11.0.2.post2-cp310-cp310-win32.whl (122.1 kB view hashes)

Uploaded CPython 3.10 Windows x86

vtece4564_websockets-11.0.2.post2-cp310-cp310-musllinux_1_1_x86_64.whl (132.6 kB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ x86-64

vtece4564_websockets-11.0.2.post2-cp310-cp310-musllinux_1_1_i686.whl (131.9 kB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ i686

vtece4564_websockets-11.0.2.post2-cp310-cp310-musllinux_1_1_aarch64.whl (132.7 kB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ ARM64

vtece4564_websockets-11.0.2.post2-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (128.7 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ ARM64

vtece4564_websockets-11.0.2.post2-cp310-cp310-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (128.0 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.5+ x86-64

vtece4564_websockets-11.0.2.post2-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (127.7 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

vtece4564_websockets-11.0.2.post2-cp310-cp310-macosx_11_0_arm64.whl (119.0 kB view hashes)

Uploaded CPython 3.10 macOS 11.0+ ARM64

vtece4564_websockets-11.0.2.post2-cp310-cp310-macosx_10_9_x86_64.whl (118.9 kB view hashes)

Uploaded CPython 3.10 macOS 10.9+ x86-64

vtece4564_websockets-11.0.2.post2-cp310-cp310-macosx_10_9_universal2.whl (121.7 kB view hashes)

Uploaded CPython 3.10 macOS 10.9+ universal2 (ARM64, x86-64)

vtece4564_websockets-11.0.2.post2-cp39-cp39-win_amd64.whl (122.6 kB view hashes)

Uploaded CPython 3.9 Windows x86-64

vtece4564_websockets-11.0.2.post2-cp39-cp39-win32.whl (122.1 kB view hashes)

Uploaded CPython 3.9 Windows x86

vtece4564_websockets-11.0.2.post2-cp39-cp39-musllinux_1_1_x86_64.whl (132.3 kB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ x86-64

vtece4564_websockets-11.0.2.post2-cp39-cp39-musllinux_1_1_i686.whl (131.7 kB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ i686

vtece4564_websockets-11.0.2.post2-cp39-cp39-musllinux_1_1_aarch64.whl (132.4 kB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ ARM64

vtece4564_websockets-11.0.2.post2-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (128.4 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ ARM64

vtece4564_websockets-11.0.2.post2-cp39-cp39-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (127.7 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.5+ x86-64

vtece4564_websockets-11.0.2.post2-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (127.4 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

vtece4564_websockets-11.0.2.post2-cp39-cp39-macosx_11_0_arm64.whl (119.0 kB view hashes)

Uploaded CPython 3.9 macOS 11.0+ ARM64

vtece4564_websockets-11.0.2.post2-cp39-cp39-macosx_10_9_x86_64.whl (118.9 kB view hashes)

Uploaded CPython 3.9 macOS 10.9+ x86-64

vtece4564_websockets-11.0.2.post2-cp39-cp39-macosx_10_9_universal2.whl (121.7 kB view hashes)

Uploaded CPython 3.9 macOS 10.9+ universal2 (ARM64, x86-64)

vtece4564_websockets-11.0.2.post2-cp38-cp38-win_amd64.whl (122.6 kB view hashes)

Uploaded CPython 3.8 Windows x86-64

vtece4564_websockets-11.0.2.post2-cp38-cp38-win32.whl (122.1 kB view hashes)

Uploaded CPython 3.8 Windows x86

vtece4564_websockets-11.0.2.post2-cp38-cp38-musllinux_1_1_x86_64.whl (132.4 kB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ x86-64

vtece4564_websockets-11.0.2.post2-cp38-cp38-musllinux_1_1_i686.whl (131.8 kB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ i686

vtece4564_websockets-11.0.2.post2-cp38-cp38-musllinux_1_1_aarch64.whl (132.5 kB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ ARM64

vtece4564_websockets-11.0.2.post2-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (128.8 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ ARM64

vtece4564_websockets-11.0.2.post2-cp38-cp38-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (128.2 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.5+ x86-64

vtece4564_websockets-11.0.2.post2-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (127.9 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

vtece4564_websockets-11.0.2.post2-cp38-cp38-macosx_11_0_arm64.whl (119.0 kB view hashes)

Uploaded CPython 3.8 macOS 11.0+ ARM64

vtece4564_websockets-11.0.2.post2-cp38-cp38-macosx_10_9_x86_64.whl (118.9 kB view hashes)

Uploaded CPython 3.8 macOS 10.9+ x86-64

vtece4564_websockets-11.0.2.post2-cp38-cp38-macosx_10_9_universal2.whl (121.7 kB view hashes)

Uploaded CPython 3.8 macOS 10.9+ universal2 (ARM64, x86-64)

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page