Skip to main content

A WebSocket to UDP proxy

Project description

ws2udp

A WebSocket to UDP proxy.

ws2udp will forward messages coming from the WebSocket server to UDP sockets, it is especially useful to send OSC messages from JavaScript applications to SuperCollider or any other software that doesn't support WebSockets. It registers all websockets connected and will broadcast messages sent to its own UDP port.

Installation

You will need Python>=3.7 and the websockets package.

The simplest way to install is using pip:

$ pip install ws2udp

Example

$ ws2udp
WebSocket to UDP proxy

optional arguments:
  -h, --help           show this help message and exit
  --udp-addr UDP_ADDR  Address of the UDP receiver for broadcasting messages (default=localhost)
  --udp-port UDP_PORT  Port of the UDP receiver (default=57142)
  --fwd-fixed          Forward UDP to fixed target address/port
  --fwd-addr FWD_ADDR  Address of the UDP target for messages (default=localhost)
  --fwd-port FWD_PORT  Port of the UDP target (default=57143)
  --addr ADDR          WebSocket address to listen (default=0.0.0.0)
  --port PORT          WebSocket port to listen (default=8765)
  --broadcast          Enable UDP broadcasting
  --quiet              No verbose output

If the fwd-fixed option is not given (default behavior), the server expects binary messages following the format:

address_length(uint32)address(string)port(uint32)data

  • address_length is an integer representing the total length of the address
  • address the address where to forward the data as a string (example: localhost)
  • port as an integer
  • data the original message data

For example, to send the message hello world to localhost:57120, one would send:

b'\x09\x00\x00\x00localhost\x20\xdf\x00\x00hello, world'

The first 4 bytes b'\x09\x00\x00\x00 represents 9, then comes b'localhost' and lastly b'\x20\xdf\x00\x00' for 57120. Whatever comes after this is forwarded.

If the fwd-fixed option is given, the original message data will be forwarded unaltered.

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

ws2udp-0.1.7.tar.gz (17.3 kB view details)

Uploaded Source

Built Distribution

ws2udp-0.1.7-py3-none-any.whl (17.9 kB view details)

Uploaded Python 3

File details

Details for the file ws2udp-0.1.7.tar.gz.

File metadata

  • Download URL: ws2udp-0.1.7.tar.gz
  • Upload date:
  • Size: 17.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for ws2udp-0.1.7.tar.gz
Algorithm Hash digest
SHA256 cddd1c59c7885727822a74dc3e002b6c48e07a1ebd92fd0b850c3eb426bfac89
MD5 3680d20acfffbb0ac198348046f851f0
BLAKE2b-256 144838b25f3ee94e608e98a8467fd2af29e21a66fcced6f5c1589d954d5cd28f

See more details on using hashes here.

File details

Details for the file ws2udp-0.1.7-py3-none-any.whl.

File metadata

  • Download URL: ws2udp-0.1.7-py3-none-any.whl
  • Upload date:
  • Size: 17.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for ws2udp-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 5c0447980885ca940374f5829f7cc21ae6c4ce1fe2a8c01ff5edeb70024b44a8
MD5 851b51bd6b50b9932c49089ea14edc45
BLAKE2b-256 86d2e3bcdfb25085e0d2353bd5ea8a051607069f06933f2bf9369b020cd66aaf

See more details on using hashes here.

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