[tor-commits] [bridgedb/develop] Change Dist.uniformMap() to return proper CIDR subnet notations.

isis at torproject.org isis at torproject.org
Tue Mar 31 11:55:45 UTC 2015


commit 1d884603013c02f145eda05e2c6bef42dc611660
Author: Isis Lovecruft <isis at torproject.org>
Date:   Tue Mar 31 01:42:41 2015 +0000

    Change Dist.uniformMap() to return proper CIDR subnet notations.
---
 lib/bridgedb/Dist.py |   30 +++++++++++++++++++-----------
 1 file changed, 19 insertions(+), 11 deletions(-)

diff --git a/lib/bridgedb/Dist.py b/lib/bridgedb/Dist.py
index 9a2b051..cd91d62 100644
--- a/lib/bridgedb/Dist.py
+++ b/lib/bridgedb/Dist.py
@@ -17,9 +17,6 @@ import logging
 import re
 import time
 
-from ipaddr import IPv6Address
-from ipaddr import IPAddress
-
 import bridgedb.Bridges
 import bridgedb.Storage
 
@@ -56,20 +53,31 @@ def uniformMap(ip):
 
     >>> from bridgedb import Dist
     >>> Dist.uniformMap('1.2.3.4')
-    '1.2.3'
+    '1.2.3.0/24'
     >>> Dist.uniformMap('1.2.3.154')
-    '1.2.3'
+    '1.2.3.0/24'
     >>> Dist.uniformMap('2001:f::bc1:b13:2808')
-    '2001:000f:0000:0000'
+    '2001:f::/64'
+    >>> Dist.uniformMap('2a00:c98:2030:a020:2::42')
+    '2a00:c98:2030:a020::/64'
 
     :param str ip: A string representing an IPv4 or IPv6 address.
     :rtype: str
-    :returns: The truncated **ip**.
+    :returns: The appropriately sized CIDR subnet representation of the **ip**.
     """
-    if type(IPAddress(ip)) is IPv6Address:
-        return ":".join(IPv6Address(ip).exploded.split(':')[:4])
+    # We aren't using bridgedb.parse.addr.isIPAddress(ip, compressed=False)
+    # here because adding the string "False" into the map would land any and
+    # all clients whose IP address appeared to be invalid at the same position
+    # in a hashring.
+    address = ipaddr.IPAddress(ip)
+    if address.version == 6:
+        truncated = ':'.join(address.exploded.split(':')[:4])
+        subnet = str(ipaddr.IPv6Network(truncated + "::/64"))
+        return subnet
     else:
-        return ".".join(ip.split(".")[:3])
+        truncated = '.'.join(address.exploded.split('.')[:3])
+        subnet = str(ipaddr.IPv4Network(truncated + '.0/24'))
+        return subnet
 
 def getNumBridgesPerAnswer(ring, max_bridges_per_answer=3):
     if len(ring) < 20:
@@ -280,7 +288,7 @@ class IPBasedDistributor(Distributor):
                       % ' '.join([x.func_name for x in bridgeFilterRules]))
 
         area = self.areaMapper(ip)
-        logging.debug("IP mapped to area:\t%s.0 /24" % area)
+        logging.debug("IP mapped to area:\t%s" % area)
 
         key1 = ''
         pos = 0





More information about the tor-commits mailing list