mirror of
https://github.com/esphome/esphome.git
synced 2025-01-23 04:45:58 +01:00
Merge branch 'dev' into add-graphical-layout-system
This commit is contained in:
commit
9d4a4784b1
10 changed files with 192 additions and 22 deletions
|
@ -17,6 +17,12 @@ void HydreonRGxxComponent::dump_config() {
|
||||||
if (this->is_failed()) {
|
if (this->is_failed()) {
|
||||||
ESP_LOGE(TAG, "Connection with hydreon_rgxx failed!");
|
ESP_LOGE(TAG, "Connection with hydreon_rgxx failed!");
|
||||||
}
|
}
|
||||||
|
if (model_ == RG9) {
|
||||||
|
ESP_LOGCONFIG(TAG, " Model: RG9");
|
||||||
|
ESP_LOGCONFIG(TAG, " Disable Led: %s", TRUEFALSE(this->disable_led_));
|
||||||
|
} else {
|
||||||
|
ESP_LOGCONFIG(TAG, " Model: RG15");
|
||||||
|
}
|
||||||
LOG_UPDATE_INTERVAL(this);
|
LOG_UPDATE_INTERVAL(this);
|
||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
@ -25,10 +31,6 @@ void HydreonRGxxComponent::dump_config() {
|
||||||
LOG_SENSOR(" ", #s, this->sensors_[i - 1]); \
|
LOG_SENSOR(" ", #s, this->sensors_[i - 1]); \
|
||||||
}
|
}
|
||||||
HYDREON_RGXX_PROTOCOL_LIST(HYDREON_RGXX_LOG_SENSOR, );
|
HYDREON_RGXX_PROTOCOL_LIST(HYDREON_RGXX_LOG_SENSOR, );
|
||||||
|
|
||||||
if (this->model_ == RG9) {
|
|
||||||
ESP_LOGCONFIG(TAG, "disable_led: %s", TRUEFALSE(this->disable_led_));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void HydreonRGxxComponent::setup() {
|
void HydreonRGxxComponent::setup() {
|
||||||
|
|
|
@ -138,6 +138,7 @@ async def to_code(config):
|
||||||
sens = await sensor.new_sensor(config[conf])
|
sens = await sensor.new_sensor(config[conf])
|
||||||
cg.add(var.set_sensor(sens, i))
|
cg.add(var.set_sensor(sens, i))
|
||||||
|
|
||||||
|
cg.add(var.set_model(config[CONF_MODEL]))
|
||||||
cg.add(var.set_request_temperature(CONF_TEMPERATURE in config))
|
cg.add(var.set_request_temperature(CONF_TEMPERATURE in config))
|
||||||
|
|
||||||
if CONF_DISABLE_LED in config:
|
if CONF_DISABLE_LED in config:
|
||||||
|
|
|
@ -84,7 +84,7 @@ UART_SELECTION_ESP32 = {
|
||||||
VARIANT_ESP32: [UART0, UART1, UART2],
|
VARIANT_ESP32: [UART0, UART1, UART2],
|
||||||
VARIANT_ESP32S2: [UART0, UART1, USB_CDC],
|
VARIANT_ESP32S2: [UART0, UART1, USB_CDC],
|
||||||
VARIANT_ESP32S3: [UART0, UART1, USB_CDC, USB_SERIAL_JTAG],
|
VARIANT_ESP32S3: [UART0, UART1, USB_CDC, USB_SERIAL_JTAG],
|
||||||
VARIANT_ESP32C3: [UART0, UART1, USB_SERIAL_JTAG],
|
VARIANT_ESP32C3: [UART0, UART1, USB_CDC, USB_SERIAL_JTAG],
|
||||||
VARIANT_ESP32C2: [UART0, UART1],
|
VARIANT_ESP32C2: [UART0, UART1],
|
||||||
VARIANT_ESP32C6: [UART0, UART1, USB_CDC, USB_SERIAL_JTAG],
|
VARIANT_ESP32C6: [UART0, UART1, USB_CDC, USB_SERIAL_JTAG],
|
||||||
VARIANT_ESP32H2: [UART0, UART1, USB_CDC, USB_SERIAL_JTAG],
|
VARIANT_ESP32H2: [UART0, UART1, USB_CDC, USB_SERIAL_JTAG],
|
||||||
|
@ -172,9 +172,10 @@ CONFIG_SCHEMA = cv.All(
|
||||||
esp8266=UART0,
|
esp8266=UART0,
|
||||||
esp32=UART0,
|
esp32=UART0,
|
||||||
esp32_s2=USB_CDC,
|
esp32_s2=USB_CDC,
|
||||||
esp32_s3_idf=USB_SERIAL_JTAG,
|
|
||||||
esp32_c3_idf=USB_SERIAL_JTAG,
|
|
||||||
esp32_s3_arduino=USB_CDC,
|
esp32_s3_arduino=USB_CDC,
|
||||||
|
esp32_s3_idf=USB_SERIAL_JTAG,
|
||||||
|
esp32_c3_arduino=USB_CDC,
|
||||||
|
esp32_c3_idf=USB_SERIAL_JTAG,
|
||||||
rp2040=USB_CDC,
|
rp2040=USB_CDC,
|
||||||
bk72xx=DEFAULT,
|
bk72xx=DEFAULT,
|
||||||
rtl87xx=DEFAULT,
|
rtl87xx=DEFAULT,
|
||||||
|
@ -265,6 +266,8 @@ async def to_code(config):
|
||||||
if CORE.using_arduino:
|
if CORE.using_arduino:
|
||||||
if config[CONF_HARDWARE_UART] == USB_CDC:
|
if config[CONF_HARDWARE_UART] == USB_CDC:
|
||||||
cg.add_build_flag("-DARDUINO_USB_CDC_ON_BOOT=1")
|
cg.add_build_flag("-DARDUINO_USB_CDC_ON_BOOT=1")
|
||||||
|
if CORE.is_esp32 and get_esp32_variant() == VARIANT_ESP32C3:
|
||||||
|
cg.add_build_flag("-DARDUINO_USB_MODE=1")
|
||||||
|
|
||||||
if CORE.using_esp_idf:
|
if CORE.using_esp_idf:
|
||||||
if config[CONF_HARDWARE_UART] == USB_CDC:
|
if config[CONF_HARDWARE_UART] == USB_CDC:
|
||||||
|
|
|
@ -272,17 +272,13 @@ void Logger::pre_setup() {
|
||||||
#endif
|
#endif
|
||||||
#if defined(USE_ESP32) && \
|
#if defined(USE_ESP32) && \
|
||||||
(defined(USE_ESP32_VARIANT_ESP32S2) || defined(USE_ESP32_VARIANT_ESP32S3) || defined(USE_ESP32_VARIANT_ESP32C3))
|
(defined(USE_ESP32_VARIANT_ESP32S2) || defined(USE_ESP32_VARIANT_ESP32S3) || defined(USE_ESP32_VARIANT_ESP32C3))
|
||||||
#if defined(USE_ESP32_VARIANT_ESP32S2) || defined(USE_ESP32_VARIANT_ESP32S3)
|
#if defined(USE_ESP32_VARIANT_ESP32S2) || defined(USE_ESP32_VARIANT_ESP32S3) || defined(USE_ESP32_VARIANT_ESP32C3)
|
||||||
case UART_SELECTION_USB_CDC:
|
case UART_SELECTION_USB_CDC:
|
||||||
#endif // USE_ESP32_VARIANT_ESP32S2 || USE_ESP32_VARIANT_ESP32S3
|
#endif // USE_ESP32_VARIANT_ESP32S2 || USE_ESP32_VARIANT_ESP32S3 || USE_ESP32_VARIANT_ESP32C3
|
||||||
#if defined(USE_ESP32_VARIANT_ESP32C3) || defined(USE_ESP32_VARIANT_ESP32S3)
|
#if defined(USE_ESP32_VARIANT_ESP32C3) || defined(USE_ESP32_VARIANT_ESP32S3)
|
||||||
case UART_SELECTION_USB_SERIAL_JTAG:
|
case UART_SELECTION_USB_SERIAL_JTAG:
|
||||||
#endif // USE_ESP32_VARIANT_ESP32C3 || USE_ESP32_VARIANT_ESP32S3
|
#endif // USE_ESP32_VARIANT_ESP32C3 || USE_ESP32_VARIANT_ESP32S3
|
||||||
#ifdef USE_ESP32_VARIANT_ESP32C3
|
#if defined(USE_ESP32_VARIANT_ESP32S2) || defined(USE_ESP32_VARIANT_ESP32S3) || defined(USE_ESP32_VARIANT_ESP32C3)
|
||||||
this->hw_serial_ = &Serial;
|
|
||||||
Serial.begin(this->baud_rate_);
|
|
||||||
#endif // USE_ESP32_VARIANT_ESP32C3
|
|
||||||
#if defined(USE_ESP32_VARIANT_ESP32S2) || defined(USE_ESP32_VARIANT_ESP32S3)
|
|
||||||
#if ARDUINO_USB_CDC_ON_BOOT
|
#if ARDUINO_USB_CDC_ON_BOOT
|
||||||
this->hw_serial_ = &Serial;
|
this->hw_serial_ = &Serial;
|
||||||
Serial.setTxTimeoutMs(0); // workaround for 2.0.9 crash when there's no data connection
|
Serial.setTxTimeoutMs(0); // workaround for 2.0.9 crash when there's no data connection
|
||||||
|
@ -291,7 +287,7 @@ void Logger::pre_setup() {
|
||||||
this->hw_serial_ = &Serial;
|
this->hw_serial_ = &Serial;
|
||||||
Serial.begin(this->baud_rate_);
|
Serial.begin(this->baud_rate_);
|
||||||
#endif // ARDUINO_USB_CDC_ON_BOOT
|
#endif // ARDUINO_USB_CDC_ON_BOOT
|
||||||
#endif // USE_ESP32_VARIANT_ESP32S2 || USE_ESP32_VARIANT_ESP32S3
|
#endif // USE_ESP32_VARIANT_ESP32S2 || USE_ESP32_VARIANT_ESP32S3 || USE_ESP32_VARIANT_ESP32C3
|
||||||
break;
|
break;
|
||||||
#endif // USE_ESP32 && (USE_ESP32_VARIANT_ESP32S2 || USE_ESP32_VARIANT_ESP32S3 || USE_ESP32_VARIANT_ESP32C3)
|
#endif // USE_ESP32 && (USE_ESP32_VARIANT_ESP32S2 || USE_ESP32_VARIANT_ESP32S3 || USE_ESP32_VARIANT_ESP32C3)
|
||||||
#ifdef USE_RP2040
|
#ifdef USE_RP2040
|
||||||
|
|
|
@ -45,9 +45,10 @@ enum UARTSelection {
|
||||||
UART_SELECTION_UART2,
|
UART_SELECTION_UART2,
|
||||||
#endif // !USE_ESP32_VARIANT_ESP32C3 && !USE_ESP32_VARIANT_ESP32C6 && !USE_ESP32_VARIANT_ESP32S2 &&
|
#endif // !USE_ESP32_VARIANT_ESP32C3 && !USE_ESP32_VARIANT_ESP32C6 && !USE_ESP32_VARIANT_ESP32S2 &&
|
||||||
// !USE_ESP32_VARIANT_ESP32S3 && !USE_ESP32_VARIANT_ESP32H2
|
// !USE_ESP32_VARIANT_ESP32S3 && !USE_ESP32_VARIANT_ESP32H2
|
||||||
#if defined(USE_ESP32_VARIANT_ESP32S2) || defined(USE_ESP32_VARIANT_ESP32S3)
|
#if defined(USE_ESP32_VARIANT_ESP32S2) || defined(USE_ESP32_VARIANT_ESP32S3) || \
|
||||||
|
(defined(USE_ESP32_VARIANT_ESP32C3) && defined(USE_ARDUINO))
|
||||||
UART_SELECTION_USB_CDC,
|
UART_SELECTION_USB_CDC,
|
||||||
#endif // USE_ESP32_VARIANT_ESP32S2 || USE_ESP32_VARIANT_ESP32S3
|
#endif // USE_ESP32_VARIANT_ESP32S2 || USE_ESP32_VARIANT_ESP32S3 || USE_ESP32_VARIANT_ESP32C3
|
||||||
#if defined(USE_ESP32_VARIANT_ESP32C3) || defined(USE_ESP32_VARIANT_ESP32C6) || defined(USE_ESP32_VARIANT_ESP32S3) || \
|
#if defined(USE_ESP32_VARIANT_ESP32C3) || defined(USE_ESP32_VARIANT_ESP32C6) || defined(USE_ESP32_VARIANT_ESP32S3) || \
|
||||||
defined(USE_ESP32_VARIANT_ESP32H2)
|
defined(USE_ESP32_VARIANT_ESP32H2)
|
||||||
UART_SELECTION_USB_SERIAL_JTAG,
|
UART_SELECTION_USB_SERIAL_JTAG,
|
||||||
|
|
|
@ -10,6 +10,7 @@ from esphome.const import (
|
||||||
)
|
)
|
||||||
from esphome.components import time
|
from esphome.components import time
|
||||||
from esphome.core import TimePeriod
|
from esphome.core import TimePeriod
|
||||||
|
from esphome import automation
|
||||||
|
|
||||||
CONF_NETMASK = "netmask"
|
CONF_NETMASK = "netmask"
|
||||||
CONF_PRIVATE_KEY = "private_key"
|
CONF_PRIVATE_KEY = "private_key"
|
||||||
|
@ -30,6 +31,16 @@ _WG_KEY_REGEX = re.compile(r"^[A-Za-z0-9+/]{42}[AEIMQUYcgkosw480]=$")
|
||||||
|
|
||||||
wireguard_ns = cg.esphome_ns.namespace("wireguard")
|
wireguard_ns = cg.esphome_ns.namespace("wireguard")
|
||||||
Wireguard = wireguard_ns.class_("Wireguard", cg.Component, cg.PollingComponent)
|
Wireguard = wireguard_ns.class_("Wireguard", cg.Component, cg.PollingComponent)
|
||||||
|
WireguardPeerOnlineCondition = wireguard_ns.class_(
|
||||||
|
"WireguardPeerOnlineCondition", automation.Condition
|
||||||
|
)
|
||||||
|
WireguardEnabledCondition = wireguard_ns.class_(
|
||||||
|
"WireguardEnabledCondition", automation.Condition
|
||||||
|
)
|
||||||
|
WireguardEnableAction = wireguard_ns.class_("WireguardEnableAction", automation.Action)
|
||||||
|
WireguardDisableAction = wireguard_ns.class_(
|
||||||
|
"WireguardDisableAction", automation.Action
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def _wireguard_key(value):
|
def _wireguard_key(value):
|
||||||
|
@ -112,3 +123,47 @@ async def to_code(config):
|
||||||
cg.add_library("droscy/esp_wireguard", "0.3.2")
|
cg.add_library("droscy/esp_wireguard", "0.3.2")
|
||||||
|
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
|
|
||||||
|
|
||||||
|
@automation.register_condition(
|
||||||
|
"wireguard.peer_online",
|
||||||
|
WireguardPeerOnlineCondition,
|
||||||
|
cv.Schema({cv.GenerateID(): cv.use_id(Wireguard)}),
|
||||||
|
)
|
||||||
|
async def wireguard_peer_up_to_code(config, condition_id, template_arg, args):
|
||||||
|
var = cg.new_Pvariable(condition_id, template_arg)
|
||||||
|
await cg.register_parented(var, config[CONF_ID])
|
||||||
|
return var
|
||||||
|
|
||||||
|
|
||||||
|
@automation.register_condition(
|
||||||
|
"wireguard.enabled",
|
||||||
|
WireguardEnabledCondition,
|
||||||
|
cv.Schema({cv.GenerateID(): cv.use_id(Wireguard)}),
|
||||||
|
)
|
||||||
|
async def wireguard_enabled_to_code(config, condition_id, template_arg, args):
|
||||||
|
var = cg.new_Pvariable(condition_id, template_arg)
|
||||||
|
await cg.register_parented(var, config[CONF_ID])
|
||||||
|
return var
|
||||||
|
|
||||||
|
|
||||||
|
@automation.register_action(
|
||||||
|
"wireguard.enable",
|
||||||
|
WireguardEnableAction,
|
||||||
|
cv.Schema({cv.GenerateID(): cv.use_id(Wireguard)}),
|
||||||
|
)
|
||||||
|
async def wireguard_enable_to_code(config, action_id, template_arg, args):
|
||||||
|
var = cg.new_Pvariable(action_id, template_arg)
|
||||||
|
await cg.register_parented(var, config[CONF_ID])
|
||||||
|
return var
|
||||||
|
|
||||||
|
|
||||||
|
@automation.register_action(
|
||||||
|
"wireguard.disable",
|
||||||
|
WireguardDisableAction,
|
||||||
|
cv.Schema({cv.GenerateID(): cv.use_id(Wireguard)}),
|
||||||
|
)
|
||||||
|
async def wireguard_disable_to_code(config, action_id, template_arg, args):
|
||||||
|
var = cg.new_Pvariable(action_id, template_arg)
|
||||||
|
await cg.register_parented(var, config[CONF_ID])
|
||||||
|
return var
|
||||||
|
|
|
@ -4,11 +4,13 @@ from esphome.components import binary_sensor
|
||||||
from esphome.const import (
|
from esphome.const import (
|
||||||
CONF_STATUS,
|
CONF_STATUS,
|
||||||
DEVICE_CLASS_CONNECTIVITY,
|
DEVICE_CLASS_CONNECTIVITY,
|
||||||
|
ENTITY_CATEGORY_DIAGNOSTIC,
|
||||||
)
|
)
|
||||||
|
|
||||||
from . import Wireguard
|
from . import Wireguard
|
||||||
|
|
||||||
CONF_WIREGUARD_ID = "wireguard_id"
|
CONF_WIREGUARD_ID = "wireguard_id"
|
||||||
|
CONF_ENABLED = "enabled"
|
||||||
|
|
||||||
DEPENDENCIES = ["wireguard"]
|
DEPENDENCIES = ["wireguard"]
|
||||||
|
|
||||||
|
@ -17,6 +19,9 @@ CONFIG_SCHEMA = {
|
||||||
cv.Optional(CONF_STATUS): binary_sensor.binary_sensor_schema(
|
cv.Optional(CONF_STATUS): binary_sensor.binary_sensor_schema(
|
||||||
device_class=DEVICE_CLASS_CONNECTIVITY,
|
device_class=DEVICE_CLASS_CONNECTIVITY,
|
||||||
),
|
),
|
||||||
|
cv.Optional(CONF_ENABLED): binary_sensor.binary_sensor_schema(
|
||||||
|
entity_category=ENTITY_CATEGORY_DIAGNOSTIC,
|
||||||
|
),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -26,3 +31,7 @@ async def to_code(config):
|
||||||
if status_config := config.get(CONF_STATUS):
|
if status_config := config.get(CONF_STATUS):
|
||||||
sens = await binary_sensor.new_binary_sensor(status_config)
|
sens = await binary_sensor.new_binary_sensor(status_config)
|
||||||
cg.add(parent.set_status_sensor(sens))
|
cg.add(parent.set_status_sensor(sens))
|
||||||
|
|
||||||
|
if enabled_config := config.get(CONF_ENABLED):
|
||||||
|
sens = await binary_sensor.new_binary_sensor(enabled_config)
|
||||||
|
cg.add(parent.set_enabled_sensor(sens))
|
||||||
|
|
|
@ -48,6 +48,8 @@ void Wireguard::setup() {
|
||||||
if (this->preshared_key_.length() > 0)
|
if (this->preshared_key_.length() > 0)
|
||||||
this->wg_config_.preshared_key = this->preshared_key_.c_str();
|
this->wg_config_.preshared_key = this->preshared_key_.c_str();
|
||||||
|
|
||||||
|
this->publish_enabled_state();
|
||||||
|
|
||||||
this->wg_initialized_ = esp_wireguard_init(&(this->wg_config_), &(this->wg_ctx_));
|
this->wg_initialized_ = esp_wireguard_init(&(this->wg_config_), &(this->wg_ctx_));
|
||||||
|
|
||||||
if (this->wg_initialized_ == ESP_OK) {
|
if (this->wg_initialized_ == ESP_OK) {
|
||||||
|
@ -68,6 +70,10 @@ void Wireguard::setup() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Wireguard::loop() {
|
void Wireguard::loop() {
|
||||||
|
if (!this->enabled_) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if ((this->wg_initialized_ == ESP_OK) && (this->wg_connected_ == ESP_OK) && (!network::is_connected())) {
|
if ((this->wg_initialized_ == ESP_OK) && (this->wg_connected_ == ESP_OK) && (!network::is_connected())) {
|
||||||
ESP_LOGV(TAG, "local network connection has been lost, stopping WireGuard...");
|
ESP_LOGV(TAG, "local network connection has been lost, stopping WireGuard...");
|
||||||
this->stop_connection_();
|
this->stop_connection_();
|
||||||
|
@ -79,8 +85,9 @@ void Wireguard::update() {
|
||||||
time_t lhs = this->get_latest_handshake();
|
time_t lhs = this->get_latest_handshake();
|
||||||
bool lhs_updated = (lhs > this->latest_saved_handshake_);
|
bool lhs_updated = (lhs > this->latest_saved_handshake_);
|
||||||
|
|
||||||
ESP_LOGV(TAG, "handshake: latest=%.0f, saved=%.0f, updated=%d", (double) lhs, (double) this->latest_saved_handshake_,
|
ESP_LOGV(TAG, "enabled=%d, connected=%d, peer_up=%d, handshake: current=%.0f latest=%.0f updated=%d",
|
||||||
(int) lhs_updated);
|
(int) this->enabled_, (int) (this->wg_connected_ == ESP_OK), (int) peer_up, (double) lhs,
|
||||||
|
(double) this->latest_saved_handshake_, (int) lhs_updated);
|
||||||
|
|
||||||
if (lhs_updated) {
|
if (lhs_updated) {
|
||||||
this->latest_saved_handshake_ = lhs;
|
this->latest_saved_handshake_ = lhs;
|
||||||
|
@ -102,13 +109,13 @@ void Wireguard::update() {
|
||||||
if (this->wg_peer_offline_time_ == 0) {
|
if (this->wg_peer_offline_time_ == 0) {
|
||||||
ESP_LOGW(TAG, LOGMSG_PEER_STATUS, LOGMSG_OFFLINE, latest_handshake.c_str());
|
ESP_LOGW(TAG, LOGMSG_PEER_STATUS, LOGMSG_OFFLINE, latest_handshake.c_str());
|
||||||
this->wg_peer_offline_time_ = millis();
|
this->wg_peer_offline_time_ = millis();
|
||||||
} else {
|
} else if (this->enabled_) {
|
||||||
ESP_LOGD(TAG, LOGMSG_PEER_STATUS, LOGMSG_OFFLINE, latest_handshake.c_str());
|
ESP_LOGD(TAG, LOGMSG_PEER_STATUS, LOGMSG_OFFLINE, latest_handshake.c_str());
|
||||||
this->start_connection_();
|
this->start_connection_();
|
||||||
}
|
}
|
||||||
|
|
||||||
// check reboot timeout every time the peer is down
|
// check reboot timeout every time the peer is down
|
||||||
if (this->reboot_timeout_ > 0) {
|
if (this->enabled_ && this->reboot_timeout_ > 0) {
|
||||||
if (millis() - this->wg_peer_offline_time_ > this->reboot_timeout_) {
|
if (millis() - this->wg_peer_offline_time_ > this->reboot_timeout_) {
|
||||||
ESP_LOGE(TAG, "WireGuard remote peer is unreachable, rebooting...");
|
ESP_LOGE(TAG, "WireGuard remote peer is unreachable, rebooting...");
|
||||||
App.reboot();
|
App.reboot();
|
||||||
|
@ -154,7 +161,7 @@ void Wireguard::dump_config() {
|
||||||
|
|
||||||
void Wireguard::on_shutdown() { this->stop_connection_(); }
|
void Wireguard::on_shutdown() { this->stop_connection_(); }
|
||||||
|
|
||||||
bool Wireguard::can_proceed() { return (this->proceed_allowed_ || this->is_peer_up()); }
|
bool Wireguard::can_proceed() { return (this->proceed_allowed_ || this->is_peer_up() || !this->enabled_); }
|
||||||
|
|
||||||
bool Wireguard::is_peer_up() const {
|
bool Wireguard::is_peer_up() const {
|
||||||
return (this->wg_initialized_ == ESP_OK) && (this->wg_connected_ == ESP_OK) &&
|
return (this->wg_initialized_ == ESP_OK) && (this->wg_connected_ == ESP_OK) &&
|
||||||
|
@ -187,6 +194,7 @@ void Wireguard::set_srctime(time::RealTimeClock *srctime) { this->srctime_ = src
|
||||||
|
|
||||||
#ifdef USE_BINARY_SENSOR
|
#ifdef USE_BINARY_SENSOR
|
||||||
void Wireguard::set_status_sensor(binary_sensor::BinarySensor *sensor) { this->status_sensor_ = sensor; }
|
void Wireguard::set_status_sensor(binary_sensor::BinarySensor *sensor) { this->status_sensor_ = sensor; }
|
||||||
|
void Wireguard::set_enabled_sensor(binary_sensor::BinarySensor *sensor) { this->enabled_sensor_ = sensor; }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_SENSOR
|
#ifdef USE_SENSOR
|
||||||
|
@ -199,7 +207,35 @@ void Wireguard::set_address_sensor(text_sensor::TextSensor *sensor) { this->addr
|
||||||
|
|
||||||
void Wireguard::disable_auto_proceed() { this->proceed_allowed_ = false; }
|
void Wireguard::disable_auto_proceed() { this->proceed_allowed_ = false; }
|
||||||
|
|
||||||
|
void Wireguard::enable() {
|
||||||
|
this->enabled_ = true;
|
||||||
|
ESP_LOGI(TAG, "WireGuard enabled");
|
||||||
|
this->publish_enabled_state();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Wireguard::disable() {
|
||||||
|
this->enabled_ = false;
|
||||||
|
this->defer(std::bind(&Wireguard::stop_connection_, this)); // defer to avoid blocking running loop
|
||||||
|
ESP_LOGI(TAG, "WireGuard disabled");
|
||||||
|
this->publish_enabled_state();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Wireguard::publish_enabled_state() {
|
||||||
|
#ifdef USE_BINARY_SENSOR
|
||||||
|
if (this->enabled_sensor_ != nullptr) {
|
||||||
|
this->enabled_sensor_->publish_state(this->enabled_);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Wireguard::is_enabled() { return this->enabled_; }
|
||||||
|
|
||||||
void Wireguard::start_connection_() {
|
void Wireguard::start_connection_() {
|
||||||
|
if (!this->enabled_) {
|
||||||
|
ESP_LOGV(TAG, "WireGuard is disabled, cannot start connection");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (this->wg_initialized_ != ESP_OK) {
|
if (this->wg_initialized_ != ESP_OK) {
|
||||||
ESP_LOGE(TAG, "cannot start WireGuard, initialization in error with code %d", this->wg_initialized_);
|
ESP_LOGE(TAG, "cannot start WireGuard, initialization in error with code %d", this->wg_initialized_);
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
namespace esphome {
|
namespace esphome {
|
||||||
namespace wireguard {
|
namespace wireguard {
|
||||||
|
|
||||||
|
/// Main Wireguard component class.
|
||||||
class Wireguard : public PollingComponent {
|
class Wireguard : public PollingComponent {
|
||||||
public:
|
public:
|
||||||
void setup() override;
|
void setup() override;
|
||||||
|
@ -53,6 +54,7 @@ class Wireguard : public PollingComponent {
|
||||||
|
|
||||||
#ifdef USE_BINARY_SENSOR
|
#ifdef USE_BINARY_SENSOR
|
||||||
void set_status_sensor(binary_sensor::BinarySensor *sensor);
|
void set_status_sensor(binary_sensor::BinarySensor *sensor);
|
||||||
|
void set_enabled_sensor(binary_sensor::BinarySensor *sensor);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_SENSOR
|
#ifdef USE_SENSOR
|
||||||
|
@ -66,6 +68,18 @@ class Wireguard : public PollingComponent {
|
||||||
/// Block the setup step until peer is connected.
|
/// Block the setup step until peer is connected.
|
||||||
void disable_auto_proceed();
|
void disable_auto_proceed();
|
||||||
|
|
||||||
|
/// Enable the WireGuard component.
|
||||||
|
void enable();
|
||||||
|
|
||||||
|
/// Stop any running connection and disable the WireGuard component.
|
||||||
|
void disable();
|
||||||
|
|
||||||
|
/// Publish the enabled state if the enabled binary sensor is configured.
|
||||||
|
void publish_enabled_state();
|
||||||
|
|
||||||
|
/// Return if the WireGuard component is or is not enabled.
|
||||||
|
bool is_enabled();
|
||||||
|
|
||||||
bool is_peer_up() const;
|
bool is_peer_up() const;
|
||||||
time_t get_latest_handshake() const;
|
time_t get_latest_handshake() const;
|
||||||
|
|
||||||
|
@ -87,6 +101,7 @@ class Wireguard : public PollingComponent {
|
||||||
|
|
||||||
#ifdef USE_BINARY_SENSOR
|
#ifdef USE_BINARY_SENSOR
|
||||||
binary_sensor::BinarySensor *status_sensor_ = nullptr;
|
binary_sensor::BinarySensor *status_sensor_ = nullptr;
|
||||||
|
binary_sensor::BinarySensor *enabled_sensor_ = nullptr;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_SENSOR
|
#ifdef USE_SENSOR
|
||||||
|
@ -100,6 +115,9 @@ class Wireguard : public PollingComponent {
|
||||||
/// Set to false to block the setup step until peer is connected.
|
/// Set to false to block the setup step until peer is connected.
|
||||||
bool proceed_allowed_ = true;
|
bool proceed_allowed_ = true;
|
||||||
|
|
||||||
|
/// When false the wireguard link will not be established
|
||||||
|
bool enabled_ = true;
|
||||||
|
|
||||||
wireguard_config_t wg_config_ = ESP_WIREGUARD_CONFIG_DEFAULT();
|
wireguard_config_t wg_config_ = ESP_WIREGUARD_CONFIG_DEFAULT();
|
||||||
wireguard_ctx_t wg_ctx_ = ESP_WIREGUARD_CONTEXT_DEFAULT();
|
wireguard_ctx_t wg_ctx_ = ESP_WIREGUARD_CONTEXT_DEFAULT();
|
||||||
|
|
||||||
|
@ -128,6 +146,30 @@ void resume_wdt();
|
||||||
/// Strip most part of the key only for secure printing
|
/// Strip most part of the key only for secure printing
|
||||||
std::string mask_key(const std::string &key);
|
std::string mask_key(const std::string &key);
|
||||||
|
|
||||||
|
/// Condition to check if remote peer is online.
|
||||||
|
template<typename... Ts> class WireguardPeerOnlineCondition : public Condition<Ts...>, public Parented<Wireguard> {
|
||||||
|
public:
|
||||||
|
bool check(Ts... x) override { return this->parent_->is_peer_up(); }
|
||||||
|
};
|
||||||
|
|
||||||
|
/// Condition to check if Wireguard component is enabled.
|
||||||
|
template<typename... Ts> class WireguardEnabledCondition : public Condition<Ts...>, public Parented<Wireguard> {
|
||||||
|
public:
|
||||||
|
bool check(Ts... x) override { return this->parent_->is_enabled(); }
|
||||||
|
};
|
||||||
|
|
||||||
|
/// Action to enable Wireguard component.
|
||||||
|
template<typename... Ts> class WireguardEnableAction : public Action<Ts...>, public Parented<Wireguard> {
|
||||||
|
public:
|
||||||
|
void play(Ts... x) override { this->parent_->enable(); }
|
||||||
|
};
|
||||||
|
|
||||||
|
/// Action to disable Wireguard component.
|
||||||
|
template<typename... Ts> class WireguardDisableAction : public Action<Ts...>, public Parented<Wireguard> {
|
||||||
|
public:
|
||||||
|
void play(Ts... x) override { this->parent_->disable(); }
|
||||||
|
};
|
||||||
|
|
||||||
} // namespace wireguard
|
} // namespace wireguard
|
||||||
} // namespace esphome
|
} // namespace esphome
|
||||||
|
|
||||||
|
|
|
@ -44,6 +44,8 @@ binary_sensor:
|
||||||
- platform: wireguard
|
- platform: wireguard
|
||||||
status:
|
status:
|
||||||
name: 'WireGuard Status'
|
name: 'WireGuard Status'
|
||||||
|
enabled:
|
||||||
|
name: 'WireGuard Enabled'
|
||||||
|
|
||||||
sensor:
|
sensor:
|
||||||
- platform: wireguard
|
- platform: wireguard
|
||||||
|
@ -54,3 +56,26 @@ text_sensor:
|
||||||
- platform: wireguard
|
- platform: wireguard
|
||||||
address:
|
address:
|
||||||
name: 'WireGuard Address'
|
name: 'WireGuard Address'
|
||||||
|
|
||||||
|
button:
|
||||||
|
- platform: template
|
||||||
|
name: 'Toggle WireGuard'
|
||||||
|
entity_category: config
|
||||||
|
on_press:
|
||||||
|
- if:
|
||||||
|
condition: wireguard.enabled
|
||||||
|
then:
|
||||||
|
- wireguard.disable:
|
||||||
|
else:
|
||||||
|
- wireguard.enable:
|
||||||
|
|
||||||
|
- platform: template
|
||||||
|
name: 'Log WireGuard status'
|
||||||
|
entity_category: config
|
||||||
|
on_press:
|
||||||
|
- if:
|
||||||
|
condition: wireguard.peer_online
|
||||||
|
then:
|
||||||
|
- logger.log: 'wireguard remote peer is online'
|
||||||
|
else:
|
||||||
|
- logger.log: 'wireguard remote peer is offline'
|
||||||
|
|
Loading…
Reference in a new issue