anonymize IP if passed as ::ffff.1.2.3.4 correctly
This commit is contained in:
parent
88a7d40bea
commit
98ab6d205a
@ -101,8 +101,13 @@ def heading(host, path):
|
|||||||
|
|
||||||
def anonymize(remote_addr):
|
def anonymize(remote_addr):
|
||||||
ip = ipaddress.ip_address(remote_addr)
|
ip = ipaddress.ip_address(remote_addr)
|
||||||
if ip.version == "4":
|
try:
|
||||||
|
ipv4 = ipaddress.IPv4Address(remote_addr)
|
||||||
return ''.join(ip.exploded.rsplit('.', 1)[0]) + '.' + '0'
|
return ''.join(ip.exploded.rsplit('.', 1)[0]) + '.' + '0'
|
||||||
|
except ipaddress.AddressValueError:
|
||||||
|
ipv6 = ipaddress.IPv6Address(remote_addr)
|
||||||
|
if ipv6.ipv4_mapped is not None:
|
||||||
|
return anonymize(ipv6.ipv4_mapped)
|
||||||
return ip.exploded.rsplit(':', 5)[0]
|
return ip.exploded.rsplit(':', 5)[0]
|
||||||
|
|
||||||
|
|
||||||
|
@ -57,7 +57,7 @@ def create(app, environ, request, uri):
|
|||||||
if "id" in data and not isinstance(data["id"], int):
|
if "id" in data and not isinstance(data["id"], int):
|
||||||
return Response("Parent ID must be an integer.")
|
return Response("Parent ID must be an integer.")
|
||||||
|
|
||||||
if "email" in data:
|
if data.get("email"):
|
||||||
hash = data["email"]
|
hash = data["email"]
|
||||||
else:
|
else:
|
||||||
hash = utils.salt(utils.anonymize(unicode(request.remote_addr)))
|
hash = utils.salt(utils.anonymize(unicode(request.remote_addr)))
|
||||||
|
Loading…
Reference in New Issue
Block a user