14static const char *
const TAG =
"template.alarm_control_panel";
18#ifdef USE_BINARY_SENSOR
24 alarm_sensor.
sensor = sensor;
28 this->
sensors_.push_back(alarm_sensor);
36 return AlarmSensorTypeStrings::get_log_str(
static_cast<uint8_t
>(
type), 0);
42 "TemplateAlarmControlPanel:\n"
43 " Current State: %s\n"
44 " Number of Codes: %zu\n"
45 " Requires Code To Arm: %s\n"
46 " Arming Away Time: %" PRIu32
"s\n"
47 " Arming Home Time: %" PRIu32
"s\n"
48 " Arming Night Time: %" PRIu32
"s\n"
49 " Pending Time: %" PRIu32
"s\n"
50 " Trigger Time: %" PRIu32
"s\n"
51 " Supported Features: %" PRIu32,
53 YESNO(!this->
codes_.
empty() && this->requires_code_to_arm_), (this->arming_away_time_ / 1000),
54 (this->arming_home_time_ / 1000), (this->arming_night_time_ / 1000), (this->pending_time_ / 1000),
55 (this->trigger_time_ / 1000), this->get_supported_features());
56#ifdef USE_BINARY_SENSOR
57 for (
const auto &alarm_sensor : this->
sensors_) {
58 const uint16_t
flags = alarm_sensor.info.flags;
63 " Armed home bypass: %s\n"
64 " Armed night bypass: %s\n"
67 alarm_sensor.sensor->get_name().c_str(), LOG_STR_ARG(sensor_type_to_string(alarm_sensor.info.type)),
115 bool delayed_sensor_faulted =
false;
116 bool instant_sensor_faulted =
false;
118#ifdef USE_BINARY_SENSOR
120 for (
const auto &alarm_sensor : this->
sensors_) {
121 const auto &info = alarm_sensor.info;
122 auto *sensor = alarm_sensor.sensor;
126 if ((!this->
sensor_data_[info.store_index].last_chime_state) && (sensor->state)) {
133 this->
sensor_data_[info.store_index].last_chime_state = sensor->state;
139 info.store_index) == 1) {
156 instant_sensor_faulted =
true;
161 delayed_sensor_faulted =
true;
163 instant_sensor_faulted =
true;
168 delayed_sensor_faulted =
true;
173 bool sensors_ready = !(instant_sensor_faulted || delayed_sensor_faulted);
184 if (instant_sensor_faulted) {
186 }
else if (delayed_sensor_faulted) {
202 ESP_LOGVV(TAG,
"Checking code: %s", code.
value().c_str());
204 const char *code_cstr = code.
value().c_str();
205 for (
const char *stored_code : this->
codes_) {
206 if (strcmp(stored_code, code_cstr) == 0)
211 ESP_LOGD(TAG,
"No code provided");
231 ESP_LOGW(TAG,
"Cannot arm when not disarmed");
235 ESP_LOGW(TAG,
"Not arming code doesn't match");
248#ifdef USE_BINARY_SENSOR
249 for (
const auto &alarm_sensor : this->
sensors_) {
252 ESP_LOGW(TAG,
"'%s' is faulted and will be automatically bypassed", alarm_sensor.sensor->get_name().c_str());
260 if (
call.get_state()) {
269 ESP_LOGW(TAG,
"Not disarming code doesn't match");
274#ifdef USE_BINARY_SENSOR
282 ESP_LOGE(TAG,
"State not yet implemented: %s",
ESPPreferenceObject make_entity_preference(uint32_t version=0)
Create a preference object for storing this entity's state/settings.
const optional< std::string > & get_code() const
const optional< AlarmControlPanelState > & get_state() const
AlarmControlPanelState desired_state_
LazyCallbackManager< void()> ready_callback_
bool is_state_armed(AlarmControlPanelState state)
ESPPreferenceObject pref_
LazyCallbackManager< void()> chime_callback_
AlarmControlPanelState current_state_
void publish_state(AlarmControlPanelState state)
Set the state of the alarm_control_panel.
Base class for all binary_sensor-type classes.
value_type const & value() const
uint32_t arming_away_time_
TemplateAlarmControlPanelRestoreMode restore_mode_
FixedVector< const char * > codes_
uint32_t arming_home_time_
void arm_(optional< std::string > code, alarm_control_panel::AlarmControlPanelState state, uint32_t delay)
void add_sensor(binary_sensor::BinarySensor *sensor, uint16_t flags=0, AlarmSensorType type=ALARM_SENSOR_TYPE_DELAYED)
Add a binary_sensor to the alarm_panel.
uint32_t arming_night_time_
void dump_config() override
uint32_t get_supported_features() const override
uint8_t next_store_index_
void bypass_before_arming()
FixedVector< AlarmSensor > sensors_
bool requires_code_to_arm_
std::vector< SensorDataStore > sensor_data_
void control(const alarm_control_panel::AlarmControlPanelCall &call) override
std::vector< uint8_t > bypassed_sensor_indicies_
bool is_code_valid_(optional< std::string > code)
TemplateAlarmControlPanel()
PROGMEM_STRING_TABLE(AlarmControlPanelStateStrings, "DISARMED", "ARMED_HOME", "ARMED_AWAY", "ARMED_NIGHT", "ARMED_VACATION", "ARMED_CUSTOM_BYPASS", "PENDING", "ARMING", "DISARMING", "TRIGGERED", "UNKNOWN")
const LogString * alarm_control_panel_state_to_string(AlarmControlPanelState state)
Returns a string representation of the state.
@ BINARY_SENSOR_MODE_BYPASS_AUTO
@ BINARY_SENSOR_MODE_CHIME
@ BINARY_SENSOR_MODE_BYPASS_ARMED_HOME
@ BINARY_SENSOR_MODE_BYPASS_ARMED_NIGHT
@ ALARM_CONTROL_PANEL_RESTORE_DEFAULT_DISARMED
@ ALARM_SENSOR_TYPE_DELAYED
@ ALARM_SENSOR_TYPE_INSTANT
@ ALARM_SENSOR_TYPE_INSTANT_ALWAYS
@ ALARM_SENSOR_TYPE_DELAYED_FOLLOWER
void HOT delay(uint32_t ms)
uint32_t IRAM_ATTR HOT millis()
binary_sensor::BinarySensor * sensor