mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-26 04:33:47 +00:00 
			
		
		
		
	[esp32_ble] Remove Arduino-specific BLE limitations and SplitDefaults (#10780)
This commit is contained in:
		| @@ -6,8 +6,6 @@ from esphome.components.esp32 import add_idf_sdkconfig_option | ||||
| from esphome.components.esp32_ble import BTLoggers | ||||
| import esphome.config_validation as cv | ||||
| from esphome.const import CONF_ACTIVE, CONF_ID | ||||
| from esphome.core import CORE | ||||
| from esphome.log import AnsiFore, color | ||||
|  | ||||
| AUTO_LOAD = ["esp32_ble_client", "esp32_ble_tracker"] | ||||
| DEPENDENCIES = ["api", "esp32"] | ||||
| @@ -48,26 +46,6 @@ def validate_connections(config): | ||||
|             config | ||||
|         ) | ||||
|  | ||||
|         # Warn about connection slot waste when using Arduino framework | ||||
|         if CORE.using_arduino and connection_slots: | ||||
|             _LOGGER.warning( | ||||
|                 "Bluetooth Proxy with active connections on Arduino framework has suboptimal performance.\n" | ||||
|                 "If BLE connections fail, they can waste connection slots for 10 seconds because\n" | ||||
|                 "Arduino doesn't allow configuring the BLE connection timeout (fixed at 30s).\n" | ||||
|                 "ESP-IDF framework allows setting it to 20s to match client timeouts.\n" | ||||
|                 "\n" | ||||
|                 "To switch to ESP-IDF, add this to your YAML:\n" | ||||
|                 "  esp32:\n" | ||||
|                 "    framework:\n" | ||||
|                 "      type: esp-idf\n" | ||||
|                 "\n" | ||||
|                 "For detailed migration instructions, see:\n" | ||||
|                 "%s", | ||||
|                 color( | ||||
|                     AnsiFore.BLUE, "https://esphome.io/guides/esp32_arduino_to_idf.html" | ||||
|                 ), | ||||
|             ) | ||||
|  | ||||
|         return { | ||||
|             **config, | ||||
|             CONF_CONNECTIONS: [CONNECTION_SCHEMA({}) for _ in range(connection_slots)], | ||||
| @@ -81,19 +59,17 @@ CONFIG_SCHEMA = cv.All( | ||||
|             { | ||||
|                 cv.GenerateID(): cv.declare_id(BluetoothProxy), | ||||
|                 cv.Optional(CONF_ACTIVE, default=True): cv.boolean, | ||||
|                 cv.SplitDefault(CONF_CACHE_SERVICES, esp32_idf=True): cv.All( | ||||
|                     cv.only_with_esp_idf, cv.boolean | ||||
|                 ), | ||||
|                 cv.Optional(CONF_CACHE_SERVICES, default=True): cv.boolean, | ||||
|                 cv.Optional( | ||||
|                     CONF_CONNECTION_SLOTS, | ||||
|                     default=DEFAULT_CONNECTION_SLOTS, | ||||
|                 ): cv.All( | ||||
|                     cv.positive_int, | ||||
|                     cv.Range(min=1, max=esp32_ble_tracker.max_connections()), | ||||
|                     cv.Range(min=1, max=esp32_ble_tracker.IDF_MAX_CONNECTIONS), | ||||
|                 ), | ||||
|                 cv.Optional(CONF_CONNECTIONS): cv.All( | ||||
|                     cv.ensure_list(CONNECTION_SCHEMA), | ||||
|                     cv.Length(min=1, max=esp32_ble_tracker.max_connections()), | ||||
|                     cv.Length(min=1, max=esp32_ble_tracker.IDF_MAX_CONNECTIONS), | ||||
|                 ), | ||||
|             } | ||||
|         ) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user