mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-30 22:53:59 +00:00 
			
		
		
		
	Fix for OTA mode not activating in safe_mode when OTA section has an on_xxxx action (#7796)
Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com>
This commit is contained in:
		| @@ -1,10 +1,9 @@ | |||||||
| import logging | import logging | ||||||
|  |  | ||||||
| import esphome.codegen as cg | import esphome.codegen as cg | ||||||
| import esphome.config_validation as cv | from esphome.components.ota import BASE_OTA_SCHEMA, OTAComponent, ota_to_code | ||||||
| import esphome.final_validate as fv |  | ||||||
| from esphome.components.ota import BASE_OTA_SCHEMA, ota_to_code, OTAComponent |  | ||||||
| from esphome.config_helpers import merge_config | from esphome.config_helpers import merge_config | ||||||
|  | import esphome.config_validation as cv | ||||||
| from esphome.const import ( | from esphome.const import ( | ||||||
|     CONF_ESPHOME, |     CONF_ESPHOME, | ||||||
|     CONF_ID, |     CONF_ID, | ||||||
| @@ -18,6 +17,7 @@ from esphome.const import ( | |||||||
|     CONF_VERSION, |     CONF_VERSION, | ||||||
| ) | ) | ||||||
| from esphome.core import coroutine_with_priority | from esphome.core import coroutine_with_priority | ||||||
|  | import esphome.final_validate as fv | ||||||
|  |  | ||||||
| _LOGGER = logging.getLogger(__name__) | _LOGGER = logging.getLogger(__name__) | ||||||
|  |  | ||||||
| @@ -124,7 +124,6 @@ FINAL_VALIDATE_SCHEMA = ota_esphome_final_validate | |||||||
| @coroutine_with_priority(52.0) | @coroutine_with_priority(52.0) | ||||||
| async def to_code(config): | async def to_code(config): | ||||||
|     var = cg.new_Pvariable(config[CONF_ID]) |     var = cg.new_Pvariable(config[CONF_ID]) | ||||||
|     await ota_to_code(var, config) |  | ||||||
|     cg.add(var.set_port(config[CONF_PORT])) |     cg.add(var.set_port(config[CONF_PORT])) | ||||||
|     if CONF_PASSWORD in config: |     if CONF_PASSWORD in config: | ||||||
|         cg.add(var.set_auth_password(config[CONF_PASSWORD])) |         cg.add(var.set_auth_password(config[CONF_PASSWORD])) | ||||||
| @@ -132,3 +131,4 @@ async def to_code(config): | |||||||
|     cg.add_define("USE_OTA_VERSION", config[CONF_VERSION]) |     cg.add_define("USE_OTA_VERSION", config[CONF_VERSION]) | ||||||
|  |  | ||||||
|     await cg.register_component(var, config) |     await cg.register_component(var, config) | ||||||
|  |     await ota_to_code(var, config) | ||||||
|   | |||||||
| @@ -92,6 +92,7 @@ async def to_code(config): | |||||||
|  |  | ||||||
|  |  | ||||||
| async def ota_to_code(var, config): | async def ota_to_code(var, config): | ||||||
|  |     await cg.past_safe_mode() | ||||||
|     use_state_callback = False |     use_state_callback = False | ||||||
|     for conf in config.get(CONF_ON_STATE_CHANGE, []): |     for conf in config.get(CONF_ON_STATE_CHANGE, []): | ||||||
|         trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var) |         trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user