Files
esphome-dev/esphome/components/status/status_binary_sensor.cpp
T
Otto Winter 8e75980ebd Cleanup dashboard JS (#491)
* Cleanup dashboard JS

* Add vscode

* Save start_mark/end_mark

* Updates

* Updates

* Remove need for cv.nameable

It's a bit hacky but removes so much bloat from integrations

* Add enum helper

* Document APIs, and Improvements

* Fixes

* Fixes

* Update PULL_REQUEST_TEMPLATE.md

* Updates

* Updates

* Updates
2019-04-22 21:56:30 +02:00

40 lines
957 B
C++

#include "status_binary_sensor.h"
#include "esphome/core/log.h"
#include "esphome/core/util.h"
#ifdef USE_MQTT
#include "esphome/components/mqtt/mqtt_client.h"
#endif
#ifdef USE_API
#include "esphome/components/api/api_server.h"
#endif
namespace esphome {
namespace status {
static const char *TAG = "status";
void StatusBinarySensor::loop() {
bool status = network_is_connected();
#ifdef USE_MQTT
if (mqtt::global_mqtt_client != nullptr) {
status = mqtt::global_mqtt_client->is_connected();
}
#endif
#ifdef USE_API
if (api::global_api_server != nullptr) {
status = api::global_api_server->is_connected();
}
#endif
if (this->last_status_ != status) {
this->publish_state(status);
this->last_status_ = status;
}
}
void StatusBinarySensor::setup() { this->publish_state(false); }
void StatusBinarySensor::dump_config() { LOG_BINARY_SENSOR("", "Status Binary Sensor", this); }
} // namespace status
} // namespace esphome