Custom component - Tapo: Cameras Control - to add Tapo cameras, doorbells and chimes into Home Assistant
⭐ Now also exposing a stream for devices that have no RTSP or ONVIF capabilities.
Copy contents of custom_components/tapo_control/ to custom_components/tapo_control/ in your Home Assistant config folder.
HACS is a community store for Home Assistant. You can install HACS and then install Tapo: Cameras Control from the HACS store.
Following (v)LAN ports must be open in firewall for the camera to access your Tapo Device from Home Assistant:
Chimes:
Cameras and Doorbells:
These are not WAN ports, DO NOT OPEN WAN PORTS VIA PORT FORWARDING. You might need to open (v)lan ports only if you know what all of this means.
Ensure you have Third Party Compatibility turned on in the official Tapo app on your smartphone.
Tapo App -> Me -> Third-Party Compatibility -> On
Add cameras, doorbells or chimes via Integrations (search for Tapo: Cameras Control) in Home Assistant UI. You can also simply click the button below if you have MyHomeAssistant redirects set up.
Note: There are other Tapo integrations, make sure you select Tapo: Cameras Control. Otherwise you might choose the one for plugs and lights, or the official HA one which has a minimum feature set compared to this integration as of December 2024.
When integrating Tapo cameras, doorbells and chimes, ensure only ONE integration is used. If multiple are used at the same time it will result in conflicts and instability of connection to camera for all the integrations / services connecting to camera.
If you are adding a chime, set Control Port to 80 instead of 443.
Devices are also automatically discovered when they are (re)connected to WIFI.
To add multiple devices, add integration multiple times.
See examples for lovelace cards.
This custom component creates:
Doorbells, Cameras (for each lens, if supported):
Use Stream from Home Assistant in options for the best performance and battery life.Chimes: - Number entity for Chime Duration, Chime Volume, Chime Play Duration and Chime Play Volume - Switch entity for Chime Ringtone and LED - Select entity for Chime Sound Type and Chime Play Type - Sensor entities for Network SSID, Signal Level, RSSI - Button entity for Reboot and Ringing the chime
Additionally, following services are available for cameras with PTZ:
tapo_control.save_preset
Saves the current PTZ position to a preset
tapo_control.delete_preset
Deletes a preset
Integration is capable of analysing sound from camera microphone and expose noise detected via binary_sensor.
You need to enable this feature in integration options by checking "Enable sound threshold detection". After enabling it, you can also set any other options starting with [Sound Detection]. You will need to restart Home Asssistant after doing any changes.
For more information and troubleshooting see Home Assistant ffmpeg documentation on which this feature is based on.
Integration is capable of synchronizing recordings for fast playback.
Synchronization is turned off by default, you can browse media stored on camera and request it to be played. However, downloading is rather slow, so it is a good idea to enable media synchronization in background. That way, you will be able to play any synchronized media from camera instantly.
You can enable this setting by navigating to Home Assistant Settings -> Devices & services and clicking the Tapo: Cameras control integration. There, click on the Configure button next to the Tapo device you wish to turn media synchronization on for, and choose Configure media. Here, you need to define the number of hours to synchronize. Unless it is specified, synchronization does not run. Here, you are able to also set the storage path where the synchronized recordings will be stored (defaults to /config/.storage/tapo_control).
Finally, you can turn on, or off switch entity switch.*_media_sync.
Notice: Recordings are deleted after the number of hours you have chosen to synchronize passes, once both the actual recording time and the file modified time is older than the number of hours set.
Whenever a recording is downloaded (either because you requested playback or media sync picked it up), the integration fires a Home Assistant event tapo_control_media_downloaded with data:
entry_id: Config entry id of the devicestartDate / endDate: Recording start/end timestamps (UTC, in seconds)filePath: Full path to the downloaded mp4 in cold storageExample automation trigger:
trigger:
- platform: event
event_type: tapo_control_media_downloaded
action:
- service: notify.mobile_app_phone
data:
message: >
New Tapo recording from {{ trigger.event.data.startDate | timestamp_local }}
I see error Invalid cloud password.
These steps apply even if camera worked before, and now does not (for example, after firmware update).
After every step, test if camera works in HA, and after each step try checking Third-Party Compatibility off and on again.
Which stream to use?
This integration exposes 4 different camera entities:
Direct streams use proprietary TP-Link streaming protocol. Non-direct ones use standard RTSP protocol.
Use Stream from Home Assistant (restart required) in integration options for the fastest experience_). Under the hood, the new streams are a binary stream of data "straight to your browser", with no unnecessary translations or overhead.If you have an option to use RTSP, it is recommended to stick with RTSP streams.
Binary sensor for motion doesn't show up or work
Motion sensor is added only after a motion is detected for the first time.
It also requires ONVIF support on the device. If the device is not exposing Onvif interface (most likely if it is battery or solar powered), motion events will not work.
/profile. Go to /config/network and under Network Adapter verify correct IP is shown for the device. If it is not correct, under Home Assistant URL uncheck Automatic next to Local Network and set it to http://<some IP address>:8123. DO NOT USE HTTPS.Also make sure that:
Big delay in camera stream
This is a known issue of Home Assistant.
There is an ability to disable usage of Home Assistant Stream component for the camera, which might lower the delay very significantly at cost of higher CPU usage.
You can choose to disable stream component when adding the camera, or via Options when camera has already been added. This change requires a restart of Home Assistant.
There might be some disadvantages to doing this, like losing option to control playback and a higher CPU usage. Results depend on your hardware and future Home Assistant updates.
If you disable stream and your hardware is not up to the task, you will get artifacts, bigger delay and freezes.
If you wish, try it out and see what works best for you.
Another possibility is using WebRTC Camera by AlexxIT.
Example working configuration:
type: custom:webrtc-camera
entity: camera.bedroom_hd
No audio in camera stream
Supported audio codecs in Home Assistant are "aac", "ac3" and "mp3".
Tapo Cameras use PCM ALAW (alaw) which is not supported.
**You can get sound working using [WebRTC Camera by Al
$ claude mcp add HomeAssistant-Tapo-Control \
-- python -m otcore.mcp_server <graph>