-
-
Notifications
You must be signed in to change notification settings - Fork 345
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
v6.0.0 Discussion #169
Comments
Been a busy week, will follow up |
Hi, I don't know if this the right place to post the information but I want to let you know that I have developped a tool to dump communication with tuyadevices. It is based upon gopacket, it can decrypt tuya commands (if provided with the keys!!). By the way, you will find here a golang port of the API https://github.com/py60800/tuya. Still experimental... |
That's cool @py60800, I'll add both projects to the README. :) |
Update; I've been focused on evaluating and reverse engineering the recent activity from Tuya, seems they are starting to take an active stance against local control and firmware freedom. Still a lot of work to be done, and I've been trying to get my hands on every firmware sample I can to speed up the process. If you come across any firmware bins or network captures of these recent updates please let me know! |
To give my contribute, If anyone is interested, I developed a python library that supports gocomma r9 that is a tuya smart remote. I developed also home-assistant remote component that supports it. |
Some thoughts I've gathered over the past year or so:
|
A lot of my suggestions amount to removing and splitting code; this should ease the testing and maintenance burden. For testing purposes I think we should gather real world samples of communication data, rather than relying on our library to convert in one direction and back in the other. |
Really like all of those suggestions @kueblc, thanks for taking the time to think through this. One other thing I was thinking about the other day was creating a second package that layers on top of TuyAPI, providing a common interface for device categories like lightbulbs and outlets. So for example, instead of encoding the color of a lightbulb whatever weird way Tuya devices expect, the user could just run Unfortunately, I've been pretty busy this summer and don't expect to really be able to dedicate a good chunk of time to implement some of this stuff until fall when I'm back in college. So if anyone else visits this issue and the last comment is a few months old, please have patience :). |
Expanding on the above, I was thinking about this yesterday: we could move TuyAPI-related functionality into a new package, Moving this package to be under the
The main downside is that I don't see it being easy to get people to migrate to one of the new packages. Just wanted to jot down some thoughts, take them or leave them. :)
|
Is the anyproxy solution not working? I was just about to try tuyapi out because my latest plugs couldn't be flashed using tuya-convert |
@fondberg people have had mixed results with AnyProxy from what I've heard. You can always just sniff the key manually instead. |
I've been working on a rough prototype for the next major version of TuyAPI over the last few weeks, and I think it's ready for some testing and review. I made a new repo for it at @tuyapi/driver. I'm not completely committed to moving the repo source at this point, and this repo may get merged or something into this one once it's ready. A few things:
Here's an example script that logs all received packets while rapidly toggling the first property of a device (save as const {Device} = require('./dist');
const device = new Device({ip: '', key: '', id: ''});
device.connect();
device.on('connect', async () => {
device.update();
});
device.on('data', frame => console.log(frame));
device.on('state-change', async () => {
console.log(device.get());
await device.set({1: !device.get()['1']});
}); I've only tested it with v3.1 devices so far, as I still haven't gotten a v3.3 device. v3.3 should work, in theory. |
Awesome, looking forward to checking it out, though I'm not familiar with Typescript so like you I may not be able to recommend the "right" way to do things. |
Has anyone had a chance to take a look at the new package? I'd love to ship it before the end of the year if possible. |
@py60800 : I'm fascinated by this. What would it take to add support for v3.3? |
What are the change between protocol 3.3 and 3.1 ? If there is any change in the way encryption is used, it may take some time (they may have fixed some errors in the implementation). I do not have any device using this protocol but I could try to add support if I am provided with samples of communication (tcpdump). |
@kueblc I've been thinking about your suggestion to run end-to-end tests against real data, but I'm having a hard time thinking through how it would work. i.e. if your source is a PCAP file, when do you send the packets coming from the simulated device? How do you check if the packets match without always doing a byte-by-byte compare (sometimes packets have timestamps in the data)? I really would like to test against captured traffic, just not sure how it would work. |
I think that my comment was more about cases like this where we are testing the parser against the encoder. (The idea being, if the parser and encoder are equally wrong, we wouldn't know.) Tests like these should be replaced with tests like this where the cipher is tested against a known fixed result. We could implement this by adding PCAPs and a pcap parser/relay, but I think it would be easiest to implement by just adding more data samples embedded as strings directly to the tests. |
Got it, that makes more sense. So test against static data for unit tests and @tuyapi/stub for end-to-end? |
Yup, that's it. Hopefully I'll be able to help out again soon, just finishing up a couple big jobs. |
Alright, sounds good. |
Due to other commitments, I unfortunately don't see this getting done by the end of the year. I think January / early February is a more realistic target at this point. The core code is mostly done, we just have tests and error handling / edge cases left (unless we want to restructure it slightly). |
Any progress? Thanks |
TL;DR: Yes. No. Maybe? I've been meaning to post an update for a while. I don't know if you saw it, but @tuyapi/driver is where I've been working on "v6". But I haven't worked on it in a while (4 months according to the commit log) for a number of factors:
So. All that to say that I don't yet know what the future holds for TuyAPI. If I do new development work in the future, it'll probably be on cloud libraries or tuya-convert. |
@codetheweb I certainly agree with your analysis of the users (2 categories of needs). Which tool would you recommend for using Tuya cloud instead of local communication with the device? |
There's already a repo for their Open API, but I haven't thoroughly documented it yet. We would also have to add a lot more functions to the wrapper to allow for device control, but that's fairly trivial. It would be nice to be able to use your login & password from the Tuya app, but without extracting the API key from the official app you're only able to use the Home Assistant API that Tuya made available. I don't think that API can control all device types / attributes. |
Came across the link here while reading through #5, and read your thoughts above:
I would say that I am in a third category. I would normally be in your second category, in fact I bought my devices from the outset with the intention of flashing {Tasmota,Espurna,etc.} on them, but ended up learning they were not ESP8266 based at all but rather TW-02 (WinnerMicro W600-based) smart sockets. Therefore I think the only option available to me will be to try and contain them on my own local network, and control them locally. I am definitely NOT OK with them "phoning home" in fact if I cannot figure out a way to get this to work without doing so, I am simply going to chuck them in the bin. I have no idea how common these "not ESP8266" based modules are, nor if they will become more common in future, but just something to factor into your consideration whether there is still a need here. I'm not implying you need to force yourself to do anything you don't want to. You have done a lot already @codetheweb, and it is greatly appreciated! If you feel 2.0 is "good enough" then so be it. Overall your assessment of the shifting sands is more or less correct I suppose. Just wanted to point out there is a third category (since you asked). 😉 Cheers, mate! 🍻 Happy Friday! 🎉 |
Good point, thanks for chipping in. If you go through Tuya's wizard to create new whitelabeled devices, there are actually a far number of hardware choices that aren't ESP* based - so I expect to continue to see non ESP* Tuya devices manufactured. I dunno how many though. Would be very nice if there were some stats somewhere showing what chipsets active Tuya devices use as percentages. |
More data points are almost always good for decision making, I suppose. In that vein, and for the record, the following is what I came across during my research. I remember @kueblc while back (2018?) in #5 saying ~ "API keys used to be easy to get, now they cost $1,000." Now maybe he was talking about different type of keys than current method (not sure) but that certainly does not appear to be the case right now (or I am mixing things up). Or possibly Tuya market strategy changed. More recently they seem to want to be much more open to devs. I base this on article like this: Tuya Smart unveils 2020 strategy, launches Cloud Development Platform to global developers during the AI+IoT Business Conference which is from May 27, 2020. Personally I am always leery of big companies marketing bullshit. I suppose maybe once I create new developer account (or perhaps independent of it) I could email them and ask what the percentages are. We will find out real fast just how "open and co-operative" they really are trying to be... |
Yeah, they are much more developer-friendly than they were a few years ago (although they still have a long ways to go). Their Home Assistent module was quite recently added, so they do seem open to hobbyist integrations. |
I was aware that Tuya themselves are in fact the official contributor / maintainer of the HA module. I don't use HA nor Tuya stuff (other than these few modules I have been trying to get working) but my understanding is that HA module is cloud only? In fact, when someone from here tried to suggest using I understand that average Joe consumer needs something easy that "just works" out of the box. Which actually requires some cloud crap if you start thinking about just how you would implement something like that. This is in fact your first case, above. However, completely locking down the platform like typical dinosaur business model control freaks is another thing entirely. And companies who act in such ways can go DIAF, IMHO. I only looked into this a moderate amount, in the context of my research trying to get these few modules working, so perhaps my read on the situation is off. But, barring further feedback from you guys more involved, I don't think it is. As a matter of fact, the amount of time this has taken just re-enforces my belief that it is ultimately a waste of time trying to deal with such closed off things at all in the first place. Don't get me wrong, I greatly appreciate all your efforts, and thankfully I suppose I am writing all of this @codetheweb mostly directed at you (and perhaps any others reading). But in your case, I realized you are still quite a young guy, still in college if I am not mistaken. And wow, good for you, having such projects under your belt already at such a young age! Anyway you are clearly a bright young person. I don't know if you ever been exposed to ideas of Free / Libre Software as more often nowadays "Open Source" seems to get mentioned a lot more. But ultimately that is what we are talking about here, freedom and control. I trust you are smart enough to figure out what is good and right actions to take, if only provided with the right information. Personally, I never understood what all the fuss was about until I got my head around these ideas, and for me that was not even until just a few years ago. Anyway, enough of my idiotic ramblings. Cheers, and thanks for all the fish! 🍻 |
Hi, I wonder if anyone can help. I'm using tuya api for a personal project, a sort of smart life app for local control of tuya devices. I will share the code if I get it finished. So far so good apart from RGB control. According to the information Here the following code should set the bulb color to yellow
On/off switch and white mode work fine. Could the device RGB encoding be different? It's a generic tuya bulb sold under the brand name 'bomcosy'. Thanks for your efforts in developing such a great api. |
I don't use RGB bulbs myself, so I'm afraid I can't really help there. You may have better luck posting here. You could also try using |
This issue will hopefully contain a more detailed plan and checklist in the future, but for now here's what we have
Not sure how you want to split up the work @kueblc. I can also work on @tuyapi/stub or similar.
The text was updated successfully, but these errors were encountered: