mirror of
https://github.com/vanhoefm/fragattacks.git
synced 2025-01-18 19:04:02 -05:00
DPP: Try to negotiate different parameters if NFC handover fails
This is mainly for NFC testing purposes now since the own DPP parameters are not yet updated. Signed-off-by: Jouni Malinen <jouni@codeaurora.org>
This commit is contained in:
parent
61c049da3d
commit
4dc3b70deb
@ -234,6 +234,7 @@ def dpp_handover_client(llc):
|
|||||||
print("Received message")
|
print("Received message")
|
||||||
print("alternative carriers: " + str(message[0].alternative_carriers))
|
print("alternative carriers: " + str(message[0].alternative_carriers))
|
||||||
|
|
||||||
|
dpp_found = False
|
||||||
for carrier in message:
|
for carrier in message:
|
||||||
if isinstance(carrier, ndef.HandoverSelectRecord):
|
if isinstance(carrier, ndef.HandoverSelectRecord):
|
||||||
continue
|
continue
|
||||||
@ -243,6 +244,7 @@ def dpp_handover_client(llc):
|
|||||||
print("URI Identifier Code 'None' not seen")
|
print("URI Identifier Code 'None' not seen")
|
||||||
continue
|
continue
|
||||||
print("DPP carrier type match - send to wpa_supplicant")
|
print("DPP carrier type match - send to wpa_supplicant")
|
||||||
|
dpp_found = True
|
||||||
uri = carrier.data[1:].decode("utf-8")
|
uri = carrier.data[1:].decode("utf-8")
|
||||||
print("DPP URI: " + uri)
|
print("DPP URI: " + uri)
|
||||||
res = wpas_report_handover_sel(uri)
|
res = wpas_report_handover_sel(uri)
|
||||||
@ -270,6 +272,12 @@ def dpp_handover_client(llc):
|
|||||||
print("Failed to initiate DPP authentication")
|
print("Failed to initiate DPP authentication")
|
||||||
break
|
break
|
||||||
|
|
||||||
|
if not dpp_found:
|
||||||
|
print("DPP carrier not seen in response - allow peer to initiate a new handover with different parameters")
|
||||||
|
client.close()
|
||||||
|
print("Returning from dpp_handover_client")
|
||||||
|
return
|
||||||
|
|
||||||
print("Remove peer")
|
print("Remove peer")
|
||||||
client.close()
|
client.close()
|
||||||
print("Done with handover")
|
print("Done with handover")
|
||||||
@ -293,6 +301,7 @@ class HandoverServer(nfc.handover.HandoverServer):
|
|||||||
self.sent_carrier = None
|
self.sent_carrier = None
|
||||||
self.ho_server_processing = False
|
self.ho_server_processing = False
|
||||||
self.success = False
|
self.success = False
|
||||||
|
self.try_own = False
|
||||||
|
|
||||||
def process_handover_request_message(self, records):
|
def process_handover_request_message(self, records):
|
||||||
self.ho_server_processing = True
|
self.ho_server_processing = True
|
||||||
@ -359,7 +368,10 @@ class HandoverServer(nfc.handover.HandoverServer):
|
|||||||
break
|
break
|
||||||
|
|
||||||
summary("Sending handover select: " + str(sel))
|
summary("Sending handover select: " + str(sel))
|
||||||
|
if found:
|
||||||
self.success = True
|
self.success = True
|
||||||
|
else:
|
||||||
|
self.try_own = True
|
||||||
return sel
|
return sel
|
||||||
|
|
||||||
def clear_raw_mode():
|
def clear_raw_mode():
|
||||||
@ -508,6 +520,12 @@ def llcp_worker(llc):
|
|||||||
global srv
|
global srv
|
||||||
global wait_connection
|
global wait_connection
|
||||||
while not wait_connection and srv.sent_carrier is None:
|
while not wait_connection and srv.sent_carrier is None:
|
||||||
|
if srv.try_own:
|
||||||
|
srv.try_own = False
|
||||||
|
print("Try to initiate another handover with own parameters")
|
||||||
|
dpp_handover_client(llc)
|
||||||
|
print("Exiting llcp_worker thread (retry with own parameters)")
|
||||||
|
return
|
||||||
if srv.ho_server_processing:
|
if srv.ho_server_processing:
|
||||||
time.sleep(0.025)
|
time.sleep(0.025)
|
||||||
elif no_input:
|
elif no_input:
|
||||||
|
Loading…
Reference in New Issue
Block a user