[Release] Unofficial Ring Integration

Notice!!!

First and foremost I need to warn any who venture to use this integration. This integration is provided for fun without hope of warranty or safety or stable or permanent use. Ring are not official partners with Hubitat or myself and all of the interactions between the Hubitat hub and Ring's cloud servers in this integration are via the private API calls that Ring does not publish or give permission to use for this purpose. I wrote this integration for fun and I do not trust it with my safety. It's a hobby project. (That said, it is well built and mostly stable. On the hubitat side the hub slows down sometimes and drops the websocket connection but there is a watchdog that starts it back up.)

If some part of this integration does not work now or stops working in the future I make no gaurantees and this is provided "AS IS" without hope of service or warranty. If you use this integration you agree to hold me unresponsible for what may happen to your Ring account in the event that Ring deems this type of usage of the API unreasonable. You agree to hold me unresponsible for what may happen to your home, personal property, self, family, etc. You agree to hold me unresponsible. End of story.

If that sounds okay then continue onwards...

I don't expect this to be a perfect experience because I'm not providing a lot of direction and I don't have documented very well which drivers go to which devices beyond the names of the drivers and files. And they have A LOT of devices.

Everyone should start by installing the app. From there, there are two types of devices; devices that communicate via classic HTTP calls and devices that communicate via websockets. It roughly breaks down like this:

  • Security cameras, doorbells and chimes (classic HTTP devices)
  • Beams devices (websocket devices)
  • Security devices (websocket devices)

The app can interact directly with the non-websocket devices. The driver for the API device is required for all of the websocket devices. The dependency heirarchy will look like this a little:

                     App
         /                        \
    websocket                cameras/chimes/doorbells
      device
    /                \
 security          beams 
 devices          devices

Before you install any classic HTTP devices know that since we are not Ring partners we cannot get motion and ring notifications pushed to us. Because of this you have three options. One option is to poll for them. Yes, this is horrible and for that reason I do not poll myself. However, I added this functionality because it seems to work for the home bridge project. AND... I know that I will spend forever explaining why I didn't add it if I don't. Now I will probably just spend forever explaining why you can't poll more often for dings or dings are missed... Option two is to setup IFTTT applets for each motion type (ring or motion) for each device. There is fairly robust documentation for how to do this within the app so I will only cover it briefly here. You must enable OAuth on the app and authorize Ring to IFTTT. Then you create applets on Ring events that call into the "Unofficial Ring Connect" app using an OAuth token by way of web service calls from the "Webhooks" IFTTT service. If it sounds complicated, don't worry. After you install the app you can navigate through to the IFTTT page and learn more. Finally, the third option is to use SmartThings and the hublink app and have separate devices for status. (I have separate devices and I use the SmartThings integration with hublink).

I also added the ability for each light device to poll for its light status. I don't use this either. I use these devices for control. I do not use them for status. I don't ever need to know their light status therefore I don't care what it is and I don't poll for light status.

You do NOT need to install all of the device drivers in this repository. You should be able to get away with installing the drivers for just the devices you own and have registered. Here are the device to driver mappings roughly:

The app

Children of the app

Children of the Ring API Virtual Device (websocket device)

The app will create the camera, chime and doorbell devices automatically. However, for testing reasons (and some level of control over what devices are installed) the security and beams devices are NOT created automatically. Once you add the "Ring API Virtual Device" you must go and click install devices on your respective device to get its websocket children device(s) to create.

IF YOU NEED SUPPORT DO NOT OPEN AN ISSUE ON GITHUB. Issues are for code problems aka bugs. If you have a support issue please make a post here in this thread.

I will try to keep the latest changes marked via the "solution" functionality in Discourse.

The repository:

*Original post:
I have written a native integration for Ring. It supports light and siren control of cameras with lights. It fully supports chimes. It fully supports the alarm and most of its devices. It fully supports the Beams bridge and most of its devices.

The integration doesn't poll for status so cameras and doorbells with motion sensors don't support motion. However, lights and security devices (anything over the websocket) do support motion.

If I can point you to a repository and you do everything from there to install apps and drivers and would like to test this out let me know. I only need a few volunteers. If you aren't capable of being very self-sufficient in setup you'll have to wait until this has been tested and I release it publicly.

Post here if you would like to participate. I need at least 1 tester with an alarm and 1 tester with a Beams bridge. Maybe a tester with a chime or two.

8 Likes

I have a Ring doorbell with two chimes. I'm willing to help, if I can test anything for you.

I have not yet received my Hubitat hub (it’s on its way now), but would be happy to help you with testing this. I’ll let you know when I receive it.

I have a Ring alarm, 2 doorbells gen 1, 1 doorbell Gen 2, 2 doorbells Pro, 1 stickup cam and a floodlight cam. I also have 4 Z-Wave locks and 4 door sensors. Finally, I have some indoor cams on pre-order which should arrive in early December.

I have a Floodlight and would be willing to help. Thanks

Doorbell and Chime here :+1: Be happy to help.

Thank you sir, count me in :slight_smile:

I have many ring products. Would like to help!

I have a Ring alarm, chime, floodlight and doorbell. I'm willing to help test.

I have 2 doorbell, 2 flood lights, 3 chime pro’s, 2 wired cameras and would love to help.

Okay, I think I have my group. If everything goes well you can expect to see something soon. Thank you, every one.

1 Like

Have door bell two stickup cams and two flood light cams. and willing to test.. :>

I have the doorbell and the alarm. I can test. Thanks

As me to list to test, I have Ring Doorbell Pro 2, 2 Ring Floodlights, Ring Chime, Ring Smartlighting and Ring indoor camera. Any support possible to be added for the Smart Lighting for motion and switch events?

Yes please! Doorbell here.

I'd be glad to help, but all I have is a doorbell pro.

I have it already working.

I have the alarm system. Would be happy to help.

I’ve played with the ring apis a lot. Happy to help

Alright, I chose busy testers. They were a little less responsive than I wanted. I got good feedback that everything they tried was working and I'm impatient. I updated the first post with information about the integration.

Knock yourselves out.

2 Likes

@codahq

I can't get the discovery to find my Ring Doorbell Pro 2 so far, it did find all of my other devices without any issues though. Do you have any suggestions at all to get it to show?

Is there anyway to add support for button presses on the doorbell cameras or is that something that isn't able to be captured?

Edit:
Looks like this particular doorbell if missing in the App code, here's the model per Smartthings:
DeviceModel: lpd_v2

"lpd_v2": [name: "Ring Video Doorbell Pro 2", driver: "Ring Generic Camera", dingable: true],

When I added this in the App Code it found it just fine: