diff options
| author | Ivan Alejandro <ivanalejandro0@gmail.com> | 2013-08-30 16:16:13 -0300 | 
|---|---|---|
| committer | Ivan Alejandro <ivanalejandro0@gmail.com> | 2013-08-30 16:32:15 -0300 | 
| commit | 3edf686a911f9fd58a0d66dcc7f2d798f5ab88f7 (patch) | |
| tree | 74d6f5d62bf54b4ef2402119e3aa805d9b9ce0fe | |
| parent | f29133e7e2244ef7181685af7d93653cb54562e8 (diff) | |
Add method to return gateways with their names.
Also the test code in the bottom was updated to work.
| -rw-r--r-- | src/leap/bitmask/services/eip/eipconfig.py | 41 | 
1 files changed, 32 insertions, 9 deletions
| diff --git a/src/leap/bitmask/services/eip/eipconfig.py b/src/leap/bitmask/services/eip/eipconfig.py index 843e7397..1f49f9cd 100644 --- a/src/leap/bitmask/services/eip/eipconfig.py +++ b/src/leap/bitmask/services/eip/eipconfig.py @@ -62,11 +62,12 @@ class VPNGatewaySelector(object):          self._eipconfig = eipconfig -    def get_gateways(self): +    def get_gateways_list(self):          """ -        Returns the 4 best gateways, sorted by timezone proximity. +        Returns the existing gateways, sorted by timezone proximity. -        :rtype: list of IPv4Address or IPv6Address object. +        :rtype: list of tuples (location, ip) +                (str, IPv4Address or IPv6Address object)          """          gateways_timezones = []          locations = self._eipconfig.get_locations() @@ -77,19 +78,35 @@ class VPNGatewaySelector(object):              gateway_distance = 99  # if hasn't location -> should go last              if gateway_location is not None: -                gw_offset = int(locations[gateway['location']]['timezone']) +                timezone = locations[gateway['location']]['timezone'] +                gateway_name = locations[gateway['location']].get('name', None) +                if gateway_name is not None: +                    gateway_location = gateway_name + +                gw_offset = int(timezone)                  if gw_offset in self.equivalent_timezones:                      gw_offset = self.equivalent_timezones[gw_offset]                  gateway_distance = self._get_timezone_distance(gw_offset)              ip = self._eipconfig.get_gateway_ip(idx) -            gateways_timezones.append((ip, gateway_distance)) +            gateways_timezones.append((ip, gateway_distance, gateway_location)) -        gateways_timezones = sorted(gateways_timezones, -                                    key=lambda gw: gw[1])[:4] +        gateways_timezones = sorted(gateways_timezones, key=lambda gw: gw[1]) + +        gateways = [] +        for ip, distance, location in gateways_timezones: +            gateways.append((location, ip)) + +        return gateways -        gateways = [ip for ip, dist in gateways_timezones] +    def get_gateways(self): +        """ +        Returns the 4 best gateways, sorted by timezone proximity. + +        :rtype: list of IPv4Address or IPv6Address object. +        """ +        gateways = [ip for location, ip in self.get_gateways_list()][:4]          return gateways      def _get_timezone_distance(self, offset): @@ -246,7 +263,8 @@ if __name__ == "__main__":      console.setFormatter(formatter)      logger.addHandler(console) -    eipconfig = EIPConfig('1') +    eipconfig = EIPConfig() +    eipconfig.set_api_version('1')      try:          eipconfig.get_clusters() @@ -255,9 +273,14 @@ if __name__ == "__main__":          print "Safe value getting is working"      if eipconfig.load("leap/providers/bitmask.net/eip-service.json"): +        print "EIPConfig methods"          print eipconfig.get_clusters()          print eipconfig.get_gateways()          print eipconfig.get_locations()          print eipconfig.get_openvpn_configuration()          print eipconfig.get_serial()          print eipconfig.get_version() +        print "VPNGatewaySelector methods" +        gws = VPNGatewaySelector(eipconfig) +        print gws.get_gateways() +        print gws.get_gateways_list() | 
