rip out port forwarding. Broken and as a result mostly unused.

This commit is contained in:
Fabian Dill 2020-05-30 03:47:40 +02:00
parent 781ec7a849
commit 10bced3d68
2 changed files with 1 additions and 38 deletions

View File

@ -967,34 +967,6 @@ async def console(ctx: Context):
traceback.print_exc()
async def forward_port(port: int):
import upnpy
import socket
upnp = upnpy.UPnP()
upnp.discover()
device = upnp.get_igd()
service = device['WANPPPConnection.1']
# get own lan IP
ip = socket.gethostbyname(socket.gethostname())
# This specific action returns an empty dict: {}
service.AddPortMapping(
NewRemoteHost='',
NewExternalPort=port,
NewProtocol='TCP',
NewInternalPort=port,
NewInternalClient=ip,
NewEnabled=1,
NewPortMappingDescription='Berserker\'s Multiworld',
NewLeaseDuration=60 * 60 * 24 # 24 hours
)
logging.info(f"Attempted to forward port {port} to {ip}, your local ip address.")
def parse_args() -> argparse.Namespace:
parser = argparse.ArgumentParser()
defaults = Utils.get_options()["server_options"]
@ -1009,7 +981,6 @@ def parse_args() -> argparse.Namespace:
parser.add_argument('--location_check_points', default=defaults["location_check_points"], type=int)
parser.add_argument('--hint_cost', default=defaults["hint_cost"], type=int)
parser.add_argument('--disable_item_cheat', default=defaults["disable_item_cheat"], action='store_true')
parser.add_argument('--port_forward', default=defaults["port_forward"], action='store_true')
parser.add_argument('--forfeit_mode', default=defaults["forfeit_mode"], nargs='?',
choices=['auto', 'enabled', 'disabled', "goal", "auto-enabled"], help='''\
Select !forfeit Accessibility. (default: %(default)s)
@ -1032,9 +1003,6 @@ def parse_args() -> argparse.Namespace:
async def main(args: argparse.Namespace):
logging.basicConfig(format='[%(asctime)s] %(message)s', level=getattr(logging, args.loglevel.upper(), logging.INFO))
portforwardtask = None
if args.port_forward:
portforwardtask = asyncio.create_task(forward_port(args.port))
ctx = Context(args.host, args.port, args.password, args.location_check_points, args.hint_cost,
not args.disable_item_cheat, args.forfeit_mode, args.remaining_mode)
@ -1081,11 +1049,7 @@ async def main(args: argparse.Namespace):
logging.error('No save data found, starting a new game')
except Exception as e:
logging.exception(e)
if portforwardtask:
try:
await portforwardtask
except:
logging.exception("Automatic port forwarding failed with:")
ctx.server = websockets.serve(functools.partial(server, ctx=ctx), ctx.host, ctx.port, ping_timeout=None,
ping_interval=None)
logging.info('Hosting game at %s:%d (%s)' % (ip, ctx.port,

View File

@ -3,6 +3,5 @@ websockets>=8.1
PyYAML>=5.3.1
fuzzywuzzy>=0.18.0
bsdiff4>=1.1.9
upnpy>=1.1.5
prompt_toolkit>=3.0.5
appdirs>=1.4.4