From 348e4403db72917ee17493b07af402913d949009 Mon Sep 17 00:00:00 2001 From: Paul Wieland Date: Fri, 12 Jul 2024 08:05:28 -0400 Subject: [PATCH] Wall panel detection (#305) * Fix wall panel detection --- components/ratgdo/secplus1.cpp | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/components/ratgdo/secplus1.cpp b/components/ratgdo/secplus1.cpp index ba5caf3..5ada444 100644 --- a/components/ratgdo/secplus1.cpp +++ b/components/ratgdo/secplus1.cpp @@ -65,14 +65,14 @@ namespace ratgdo { void Secplus1::wall_panel_emulation(size_t index) { if (this->wall_panel_emulation_state_ == WallPanelEmulationState::WAITING) { - ESP_LOG1(TAG, "Looking for security+ 1.0 wall panel..."); + ESP_LOGD(TAG, "Looking for security+ 1.0 wall panel..."); if (this->door_state != DoorState::UNKNOWN || this->light_state != LightState::UNKNOWN) { ESP_LOG1(TAG, "Wall panel detected"); return; } if (millis() - this->wall_panel_emulation_start_ > 35000 && !this->wall_panel_starting_) { - ESP_LOG1(TAG, "No wall panel detected. Switching to emulation mode."); + ESP_LOGD(TAG, "No wall panel detected. Switching to emulation mode."); this->wall_panel_emulation_state_ = WallPanelEmulationState::RUNNING; } this->scheduler_->set_timeout(this->ratgdo_, "wall_panel_emulation", 2000, [=] { @@ -293,7 +293,10 @@ namespace ratgdo { void Secplus1::handle_command(const RxCommand& cmd) { - if (cmd.req == CommandType::QUERY_DOOR_STATUS) { + if (cmd.req == CommandType::TOGGLE_DOOR_RELEASE || cmd.resp == 0x31) { + ESP_LOGD(TAG, "wall panel is starting"); + this->wall_panel_starting_ = true; + } else if (cmd.req == CommandType::QUERY_DOOR_STATUS) { DoorState door_state; auto val = cmd.resp & 0x7; @@ -365,10 +368,6 @@ namespace ratgdo { } else if (cmd.req == CommandType::OBSTRUCTION) { ObstructionState obstruction_state = cmd.resp == 0 ? ObstructionState::CLEAR : ObstructionState::OBSTRUCTED; this->ratgdo_->received(obstruction_state); - } else if (cmd.req == CommandType::TOGGLE_DOOR_RELEASE) { - if (cmd.resp == 0x31) { - this->wall_panel_starting_ = true; - } } else if (cmd.req == CommandType::TOGGLE_LIGHT_PRESS) { // motion was detected, or the light toggle button was pressed // either way it's ok to trigger motion detection