mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-24 20:53:48 +01:00 
			
		
		
		
	fix --device OTA
This commit is contained in:
		| @@ -107,30 +107,50 @@ def choose_prompt(options, purpose: str = None): | |||||||
|  |  | ||||||
|  |  | ||||||
| def choose_upload_log_host( | def choose_upload_log_host( | ||||||
|     default, check_default, show_ota, show_mqtt, show_api, purpose: str = None |     default: list[str] | str | None, | ||||||
| ): |     check_default: str | None, | ||||||
|  |     show_ota: bool, | ||||||
|  |     show_mqtt: bool, | ||||||
|  |     show_api: bool, | ||||||
|  |     purpose: str | None = None, | ||||||
|  | ) -> list[str]: | ||||||
|  |     # Convert to list for uniform handling | ||||||
|  |     defaults = [default] if isinstance(default, str) else default or [] | ||||||
|  |  | ||||||
|  |     # If devices specified, resolve them | ||||||
|  |     if defaults: | ||||||
|  |         resolved: list[str] = [] | ||||||
|  |         for device in defaults: | ||||||
|  |             if device == "SERIAL": | ||||||
|  |                 options = [ | ||||||
|  |                     (f"{port.path} ({port.description})", port.path) | ||||||
|  |                     for port in get_serial_ports() | ||||||
|  |                 ] | ||||||
|  |                 resolved.append(choose_prompt(options, purpose=purpose)) | ||||||
|  |             elif device == "OTA": | ||||||
|  |                 if (show_ota and "ota" in CORE.config) or ( | ||||||
|  |                     show_api and "api" in CORE.config | ||||||
|  |                 ): | ||||||
|  |                     resolved.append(CORE.address) | ||||||
|  |                 elif show_mqtt and has_mqtt_logging(): | ||||||
|  |                     resolved.append("MQTT") | ||||||
|  |             else: | ||||||
|  |                 resolved.append(device) | ||||||
|  |         return resolved | ||||||
|  |  | ||||||
|  |     # No devices specified, show interactive chooser | ||||||
|     options = [ |     options = [ | ||||||
|         (f"{port.path} ({port.description})", port.path) for port in get_serial_ports() |         (f"{port.path} ({port.description})", port.path) for port in get_serial_ports() | ||||||
|     ] |     ] | ||||||
|     if default == "SERIAL": |  | ||||||
|         return choose_prompt(options, purpose=purpose) |  | ||||||
|     if (show_ota and "ota" in CORE.config) or (show_api and "api" in CORE.config): |     if (show_ota and "ota" in CORE.config) or (show_api and "api" in CORE.config): | ||||||
|         options.append((f"Over The Air ({CORE.address})", CORE.address)) |         options.append((f"Over The Air ({CORE.address})", CORE.address)) | ||||||
|         if default == "OTA": |     if show_mqtt and has_mqtt_logging(): | ||||||
|             return CORE.address |         mqtt_config = CORE.config[CONF_MQTT] | ||||||
|     if ( |  | ||||||
|         show_mqtt |  | ||||||
|         and (mqtt_config := CORE.config.get(CONF_MQTT)) |  | ||||||
|         and mqtt_logging_enabled(mqtt_config) |  | ||||||
|     ): |  | ||||||
|         options.append((f"MQTT ({mqtt_config[CONF_BROKER]})", "MQTT")) |         options.append((f"MQTT ({mqtt_config[CONF_BROKER]})", "MQTT")) | ||||||
|         if default == "OTA": |  | ||||||
|             return "MQTT" |  | ||||||
|     if default is not None: |  | ||||||
|         return default |  | ||||||
|     if check_default is not None and check_default in [opt[1] for opt in options]: |     if check_default is not None and check_default in [opt[1] for opt in options]: | ||||||
|         return check_default |         return [check_default] | ||||||
|     return choose_prompt(options, purpose=purpose) |     return [choose_prompt(options, purpose=purpose)] | ||||||
|  |  | ||||||
|  |  | ||||||
| def mqtt_logging_enabled(mqtt_config): | def mqtt_logging_enabled(mqtt_config): | ||||||
| @@ -142,6 +162,13 @@ def mqtt_logging_enabled(mqtt_config): | |||||||
|     return log_topic.get(CONF_LEVEL, None) != "NONE" |     return log_topic.get(CONF_LEVEL, None) != "NONE" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def has_mqtt_logging() -> bool: | ||||||
|  |     """Check if MQTT logging is available.""" | ||||||
|  |     return (mqtt_config := CORE.config.get(CONF_MQTT)) and mqtt_logging_enabled( | ||||||
|  |         mqtt_config | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |  | ||||||
| def get_port_type(port: str) -> str: | def get_port_type(port: str) -> str: | ||||||
|     if port.startswith("/") or port.startswith("COM"): |     if port.startswith("/") or port.startswith("COM"): | ||||||
|         return "SERIAL" |         return "SERIAL" | ||||||
| @@ -507,19 +534,18 @@ def command_compile(args: ArgsProtocol, config: ConfigType) -> int | None: | |||||||
|  |  | ||||||
|  |  | ||||||
| def command_upload(args: ArgsProtocol, config: ConfigType) -> int | None: | def command_upload(args: ArgsProtocol, config: ConfigType) -> int | None: | ||||||
|     # No devices specified, use the interactive chooser |     # Get devices, resolving special identifiers like OTA | ||||||
|     devices: list[str] = args.device or [ |     devices = choose_upload_log_host( | ||||||
|         choose_upload_log_host( |         default=args.device, | ||||||
|             default=None, |         check_default=None, | ||||||
|             check_default=None, |         show_ota=True, | ||||||
|             show_ota=True, |         show_mqtt=False, | ||||||
|             show_mqtt=False, |         show_api=False, | ||||||
|             show_api=False, |         purpose="uploading", | ||||||
|             purpose="uploading", |     ) | ||||||
|         ) |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     # Try each device until one succeeds |     # Try each device until one succeeds | ||||||
|  |     exit_code = 1 | ||||||
|     for device in devices: |     for device in devices: | ||||||
|         _LOGGER.info("Uploading to %s", device) |         _LOGGER.info("Uploading to %s", device) | ||||||
|         exit_code = upload_program(config, args, device) |         exit_code = upload_program(config, args, device) | ||||||
| @@ -542,17 +568,15 @@ def command_discover(args: ArgsProtocol, config: ConfigType) -> int | None: | |||||||
|  |  | ||||||
|  |  | ||||||
| def command_logs(args: ArgsProtocol, config: ConfigType) -> int | None: | def command_logs(args: ArgsProtocol, config: ConfigType) -> int | None: | ||||||
|     # No devices specified, use the interactive chooser |     # Get devices, resolving special identifiers like OTA | ||||||
|     devices = args.device or [ |     devices = choose_upload_log_host( | ||||||
|         choose_upload_log_host( |         default=args.device, | ||||||
|             default=None, |         check_default=None, | ||||||
|             check_default=None, |         show_ota=False, | ||||||
|             show_ota=False, |         show_mqtt=True, | ||||||
|             show_mqtt=True, |         show_api=True, | ||||||
|             show_api=True, |         purpose="logging", | ||||||
|             purpose="logging", |     ) | ||||||
|         ) |  | ||||||
|     ] |  | ||||||
|     return show_logs(config, args, devices) |     return show_logs(config, args, devices) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -573,17 +597,15 @@ def command_run(args: ArgsProtocol, config: ConfigType) -> int | None: | |||||||
|         program_path = idedata.raw["prog_path"] |         program_path = idedata.raw["prog_path"] | ||||||
|         return run_external_process(program_path) |         return run_external_process(program_path) | ||||||
|  |  | ||||||
|     # No devices specified, use the interactive chooser |     # Get devices, resolving special identifiers like OTA | ||||||
|     devices = args.device or [ |     devices = choose_upload_log_host( | ||||||
|         choose_upload_log_host( |         default=args.device, | ||||||
|             default=None, |         check_default=None, | ||||||
|             check_default=None, |         show_ota=True, | ||||||
|             show_ota=True, |         show_mqtt=False, | ||||||
|             show_mqtt=False, |         show_api=True, | ||||||
|             show_api=True, |         purpose="uploading", | ||||||
|             purpose="uploading", |     ) | ||||||
|         ) |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     # Try each device for upload until one succeeds |     # Try each device for upload until one succeeds | ||||||
|     successful_device: str | None = None |     successful_device: str | None = None | ||||||
| @@ -604,7 +626,7 @@ def command_run(args: ArgsProtocol, config: ConfigType) -> int | None: | |||||||
|         return 0 |         return 0 | ||||||
|  |  | ||||||
|     # For logs, prefer the device we successfully uploaded to |     # For logs, prefer the device we successfully uploaded to | ||||||
|     port = choose_upload_log_host( |     devices = choose_upload_log_host( | ||||||
|         default=successful_device, |         default=successful_device, | ||||||
|         check_default=successful_device, |         check_default=successful_device, | ||||||
|         show_ota=False, |         show_ota=False, | ||||||
| @@ -612,7 +634,7 @@ def command_run(args: ArgsProtocol, config: ConfigType) -> int | None: | |||||||
|         show_api=True, |         show_api=True, | ||||||
|         purpose="logging", |         purpose="logging", | ||||||
|     ) |     ) | ||||||
|     return show_logs(config, args, [port]) |     return show_logs(config, args, devices) | ||||||
|  |  | ||||||
|  |  | ||||||
| def command_clean_mqtt(args: ArgsProtocol, config: ConfigType) -> int | None: | def command_clean_mqtt(args: ArgsProtocol, config: ConfigType) -> int | None: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user