TuyAPI 🌧 🔌

A library for communicating with devices that use the Tuya cloud network. These devices are branded under many different names, but if your device works with the TuyaSmart app or port 6668 is open on your device chances are this library will work.
Installation
npm install codetheweb/tuyapi
Basic Usage
See the setup instructions for how to find the needed parameters.
These examples should report the current status, set the default property to the opposite of what it currently is, then report the changed status.
They will need to be adapted if your device does not have a boolean property at index 1 (i.e. it doesn't have an on/off property).
Asynchronous (event based, recommended)
const TuyAPI = require('tuyapi');
const device = new TuyAPI({
id: 'xxxxxxxxxxxxxxxxxxxx',
key: 'xxxxxxxxxxxxxxxx'});
let stateHasChanged = false;
device.find().then(() => {
device.connect();
});
device.on('connected', () => {
console.log('Connected to device!');
});
device.on('disconnected', () => {
console.log('Disconnected from device.');
});
device.on('error', error => {
console.log('Error!', error);
});
device.on('data', data => {
console.log('Data from device:', data);
console.log(`Boolean status of default property: ${data.dps['1']}.`);
if (!stateHasChanged) {
device.set({set: !(data.dps['1'])});
stateHasChanged = true;
}
});
setTimeout(() => { device.disconnect(); }, 10000);
Synchronous
const TuyAPI = require('tuyapi');
const device = new TuyAPI({
id: 'xxxxxxxxxxxxxxxxxxxx',
key: 'xxxxxxxxxxxxxxxx',
issueGetOnConnect: false});
(async () => {
await device.find();
await device.connect();
let status = await device.get();
console.log(`Current status: ${status}.`);
await device.set({set: !status});
status = await device.get();
console.log(`New status: ${status}.`);
device.disconnect();
})();
📝 Notes
- Only one TCP connection can be in use with a device at once. If using this, do not have the app on your phone open.
- Some devices ship with older firmware that may not work with
tuyapi
. If you're experiencing issues, please try updating the device's firmware in the official app.
- Newer firmware may use protocol 3.3. If you are not using
find()
, you will need to manually pass version: 3.3
to the constructor.
- TuyAPI does not support sensors due to the fact that they only connect to the network when their state changes. There are no plans to add support as it's out of scope to intercept network requests.
- The key parameter for devices changes every time a device is removed and re-added to the TuyaSmart app. If you're getting decrypt errors, try getting the key again - it might have changed.
📓 Documentation
See the docs.
Contributing
See CONTRIBUTING.
Contributors
(If you're not on the above list, open a PR.)
Related
Flash alternative firmware
- tuya-convert a project that allows you to flash custom firmware OTA on devices
Ports
Clients for Tuya's Cloud
Projects built with TuyAPI
To add your project to either of the above lists, please open a pull request.
