mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-31 07:03:55 +00:00 
			
		
		
		
	service uuid based ble tracking (#800)
* service uuid based ble tracking * code review fixes * fix import, format * fix indentation * reformat
This commit is contained in:
		| @@ -1,7 +1,7 @@ | ||||
| import esphome.codegen as cg | ||||
| import esphome.config_validation as cv | ||||
| from esphome.components import binary_sensor, esp32_ble_tracker | ||||
| from esphome.const import CONF_MAC_ADDRESS, CONF_ID | ||||
| from esphome.const import CONF_MAC_ADDRESS, CONF_SERVICE_UUID, CONF_ID | ||||
|  | ||||
| DEPENDENCIES = ['esp32_ble_tracker'] | ||||
|  | ||||
| @@ -9,10 +9,12 @@ ble_presence_ns = cg.esphome_ns.namespace('ble_presence') | ||||
| BLEPresenceDevice = ble_presence_ns.class_('BLEPresenceDevice', binary_sensor.BinarySensor, | ||||
|                                            cg.Component, esp32_ble_tracker.ESPBTDeviceListener) | ||||
|  | ||||
| CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend({ | ||||
| CONFIG_SCHEMA = cv.All(binary_sensor.BINARY_SENSOR_SCHEMA.extend({ | ||||
|     cv.GenerateID(): cv.declare_id(BLEPresenceDevice), | ||||
|     cv.Required(CONF_MAC_ADDRESS): cv.mac_address, | ||||
| }).extend(esp32_ble_tracker.ESP_BLE_DEVICE_SCHEMA).extend(cv.COMPONENT_SCHEMA) | ||||
|     cv.Optional(CONF_MAC_ADDRESS): cv.mac_address, | ||||
|     cv.Optional(CONF_SERVICE_UUID): esp32_ble_tracker.bt_uuid, | ||||
| }).extend(esp32_ble_tracker.ESP_BLE_DEVICE_SCHEMA).extend( | ||||
|     cv.COMPONENT_SCHEMA), cv.has_exactly_one_key(CONF_MAC_ADDRESS, CONF_SERVICE_UUID)) | ||||
|  | ||||
|  | ||||
| def to_code(config): | ||||
| @@ -21,4 +23,14 @@ def to_code(config): | ||||
|     yield esp32_ble_tracker.register_ble_device(var, config) | ||||
|     yield binary_sensor.register_binary_sensor(var, config) | ||||
|  | ||||
|     cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex)) | ||||
|     if CONF_MAC_ADDRESS in config: | ||||
|         cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex)) | ||||
|  | ||||
|     if CONF_SERVICE_UUID in config: | ||||
|         if len(config[CONF_SERVICE_UUID]) == len(esp32_ble_tracker.bt_uuid16_format): | ||||
|             cg.add(var.set_service_uuid16(esp32_ble_tracker.as_hex(config[CONF_SERVICE_UUID]))) | ||||
|         elif len(config[CONF_SERVICE_UUID]) == len(esp32_ble_tracker.bt_uuid32_format): | ||||
|             cg.add(var.set_service_uuid32(esp32_ble_tracker.as_hex(config[CONF_SERVICE_UUID]))) | ||||
|         elif len(config[CONF_SERVICE_UUID]) == len(esp32_ble_tracker.bt_uuid128_format): | ||||
|             uuid128 = esp32_ble_tracker.as_hex_array(config[CONF_SERVICE_UUID]) | ||||
|             cg.add(var.set_service_uuid128(uuid128)) | ||||
|   | ||||
| @@ -13,17 +13,67 @@ class BLEPresenceDevice : public binary_sensor::BinarySensor, | ||||
|                           public esp32_ble_tracker::ESPBTDeviceListener, | ||||
|                           public Component { | ||||
|  public: | ||||
|   void set_address(uint64_t address) { address_ = address; } | ||||
|   void set_address(uint64_t address) { | ||||
|     this->by_address_ = true; | ||||
|     this->address_ = address; | ||||
|   } | ||||
|   void set_service_uuid16(uint16_t uuid) { | ||||
|     this->by_address_ = false; | ||||
|     this->uuid_ = esp32_ble_tracker::ESPBTUUID::from_uint16(uuid); | ||||
|   } | ||||
|   void set_service_uuid32(uint32_t uuid) { | ||||
|     this->by_address_ = false; | ||||
|     this->uuid_ = esp32_ble_tracker::ESPBTUUID::from_uint32(uuid); | ||||
|   } | ||||
|   void set_service_uuid128(uint8_t *uuid) { | ||||
|     this->by_address_ = false; | ||||
|     this->uuid_ = esp32_ble_tracker::ESPBTUUID::from_raw(uuid); | ||||
|   } | ||||
|   void on_scan_end() override { | ||||
|     if (!this->found_) | ||||
|       this->publish_state(false); | ||||
|     this->found_ = false; | ||||
|   } | ||||
|   bool parse_device(const esp32_ble_tracker::ESPBTDevice &device) override { | ||||
|     if (device.address_uint64() == this->address_) { | ||||
|       this->publish_state(true); | ||||
|       this->found_ = true; | ||||
|       return true; | ||||
|     if (this->by_address_) { | ||||
|       if (device.address_uint64() == this->address_) { | ||||
|         this->publish_state(true); | ||||
|         this->found_ = true; | ||||
|         return true; | ||||
|       } | ||||
|     } else { | ||||
|       for (auto uuid : device.get_service_uuids()) { | ||||
|         switch (this->uuid_.get_uuid().len) { | ||||
|           case ESP_UUID_LEN_16: | ||||
|             if (uuid.get_uuid().len == ESP_UUID_LEN_16 && | ||||
|                 uuid.get_uuid().uuid.uuid16 == this->uuid_.get_uuid().uuid.uuid16) { | ||||
|               this->publish_state(true); | ||||
|               this->found_ = true; | ||||
|               return true; | ||||
|             } | ||||
|             break; | ||||
|           case ESP_UUID_LEN_32: | ||||
|             if (uuid.get_uuid().len == ESP_UUID_LEN_32 && | ||||
|                 uuid.get_uuid().uuid.uuid32 == this->uuid_.get_uuid().uuid.uuid32) { | ||||
|               this->publish_state(true); | ||||
|               this->found_ = true; | ||||
|               return true; | ||||
|             } | ||||
|             break; | ||||
|           case ESP_UUID_LEN_128: | ||||
|             if (uuid.get_uuid().len == ESP_UUID_LEN_128) { | ||||
|               for (int i = 0; i < ESP_UUID_LEN_128; i++) { | ||||
|                 if (this->uuid_.get_uuid().uuid.uuid128[i] != uuid.get_uuid().uuid.uuid128[i]) { | ||||
|                   return false; | ||||
|                 } | ||||
|               } | ||||
|               this->publish_state(true); | ||||
|               this->found_ = true; | ||||
|               return true; | ||||
|             } | ||||
|             break; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     return false; | ||||
|   } | ||||
| @@ -32,7 +82,9 @@ class BLEPresenceDevice : public binary_sensor::BinarySensor, | ||||
|  | ||||
|  protected: | ||||
|   bool found_{false}; | ||||
|   bool by_address_{false}; | ||||
|   uint64_t address_; | ||||
|   esp32_ble_tracker::ESPBTUUID uuid_; | ||||
| }; | ||||
|  | ||||
| }  // namespace ble_presence | ||||
|   | ||||
		Reference in New Issue
	
	Block a user