mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-12 05:02:32 +01:00
Since Windows' version of Python doesn't build with IPV6 support, we have
to be careful about how we try to detect whether a string is IPV6.
This commit is contained in:
parent
75dc3e804a
commit
911d9db4a4
29
src/utils.py
29
src/utils.py
@ -612,25 +612,32 @@ def isIP(s):
|
|||||||
except socket.error:
|
except socket.error:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
def bruteIsIPV6(s):
|
||||||
|
if s.count('::') <= 1:
|
||||||
|
L = s.split(':')
|
||||||
|
if len(L) <= 8:
|
||||||
|
for x in L:
|
||||||
|
if x:
|
||||||
|
try:
|
||||||
|
int(x, 16)
|
||||||
|
except ValueError:
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
def isIPV6(s):
|
def isIPV6(s):
|
||||||
"""Returns whether or not a given string is an IPV6 address."""
|
"""Returns whether or not a given string is an IPV6 address."""
|
||||||
try:
|
try:
|
||||||
return bool(socket.inet_pton(socket.AF_INET6, s))
|
if hasattr(socket, 'inet_pton'):
|
||||||
|
return bool(socket.inet_pton(socket.AF_INET6, s))
|
||||||
|
else:
|
||||||
|
return bruteIsIPV6(s)
|
||||||
except socket.error:
|
except socket.error:
|
||||||
try:
|
try:
|
||||||
socket.inet_pton(socket.AF_INET6, '::')
|
socket.inet_pton(socket.AF_INET6, '::')
|
||||||
except socket.error:
|
except socket.error:
|
||||||
# We gotta fake it.
|
# We gotta fake it.
|
||||||
if s.count('::') <= 1:
|
return bruteIsIPV6(s)
|
||||||
L = s.split(':')
|
|
||||||
if len(L) <= 8:
|
|
||||||
for x in L:
|
|
||||||
if x:
|
|
||||||
try:
|
|
||||||
int(x, 16)
|
|
||||||
except ValueError:
|
|
||||||
return False
|
|
||||||
return True
|
|
||||||
return False
|
return False
|
||||||
|
|
||||||
class InsensitivePreservingDict(UserDict.DictMixin, object):
|
class InsensitivePreservingDict(UserDict.DictMixin, object):
|
||||||
|
Loading…
Reference in New Issue
Block a user