mirror of
https://github.com/esphome/esphome.git
synced 2024-12-02 11:44:13 +01:00
40 lines
1.3 KiB
Python
40 lines
1.3 KiB
Python
from esphome.components.logger import USB_CDC, USB_SERIAL_JTAG
|
|
from esphome.const import CONF_BAUD_RATE, CONF_HARDWARE_UART, CONF_ID, CONF_LOGGER
|
|
import esphome.codegen as cg
|
|
import esphome.config_validation as cv
|
|
from esphome.core import CORE
|
|
import esphome.final_validate as fv
|
|
|
|
CODEOWNERS = ["@esphome/core"]
|
|
DEPENDENCIES = ["logger", "wifi"]
|
|
|
|
improv_serial_ns = cg.esphome_ns.namespace("improv_serial")
|
|
|
|
ImprovSerialComponent = improv_serial_ns.class_("ImprovSerialComponent", cg.Component)
|
|
|
|
CONFIG_SCHEMA = cv.Schema(
|
|
{
|
|
cv.GenerateID(): cv.declare_id(ImprovSerialComponent),
|
|
}
|
|
).extend(cv.COMPONENT_SCHEMA)
|
|
|
|
|
|
def validate_logger(config):
|
|
logger_conf = fv.full_config.get()[CONF_LOGGER]
|
|
if logger_conf[CONF_BAUD_RATE] == 0:
|
|
raise cv.Invalid("improv_serial requires the logger baud_rate to be not 0")
|
|
if CORE.using_esp_idf:
|
|
if logger_conf[CONF_HARDWARE_UART] in [USB_SERIAL_JTAG, USB_CDC]:
|
|
raise cv.Invalid(
|
|
"improv_serial does not support the selected logger hardware_uart"
|
|
)
|
|
return config
|
|
|
|
|
|
FINAL_VALIDATE_SCHEMA = validate_logger
|
|
|
|
|
|
async def to_code(config):
|
|
var = cg.new_Pvariable(config[CONF_ID])
|
|
await cg.register_component(var, config)
|
|
cg.add_library("esphome/Improv", "1.2.3")
|