[tor-commits] [bridgedb/develop] Change isValidRouterNickname() to only return booleans.

isis at torproject.org isis at torproject.org
Thu Feb 19 02:21:13 UTC 2015


commit 192a3e876015fd6bc1414af2df55945bb79471a2
Author: Isis Lovecruft <isis at torproject.org>
Date:   Thu Dec 11 04:28:04 2014 +0000

    Change isValidRouterNickname() to only return booleans.
---
 lib/bridgedb/parse/networkstatus.py |    2 ++
 lib/bridgedb/parse/nickname.py      |   25 +++++++++++++++++--------
 2 files changed, 19 insertions(+), 8 deletions(-)

diff --git a/lib/bridgedb/parse/networkstatus.py b/lib/bridgedb/parse/networkstatus.py
index 106edd9..8140fe0 100644
--- a/lib/bridgedb/parse/networkstatus.py
+++ b/lib/bridgedb/parse/networkstatus.py
@@ -39,6 +39,8 @@ from twisted.python.log import showwarning
 from bridgedb.parse import addr
 from bridgedb.parse import parseUnpaddedBase64
 from bridgedb.parse import InvalidBase64
+from bridgedb.parse.nickname import InvalidRouterNickname
+from bridgedb.parse.nickname import isValidRouterNickname
 
 
 class NetworkstatusParsingError(Exception):
diff --git a/lib/bridgedb/parse/nickname.py b/lib/bridgedb/parse/nickname.py
index b38bdb8..9c3a559 100644
--- a/lib/bridgedb/parse/nickname.py
+++ b/lib/bridgedb/parse/nickname.py
@@ -33,16 +33,25 @@ class InvalidRouterNickname(ValueError):
 def isValidRouterNickname(nickname):
     """Determine if a router's given nickname meets the specification.
 
-    :raises InvalidRouterNickname: if the nickname is invalid.
     :param string nickname: An OR's nickname.
+    :rtype: bool
+    :returns: ``True`` if the nickname is valid, ``False`` otherwise.
     """
     ALPHANUMERIC = string.letters + string.digits
 
-    if not (1 <= len(nickname) <= 19):
-        raise InvalidRouterNickname(
-            "Nicknames must be between 1 and 19 characters: %r" % nickname)
-    for letter in nickname:
-        if not letter in ALPHANUMERIC:
+    try:
+        if not (1 <= len(nickname) <= 19):
             raise InvalidRouterNickname(
-                "Nicknames must only use [A-Za-z0-9]: %r" % nickname)
-    return True
+                "Nicknames must be between 1 and 19 characters: %r" % nickname)
+        for letter in nickname:
+            if not letter in ALPHANUMERIC:
+                raise InvalidRouterNickname(
+                    "Nicknames must only use [A-Za-z0-9]: %r" % nickname)
+    except InvalidRouterNickname as error:
+        logging.error(str(error))
+    except TypeError:  # The nickname was probably still set to ``None``
+        pass
+    else:
+        return True
+
+    return False





More information about the tor-commits mailing list