Python interface to Tuya WiFi smart devices.
Project description
TuyaFace
Tuya client that allows you to locally communicate with tuya devices without the tuya-cloud.
Installation
pip install tuyaface
or
pip install tuyaface==1.1.0
Public Interface
Request device status
status(device: dict)
Returns json string
Change device state
set_state(device: dict, value: bool, idx: int = 1)
Returns json string
Change device status
set_status(device: dict, dps: dict)
Returns json string
Device dict
device = {
'protocol': '3.3', # 3.1 | 3.3
'deviceid': '34280100600194d17c96',
'localkey': 'e7e9339aa82abe61',
'ip': '192.168.1.101',
}
DPS dict
dps = {
'1': 0,
'103' 255,
...etc...
}
Todo
- _select_reply use filter
Changelog
v1.1.2
- moved constants to separate file
- _stitch_payload type casting
v1.1.1
- better description pub interface
- replaced pycrypto with pycryptodome
v1.1.0 Breaking
- function set_status was added
- functionname set_status was changed to set_state
v1.0.5
- setup fixed
- split _generate_payload function to a readable format
- add support for older devices back in (untested, please report back)
- solved recursion problem in send_request
- moved functions back to init
- removed TuyaConnection class, use send_request in try/except
- declassified aescipher
- moved to a more functional programming style
- yield and list comprehensions
- setup.py
- removed code for older devices < 3.3
Implementations
- https://github.com/TradeFace/tuyamqtt
- let me know, I'll add it here
Acknowledgements
- This module is a rewrite of https://github.com/clach04/python-tuya
- https://github.com/codetheweb/tuyapi as reference on commands
- https://github.com/SDNick484 for testing protocol 3.1 reimplementation
- https://github.com/jkerdreux-imt several improvements
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
tuyaface-1.1.2.tar.gz
(5.9 kB
view hashes)