Simple lightweight zero-dependency asynchronous IO library
Project description
simio
Python simple lightweight zero-dependency asynchronous IO library.
Motivation
Python 3.4 introduced native support for asynchronous code and announced asyncio standard library. async/await syntax provided a very convenient way to write single-threaded concurrent code but asyncio library itself caused a lot of pain to developers since it was ugly designed and provides very inconvenient api and asynchronous primitives. To fix that problem developers implemented some third-party libraries to replace the standard one like trio.
You may use trio or anyio, but trio implements its own runtime, anyio although work on top of asyncio but provides too high level interface which may be undesirable for small projects.
This library is intended to solve some of that tensions.
Features
- Buffered streams
- TCP stream
- TCP server
Installation
You can install simio with pip:
pip install simio
Quickstart
Buffered stream:
import asyncio as aio
from simio import net, stream
async def main() -> None:
async with await net.open_tcp_stream(
address=net.IPv4Address("httpforever.com", 80),
socket=net.TcpSocketInet(),
) as http_stream:
buffered_stream = stream.BufferedStream(http_stream)
await buffered_stream.write_all(
b'GET / HTTP/1.1\r\n'
b'Host: httpforever.com\r\n'
b'\r\n',
)
status = await buffered_stream.read_until(b'\r\n')
print(status.decode())
headers = await buffered_stream.read_until(b'\r\n\r\n')
headers = dict(line.split(b':', maxsplit=1) for line in headers.removesuffix(b'\r\n\r\n').split(b'\r\n'))
body = await buffered_stream.read_exactly(size=int(headers[b'Content-Length']))
print(body.decode())
aio.run(main())
Echo TCP server:
import asyncio as aio
import logging
from simio import net
async def echo(socket: net.TcpSocket[net.IPv4Address]) -> None:
data = await socket.recv(1024)
await socket.sendall(data)
async def main() -> None:
logging.basicConfig(level=logging.INFO)
await net.start_tcp_server(
net.IPv4Address("127.0.0.1", 8080),
srv_socket=net.TcpSocketInet(),
handler=echo,
graceful_shutdown=10.0,
)
aio.run(main())
TCP client stream:
import asyncio as aio
from simio import net
async def main() -> None:
async with await net.open_tcp_stream(
address=net.IPv4Address("127.0.0.1", 8080),
socket=net.TcpSocketInet(),
) as tcp_stream:
await tcp_stream.write(b"Hello World!!!")
while data := await tcp_stream.read(1024):
print(data)
aio.run(main())
TLS client stream:
import asyncio as aio
from simio import net, stream, tls
async def main() -> None:
hostname = "www.wikipedia.org"
async with await net.open_tcp_stream(net.IPv4Address(hostname, 443), socket=net.TcpSocketInet()) as tcp_stream:
async with tls.open_tls_stream(tcp_stream, server_side=False, server_hostname=hostname) as tls_stream:
http_stream = stream.BufferedStream(tls_stream)
await http_stream.write_all(
b'GET / HTTP/1.0\r\n'
b'Host: www.wikipedia.org\r\n'
b'User-Agent: simio\r\n'
b'\r\n',
)
status = await http_stream.read_until(b'\r\n')
print(status.decode())
raw_headers = await http_stream.read_until(b'\r\n\r\n')
headers: dict[bytes, bytes] = {}
for line in raw_headers.removesuffix(b'\r\n\r\n').split(b'\r\n'):
key, value = line.split(b':', maxsplit=1)
headers[key.lower()] = value.lstrip()
body = await http_stream.read_exactly(size=int(headers[b'content-length']))
print(body.decode())
aio.run(main())
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file simio-1.2.0.tar.gz.
File metadata
- Download URL: simio-1.2.0.tar.gz
- Upload date:
- Size: 12.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.3.4 CPython/3.14.4 Linux/6.17.0-1010-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
38264992bba5f6c5d2de79f13bfe695dd6702738714651ddf7c61b9bc7ec4b9b
|
|
| MD5 |
e4c023e0fbb273051ca4e0e133865081
|
|
| BLAKE2b-256 |
410cb79f3949d09f800444e921244c69d4402bce4cac7fe0c03b55646a955bf2
|
File details
Details for the file simio-1.2.0-py3-none-any.whl.
File metadata
- Download URL: simio-1.2.0-py3-none-any.whl
- Upload date:
- Size: 17.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.3.4 CPython/3.14.4 Linux/6.17.0-1010-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ce5669cb4be03e88f0f875914cc8504cdfbb23e8ab827f9b747ea410d93cd309
|
|
| MD5 |
eed6b947fec0a43295795275b94c30a7
|
|
| BLAKE2b-256 |
846804717641b498ce328d5761604f935b165135f0d3b3fa6d00d8dfaad687f5
|