V0.6 #852

Merged
Atheros1 merged 399 commits from v0.6 into master 2016-05-03 01:58:38 +02:00
Showing only changes of commit 5432c6e0c8 - Show all commits

View File

@ -23,8 +23,18 @@ def searchRouter():
routers = [] routers = []
sock.settimeout(0.5) sock.settimeout(0.5)
try: try:
resp,(ip,port) = sock.recvfrom(1000) sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
while resp: sock.setsockopt(socket.IPPROTO_IP, socket.IP_MULTICAST_TTL, 2)
sock.settimeout(2)
logger.debug("Sending UPnP query")
sock.sendto(ssdpRequest, (SSDP_ADDR, SSDP_PORT))
except:
logger.exception("UPnP sock failed")
try:
while True:
resp,(ip,port) = sock.recvfrom(1000)
if resp is None:
continue
routers.append(Router(resp, ip)) routers.append(Router(resp, ip))
resp,(ip,port) = sock.recvfrom(1000) resp,(ip,port) = sock.recvfrom(1000)
except:pass except:pass
@ -146,10 +156,12 @@ class Router:
return resp return resp
def DeletePortMapping(self, externalPort, protocol): def DeletePortMapping(self, externalPort, protocol):
from debug import logger
resp = self.soapRequest('WANIPConnection:1', 'DeletePortMapping', [ resp = self.soapRequest('WANIPConnection:1', 'DeletePortMapping', [
('NewExternalPort', str(externalPort)), ('NewExternalPort', str(externalPort)),
('NewProtocol', protocol), ('NewProtocol', protocol),
]) ])
logger.info("Removed UPnP mapping on external port %i", extPort)
return resp return resp
def GetExternalIPAddress(self): def GetExternalIPAddress(self):