From f94765f7b989263605c9148e1036e176fa71a45e Mon Sep 17 00:00:00 2001 From: caryoscelus Date: Sun, 23 Jul 2023 09:37:52 +0000 Subject: [PATCH] more anonymous upnp thanks to 0netdwf for reporting --- src/Peer/PeerPortchecker.py | 5 +---- src/util/UpnpPunch.py | 17 ++++++----------- 2 files changed, 7 insertions(+), 15 deletions(-) diff --git a/src/Peer/PeerPortchecker.py b/src/Peer/PeerPortchecker.py index f7ca68e34..8bf337cf5 100644 --- a/src/Peer/PeerPortchecker.py +++ b/src/Peer/PeerPortchecker.py @@ -28,11 +28,8 @@ def requestUrl(self, url, post_data=None): return urllib.request.urlopen(req, timeout=20.0) def portOpen(self, port): - # self.log.info("Not trying to open port using UpnpPunch until it's proven robust...") - # return False - try: - UpnpPunch.ask_to_open_port(port, 'ZeroNet', retries=3, protos=["TCP"]) + UpnpPunch.ask_to_open_port(port, retries=3, protos=["TCP"]) self.upnp_port_opened = True except Exception as err: self.log.warning("UpnpPunch run error: %s" % Debug.formatException(err)) diff --git a/src/util/UpnpPunch.py b/src/util/UpnpPunch.py index 2fa85209d..4fd17c61c 100644 --- a/src/util/UpnpPunch.py +++ b/src/util/UpnpPunch.py @@ -181,7 +181,6 @@ def method3(): def _create_open_message(local_ip, port, - description="UPnPPunch", protocol="TCP", upnp_schema='WANIPConnection'): """ @@ -205,14 +204,13 @@ def _create_open_message(local_ip, """.format(port=port, protocol=protocol, host_ip=local_ip, - description=description, + description='', upnp_schema=upnp_schema) return (REMOVE_WHITESPACE.sub('><', soap_message), 'AddPortMapping') def _create_close_message(local_ip, port, - description=None, protocol='TCP', upnp_schema='WANIPConnection'): soap_message = """ @@ -294,12 +292,12 @@ def _send_requests(messages, location, upnp_schema, control_path): raise UpnpError('Sending requests using UPnP failed.') -def _orchestrate_soap_request(ip, port, msg_fn, desc=None, protos=("TCP", "UDP")): +def _orchestrate_soap_request(ip, port, msg_fn, protos=("TCP", "UDP")): logger.debug("Trying using local ip: %s" % ip) idg_data = _collect_idg_data(ip) soap_messages = [ - msg_fn(ip, port, desc, proto, idg_data['upnp_schema']) + msg_fn(ip, port, proto, idg_data['upnp_schema']) for proto in protos ] @@ -307,7 +305,6 @@ def _orchestrate_soap_request(ip, port, msg_fn, desc=None, protos=("TCP", "UDP") def _communicate_with_igd(port=15441, - desc="UpnpPunch", retries=3, fn=_create_open_message, protos=("TCP", "UDP")): @@ -321,7 +318,7 @@ def _communicate_with_igd(port=15441, def job(local_ip): for retry in range(retries): try: - _orchestrate_soap_request(local_ip, port, fn, desc, protos) + _orchestrate_soap_request(local_ip, port, fn, protos) return True except Exception as e: logger.debug('Upnp request using "{0}" failed: {1}'.format(local_ip, e)) @@ -357,20 +354,18 @@ def job(local_ip): return success -def ask_to_open_port(port=15441, desc="UpnpPunch", retries=3, protos=("TCP", "UDP")): +def ask_to_open_port(port=15441, retries=3, protos=("TCP", "UDP")): logger.debug("Trying to open port %d." % port) return _communicate_with_igd(port=port, - desc=desc, retries=retries, fn=_create_open_message, protos=protos) -def ask_to_close_port(port=15441, desc="UpnpPunch", retries=3, protos=("TCP", "UDP")): +def ask_to_close_port(port=15441, retries=3, protos=("TCP", "UDP")): logger.debug("Trying to close port %d." % port) # retries=1 because multiple successes cause 500 response and failure return _communicate_with_igd(port=port, - desc=desc, retries=retries, fn=_create_close_message, protos=protos)