Asynchronous library to control Shelly devices.
Project description
Aioshelly
Asynchronous library to control Shelly devices
This library is under development
Requires Python 3 and uses asyncio, aiohttp and socket.
From release 1.0.0 and up library has breaking changes to support Shelly Gen2 devices Gen1 Device
class moved under block_device
Gen1 Device (Block/CoAP) example:
import asyncio
from pprint import pprint
import aiohttp
import async_timeout
from aioshelly.block_device import COAP, BlockDevice
from aioshelly.common import ConnectionOptions
async def test_block_device():
"""Test Gen1 Block (CoAP) based device."""
options = ConnectionOptions("192.168.1.165", "username", "password")
async with aiohttp.ClientSession() as aiohttp_session, COAP() as coap_context:
try:
async with async_timeout.timeout(10):
device = await BlockDevice.create(
aiohttp_session, coap_context, options
)
except asyncio.TimeoutError:
print("Timeout connecting to", options.ip_address)
return
for block in device.blocks:
print(block)
pprint(block.current_values())
print()
if __name__ == "__main__":
asyncio.run(test_block_device())
Gen2 (RPC/WebSocket) device example:
import asyncio
from pprint import pprint
import aiohttp
import async_timeout
from aioshelly.common import ConnectionOptions
from aioshelly.rpc_device import RpcDevice
async def test_rpc_device():
"""Test Gen2 RPC (WebSocket) based device."""
options = ConnectionOptions("192.168.1.188", "username", "password")
async with aiohttp.ClientSession() as aiohttp_session:
try:
async with async_timeout.timeout(10):
device = await RpcDevice.create(aiohttp_session, options)
except asyncio.TimeoutError:
print("Timeout connecting to", ConnectionOptions.ip_address)
return
pprint(device.status)
if __name__ == "__main__":
asyncio.run(test_rpc_device())
Included examples
The repository includes two examples to quickly try it out.
Connect to a device and print its status whenever we receive a state change:
python3 example.py -ip <ip> [-u <username>] [-p <password]
Connect to all the devices in devices.json
at once and print their status:
python3 example.py -d -i
Show usage help:
python3 example.py -h
Contribution guidelines
Object hierarchy and property/method names should match the Shelly API.
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
aioshelly-1.0.6.tar.gz
(17.1 kB
view details)
Built Distribution
aioshelly-1.0.6-py3-none-any.whl
(19.3 kB
view details)
File details
Details for the file aioshelly-1.0.6.tar.gz
.
File metadata
- Download URL: aioshelly-1.0.6.tar.gz
- Upload date:
- Size: 17.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1f5dc0c8873925222f8b2136bca42ed77763ee136ac1135f08fc3872064f8848 |
|
MD5 | 97a7626d30389af512ccac3abfa25c21 |
|
BLAKE2b-256 | f1b5701c29ecafc77f13e19234b9d045247472af13b32070a7a04760f8fcd32b |
File details
Details for the file aioshelly-1.0.6-py3-none-any.whl
.
File metadata
- Download URL: aioshelly-1.0.6-py3-none-any.whl
- Upload date:
- Size: 19.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 704ac4b78820ab03ee6bf29c12f006a8cfc5c3693422c8410f1a6bea58e9cf3b |
|
MD5 | 8808643f24e4f7a8dd802a3d8ff0d83c |
|
BLAKE2b-256 | 01da6b70f5f77e01a8252b9271e1f9fdab4ceedae673d8077b757da9460c1830 |