From 4c9447e258156172d277fa1656f981606d706f36 Mon Sep 17 00:00:00 2001 From: robk-tahoe <robk-tahoe@allmydata.com> Date: Thu, 10 Jan 2008 20:37:18 -0700 Subject: [PATCH] added a small script as a stub for a config wizard this doesn't implement any config wizard ui, but does a simple http fetch of root_cap and introducer.furl from a php backend stub. --- windows/confwiz.py | 46 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 windows/confwiz.py diff --git a/windows/confwiz.py b/windows/confwiz.py new file mode 100644 index 00000000..f26484f2 --- /dev/null +++ b/windows/confwiz.py @@ -0,0 +1,46 @@ + +import urllib2 +from urllib import urlencode + +from allmydata.util.assertutil import precondition +from allmydata import uri + +class AuthError(Exception): + pass + +def unicode_to_utf8(uobj): + assert precondition(isinstance(uobj, unicode)) + return uobj.encode('utf-8') + +def post(url, args): + argstr = urlencode(args) + conn = urllib2.urlopen(url, argstr) + return conn.read() + +def get_root_cap(url, user, passwd): + args = { + 'action': 'authenticate', + 'email': unicode_to_utf8(user), + 'passwd': unicode_to_utf8(passwd), + } + root_cap = post(url, args) + if root_cap == '0': + raise AuthError() + elif not uri.is_uri(root_cap): + raise ValueError('%r is not a URI' % (root_cap,)) + else: + return root_cap + +def get_introducer_furl(url): + return post(url, { 'action': 'getintroducerfurl' }) + +def main(): + + URL = 'https://www-test.allmydata.com/native_client2.php' + + print get_introducer_furl(URL) + print get_root_cap(URL, u'user', u'pass') + + +if __name__ == '__main__': + main() -- 2.45.2