-
Notifications
You must be signed in to change notification settings - Fork 54
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
AC2889/10 no longer working #93
Comments
I can confirm this issue. AFAIK: Philips released a new firmware version which installed without user interaction. If anybody could give me any hint how to decode the new interaction. Help would be much appreciated. My router supports packet capture and exporting to wireshark compatible file type. But i have no idea what to do from there on. Best regards, Peter |
Fortunately, I blocked internet access for the cleaner some weeks ago and I still have the FW 62.1. I have never done such a network analysis, but if you could step me through, I would like to provide the data for the old firmware. |
What ever you do, do not post the package capture file itself to the internet, it contains ANYTHING transmitted by WLAN in the regarding timeframe. Best regards, Peter P.S.: I really hope you don't hit a roadblock at step 1 |
I have the same error from yesterday. airctrl --ipaddr 192.168.0.10 --protocol coap I think philips updated firmware and something was changed. |
Yes, indeed, my AC1214/10 started to show the same error, right after performing the firmware update (WiFi WPA3). |
I've been in the same situation, on the new firmware and I lost local control most of the time (it would occasionally work), so I took a closer look. It seems the requests are timing out so increasing the hard-coded timeouts to 10s in coap_client (and adding a timeout argument on line 177) restores operation for me. |
Can you show what did you added? |
The first couple of lines were just some trailing whitespace which was triggering syntastic, but the remainder is the relevant part: index 9d5b142..d2f76eb 100644
--- a/pyairctrl/coap_client.py
+++ b/pyairctrl/coap_client.py
@@ -83,15 +83,15 @@ class CoAPAirClient(HTTPAirClientBase):
def __del__(self):
# TODO call a close method explicitly instead
if self.response:
- self.client.cancel_observing(self.response, True)
- self.client.stop()
+ self.client.cancel_observing(self.response, True)
+ self.client.stop()
def _create_coap_client(self, host, port):
return HelperClient(server=(host, port))
def _sync(self):
self.syncrequest = binascii.hexlify(os.urandom(4)).decode("utf8").upper()
- resp = self.client.post("/sys/dev/sync", self.syncrequest, timeout=5)
+ resp = self.client.post("/sys/dev/sync", self.syncrequest, timeout=10)
if resp:
self.client_key = resp.payload
else:
@@ -145,7 +145,7 @@ class CoAPAirClient(HTTPAirClientBase):
try:
request = self.client.mk_request(defines.Codes.GET, path)
request.observe = 0
- self.response = self.client.send_request(request, None, 2)
+ self.response = self.client.send_request(request, None, 10)
encrypted_payload = self.response.payload
decrypted_payload = self._decrypt_payload(encrypted_payload)
except WrongDigestException:
@@ -174,7 +174,7 @@ class CoAPAirClient(HTTPAirClientBase):
}
}
encrypted_payload = self._encrypt_payload(json.dumps(payload))
- response = self.client.post(path, encrypted_payload)
+ response = self.client.post(path, encrypted_payload, timeout=10)
if self.debug:
print(response)
return response.payload == '{"status":"success"}' Ideally, I'd suggest using a defined constant but I thought I'd see what people thought before proposing something more concrete. |
I ping airtctl 10 times and 2 times I got Thanks. |
Both changes seem to go into the right direction (thanks!!). Nevertheless, I found more timeouts than before. I use the connection to (a) change the level based on time of day and (b) track air quality via FHEM. As I send the change command three times in a row, that seems to be more stable. Tracking misses many data points, unfortunately. |
FYI .. timeout with 60 does not help on my new Model: AC2889/10 (AC2889/10) |
Same problem here with the AC2939/10 and Firmware 64.3. |
My AC2889/10 still only responds less than half of the time after changing timeouts to 60 seconds. When it does respond, the time taken seems to be totally random - occasionally it's almost immediate, other times anything up to the timeout limit. Most of my testing is done when the device is "off", and I'm wondering what else it's doing that would prevent it responding to a status inquiry.
|
I've spent a few hours now looking into this, what's a tad more "reliable/speedy" than the increased timeout is a recursive call to establish the connection on error/timeout, but that's not really pretty either. |
Just got a new AC2889/10 with FW 1.0.7. The app doesn't even find the device in the lan: |
I have a workaround... using another package. I am now using this package https://github.com/betaboon/aioairctrl which has a small bug which i fixed here https://github.com/Peter-J/aioairctrl (output was not flushed so piping it to another script did not work). You can install it using
Biggest feature is that aioairctrl can continously listen to the air purifyer. Again, if your airquality is too god / does not change you will have to wait a long time for the first message. Changing your fanspeed will force new messages to be send. I included my scripts in the examples folder. Don't expect too much in regards of code quality / readability and so on but i have not a single faild send or recieve. Zero user intervention since. If you find any bugs / have suggestions please let me know. Will make a pull-request in a few days. Best regards, Peter |
Thanks, @peter-j , for your efforts. Unfortunately, your version of Both devices are on firmware version 67.5 Edit: it sometimes does indeed work, and then again stops working. |
both devices still don't work all the time (most of the time not) |
Im wondering if I have the same issue as you. Does your air purifier stay on the same readings for a long time? My replacement 2000i (1st one had a faulty sensor) is freezing on 4-IAI and 13-PM2.5 for a good 5 minutes before jumping to 2 on the Allergen Index and skipping 3. Is there some kind of buffer value built in so the fan speeds don't adjust too often when just above or below the thresholds for good and fair air quality? I'm trying to work out if its a fault or a feature but I'm getting nowhere with Philips support. Cheers |
No, it doesn't freeze. I'm pretty sure it is a bug in their implementation. When I capture the network traffic, at times the device stops sending CoaP telegrams, but keeps talking to some Amazon servers, which presumably are serving the cloud service of Philips. The most stable solution would probably be to understand the cloud protocol. |
https://github.com/betaboon/aioairctrl still works. But because its using the observer pattern as opposed to continously poll. Big reason I had to switch to this library instead. At least if my memory serves correctly... |
Not working for me at the moment. But I guess, this is down to the Philips devices. If they don't transmit any CoaP, |
both ours AC5659/10 and2889/10 on 69.1. I should have disconnected them from getting on the WAN. |
I think there has to be a command to request state re-transmission. I've done the following test:
This is stuck, waiting for updates... But when you then open the |
@dfrommi, @kongo09: Peter and siren wrote solution, I will let myself provide some examples.
siren meant reding status that way [1️⃣]: I like You can force message to appear some while using cmd [※1️⃣] on another terminal/panel, as it have to have be running before next step, which is an attempt to control yours purifiers, e.g.: Unfortunately, sometimes I need to do it twice, so again: Which will result that the |
I have a AC2889/10 with updated firmware of course (I guess). Is there any way at all to at least set a wifi network+pw without the app? Currently it seems the default wifi is always active and I cannot do anything about that. |
In that case you're probably stuck. |
I was using py-air-control for some months to control my AC2889/10 without problems. Since today it does not work any longer although I have changed absolutely nothing. I can switch on and switch off the air purifier using
But when calling
airctrl --ipaddr 192.168.0.84 --protocol coap
I now get the following almost on every call:But this does not happen on every call. A small number of calls (roundabout 1 of 20) succeed and return the correct status:
Is this a known problem and there is a solution for that?
The text was updated successfully, but these errors were encountered: