Closed Jtupz closed 1 year ago
Hi,
I see options regarding the LED light (which works),
Where do you see this? Do you have any light entity?
Please enable debug logs.
logger:
default: critical
logs:
custom_components.tapo_control: debug
Wait until you see "Setting up light for floodlight" and upload the full log here.
Thanks for the quick reply, see below:
Hi,
I see options regarding the LED light (which works),
Where do you see this? Do you have any light entity?
The entity is shown in the configuration area of the device, along with "flip", "format SD card" etc. Its named switch.garden_indicator_led
As far as I can see there is no light entity associated with this device.
Please enable debug logs.
logger: default: critical logs: custom_components.tapo_control: debug
Wait until you see "Setting up light for floodlight" and upload the full log here.
Logs below:
2023-08-08 08:35:19.775 DEBUG (MainThread) [custom_components.tapo_control] Setting up light for floodlight 2023-08-08 08:35:19.775 DEBUG (MainThread) [custom_components.tapo_control] Capability getForceWhitelampState not found, querying again... 2023-08-08 08:35:19.775 DEBUG (MainThread) [custom_components.tapo_control] Setting up number for movement angle 2023-08-08 08:35:19.775 DEBUG (MainThread) [custom_components.tapo_control] Capability getPresets not found, querying again...
Please post full log. The relevant section to help you is not included in the snippet you sent.
Setting up light for floodlight
2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Setting up switches 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getPrivacyMode, creating TapoPrivacySwitch 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Tapo Privacy - init - start 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Updating TapoPrivacySwitch to: off 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Tapo Privacy - init - end 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoPrivacySwitch... 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getLensDistortionCorrection, creating TapoLensDistortionCorrectionSwitch 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Tapo Lens Distortion Correction - init - start 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Tapo Lens Distortion Correction - init - end 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoLensDistortionCorrectionSwitch... 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getLED, creating TapoIndicatorLedSwitch 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Tapo Indicator LED - init - start 2023-08-08 09:13:20.860 DEBUG (MainThread) [custom_components.tapo_control] Tapo Indicator LED - init - end 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoIndicatorLedSwitch... 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getImageFlipVertical, creating TapoFlipSwitch 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Flip - init - start 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Flip - init - end 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoFlipSwitch... 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Capability getAutoTrackTarget not found, querying again... 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Setting up buttons 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Reboot - init - start 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Reboot - init - end 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Format SD Card - init - start 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Format SD Card - init - end 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getAlarm, creating TapoStartManualAlarmButton 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Manual Alarm Start - init - start 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Manual Alarm Start - init - end 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoStartManualAlarmButton... 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getAlarm, creating TapoStopManualAlarmButton 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Manual Alarm Stop - init - start 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Manual Alarm Stop - init - end 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoStopManualAlarmButton... 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Sync Time - init - start 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Sync Time - init - end 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Capability getPresets not found, querying again... 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Setting up light for floodlight 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Capability getForceWhitelampState not found, querying again... 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Setting up number for movement angle 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Capability getPresets not found, querying again... 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Setting up selects 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getDayNightMode, creating TapoNightVisionSelect 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Night Vision - init - start 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Night Vision - init - append 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Night Vision - init - update 2023-08-08 09:13:20.861 DEBUG (MainThread) [custom_components.tapo_control] Tapo Night Vision - init - TapoEntity 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Night Vision - init - SelectEntity 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Night Vision - init - end 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoNightVisionSelect... 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getLightFrequencyMode, creating TapoLightFrequencySelect 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Light Frequency - init - start 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Light Frequency - init - append 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Light Frequency - init - update 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Light Frequency - init - TapoEntity 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Light Frequency - init - SelectEntity 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Light Frequency - init - end 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoLightFrequencySelect... 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getAlarm, creating TapoAutomaticAlarmModeSelect 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Automatic Alarm - init - start 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Automatic Alarm - init - append 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Automatic Alarm - init - update 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Automatic Alarm - init - TapoEntity 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Automatic Alarm - init - SelectEntity 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Automatic Alarm - init - end 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoAutomaticAlarmModeSelect... 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getMotionDetection, creating TapoMotionDetectionSelect 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Motion Detection - init - start 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Motion Detection - init - append 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Motion Detection - init - update 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] TapoMotionDetectionSelect updateTapo 1 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] TapoMotionDetectionSelect updateTapo 3 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] TapoMotionDetectionSelect updateTapo 4 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] TapoMotionDetectionSelect updateTapo 6 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Updating TapoMotionDetectionSelect to: off 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Motion Detection - init - TapoEntity 2023-08-08 09:13:20.862 DEBUG (MainThread) [custom_components.tapo_control] Tapo Motion Detection - init - SelectEntity 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Motion Detection - init - end 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Adding TapoMotionDetectionSelect... 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getPersonDetection, creating TapoPersonDetectionSelect 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Person Detection - init - start 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Person Detection - init - append 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Person Detection - init - update 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoPersonDetectionSelect updateTapo 1 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoPersonDetectionSelect updateTapo 3 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoPersonDetectionSelect updateTapo 4 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoPersonDetectionSelect updateTapo 6 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Updating TapoPersonDetectionSelect to: off 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Person Detection - init - TapoEntity 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Person Detection - init - SelectEntity 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Person Detection - init - end 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoPersonDetectionSelect... 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getVehicleDetection, creating TapoVehicleDetectionSelect 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Vehicle Detection - init - start 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Vehicle Detection - init - append 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Vehicle Detection - init - update 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoVehicleDetectionSelect updateTapo 1 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoVehicleDetectionSelect updateTapo 3 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoVehicleDetectionSelect updateTapo 4 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoVehicleDetectionSelect updateTapo 6 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Updating TapoVehicleDetectionSelect to: off 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Vehicle Detection - init - TapoEntity 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Vehicle Detection - init - SelectEntity 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Vehicle Detection - init - end 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoVehicleDetectionSelect... 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Capability getBabyCryDetection not found, querying again... 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Setting up sirens 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getAlarm, creating TapoSiren 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Siren - init - start 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Siren - init - end 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Adding TapoSirenEntity... 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Update - init - start 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Update - init - end 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Setting up binary sensor for motion. 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] EventsListener init 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Adding TapoNoiseBinarySensor... 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] TapoNoiseBinarySensor - init - start 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Noise - init - start 2023-08-08 09:13:20.863 DEBUG (MainThread) [custom_components.tapo_control] Tapo Noise - init - end 2023-08-08 09:13:20.864 DEBUG (MainThread) [custom_components.tapo_control] TapoNoiseBinarySensor - init - end 2023-08-08 09:13:21.161 WARNING (MainThread) [homeassistant.components.camera] Updating xiaomi_cloud_map_extractor camera took longer than the scheduled update interval 0:00:05 2023-08-08 09:13:21.222 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoAutoTrackSwitch 2023-08-08 09:13:21.222 DEBUG (MainThread) [custom_components.tapo_control] Adding switch entities... 2023-08-08 09:13:21.277 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoCalibrateButton 2023-08-08 09:13:21.277 INFO (MainThread) [custom_components.tapo_control] Buttons: Camera does not support movement. 2023-08-08 09:13:21.303 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoFloodlight 2023-08-08 09:13:21.360 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoMovementAngle 2023-08-08 09:13:21.365 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoBabyCryDetectionSelect 2023-08-08 09:13:21.365 DEBUG (MainThread) [custom_components.tapo_control] Capability getPetDetection not found, querying again... 2023-08-08 09:13:21.489 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoPetDetectionSelect 2023-08-08 09:13:21.489 DEBUG (MainThread) [custom_components.tapo_control] Capability getBarkDetection not found, querying again... 2023-08-08 09:13:21.569 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoBarkDetectionSelect 2023-08-08 09:13:21.570 DEBUG (MainThread) [custom_components.tapo_control] Capability getMeowDetection not found, querying again... 2023-08-08 09:13:21.670 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoMeowDetectionSelect 2023-08-08 09:13:21.670 DEBUG (MainThread) [custom_components.tapo_control] Capability getGlassBreakDetection not found, querying again... 2023-08-08 09:13:21.776 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoGlassBreakDetectionSelect 2023-08-08 09:13:21.776 DEBUG (MainThread) [custom_components.tapo_control] Found cached capability getTamperDetection, creating TapoTamperDetectionSelect 2023-08-08 09:13:21.776 DEBUG (MainThread) [custom_components.tapo_control] Tapo Tamper Detection - init - start 2023-08-08 09:13:21.776 DEBUG (MainThread) [custom_components.tapo_control] Tapo Tamper Detection - init - append 2023-08-08 09:13:21.776 DEBUG (MainThread) [custom_components.tapo_control] Tapo Tamper Detection - init - update 2023-08-08 09:13:21.776 DEBUG (MainThread) [custom_components.tapo_control] TapoTamperDetectionSelect updateTapo 1 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] TapoTamperDetectionSelect updateTapo 3 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] TapoTamperDetectionSelect updateTapo 5 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] TapoTamperDetectionSelect updateTapo 6 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] Updating TapoTamperDetectionSelect to: high 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] Tapo Tamper Detection - init - TapoEntity 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] Tapo Tamper Detection - init - SelectEntity 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] Tapo Tamper Detection - init - end 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] Adding tapoTamperDetectionSelect... 2023-08-08 09:13:21.777 DEBUG (MainThread) [custom_components.tapo_control] Capability getPresets not found, querying again... 2023-08-08 09:13:21.891 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoMoveToPresetSelect 2023-08-08 09:13:21.891 DEBUG (MainThread) [custom_components.tapo_control] Capability getPresets not found, querying again... 2023-08-08 09:13:22.112 INFO (MainThread) [custom_components.tapo_control] Camera does not support TapoPatrolModeSelect
It mentioned the camera does not support floodlight, but it has a floodlight and it can be controlled in the Tapo app.
Thank you.
That means the app is controlling the light in a different way. Someone who owns this camera will need to inspect the communication between the camera and app and document the calls, then I can make an update to the integration.
Thanks again, understood.
I am happy to do this if its something you are able to assist me with?
I can (probably) help with inspecting the app traffic if necessary. However, I have a C320WS and I can control the floodlight in HA (a light entity is created). I have latest firmware on the camera, 1.3.0. @Jtupz Have I understood correctly that you do not see any floodlight control at all in your integration? When I go to Settings -> Devices & Services -> Tapo: Cameras Control -> "1 device", I can see Floodlight in the "Controls" card.
I can (probably) help with inspecting the app traffic if necessary. However, I have a C320WS and I can control the floodlight in HA (a light entity is created). I have latest firmware on the camera, 1.3.0. @Jtupz Have I understood correctly that you do not see any floodlight control at all in your integration? When I go to Settings -> Devices & Services -> Tapo: Cameras Control -> "1 device", I can see Floodlight in the "Controls" card.
Correct, the only entities I see under the control section are:
Manual Alarm Set (button press) Manual Alarm Stop (button Press) Privacy (switch) Siren (switch)
Any help would be greatly appreciated!
@Jtupz Well, I did look at the traffic between app -> camera, but since it already works for me I doubt that it will help... However, can you please perform these steps and post the response from the last curl request:
Go to https://coding.tools/md5 and enter the password you've set up as device account for the camera. Copy the MD5 hashed value.
Perform this request and copy stok from the result (needed in next step). Make sure to replace the password value with the hash from step 1, and the IP with the actual (local) ip of the camera:
curl -i -s -k -X $'POST' \
-H $'Content-Type: application/json'-H $'Accept-Encoding: gzip, deflate' \
--data-binary $'{\"method\":\"login\",\"params\":{\"username\":\"admin\",\"password\":\"YOUR-MD5-HASH\"}}' \
$'https://YOUR-CAMERAIP/'
Perform this request. Replace IP with the local IP of your camera and "STOK-FROM-PREV-REQUEST" with the stok you received earlier:
curl -i -s -k -X $'POST' \
-H $'Content-Type: application/json' \
--data-binary $'{\"method\":\"multipleRequest\",\"params\":{\"requests\":[{\"method\": \"getLdc\",\"params\": {\"image\": {\"name\": [\"switch\", \"common\"]}},},]}}' \
$'https://YOUR-CAMERAIP/stok=STOK-FROM-PREV-REQUEST/ds'
Post the result from the last request.
I have several CW320WS, some HW 1.0 FW 1.3.0 that runs flawless, instead HW 2.0 FW 1.0.5 expose a less quality image sensor and different behavior on services like siren and alarm and floodlight. I hope will help the output of the curl command suggested above:
HTTP/1.1 200 OK Connection: close Cache-Control: no-cache Content-Type: application/json;charset=UTF-8 Transfer-Encoding: chunked
{"result":{"responses":[{"method":"getLdc","result":{"image":{"switch":{"schedule_end_time":"64800","schedule_start_time":"21600","clear_licence_plate_mode":"off","switch_mode":"common","rotate_type":"off","flip_type":"off","ldc":"off","night_vision_mode":"md_night_vision","full_color_people_enhance":"off","full_color_min_keep_time":"5","wtl_intensity_level":"3","wtl_force_time":"300","overexposure_people_suppression":"off","best_view_distance":"0","image_scene_mode":"normal","image_scene_mode_common":"normal","image_scene_mode_shedday":"normal","image_scene_mode_shednight":"normal","image_scene_mode_autoday":"normal","image_scene_mode_autonight":"normal"},"common":{"chroma":"50","luma":"50","sharpness":"50","saturation":"50","contrast":"50","inf_delay":"5","wd_gain":"50","exp_gain":"0","smartir_level":"0","auto_exp_gain_max":"0","wb_R_gain":"50","wb_B_gain":"50","wb_G_gain":"50","wtl_sensitivity":"4","wtl_delay":"5","wtl_sensitivity_day2night":"1400","wtl_sensitivity_night2day":"9100","iris_level":"160","lock_red_gain":"0","lock_gr_gain":"0","lock_gb_gain":"0","lock_blue_gain":"0","lock_red_colton":"0","lock_green_colton":"0","lock_blue_colton":"0","focus_limited":"10","inf_start_time":"64800","inf_end_time":"21600","wtl_start_time":"64800","wtl_end_time":"21600","inf_sensitivity_day2night":"1400","inf_sensitivity_night2day":"9100","wide_dynamic":"off","high_light_compensation":"off","dehaze":"off","eis":"off","auto_exp_antiflicker":"off","inf_type":"auto","inf_sensitivity":"4","wtl_type":"auto","backlight":"off","area_compensation":"default","smartir":"auto_ir","exp_type":"auto","exp_level":"0","shutter":"1\/25","style":"original","focus_type":"manual","wb_type":"auto","lock_source":"local","smartwtl":"auto_wtl","smartwtl_level":"5","smartwtl_digital_level":"100","light_freq_mode":"auto"}}},"error_code":0}]},"error_code":0}
HTTP/1.1 200 OK Connection: keep-alive Content-Type: application/json Cache-Control: no-cache Expires: 0 Transfer-Encoding: chunked
{ "result": { "responses": [ { "method": "getLdc", "result": { "image": { "switch": { ".name": "switch", ".type": "switch_type", "switch_mode": "common", "schedule_start_time": "21600", "schedule_end_time": "64800", "flip_type": "off", "rotate_type": "off", "ldc": "off", "night_vision_mode": "inf_night_vision", "wtl_intensity_level": "5", "force_wtl_state": "off", "lct_style_enable": "1" }, "common": { ".name": "common", ".type": "para", "luma": "50", "contrast": "50", "chroma": "50", "saturation": "50", "sharpness": "50", "exp_type": "auto", "shutter": "1\/25", "focus_type": "semi_auto", "focus_limited": "600", "exp_gain": "0", "inf_type": "auto", "inf_start_time": "64800", "inf_end_time": "21600", "inf_sensitivity": "4", "inf_delay": "5", "wide_dynamic": "off", "light_freq_mode": "auto", "wd_gain": "50", "wb_type": "auto", "wb_R_gain": "50", "wb_G_gain": "50", "wb_B_gain": "50", "lock_red_gain": "0", "lock_gr_gain": "0", "lock_gb_gain": "0", "lock_blue_gain": "0", "lock_red_colton": "0", "lock_green_colton": "0", "lock_blue_colton": "0", "lock_source": "local", "area_compensation": "default", "smartir": "off", "smartir_level": "100", "high_light_compensation": "off", "dehaze": "off" } } }, "error_code": 0 } ] }, "error_code": 0 }
Let me know if could help with other tests
Thanks @fuzzybear62! I'm not really entirely familiar with the code of this project, but from what I can see, HW 2.0 does not have property "force_wtl_state" in the getLdc result. I think that's the property used for creating the floodlight entity. Is this correct, @JurajNyiri? Not sure which property to use instead on hw 2.0...
Please turn on the light and post the result, then turn off the light and post the result.
Yes, please post result from when lamp is off and then on, but please use this request instead of the one in step 4 above:
curl -i -s -k -X $'POST' \
-H $'Content-Type: application/json' \
--data-binary $'{\"method\":\"multipleRequest\",\"params\":{\"requests\":[{\"method\": \"getLdc\",\"params\": {\"image\": {\"name\": [\"switch\", \"common\"]}}},{\"method\":\"getForceWhitelampState\",\"params\":{\"image\":{\"name\":\"switch\"}}},{\"method\":\"getWhitelampConfig\",\"params\":{\"image\":{\"name\":\"switch\"}}}]}}' \
$'https://YOUR-CAMERAIP/stok=STOK-FROM-PREV-REQUEST/ds'
HTTP/1.1 200 OK Connection: close Cache-Control: no-cache Content-Type: application/json;charset=UTF-8 Transfer-Encoding: chunked
{"result":{"responses":[{"method":"getLdc","result":{"image":{"switch":{"schedule_end_time":"64800","schedule_start_time":"21600","clear_licence_plate_mode":"off","switch_mode":"common","rotate_type":"off","flip_type":"off","ldc":"off","night_vision_mode":"md_night_vision","full_color_people_enhance":"off","full_color_min_keep_time":"5","wtl_intensity_level":"3","wtl_force_time":"300","overexposure_people_suppression":"off","best_view_distance":"0","image_scene_mode":"normal","image_scene_mode_common":"normal","image_scene_mode_shedday":"normal","image_scene_mode_shednight":"normal","image_scene_mode_autoday":"normal","image_scene_mode_autonight":"normal"},"common":{"chroma":"50","luma":"50","sharpness":"50","saturation":"50","contrast":"50","inf_delay":"5","wd_gain":"50","exp_gain":"0","smartir_level":"0","auto_exp_gain_max":"0","wb_R_gain":"50","wb_B_gain":"50","wb_G_gain":"50","wtl_sensitivity":"4","wtl_delay":"5","wtl_sensitivity_day2night":"1400","wtl_sensitivity_night2day":"9100","iris_level":"160","lock_red_gain":"0","lock_gr_gain":"0","lock_gb_gain":"0","lock_blue_gain":"0","lock_red_colton":"0","lock_green_colton":"0","lock_blue_colton":"0","focus_limited":"10","inf_start_time":"64800","inf_end_time":"21600","wtl_start_time":"64800","wtl_end_time":"21600","inf_sensitivity_day2night":"1400","inf_sensitivity_night2day":"9100","wide_dynamic":"off","high_light_compensation":"off","dehaze":"off","eis":"off","auto_exp_antiflicker":"off","inf_type":"auto","inf_sensitivity":"4","wtl_type":"auto","backlight":"off","area_compensation":"default","smartir":"auto_ir","exp_type":"auto","exp_level":"0","shutter":"1\/25","style":"original","focus_type":"manual","wb_type":"auto","lock_source":"local","smartwtl":"auto_wtl","smartwtl_level":"5","smartwtl_digital_level":"100","light_freq_mode":"auto"}}},"error_code":0},{"method":"getForceWhitelampState","result":{},"error_code":-40210},{"method":"getWhitelampConfig","result":{"image":{"switch":{"schedule_end_time":"64800","schedule_start_time":"21600","clear_licence_plate_mode":"off","switch_mode":"common","rotate_type":"off","flip_type":"off","ldc":"off","night_vision_mode":"md_night_vision","full_color_people_enhance":"off","full_color_min_keep_time":"5","wtl_intensity_level":"3","wtl_force_time":"300","overexposure_people_suppression":"off","best_view_distance":"0","image_scene_mode":"normal","image_scene_mode_common":"normal","image_scene_mode_shedday":"normal","image_scene_mode_shednight":"normal","image_scene_mode_autoday":"normal","image_scene_mode_autonight":"normal"}}},"error_code":0}]},"error_code":0}
HTTP/1.1 200 OK Connection: close Cache-Control: no-cache Content-Type: application/json;charset=UTF-8 Transfer-Encoding: chunked
{"result":{"responses":[{"method":"getLdc","result":{"image":{"switch":{"schedule_end_time":"64800","schedule_start_time":"21600","clear_licence_plate_mode":"off","switch_mode":"common","rotate_type":"off","flip_type":"off","ldc":"off","night_vision_mode":"md_night_vision","full_color_people_enhance":"off","full_color_min_keep_time":"5","wtl_intensity_level":"3","wtl_force_time":"300","overexposure_people_suppression":"off","best_view_distance":"0","image_scene_mode":"normal","image_scene_mode_common":"normal","image_scene_mode_shedday":"normal","image_scene_mode_shednight":"normal","image_scene_mode_autoday":"normal","image_scene_mode_autonight":"normal"},"common":{"chroma":"50","luma":"50","sharpness":"50","saturation":"50","contrast":"50","inf_delay":"5","wd_gain":"50","exp_gain":"0","smartir_level":"0","auto_exp_gain_max":"0","wb_R_gain":"50","wb_B_gain":"50","wb_G_gain":"50","wtl_sensitivity":"4","wtl_delay":"5","wtl_sensitivity_day2night":"1400","wtl_sensitivity_night2day":"9100","iris_level":"160","lock_red_gain":"0","lock_gr_gain":"0","lock_gb_gain":"0","lock_blue_gain":"0","lock_red_colton":"0","lock_green_colton":"0","lock_blue_colton":"0","focus_limited":"10","inf_start_time":"64800","inf_end_time":"21600","wtl_start_time":"64800","wtl_end_time":"21600","inf_sensitivity_day2night":"1400","inf_sensitivity_night2day":"9100","wide_dynamic":"off","high_light_compensation":"off","dehaze":"off","eis":"off","auto_exp_antiflicker":"off","inf_type":"auto","inf_sensitivity":"4","wtl_type":"auto","backlight":"off","area_compensation":"default","smartir":"auto_ir","exp_type":"auto","exp_level":"0","shutter":"1\/25","style":"original","focus_type":"manual","wb_type":"auto","lock_source":"local","smartwtl":"auto_wtl","smartwtl_level":"5","smartwtl_digital_level":"100","light_freq_mode":"auto"}}},"error_code":0},{"method":"getForceWhitelampState","result":{},"error_code":-40210},{"method":"getWhitelampConfig","result":{"image":{"switch":{"schedule_end_time":"64800","schedule_start_time":"21600","clear_licence_plate_mode":"off","switch_mode":"common","rotate_type":"off","flip_type":"off","ldc":"off","night_vision_mode":"md_night_vision","full_color_people_enhance":"off","full_color_min_keep_time":"5","wtl_intensity_level":"3","wtl_force_time":"300","overexposure_people_suppression":"off","best_view_distance":"0","image_scene_mode":"normal","image_scene_mode_common":"normal","image_scene_mode_shedday":"normal","image_scene_mode_shednight":"normal","image_scene_mode_autoday":"normal","image_scene_mode_autonight":"normal"}}},"error_code":0}]},"error_code":0}
The responses are identical which I guess means that HW 2.0 handles the floodlight in a totally separate call then the HW 1.0 camera. I think we need to go back to @JurajNyiri original request: someone needs to trace the app traffic to see the request used for toggling/handling floodlight in the HW 2 camera. This can be done fairly easy for example using Burp suite.
@Jtupz Well, I did look at the traffic between app -> camera, but since it already works for me I doubt that it will help... However, can you please perform these steps and post the response from the last curl request:
- Go to https://coding.tools/md5 and enter the password you've set up as device account for the camera. Copy the MD5 hashed value.
- Perform this request and copy stok from the result (needed in next step). Make sure to replace the password value with the hash from step 1, and the IP with the actual (local) ip of the camera:
curl -i -s -k -X $'POST' \ -H $'Content-Type: application/json'-H $'Accept-Encoding: gzip, deflate' \ --data-binary $'{\"method\":\"login\",\"params\":{\"username\":\"admin\",\"password\":\"YOUR-MD5-HASH\"}}' \ $'https://YOUR-CAMERAIP/'
- Perform this request. Replace IP with the local IP of your camera and "STOK-FROM-PREV-REQUEST" with the stok you received earlier:
curl -i -s -k -X $'POST' \ -H $'Content-Type: application/json' \ --data-binary $'{\"method\":\"multipleRequest\",\"params\":{\"requests\":[{\"method\": \"getLdc\",\"params\": {\"image\": {\"name\": [\"switch\", \"common\"]}},},]}}' \ $'https://YOUR-CAMERAIP/stok=STOK-FROM-PREV-REQUEST/ds'
Post the result from the last request.
I have the MD5 and IP address ready, but where should I be performing these actions?
To add to this, the service request for the sirens do not work for me:
_Failed to call service button/press. Error: Parameter to get/do does not exist, Response: {"errorcode": -40106}
This is a simple shell script I used to verify the commands:
echo "\n\n\n================ Config\n" curl -i -s -k -X $'POST' \ -H $'Content-Type: application/json' \ --data-binary $'{"method":"multipleRequest","params":{"requests":[{"method":"getWhitelampConfig","params":{"image":{"name":"switch"}}}]}}' \ $'https://YOUR-IP/stok=YOUR-STOK/ds' echo "\n\n\n================ Status\n" curl -i -s -k -X $'POST' \ -H $'Content-Type: application/json' \ --data-binary $'{"method":"multipleRequest","params":{"requests":[{"method":"getWhitelampStatus","params":{"image":{"get_wtl_status":["null"]}}}]}}' \ $'https://YOUR-IP/stok=YOUR-STOK/ds' echo "\n\n\n================ Switch State\n" curl -i -s -k -X $'POST' \ -H $'Content-Type: application/json' \ --data-binary $'{"method":"multipleRequest","params":{"requests":[{"method":"reverseWhitelampStatus","params":{"image":{"reverse_wtl_status":["null"]}}}]}}' \ $'https://YOUR-IP/stok=YOUR-STOK/ds' echo "\n\n\n================ Status\n" curl -i -s -k -X $'POST' \ -H $'Content-Type: application/json' \ --data-binary $'{"method":"multipleRequest","params":{"requests":[{"method":"getWhitelampStatus","params":{"image":{"get_wtl_status":["null"]}}}]}}' \ $'https://YOUR-IP/stok=YOUR-STOK/ds'
On the app there isn't a button for siren, so I don't know how to activate/deactivate
If needed I can capture more protocol calls
@fuzzybear62 could you please also provide responses there? I need those to make adjustments to the code. Especially with the lamp statuses, please document also when it was ON, when OFF etc. Please also add request to turn on/off the lamp. What is reverseWhiteLamp and whiteLamp?
There is no On or Off call, buth toggle. So you have to obtain status (as in my example) and then take the correct action on that
reverseWhiteLamp toggle the status On/Off
Upon app configuration the lamp will stay on for "X" seconds (user's choice in app) and with light intensity (user's choice in app) that I suppose are "wtl_intensity_level":"3","wtl_force_time":"300" in the status query
I see "getWhitelampStatus","result":{"status":1,
in both requests even after executing the reverse. How does this work? What is the value when the lamp is ON and what is the value when lamp is OFF?
Could you please also gather calls for setting the intensity and time and take screenshots from the app how it looks like and all the options?
"result":{"rest_time":300,"status":1} LAMP in ON "result":{"rest_time":0,"status":0} LAMP is OFF
With HW 2.0 the lamp behavior depends on the Night mode settings that are IR, Color and "Intelligent". Mine are settled up to "intelligent" and the commands refer to that setting. For sure I can dig for each option, but I need some time. I'll post here as soon I've done.
Here a near complete protocol for HW 2.0 and 1.0.5 FW HW2.0_protocol.txt
and here the input/output json for many commands C320WS_HW2.0_Protocol.json.txt
the response for the set command it seems always the same I don't belive that you would replicate the full app in HA and keep in mind that is on the market the HW 2.2 (I do not have one of this batch) but if you need some other output I'll do in the spare time
Thank you, this is great. I will try to implement this soon.
@fuzzybear62 released pytapo 3.2.2
Please install it using pip install pytapo==3.2.2
. Then create following file
from pytapo import Tapo
# Camera
user = "admin" # admin user
password = "" # cloud password
host = "" # ip of the camera, example: 192.168.1.52
tapo = Tapo(host, user, password, password)
print(tapo.getMost())
print(tapo.getWhitelampStatus())
print(tapo.reverseWhitelampStatus())
print(tapo.getWhitelampStatus())
print(tapo.reverseWhitelampStatus())
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(300))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(600))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 3))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 4))
print(tapo.getWhitelampConfig())
And post results, this should verify all the new functionality in 3.2.1. Once we verify it works I can do changes to HA integration.
@fuzzybear62 also please post all the possible choices in the app for intensityLevel and forceTime of the light so that these can be replicated in HA as well.
Il gio 17 ago 2023, 13:01 Juraj Nyíri @.***> ha scritto:
@fuzzybear62 https://github.com/fuzzybear62 also please post all the possible choices in the app for intensityLevel and forceTime of the light so that these can be replicated in HA as well.
— Reply to this email directly, view it on GitHub https://github.com/JurajNyiri/HomeAssistant-Tapo-Control/issues/377#issuecomment-1682077241, or unsubscribe https://github.com/notifications/unsubscribe-auth/AIXEEPZY2FWY6NPXBSW2GCDXVX22LANCNFSM6AAAAAA3HO7QEA . You are receiving this because you were mentioned.Message ID: @.***>
I'll be able todo this evening
Il gio 17 ago 2023, 13:00 Juraj Nyíri @.***> ha scritto:
@fuzzybear62 https://github.com/fuzzybear62 released pytapo 3.2.1
Please install it using pip install pytapo==3.2.1. Then create following file
from pytapo import Tapo
Camera
user = "admin" # admin user password = "" # cloud password host = "" # ip of the camera, example: 192.168.1.52
tapo = Tapo(host, user, password, password)
print(tapo.getMost()) print(tapo.getWhitelampStatus()) print(tapo.reverseWhitelampStatus()) print(tapo.getWhitelampStatus()) print(tapo.reverseWhitelampStatus()) print(tapo.getWhitelampConfig()) print(tapo.setWhitelampConfig(300)) print(tapo.getWhitelampConfig()) print(tapo.setWhitelampConfig(600)) print(tapo.getWhitelampConfig()) print(tapo.setWhitelampConfig(False, 3)) print(tapo.getWhitelampConfig()) print(tapo.setWhitelampConfig(False, 4)) print(tapo.getWhitelampConfig())
And post results, this should verify all the new functionality in 3.2.1. Once we verify it works I can do changes to HA integration.
— Reply to this email directly, view it on GitHub https://github.com/JurajNyiri/HomeAssistant-Tapo-Control/issues/377#issuecomment-1682075802, or unsubscribe https://github.com/notifications/unsubscribe-auth/AIXEEP2BKX6DDV7WA7SV4BDXVX2V5ANCNFSM6AAAAAA3HO7QEA . You are receiving this because you were mentioned.Message ID: @.***>
@JurajNyiri Great! I think this should be set to "intensityLevel" and not "forceTime" (line 491): https://github.com/JurajNyiri/pytapo/blob/c1f5b68b2242d7d1f6b32ea99f96a631b509d03c/pytapo/__init__.py#L491C64-L491C73
Nice catch! Fixed.
Here a near complete protocol for HW 2.0 and 1.0.5 FW HW2.0_protocol.txt
and here the input/output json for many commands C320WS_HW2.0_Protocol.json.txt
the response for the set command it seems always the same I don't belive that you would replicate the full app in HA and keep in mind that is on the market the HW 2.2 (I do not have one of this batch) but if you need some other output I'll do in the spare time
@fuzzybear62 thank you, released pytapo 3.2.2
Please install it using pip install pytapo==3.2.2
. Then create following file
from pytapo import Tapo
# Camera
user = "admin" # admin user
password = "" # cloud password
host = "" # ip of the camera, example: 192.168.1.52
tapo = Tapo(host, user, password, password)
print(tapo.getMost())
print(tapo.getWhitelampStatus())
print(tapo.reverseWhitelampStatus())
print(tapo.getWhitelampStatus())
print(tapo.reverseWhitelampStatus())
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(300))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(600))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 3))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 4))
print(tapo.getWhitelampConfig())
And post results, this should verify all the new functionality in 3.2.1. Once we verify it works I can do changes to HA integration.
Done output.txt
Thank you! Looks like wtl_intensity_level
did not change.
print(tapo.setWhitelampConfig(False, 1))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 2))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 3))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 4))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 5))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(300, 1))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(600, 2))
print(tapo.getWhitelampConfig())
Could you please try again? Make sure that you are using 3.2.2 as there was a bug in 3.2.1.
"Collecting pytapo==3.2.2" pretty sure :-)
Confirm that time is set, but luminosity is not
Manually with this command:
{"method":"multipleRequest","params":{"requests":[{"method":"setWhitelampConfig","params":{"image":{"switch":{"wtl_force_time":"1800","wtl_intensity_level":"4"}}}}]}}
it works
Could you please try the commands I sent above and post output?
I have tested the last command you sent. And also checked on the camera. This is the output output_second.txt
Thank you, this was helpful, the only difference I see it expects a string and we were sending in an integer.
Please download 3.2.3 and run this again and send output, should work at least partially now.
print(tapo.setWhitelampConfig(False, 1))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 2))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 3))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 4))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(False, 5))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(300, 1))
print(tapo.getWhitelampConfig())
print(tapo.setWhitelampConfig(600, 2))
print(tapo.getWhitelampConfig())
It works output_third.txt
@fuzzybear62 @Jtupz please download manually https://github.com/JurajNyiri/HomeAssistant-Tapo-Control/archive/refs/heads/reverseLight.zip and follow manual installation steps or install 5.3.0.beta.6.
Then enable debug logs.
logger:
default: critical
logs:
custom_components.tapo_control: debug
You should now see a new button entity Toggle Spotlight and 2 select entites - Spotlight Intensity and Spotlight on/off for. I had no way how to test this so it will probably not work, let me know and upload debug logs if it is not working. Selects should be automatically reflecting also settings in the app, and setting it once selected. Button should be toggling the spotlight.
Follow up question: Can you try setting forceTime to something that is not supported by the app? For example print(tapo.setWhitelampConfig(10, 2))
or print(tapo.setWhitelampConfig(3600, 2))
, does it actually set it and work? If yes, try a lot higher numbers to see if there is a limit.
I've already tested to send values out of boundaries for time and luminosity, and they are ignored. The only values admited are those in the limit I wrote on the doc
My istance of HA is managing my house, and I'll prefer to maintain the status of production system. How can I test without messing up the running installation?
You could spin up another instance of HA. Or you could test and if something is broken roll back to stable 5.2.4. I am running BETA versions of this integration myself in my house so you could consider it kind of stable. Go with beta.6 I just released, there is not much that could go wrong (worst case you do not see new entities) and worst case you rollback and restart.
Sorry, but I've no time to start up another HA. Have you put this version on HACS marked as beta?
Yes, you can download it here: https://github.com/JurajNyiri/HomeAssistant-Tapo-Control/releases/tag/5.3.0.beta.6 See https://hacs.xyz/docs/faq/beta/
Interesting, I have just found that C200 HW 3.0 "supports" this spotlight - it turns on little white LED, but there is no force time! It also ignores setting for intensity even if it reports "5".
I'll candidate myself to manage their dev team :-)
Haha. Unfortunately that means that I am still not able to test this fully - but the entities are there so it should work for you. Let me know how it goes.
Released 5.3.0.beta.7 based on what I learned from C200 HW3.0.
@fuzzybear62 What is left to test:
I've tested the beta6 and it works for luminosity, time and toggle. There is a glitch in the tapo app when you change the time the goes in loop, but I'll investigate later.
Let my test the 7th before sending the logs
Description
Everything seems to work fine, with the exception of the floodlight entity control. Documentation says that it should be available, however I do not see this option.
Reproduction Steps
Download from HACS, follow setup instructions Connect with account Camera is Tapo C320WS
Expected behavior
To see the ability to turn on and off the floodlight
If applicable, add error logs.
No response
Device Firmware
1.0.5
Using stream component
No
Does camera work via official integrations?
Yes
Camera has all attributes filled out in developer tools
Yes
HASS Environment
HASS OS VM in Proxmox
Search for similar issues
Yes
Additional information
I see options regarding the LED light (which works), and the option to use the light as the alarm “siren” (no action taken)