esphome-ratgdo/components/ratgdo/binary_sensor/ratgdo_binary_sensor.cpp

33 lines
1.4 KiB
C++
Raw Normal View History

2023-06-07 15:37:51 +00:00
#include "ratgdo_binary_sensor.h"
#include "../ratgdo_state.h"
2023-06-07 16:41:02 +00:00
#include "esphome/core/log.h"
2023-06-07 15:37:51 +00:00
namespace esphome {
namespace ratgdo {
2023-06-07 16:41:02 +00:00
static const char* const TAG = "ratgdo.binary_sensor";
2023-06-07 16:40:49 +00:00
2023-06-07 16:41:02 +00:00
void RATGDOBinarySensor::dump_config()
{
LOG_BINARY_SENSOR("", "RATGDO BinarySensor", this);
2023-06-07 19:49:01 +00:00
ESP_LOGCONFIG(TAG, " Type: %s", this->binary_sensor_type_ == SensorType::RATGDO_SENSOR_MOTION ? "Motion" : "Obstruction");
2023-06-07 16:41:02 +00:00
}
2023-06-07 19:08:35 +00:00
void RATGDOBinarySensor::on_motion_state(MotionState state)
2023-06-07 16:41:02 +00:00
{
2023-06-07 19:48:20 +00:00
ESP_LOGD(TAG, "name: %s this->type_:%d on_motion_state: %d", this->get_name(), this->binary_sensor_type_, state);
if (this->binary_sensor_type_ == SensorType::RATGDO_SENSOR_MOTION)
2023-06-07 19:08:35 +00:00
this->publish_state(state == MotionState::MOTION_STATE_DETECTED);
2023-06-07 16:41:02 +00:00
}
2023-06-07 19:08:35 +00:00
void RATGDOBinarySensor::on_obstruction_state(ObstructionState state)
2023-06-07 16:41:02 +00:00
{
2023-06-07 19:48:20 +00:00
ESP_LOGD(TAG, "name: %s this->type_:%d on_obstruction_state: %d", this->get_name(), this->binary_sensor_type_, state);
if (this->binary_sensor_type_ == SensorType::RATGDO_SENSOR_OBSTRUCTION)
2023-06-07 19:08:35 +00:00
this->publish_state(state == ObstructionState::OBSTRUCTION_STATE_OBSTRUCTED);
2023-06-07 16:41:02 +00:00
}
2023-06-07 19:08:35 +00:00
void RATGDOBinarySensor::on_door_state(DoorState state) { }
void RATGDOBinarySensor::on_light_state(LightState state) { }
2023-06-07 19:08:52 +00:00
void RATGDOBinarySensor::on_lock_state(LockState state) { }
2023-06-07 15:37:51 +00:00
2023-06-07 16:41:02 +00:00
} // namespace ratgdo
} // namespace esphome