From bf34685ae0a8eb893a23440871bbeef99f2dbc6c Mon Sep 17 00:00:00 2001
From: David Stainton <dstainton415@gmail.com>
Date: Fri, 19 Jun 2015 02:50:49 -0700
Subject: [PATCH] Sleepy time WIP almost got invite's mkdir working...

---
 src/allmydata/scripts/magic_folder_cli.py   | 29 ++++++++++++++++++---
 src/allmydata/test/test_cli_magic_folder.py | 22 ++++++++++++----
 2 files changed, 43 insertions(+), 8 deletions(-)

diff --git a/src/allmydata/scripts/magic_folder_cli.py b/src/allmydata/scripts/magic_folder_cli.py
index 6eb7b43f..993c1c4a 100644
--- a/src/allmydata/scripts/magic_folder_cli.py
+++ b/src/allmydata/scripts/magic_folder_cli.py
@@ -3,7 +3,8 @@ import os
 
 from twisted.python import usage, failure
 from allmydata.scripts.common import BaseOptions
-from .common import BaseOptions, BasedirOptions
+from .common import BaseOptions, BasedirOptions, get_aliases
+from .cli import MakeDirectoryOptions
 
 class CreateOptions(BasedirOptions):
     nickname = None
@@ -25,10 +26,32 @@ def create(options):
     return rc
 
 class InviteOptions(BasedirOptions):
-    pass
+    nickname = None
+    synopsis = "MAGIC_ALIAS: NICKNAME"
+    def parseArgs(self, alias, nickname=None):
+        BasedirOptions.parseArgs(self)
+        print "InviteOptions parseArgs() alias %s nickname %s" % (alias, nickname,)
+        self.alias = alias
+        self.nickname = nickname
+        node_url_file = os.path.join(self['node-directory'], "node.url")
+        self['node-url'] = open(node_url_file, "r").read().strip()
+
+        aliases = get_aliases(self['node-directory'])
+        print "ALIASES %s" % (aliases,)
+        self.aliases = aliases
 
 def invite(options):
-    pass
+    from allmydata.scripts import tahoe_mkdir
+    mkdirOptions = MakeDirectoryOptions()
+    mkdirOptions.where = options.nickname
+    mkdirOptions.stdout = options.stdout
+    mkdirOptions.stdin = options.stdin
+    mkdirOptions.stderr = options.stderr
+    mkdirOptions['node-url'] = options['node-url']
+    mkdirOptions.aliases = options.aliases
+    mkdirOptions['node-directory'] = options['node-directory']
+    rc = tahoe_mkdir.mkdir(mkdirOptions)
+    return rc
 
 class JoinOptions(BasedirOptions):
     pass
diff --git a/src/allmydata/test/test_cli_magic_folder.py b/src/allmydata/test/test_cli_magic_folder.py
index 1695b633..c6df73f5 100644
--- a/src/allmydata/test/test_cli_magic_folder.py
+++ b/src/allmydata/test/test_cli_magic_folder.py
@@ -13,10 +13,7 @@ from .test_cli import CLITestMixin
 
 class CreateMagicFolder(GridTestMixin, CLITestMixin, unittest.TestCase):
 
-    def test_create(self):
-        self.basedir = "cli/MagicFolder/create"
-        self.set_up_grid()
-
+    def _create_magic_folder(self):
         d = self.do_cli("magic-folder", "create", "my_magic_folder")
         def _done((rc,stdout,stderr)):
             self.failUnless("Alias 'my_magic_folder' created" in stdout)
@@ -26,4 +23,19 @@ class CreateMagicFolder(GridTestMixin, CLITestMixin, unittest.TestCase):
             self.failUnless(aliases["my_magic_folder"].startswith("URI:DIR2:"))
         d.addCallback(_done)
         return d
-# XXX more stuff ...
+
+    def test_create(self):
+        self.basedir = "cli/MagicFolder/create"
+        self.set_up_grid()
+        return self._create_magic_folder()
+
+    def _invite(self, ignore):
+        d = self.do_cli("magic-folder", "invite", "magicFolder1", "Nicki")
+        return d
+
+    def test_invite(self):
+        self.basedir = "cli/MagicFolder/invite"
+        self.set_up_grid()
+        d = self._create_magic_folder()
+        d.addCallback(self._invite)
+        return d
-- 
2.45.2