For those who are interested in restoring sensor status information (and who would like to help with testing) there’s a new PR that uses Alarm.com’s web api – which hopefully is a little more stable than screen-scraping the web interface directly.
This PR also includes the HA plugin driver (alarm_control_panel.py) to simplify deployment and testing on HA using custom_components.
Copy all files from the PR to config/custom_components/alarmdotcomwebapi/
In your configuration.yaml, change platform: alarmdotcom
to platform: alarmdotcomwebapi
I have been testing it for a few hours on HomeAssistant 0.103.6 / HASSIO 195. So far so good.
This version maintains the same interface as the original pyalarmdotcom module but uses the web API through a dev version of the mechanicalsoup module (which is embedded in the plugin because StatefulBrowser is still not part of the released version of mechanicalsoup.)
Copy pyalarmdotcomajax.py from the PR to config/custom_components/alarmdotcomajax/
Copy alarm_control_panel.py from the github repository to config/custom_components/alarmdotcomajax/
Update line 5 of alarm_control_panel.py to say:
from .pyalarmdotcomajax import Alarmdotcom
Add an __init__.py file in config/custom_components/alarmdotcomajax/ containing the following: """The alarmdotcom component.""" from .pyalarmdotcomajax import Alarmdotcom
In your configuration.yaml, change platform: alarmdotcom
to platform: alarmdotcomajax
You may want to copy that section and comment it out to make it easy to switch back once the official plugin is fixed.
To revert, just replace alarmdotcom in your configuration.yaml and delete directory config/custom_components/alarmdotcomajax/
Copy all files from the PR to config/custom_components/alarmdotcomajax/
Copy alarm_control_panel.py from the github repository to config/custom_components/alarmdotcomajax/
Update line 5 of alarm_control_panel.py to say:
from .pyalarmdotcomajax import Alarmdotcom
In your configuration.yaml, change platform: alarmdotcom
to platform: alarmdotcomajax
I would advise using this version because 1) the code has been tested for a couple of months and 2) it doesn’t depend on the mechanicalsoup module, and 3) it’s likely to get elevated to replace the version used by the HA alarmdotcom module.
Thank you. These changes resolved my issue also. One other change I have also been doing is changing the CONF_CODE from int to string. I found when I was testing various PINs in the past that it breaks if they contain a leading zero. This should resolve that issue.
I had the same issue and got the core problem resolved by moving to alarmdotcomajax as described but I do not have access to any of my sensors. Just Arm/Disarm options. Any thoughts? I double checked permissions on the account being used to login and they are fine…
Sounds like you’d need to move to this version that @aechelon is graciously working on - though it’s not 100% tested - and in need of beta testers from what I gather.
I personally don’t use sensor data currently, so the AJAX version ok for me and I’m sadly unable to test sensors w/ the new API version.
@aechelon, can you confirm that this line is blank prior to this addition? The first six lines of alarm_control_panel.py are blank when I open it to edit.
The method your describe does not seem to be working on this end. Once I change the line in the config.yaml, an effort to validate the config fails and HA will not reboot. If I change the confirmation.yaml back, it validates and reboots fine.
Wow. Thanks for that. That’s terrible…alarm.com is one of the main reasons I have HA in the first place. I was hoping it would just start working again, but at least we have good devs here that are picking up the slack.