2006-12-05 19:25:23 +00:00
|
|
|
|
2007-07-11 02:05:18 +00:00
|
|
|
import sys
|
2007-06-26 23:19:18 +00:00
|
|
|
from cStringIO import StringIO
|
2008-11-12 22:25:03 +00:00
|
|
|
|
2006-12-05 19:25:23 +00:00
|
|
|
from twisted.python import usage
|
|
|
|
|
2007-08-16 19:50:19 +00:00
|
|
|
from allmydata.scripts.common import BaseOptions
|
2010-02-26 08:14:33 +00:00
|
|
|
from allmydata.scripts import debug, create_node, startstop_node, cli, keygen, stats_gatherer
|
2011-06-29 18:53:56 +00:00
|
|
|
from allmydata.util.encodingutil import quote_output, get_io_encoding
|
2006-12-05 19:25:23 +00:00
|
|
|
|
2010-01-27 22:37:58 +00:00
|
|
|
def GROUP(s):
|
|
|
|
# Usage.parseOptions compares argv[1] against command[0], so it will
|
|
|
|
# effectively ignore any "subcommand" that starts with a newline. We use
|
|
|
|
# these to insert section headers into the --help output.
|
|
|
|
return [("\n" + s, None, None, None)]
|
2010-01-26 04:45:59 +00:00
|
|
|
|
2008-01-09 02:51:18 +00:00
|
|
|
|
2007-08-16 19:50:19 +00:00
|
|
|
class Options(BaseOptions, usage.Options):
|
2010-07-25 08:32:16 +00:00
|
|
|
synopsis = "\nUsage: tahoe <command> [command options]"
|
2010-01-27 22:37:58 +00:00
|
|
|
subCommands = ( GROUP("Administration")
|
|
|
|
+ create_node.subCommands
|
|
|
|
+ keygen.subCommands
|
|
|
|
+ stats_gatherer.subCommands
|
|
|
|
+ GROUP("Controlling a node")
|
|
|
|
+ startstop_node.subCommands
|
|
|
|
+ GROUP("Debugging")
|
|
|
|
+ debug.subCommands
|
|
|
|
+ GROUP("Using the filesystem")
|
|
|
|
+ cli.subCommands
|
|
|
|
)
|
2006-12-05 19:25:23 +00:00
|
|
|
|
2010-01-26 04:45:59 +00:00
|
|
|
def getUsage(self, **kwargs):
|
2010-01-27 22:37:58 +00:00
|
|
|
t = usage.Options.getUsage(self, **kwargs)
|
2010-01-26 04:45:59 +00:00
|
|
|
return t + "\nPlease run 'tahoe <command> --help' for more details on each command.\n"
|
2006-12-05 19:25:23 +00:00
|
|
|
|
|
|
|
def postOptions(self):
|
|
|
|
if not hasattr(self, 'subOptions'):
|
2011-01-21 07:59:13 +00:00
|
|
|
if not hasattr(self, 'no_command_needed'):
|
|
|
|
raise usage.UsageError("must specify a command")
|
|
|
|
sys.exit(0)
|
2006-12-05 19:25:23 +00:00
|
|
|
|
2010-08-03 08:54:16 +00:00
|
|
|
|
|
|
|
create_dispatch = {}
|
|
|
|
for module in (create_node, keygen, stats_gatherer):
|
|
|
|
create_dispatch.update(module.dispatch)
|
|
|
|
|
2008-08-01 18:46:24 +00:00
|
|
|
def runner(argv,
|
|
|
|
run_by_human=True,
|
2010-07-25 08:32:16 +00:00
|
|
|
stdin=None, stdout=None, stderr=None,
|
2008-08-01 18:46:24 +00:00
|
|
|
install_node_control=True, additional_commands=None):
|
2008-01-09 02:51:18 +00:00
|
|
|
|
2010-07-25 08:32:16 +00:00
|
|
|
stdin = stdin or sys.stdin
|
|
|
|
stdout = stdout or sys.stdout
|
|
|
|
stderr = stderr or sys.stderr
|
|
|
|
|
2008-02-20 00:05:14 +00:00
|
|
|
config = Options()
|
|
|
|
if install_node_control:
|
|
|
|
config.subCommands.extend(startstop_node.subCommands)
|
2008-01-09 02:51:18 +00:00
|
|
|
|
2008-02-20 00:05:14 +00:00
|
|
|
ac_dispatch = {}
|
|
|
|
if additional_commands:
|
|
|
|
for ac in additional_commands:
|
|
|
|
config.subCommands.extend(ac.subCommands)
|
|
|
|
ac_dispatch.update(ac.dispatch)
|
2008-01-09 02:51:18 +00:00
|
|
|
|
2006-12-05 19:25:23 +00:00
|
|
|
try:
|
2007-04-20 01:56:45 +00:00
|
|
|
config.parseOptions(argv)
|
2006-12-05 19:25:23 +00:00
|
|
|
except usage.error, e:
|
2007-04-24 04:28:19 +00:00
|
|
|
if not run_by_human:
|
|
|
|
raise
|
2008-08-12 20:37:32 +00:00
|
|
|
c = config
|
|
|
|
while hasattr(c, 'subOptions'):
|
|
|
|
c = c.subOptions
|
2010-07-25 08:32:16 +00:00
|
|
|
print >>stdout, str(c)
|
|
|
|
try:
|
2011-06-29 18:53:56 +00:00
|
|
|
msg = e.args[0].decode(get_io_encoding())
|
2010-07-25 08:32:16 +00:00
|
|
|
except Exception:
|
|
|
|
msg = repr(e)
|
|
|
|
print >>stdout, "%s: %s\n" % (sys.argv[0], quote_output(msg, quotemarks=False))
|
2007-04-20 01:56:45 +00:00
|
|
|
return 1
|
2006-12-05 19:25:23 +00:00
|
|
|
|
|
|
|
command = config.subCommand
|
|
|
|
so = config.subOptions
|
|
|
|
|
2007-06-26 23:19:18 +00:00
|
|
|
if config['quiet']:
|
|
|
|
stdout = StringIO()
|
|
|
|
|
2008-08-01 18:46:24 +00:00
|
|
|
so.stdout = stdout
|
|
|
|
so.stderr = stderr
|
|
|
|
so.stdin = stdin
|
|
|
|
|
2010-08-03 08:54:16 +00:00
|
|
|
if command in create_dispatch:
|
2010-11-27 08:38:09 +00:00
|
|
|
rc = create_dispatch[command](so, stdout, stderr)
|
2007-07-11 02:05:18 +00:00
|
|
|
elif command in startstop_node.dispatch:
|
|
|
|
rc = startstop_node.dispatch[command](so, stdout, stderr)
|
2007-07-11 01:41:52 +00:00
|
|
|
elif command in debug.dispatch:
|
2008-08-12 20:37:32 +00:00
|
|
|
rc = debug.dispatch[command](so)
|
2007-07-11 02:37:37 +00:00
|
|
|
elif command in cli.dispatch:
|
2008-08-01 18:46:24 +00:00
|
|
|
rc = cli.dispatch[command](so)
|
2008-02-20 00:05:14 +00:00
|
|
|
elif command in ac_dispatch:
|
|
|
|
rc = ac_dispatch[command](so, stdout, stderr)
|
2007-08-17 20:23:16 +00:00
|
|
|
else:
|
|
|
|
raise usage.UsageError()
|
2007-07-11 01:41:52 +00:00
|
|
|
|
2007-04-20 01:56:45 +00:00
|
|
|
return rc
|
|
|
|
|
2010-07-25 08:32:16 +00:00
|
|
|
|
2008-01-09 02:51:18 +00:00
|
|
|
def run(install_node_control=True):
|
2010-07-25 08:32:16 +00:00
|
|
|
if sys.platform == "win32":
|
|
|
|
from allmydata.windows.fixups import initialize
|
|
|
|
initialize()
|
|
|
|
|
|
|
|
rc = runner(sys.argv[1:], install_node_control=install_node_control)
|
2006-12-05 19:25:23 +00:00
|
|
|
sys.exit(rc)
|