Merge PR187

closes #187
closes #185
This commit is contained in:
Brian Warner 2017-06-26 21:59:59 +01:00
commit 1d5fee04ae

View File

@ -22,122 +22,88 @@ def server(ctx): # this is the setuptools entrypoint for bin/wormhole-server
ctx.obj = Config() ctx.obj = Config()
_relay_database_path = click.option( _click_decorators = [
"--relay-database-path", default="relay.sqlite", metavar="PATH", server.command(),
help="location for the relay server state database", click.option(
) "--rendezvous", default="tcp:4000", metavar="tcp:PORT",
_stats_json_path = click.option( help="endpoint specification for the rendezvous port",
"--stats-json-path", default="stats.json", metavar="PATH", ),
help="location to write the relay stats file", click.option(
) "--transit", default="tcp:4001", metavar="tcp:PORT",
help="endpoint specification for the transit-relay port",
),
click.option(
"--advertise-version", metavar="VERSION",
help="version to recommend to clients",
),
click.option(
"--blur-usage", default=None, type=int,
metavar="SECONDS",
help="round logged access times to improve privacy",
),
click.option(
"--no-daemon", "-n", is_flag=True,
help="Run in the foreground",
),
click.option(
"--signal-error", is_flag=True,
help="force all clients to fail with a message",
),
click.option(
"--disallow-list", is_flag=True,
help="never send list of allocated nameplates",
),
click.option(
"--relay-database-path", default="relay.sqlite", metavar="PATH",
help="location for the relay server state database",
),
click.option(
"--stats-json-path", default="stats.json", metavar="PATH",
help="location to write the relay stats file",
),
click.pass_obj,
]
@server.command()
@click.option( def _start_command(f):
"--rendezvous", default="tcp:4000", metavar="tcp:PORT", for dec in _click_decorators[::-1]:
help="endpoint specification for the rendezvous port", f = dec(f)
) return f
@click.option(
"--transit", default="tcp:4001", metavar="tcp:PORT",
help="endpoint specification for the transit-relay port", def arguments_to_config(
) cfg, signal_error, no_daemon, blur_usage, advertise_version,
@click.option( transit, rendezvous, disallow_list, relay_database_path,
"--advertise-version", metavar="VERSION", stats_json_path,
help="version to recommend to clients",
)
@click.option(
"--blur-usage", default=None, type=int,
metavar="SECONDS",
help="round logged access times to improve privacy",
)
@click.option(
"--no-daemon", "-n", is_flag=True,
help="Run in the foreground",
)
@click.option(
"--signal-error", is_flag=True,
help="force all clients to fail with a message",
)
@click.option(
"--disallow-list", is_flag=True,
help="never send list of allocated nameplates",
)
@_relay_database_path
@_stats_json_path
@click.pass_obj
def start(cfg, signal_error, no_daemon, blur_usage, advertise_version,
transit, rendezvous, disallow_list, relay_database_path,
stats_json_path,
): ):
cfg.no_daemon = no_daemon
cfg.blur_usage = blur_usage
cfg.advertise_version = advertise_version
cfg.transit = str(transit)
cfg.rendezvous = str(rendezvous)
cfg.signal_error = signal_error
cfg.allow_list = not disallow_list
cfg.relay_database_path = relay_database_path
cfg.stats_json_path = stats_json_path
@_start_command
def start(cfg, **arguments):
""" """
Start a relay server Start a relay server
""" """
from wormhole.server.cmd_server import start_server from wormhole.server.cmd_server import start_server
cfg.no_daemon = no_daemon arguments_to_config(cfg, **arguments)
cfg.blur_usage = blur_usage
cfg.advertise_version = advertise_version
cfg.transit = str(transit)
cfg.rendezvous = str(rendezvous)
cfg.signal_error = signal_error
cfg.allow_list = not disallow_list
cfg.relay_database_path = relay_database_path
cfg.stats_json_path = stats_json_path
start_server(cfg) start_server(cfg)
# XXX it would be nice to reduce the duplication between 'restart' and @_start_command
# 'start' options... def restart(cfg, **arguments):
@server.command()
@click.option(
"--rendezvous", default="tcp:4000", metavar="tcp:PORT",
help="endpoint specification for the rendezvous port",
)
@click.option(
"--transit", default="tcp:4001", metavar="tcp:PORT",
help="endpoint specification for the transit-relay port",
)
@click.option(
"--advertise-version", metavar="VERSION",
help="version to recommend to clients",
)
@click.option(
"--blur-usage", default=None, type=int,
metavar="SECONDS",
help="round logged access times to improve privacy",
)
@click.option(
"--no-daemon", "-n", is_flag=True,
help="Run in the foreground",
)
@click.option(
"--signal-error", is_flag=True,
help="force all clients to fail with a message",
)
@click.option(
"--disallow-list", is_flag=True,
help="never send list of allocated nameplates",
)
@_relay_database_path
@_stats_json_path
@click.pass_obj
def restart(cfg, signal_error, no_daemon, blur_usage, advertise_version,
transit, rendezvous, disallow_list, relay_database_path,
stats_json_path,
):
""" """
Re-start a relay server Re-start a relay server
""" """
from wormhole.server.cmd_server import restart_server from wormhole.server.cmd_server import restart_server
cfg.no_daemon = no_daemon arguments_to_config(cfg, **arguments)
cfg.blur_usage = blur_usage
cfg.advertise_version = advertise_version
cfg.transit = str(transit)
cfg.rendezvous = str(rendezvous)
cfg.signal_error = signal_error
cfg.allow_list = not disallow_list
cfg.relay_database_path = relay_database_path
cfg.stats_json_path = stats_json_path
restart_server(cfg) restart_server(cfg)