mirror of
https://github.com/google/bumble.git
synced 2026-06-01 07:37:02 +00:00
Merge pull request #65 from google/gbg/fix-classic-connect-await
fix classic connection event filtering
This commit is contained in:
+5
-1
@@ -1211,11 +1211,15 @@ class Device(CompositeEventEmitter):
|
|||||||
|
|
||||||
if type(peer_address) is str:
|
if type(peer_address) is str:
|
||||||
try:
|
try:
|
||||||
peer_address = Address(peer_address)
|
peer_address = Address.from_string_for_transport(peer_address, transport)
|
||||||
except ValueError:
|
except ValueError:
|
||||||
# If the address is not parsable, assume it is a name instead
|
# If the address is not parsable, assume it is a name instead
|
||||||
logger.debug('looking for peer by name')
|
logger.debug('looking for peer by name')
|
||||||
peer_address = await self.find_peer_by_name(peer_address, transport) # TODO: timeout
|
peer_address = await self.find_peer_by_name(peer_address, transport) # TODO: timeout
|
||||||
|
else:
|
||||||
|
# All BR/EDR addresses should be public addresses
|
||||||
|
if transport == BT_BR_EDR_TRANSPORT and peer_address.address_type != Address.PUBLIC_DEVICE_ADDRESS:
|
||||||
|
raise ValueError('BR/EDR addresses must be PUBLIC')
|
||||||
|
|
||||||
def on_connection(connection):
|
def on_connection(connection):
|
||||||
if transport == BT_LE_TRANSPORT or (
|
if transport == BT_LE_TRANSPORT or (
|
||||||
|
|||||||
@@ -1666,6 +1666,14 @@ class Address:
|
|||||||
def address_type_name(address_type):
|
def address_type_name(address_type):
|
||||||
return name_or_number(Address.ADDRESS_TYPE_NAMES, address_type)
|
return name_or_number(Address.ADDRESS_TYPE_NAMES, address_type)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def from_string_for_transport(string, transport):
|
||||||
|
if transport == BT_BR_EDR_TRANSPORT:
|
||||||
|
address_type = Address.PUBLIC_DEVICE_ADDRESS
|
||||||
|
else:
|
||||||
|
address_type = Address.RANDOM_DEVICE_ADDRESS
|
||||||
|
return Address(string, address_type)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def parse_address(data, offset):
|
def parse_address(data, offset):
|
||||||
# Fix the type to a default value. This is used for parsing type-less Classic addresses
|
# Fix the type to a default value. This is used for parsing type-less Classic addresses
|
||||||
@@ -1706,6 +1714,9 @@ class Address:
|
|||||||
|
|
||||||
self.address_type = address_type
|
self.address_type = address_type
|
||||||
|
|
||||||
|
def clone(self):
|
||||||
|
return Address(self.address_bytes, self.address_type)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_public(self):
|
def is_public(self):
|
||||||
return self.address_type == self.PUBLIC_DEVICE_ADDRESS or self.address_type == self.PUBLIC_IDENTITY_ADDRESS
|
return self.address_type == self.PUBLIC_DEVICE_ADDRESS or self.address_type == self.PUBLIC_IDENTITY_ADDRESS
|
||||||
|
|||||||
Reference in New Issue
Block a user