2007-07-11 02:05:18 +00:00
|
|
|
|
|
|
|
import os, sys
|
2010-08-02 04:30:04 +00:00
|
|
|
from allmydata.scripts.common import BasedirMixin, BaseOptions
|
2010-08-02 01:05:52 +00:00
|
|
|
from allmydata.util.assertutil import precondition
|
|
|
|
from allmydata.util.encodingutil import listdir_unicode, argv_to_unicode, quote_output
|
2010-08-01 16:42:07 +00:00
|
|
|
import allmydata
|
2007-07-11 02:05:18 +00:00
|
|
|
|
2010-08-02 04:30:04 +00:00
|
|
|
class CreateClientOptions(BasedirMixin, BaseOptions):
|
2007-07-11 02:05:18 +00:00
|
|
|
optParameters = [
|
2010-01-16 05:20:55 +00:00
|
|
|
# we provide 'create-node'-time options for the most common
|
2008-09-30 23:21:49 +00:00
|
|
|
# configuration knobs. The rest can be controlled by editing
|
|
|
|
# tahoe.cfg before node startup.
|
2010-08-03 08:48:01 +00:00
|
|
|
("nickname", "n", None, "Specify the nickname for this node."),
|
|
|
|
("introducer", "i", None, "Specify the introducer FURL to use."),
|
2008-11-26 00:57:37 +00:00
|
|
|
("webport", "p", "tcp:3456:interface=127.0.0.1",
|
2010-08-03 08:48:01 +00:00
|
|
|
"Specify which TCP port to run the HTTP interface on. Use 'none' to disable."),
|
2008-09-30 23:21:49 +00:00
|
|
|
]
|
2010-01-16 05:20:55 +00:00
|
|
|
|
|
|
|
class CreateNodeOptions(CreateClientOptions):
|
2008-09-30 23:21:49 +00:00
|
|
|
optFlags = [
|
2010-08-03 08:48:01 +00:00
|
|
|
("no-storage", None, "Do not offer storage service to other nodes."),
|
2007-07-11 02:05:18 +00:00
|
|
|
]
|
|
|
|
|
2010-08-02 04:30:04 +00:00
|
|
|
class CreateIntroducerOptions(BasedirMixin, BaseOptions):
|
|
|
|
default_nodedir = None
|
|
|
|
|
2007-07-11 02:05:18 +00:00
|
|
|
optParameters = [
|
2010-08-03 08:54:16 +00:00
|
|
|
["node-directory", "d", None, "Specify which directory the introducer should be created in. [no default]"],
|
|
|
|
]
|
2007-07-11 02:05:18 +00:00
|
|
|
|
|
|
|
client_tac = """
|
|
|
|
# -*- python -*-
|
|
|
|
|
1970-01-02 00:50:05 +00:00
|
|
|
import pkg_resources
|
2010-08-01 16:42:07 +00:00
|
|
|
pkg_resources.require('%s')
|
1970-01-02 00:50:05 +00:00
|
|
|
pkg_resources.require('twisted')
|
2007-07-11 02:05:18 +00:00
|
|
|
from allmydata import client
|
|
|
|
from twisted.application import service
|
|
|
|
|
|
|
|
c = client.Client()
|
|
|
|
|
|
|
|
application = service.Application("allmydata_client")
|
|
|
|
c.setServiceParent(application)
|
2010-08-01 16:42:07 +00:00
|
|
|
""" % (allmydata.__appname__,)
|
2007-07-11 02:05:18 +00:00
|
|
|
|
|
|
|
introducer_tac = """
|
|
|
|
# -*- python -*-
|
|
|
|
|
1970-01-02 00:50:05 +00:00
|
|
|
import pkg_resources
|
2010-08-01 16:42:07 +00:00
|
|
|
pkg_resources.require('%s')
|
1970-01-02 00:50:05 +00:00
|
|
|
pkg_resources.require('twisted')
|
2007-12-03 21:52:42 +00:00
|
|
|
from allmydata import introducer
|
2007-07-11 02:05:18 +00:00
|
|
|
from twisted.application import service
|
|
|
|
|
2007-12-03 21:52:42 +00:00
|
|
|
c = introducer.IntroducerNode()
|
2007-07-11 02:05:18 +00:00
|
|
|
|
|
|
|
application = service.Application("allmydata_introducer")
|
|
|
|
c.setServiceParent(application)
|
2010-08-01 16:42:07 +00:00
|
|
|
""" % (allmydata.__appname__,)
|
2007-07-11 02:05:18 +00:00
|
|
|
|
2008-09-30 23:21:49 +00:00
|
|
|
def write_node_config(c, config):
|
|
|
|
# this is shared between clients and introducers
|
|
|
|
c.write("# -*- mode: conf; coding: utf-8 -*-\n")
|
|
|
|
c.write("\n")
|
|
|
|
c.write("# This file controls the configuration of the Tahoe node that\n")
|
|
|
|
c.write("# lives in this directory. It is only read at node startup.\n")
|
|
|
|
c.write("# For details about the keys that can be set here, please\n")
|
2010-11-28 17:45:07 +00:00
|
|
|
c.write("# read the 'docs/configuration.rst' file that came with your\n")
|
2008-09-30 23:21:49 +00:00
|
|
|
c.write("# Tahoe installation.\n")
|
|
|
|
c.write("\n\n")
|
|
|
|
|
|
|
|
c.write("[node]\n")
|
2010-08-02 00:02:12 +00:00
|
|
|
nickname = argv_to_unicode(config.get("nickname") or "")
|
|
|
|
c.write("nickname = %s\n" % (nickname.encode('utf-8'),))
|
|
|
|
|
|
|
|
# TODO: validate webport
|
|
|
|
webport = argv_to_unicode(config.get("webport") or "none")
|
2008-09-30 23:21:49 +00:00
|
|
|
if webport.lower() == "none":
|
|
|
|
webport = ""
|
2010-08-02 00:02:12 +00:00
|
|
|
c.write("web.port = %s\n" % (webport.encode('utf-8'),))
|
2008-10-30 00:13:36 +00:00
|
|
|
c.write("web.static = public_html\n")
|
2008-09-30 23:21:49 +00:00
|
|
|
c.write("#tub.port =\n")
|
2008-11-13 01:44:58 +00:00
|
|
|
c.write("#tub.location = \n")
|
2008-09-30 23:21:49 +00:00
|
|
|
c.write("#log_gatherer.furl =\n")
|
|
|
|
c.write("#timeout.keepalive =\n")
|
|
|
|
c.write("#timeout.disconnect =\n")
|
|
|
|
c.write("#ssh.port = 8022\n")
|
|
|
|
c.write("#ssh.authorized_keys_file = ~/.ssh/authorized_keys\n")
|
|
|
|
c.write("\n")
|
|
|
|
|
|
|
|
|
2010-11-27 08:38:09 +00:00
|
|
|
def create_node(config, out=sys.stdout, err=sys.stderr):
|
|
|
|
basedir = config['basedir']
|
2010-07-22 00:14:18 +00:00
|
|
|
# This should always be called with an absolute Unicode basedir.
|
|
|
|
precondition(isinstance(basedir, unicode), basedir)
|
|
|
|
|
2007-07-11 02:05:18 +00:00
|
|
|
if os.path.exists(basedir):
|
2010-07-22 00:14:18 +00:00
|
|
|
if listdir_unicode(basedir):
|
|
|
|
print >>err, "The base directory %s is not empty." % quote_output(basedir)
|
2008-02-15 20:11:02 +00:00
|
|
|
print >>err, "To avoid clobbering anything, I am going to quit now."
|
|
|
|
print >>err, "Please use a different directory, or empty this one."
|
2007-07-11 02:05:18 +00:00
|
|
|
return -1
|
|
|
|
# we're willing to use an empty directory
|
|
|
|
else:
|
|
|
|
os.mkdir(basedir)
|
2007-10-11 09:48:06 +00:00
|
|
|
f = open(os.path.join(basedir, "tahoe-client.tac"), "w")
|
2007-07-11 02:05:18 +00:00
|
|
|
f.write(client_tac)
|
|
|
|
f.close()
|
2008-09-30 23:21:49 +00:00
|
|
|
|
|
|
|
c = open(os.path.join(basedir, "tahoe.cfg"), "w")
|
|
|
|
|
|
|
|
write_node_config(c, config)
|
|
|
|
|
|
|
|
c.write("[client]\n")
|
2011-01-17 05:24:19 +00:00
|
|
|
c.write("# Which services should this client connect to?\n")
|
2008-09-30 23:21:49 +00:00
|
|
|
c.write("introducer.furl = %s\n" % config.get("introducer", ""))
|
|
|
|
c.write("helper.furl =\n")
|
|
|
|
c.write("#key_generator.furl =\n")
|
|
|
|
c.write("#stats_gatherer.furl =\n")
|
2011-01-17 05:24:19 +00:00
|
|
|
c.write("\n")
|
|
|
|
c.write("# What encoding parameters should this client use for uploads?\n")
|
2008-11-18 07:29:44 +00:00
|
|
|
c.write("#shares.needed = 3\n")
|
|
|
|
c.write("#shares.happy = 7\n")
|
|
|
|
c.write("#shares.total = 10\n")
|
2008-09-30 23:21:49 +00:00
|
|
|
c.write("\n")
|
|
|
|
|
|
|
|
boolstr = {True:"true", False:"false"}
|
|
|
|
c.write("[storage]\n")
|
2011-01-17 05:24:19 +00:00
|
|
|
c.write("# Shall this node provide storage service?\n")
|
2008-09-30 23:21:49 +00:00
|
|
|
storage_enabled = not config.get("no-storage", None)
|
|
|
|
c.write("enabled = %s\n" % boolstr[storage_enabled])
|
|
|
|
c.write("#readonly =\n")
|
2011-01-16 20:58:22 +00:00
|
|
|
c.write("reserved_space = 1G\n")
|
2009-03-23 23:08:20 +00:00
|
|
|
c.write("#expire.enabled =\n")
|
|
|
|
c.write("#expire.mode =\n")
|
2008-09-30 23:21:49 +00:00
|
|
|
c.write("\n")
|
|
|
|
|
|
|
|
c.write("[helper]\n")
|
2011-01-17 05:24:19 +00:00
|
|
|
c.write("# Shall this node run a helper service that clients can use?\n")
|
2008-09-30 23:21:49 +00:00
|
|
|
c.write("enabled = false\n")
|
|
|
|
c.write("\n")
|
|
|
|
|
|
|
|
c.close()
|
|
|
|
|
2007-12-18 22:42:18 +00:00
|
|
|
from allmydata.util import fileutil
|
|
|
|
fileutil.make_dirs(os.path.join(basedir, "private"), 0700)
|
2010-07-22 00:14:18 +00:00
|
|
|
print >>out, "Node created in %s" % quote_output(basedir)
|
2008-09-30 23:21:49 +00:00
|
|
|
if not config.get("introducer", ""):
|
|
|
|
print >>out, " Please set [client]introducer.furl= in tahoe.cfg!"
|
|
|
|
print >>out, " The node cannot connect to a grid without it."
|
|
|
|
if not config.get("nickname", ""):
|
|
|
|
print >>out, " Please set [node]nickname= in tahoe.cfg"
|
2010-11-27 08:38:09 +00:00
|
|
|
return 0
|
2007-07-11 02:05:18 +00:00
|
|
|
|
2010-11-27 08:38:09 +00:00
|
|
|
def create_client(config, out=sys.stdout, err=sys.stderr):
|
2010-01-16 05:20:55 +00:00
|
|
|
config['no-storage'] = True
|
2010-11-27 08:38:09 +00:00
|
|
|
return create_node(config, out=out, err=err)
|
2010-01-16 05:20:55 +00:00
|
|
|
|
|
|
|
|
2010-11-27 08:38:09 +00:00
|
|
|
def create_introducer(config, out=sys.stdout, err=sys.stderr):
|
|
|
|
basedir = config['basedir']
|
2010-07-22 00:14:18 +00:00
|
|
|
# This should always be called with an absolute Unicode basedir.
|
|
|
|
precondition(isinstance(basedir, unicode), basedir)
|
|
|
|
|
2007-07-11 02:05:18 +00:00
|
|
|
if os.path.exists(basedir):
|
2010-07-22 00:14:18 +00:00
|
|
|
if listdir_unicode(basedir):
|
|
|
|
print >>err, "The base directory %s is not empty." % quote_output(basedir)
|
2008-02-15 20:11:02 +00:00
|
|
|
print >>err, "To avoid clobbering anything, I am going to quit now."
|
|
|
|
print >>err, "Please use a different directory, or empty this one."
|
2007-07-11 02:05:18 +00:00
|
|
|
return -1
|
|
|
|
# we're willing to use an empty directory
|
|
|
|
else:
|
|
|
|
os.mkdir(basedir)
|
2007-10-11 09:48:06 +00:00
|
|
|
f = open(os.path.join(basedir, "tahoe-introducer.tac"), "w")
|
2007-07-11 02:05:18 +00:00
|
|
|
f.write(introducer_tac)
|
|
|
|
f.close()
|
2008-09-30 23:21:49 +00:00
|
|
|
|
|
|
|
c = open(os.path.join(basedir, "tahoe.cfg"), "w")
|
|
|
|
write_node_config(c, config)
|
|
|
|
c.close()
|
|
|
|
|
2010-07-22 00:14:18 +00:00
|
|
|
print >>out, "Introducer created in %s" % quote_output(basedir)
|
2010-11-27 08:38:09 +00:00
|
|
|
return 0
|
2010-01-16 05:20:55 +00:00
|
|
|
|
2007-07-11 02:05:18 +00:00
|
|
|
|
|
|
|
subCommands = [
|
2010-01-26 04:45:59 +00:00
|
|
|
["create-node", None, CreateNodeOptions, "Create a node that acts as a client, server or both."],
|
|
|
|
["create-client", None, CreateClientOptions, "Create a client node (with storage initially disabled)."],
|
|
|
|
["create-introducer", None, CreateIntroducerOptions, "Create an introducer node."],
|
2007-07-11 02:05:18 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
dispatch = {
|
2010-01-16 05:20:55 +00:00
|
|
|
"create-node": create_node,
|
2007-07-11 02:05:18 +00:00
|
|
|
"create-client": create_client,
|
|
|
|
"create-introducer": create_introducer,
|
|
|
|
}
|