use hashlib module if available, thus avoiding a DeprecationWarning for importing...
authorZooko O'Whielacronx <zooko@zooko.com>
Mon, 14 Dec 2009 21:27:03 +0000 (13:27 -0800)
committerZooko O'Whielacronx <zooko@zooko.com>
Mon, 14 Dec 2009 21:27:03 +0000 (13:27 -0800)
src/allmydata/storage_client.py

index 69161924bb19b77912af2422c10991c9175e0965..d12cb8b7a68f80a3fa91cc9000b7121d54072952 100644 (file)
@@ -28,7 +28,15 @@ the foolscap-based server implemented in src/allmydata/storage/*.py .
 #
 # 6: implement other sorts of IStorageClient classes: S3, etc
 
-import sha, time
+try:
+    from hashlib import sha1
+except ImportError:
+    # hashlib was added in Python 2.5
+    import sha
+    def sha1(x):
+        return sha.new(x)
+
+import time
 from zope.interface import implements, Interface
 from foolscap.api import eventually
 from allmydata.interfaces import IStorageBroker
@@ -119,7 +127,7 @@ class StorageFarmBroker:
         assert self.permute_peers == True
         servers = self.get_all_servers()
         key = peer_selection_index
-        return sorted(servers, key=lambda x: sha.new(key+x[0]).digest())
+        return sorted(servers, key=lambda x: sha1(key+x[0]).digest())
 
     def get_all_servers(self):
         # return a frozenset of (peerid, versioned-rref) tuples