From 7ae7a84eefd43ed9385e2f8f520a918468f87178 Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Thu, 13 Feb 2014 16:14:04 +0200 Subject: [PATCH] NFC: Workaround nfcpy message debug exception The current nfcpy version does not support new WSC connection handover message format and the handover server fails to process the request due to a debug print. As a temporary workaround, override HandoverServer::_process_request() with a version that avoids pretty() print of the handover messages. This can be removed once nfcpy has been updated to support the new format. Signed-off-by: Jouni Malinen --- hostapd/wps-ap-nfc.py | 17 +++++++++++++++++ wpa_supplicant/examples/p2p-nfc.py | 17 +++++++++++++++++ wpa_supplicant/examples/wps-nfc.py | 17 +++++++++++++++++ 3 files changed, 51 insertions(+) diff --git a/hostapd/wps-ap-nfc.py b/hostapd/wps-ap-nfc.py index aa75d5bca..2fc301296 100755 --- a/hostapd/wps-ap-nfc.py +++ b/hostapd/wps-ap-nfc.py @@ -113,6 +113,23 @@ class HandoverServer(nfc.handover.HandoverServer): self.ho_server_processing = False self.success = False + # override to avoid parser error in request/response.pretty() in nfcpy + # due to new WSC handover format + def _process_request(self, request): + summary("received handover request {}".format(request.type)) + response = nfc.ndef.Message("\xd1\x02\x01Hs\x12") + if not request.type == 'urn:nfc:wkt:Hr': + summary("not a handover request") + else: + try: + request = nfc.ndef.HandoverRequestMessage(request) + except nfc.ndef.DecodeError as e: + summary("error decoding 'Hr' message: {}".format(e)) + else: + response = self.process_request(request) + summary("send handover response {}".format(response.type)) + return response + def process_request(self, request): summary("HandoverServer - request received") try: diff --git a/wpa_supplicant/examples/p2p-nfc.py b/wpa_supplicant/examples/p2p-nfc.py index 94edca1dc..91eba2890 100755 --- a/wpa_supplicant/examples/p2p-nfc.py +++ b/wpa_supplicant/examples/p2p-nfc.py @@ -263,6 +263,23 @@ class HandoverServer(nfc.handover.HandoverServer): self.ho_server_processing = False self.success = False + # override to avoid parser error in request/response.pretty() in nfcpy + # due to new WSC handover format + def _process_request(self, request): + summary("received handover request {}".format(request.type)) + response = nfc.ndef.Message("\xd1\x02\x01Hs\x12") + if not request.type == 'urn:nfc:wkt:Hr': + summary("not a handover request") + else: + try: + request = nfc.ndef.HandoverRequestMessage(request) + except nfc.ndef.DecodeError as e: + summary("error decoding 'Hr' message: {}".format(e)) + else: + response = self.process_request(request) + summary("send handover response {}".format(response.type)) + return response + def process_request(self, request): self.ho_server_processing = True clear_raw_mode() diff --git a/wpa_supplicant/examples/wps-nfc.py b/wpa_supplicant/examples/wps-nfc.py index e57eded8f..7459eb9ae 100755 --- a/wpa_supplicant/examples/wps-nfc.py +++ b/wpa_supplicant/examples/wps-nfc.py @@ -142,6 +142,23 @@ class HandoverServer(nfc.handover.HandoverServer): self.ho_server_processing = False self.success = False + # override to avoid parser error in request/response.pretty() in nfcpy + # due to new WSC handover format + def _process_request(self, request): + summary("received handover request {}".format(request.type)) + response = nfc.ndef.Message("\xd1\x02\x01Hs\x12") + if not request.type == 'urn:nfc:wkt:Hr': + summary("not a handover request") + else: + try: + request = nfc.ndef.HandoverRequestMessage(request) + except nfc.ndef.DecodeError as e: + summary("error decoding 'Hr' message: {}".format(e)) + else: + response = self.process_request(request) + summary("send handover response {}".format(response.type)) + return response + def process_request(self, request): self.ho_server_processing = True summary("HandoverServer - request received")