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.
npm install codetheweb/tuyapi
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).
const TuyAPI = require('tuyapi');
const device = new TuyAPI({
id: 'xxxxxxxxxxxxxxxxxxxx',
key: 'xxxxxxxxxxxxxxxx'});
let stateHasChanged = false;
// Find device on network
device.find().then(() => {
// Connect to device
device.connect();
});
// Add event listeners
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']}.`);
// Set default property to opposite
if (!stateHasChanged) {
device.set({set: !(data.dps['1'])});
// Otherwise we'll be stuck in an endless
// loop of toggling the state.
stateHasChanged = true;
}
});
// Disconnect after 10 seconds
setTimeout(() => { device.disconnect(); }, 10000);
const TuyAPI = require('tuyapi');
const device = new TuyAPI({
id: 'xxxxxxxxxxxxxxxxxxxx',
key: 'xxxxxxxxxxxxxxxx'});
(async () => {
await device.find();
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();
})();
- 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.
See the docs.
- Document details of protocol
- Figure out correct CRC algorithm
- codetheweb
- blackrozes
- clach04
- jepsonrob
- tjfontaine
- NorthernMan54
- Apollon77
- dresende
- kaveet
- johnyorke
- jpillora
- neojski
- unparagoned
(If you're not on the above list, open a PR.)
- tuya-convert a project that allows you to flash custom firmware OTA on devices
- python-tuya a Python port by clach04
- m4rcus.TuyaCore a .NET port by Marcus-L
- TuyaKit a .NET port by eppz
- tuya-cli: a CLI interface for Tuya devices
- homebridge-tuya: a Homebridge plugin for Tuya devices
- tuyaweb: a web interface for controlling devices by bmachek
- homebridge-igenix-air-conditioner: a Homebridge plugin for the Igenix IG9901WIFI air conditioner
- magichome-led-controller: a node to use magichome led RGB controller in node-red
- ioBroker.tuya: an ioBroker (http://iobroker.net/) adapter to get data and control devices incl. schema parsing
- node-red-contrib-tuya-smart: A NodeRED input node utilizing tuyapi to connect the smart home
To add your project to either of the above lists, please open a pull request.