[tor-commits] [arm/master] Add cagraph as a prereq.
atagar at torproject.org
atagar at torproject.org
Fri Jun 10 15:42:29 UTC 2011
commit bffe945d864799ef8f83f60911740958aa0c7572
Author: Kamran Riaz Khan <krkhan at inspirated.com>
Date: Tue Jun 7 15:31:36 2011 +0500
Add cagraph as a prereq.
---
src/prereq.py | 66 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 66 insertions(+), 0 deletions(-)
diff --git a/src/prereq.py b/src/prereq.py
index 4bda913..2e26161 100644
--- a/src/prereq.py
+++ b/src/prereq.py
@@ -8,6 +8,9 @@ import shutil
import tempfile
TORCTL_REPO = "git://git.torproject.org/pytorctl.git"
+CAGRAPH_TARBALL_URL = "http://cagraph.googlecode.com/files/cagraph-1.2.tar.gz"
+CAGRAPH_TARBALL_NAME = "cagraph-1.2.tar.gz"
+CAGRAPH_TARBALL_ROOT = "cagraph-1.2"
def isTorCtlAvailable():
"""
@@ -20,6 +23,16 @@ def isTorCtlAvailable():
except ImportError:
return False
+def isCagraphAvailable():
+ """
+ True if cagraph is already available on the platform, false otherwise.
+ """
+ try:
+ import cagraph
+ return True
+ except ImportError:
+ return False
+
def promptTorCtlInstall():
"""
Asks the user to install TorCtl. This returns True if it was installed and
@@ -44,6 +57,30 @@ def promptTorCtlInstall():
print exc
return False
+def promptCagraphInstall():
+ """
+ Asks the user to install cagraph. This returns True if it was installed and
+ False otherwise (if it was either declined or failed to be fetched).
+ """
+
+ userInput = raw_input("Arm requires cagraph to run, but it's unavailable. Would you like to install it? (y/n): ")
+
+ # if user says no then terminate
+ if not userInput.lower() in ("y", "yes"): return False
+
+ # attempt to install TorCtl, printing the issue if unsuccessful
+ try:
+ installCagraph()
+
+ if not isCagraphAvailable():
+ raise IOError("Unable to install cagraph, sorry")
+
+ print "cagraph successfully installed"
+ return True
+ except IOError, exc:
+ print exc
+ return False
+
def installTorCtl():
"""
Checks out the current git head release for TorCtl and bundles it with arm.
@@ -71,6 +108,31 @@ def installTorCtl():
# of errors.
shutil.rmtree(tmpFilename, ignore_errors=True)
+def installCagraph():
+ """
+ Downloads and extracts the cagraph tarball.
+ This raises an IOError if unsuccessful.
+ """
+
+ if isCagraphAvailable(): return
+
+ tmpDir = tempfile.mkdtemp()
+ tmpFilename = os.path.join(tmpDir, CAGRAPH_TARBALL_NAME)
+
+ exitStatus = os.system("wget -P %s %s" % (tmpDir, CAGRAPH_TARBALL_URL))
+ if exitStatus: raise IOError("Unable to fetch cagraph from %s. Is wget installed?" % CAGRAPH_TARBALL_URL)
+
+ # the destination for TorCtl will be our directory
+ ourDir = os.path.dirname(os.path.realpath(__file__))
+
+ # exports TorCtl to our location
+ exitStatus = os.system("(cd %s && tar --strip-components=1 -xzf %s %s/cagraph)" % (ourDir, tmpFilename, CAGRAPH_TARBALL_ROOT))
+ if exitStatus: raise IOError("Unable to extract cagraph to %s" % ourDir)
+
+ # Clean up the temporary contents. This isn't vital so quietly fails in case
+ # of errors.
+ shutil.rmtree(tmpDir, ignore_errors=True)
+
if __name__ == '__main__':
majorVersion = sys.version_info[0]
minorVersion = sys.version_info[1]
@@ -92,3 +154,7 @@ if __name__ == '__main__':
isInstalled = promptTorCtlInstall()
if not isInstalled: sys.exit(1)
+ if not isCagraphAvailable():
+ isInstalled = promptCagraphInstall()
+ if not isInstalled: sys.exit(1)
+
More information about the tor-commits
mailing list