[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r22204: {weather} Fix #1361: Accept strings like "MyGreatNode 64E0 A664 09CA 5 (in weather/trunk: . lib/weather)



Author: kaner
Date: 2010-04-18 09:55:46 +0000 (Sun, 18 Apr 2010)
New Revision: 22204

Modified:
   weather/trunk/TODO
   weather/trunk/Weather.py
   weather/trunk/lib/weather/utils.py
Log:
Fix #1361: Accept strings like "MyGreatNode 64E0 A664 09CA 5371 D02E 7176 902B 753A D041 F753"


Modified: weather/trunk/TODO
===================================================================
--- weather/trunk/TODO	2010-04-18 07:50:51 UTC (rev 22203)
+++ weather/trunk/TODO	2010-04-18 09:55:46 UTC (rev 22204)
@@ -4,9 +4,5 @@
 
 * add /usr/sbin/sendmail support for sending email 
 
-* Tolerate a string preceding the identity fingerprint, as long as the
-rest of the line is a valid fingerprint. So people can paste in lines like
-  moria1 FFCB 46DB 1339 DA84 674C 70D7 CB58 6434 C437 0441
-
 * Let's also look at server versions and alert admins when they should upgrade.
 

Modified: weather/trunk/Weather.py
===================================================================
--- weather/trunk/Weather.py	2010-04-18 07:50:51 UTC (rev 22203)
+++ weather/trunk/Weather.py	2010-04-18 09:55:46 UTC (rev 22204)
@@ -48,7 +48,9 @@
         if not self.request.args.has_key("node"):
             logging.error("Request provided no node ID")
             return False
-        self.node = self.request.args['node'][0]
+        n = self.request.args['node'][0]
+        # Accept node IDs with spaces in between
+        self.node = utils.unifyNodeID(n)
         if not utils.checkNodeID(self.node):
             logging.error("Bad node ID '%s'" % self.email)
             return False
@@ -125,6 +127,7 @@
         self.request.finish()
 
     def _rollBack(self, errorMsg):
+        logging.error("Rolling back: %s" % errorMsg)
         dbQuery = queries.ROLLBACK_Q % (self.email, self.node)
         self.dbConn.runQuery(dbQuery).addCallback(
             self._errOut, errorMsg).addErrback(
@@ -133,7 +136,10 @@
     def _errback(self, failure):
         self._errOut("Error in subscribe: %s" % (failure.getErrorMessage()))
 
-    def _errOut(self, error):
+    def _errOut(self, error, extra=None):
+        if extra is not None:
+            # We're called by callback
+            error = extra
         logging.error(error)
         self.request.setResponseCode(http.INTERNAL_SERVER_ERROR)
         self.request.write(utils.pageOut(error))
@@ -234,7 +240,7 @@
         error = "Error in UnsubscribeRequest: %s" % (failure.getErrorMessage())
         self._errOut(error)
 
-    def _errOut(self, error):
+    def _errOut(self, error, extra=None):
         logging.error(error)
         self.request.setResponseCode(http.INTERNAL_SERVER_ERROR)
         self.request.write(utils.pageOut(error))

Modified: weather/trunk/lib/weather/utils.py
===================================================================
--- weather/trunk/lib/weather/utils.py	2010-04-18 07:50:51 UTC (rev 22203)
+++ weather/trunk/lib/weather/utils.py	2010-04-18 09:55:46 UTC (rev 22204)
@@ -62,6 +62,22 @@
         r = r.replace("-", "x")
     return r
 
+def unifyNodeID(nodeID):
+    """Perform some basic unifying artistics on the node ID"""
+    if nodeID.find(" ") is -1:
+        # No spaces found, check length
+        if len(nodeID) is 40:
+            return nodeID
+        else:
+            logging.error("Bad nodeID: %s" % nodeID)
+            return nodeID
+    unified = nodeID.replace(" ", "")
+    if len(unified) > 40:
+        # Maybe someone pasted the ID like so:
+        # TorKServer 74E0 A664 09CA 5371 D02E 7176 902B 753A D041 F753
+        unified = nodeID.partition(" ")[2].replace(" ", "")
+    return unified
+
 def checkNodeID(nodeID):
     """Check if a given Tor node ID looks ok"""
     nodeOk = re.compile("(0x)?[a-fA-F0-9]{40}\Z")