Disable raw IPv6 addresses by default

(they're scarier than I thought, and a bit dangerous in Web and maybe Windows
shell contexts)
This commit is contained in:
Peter Eckersley 2012-08-06 15:27:05 -07:00
parent e119f50f14
commit 84eb5058c6
3 changed files with 22 additions and 4 deletions

View file

@ -17,15 +17,31 @@ if len(sys.argv) > 1:
else:
server = os.environ["CHOCOLATESERVER"]
# it's weird to point to chocolate servers via raw IPv6 addresses, and such
# addresses can be %SCARY in some contexts, so out of paranoia let's disable
# them by default
allow_raw_ipv6_server = False
def is_hostname_sane(hostname):
"""
Do just enough to ensure to avoid shellcode from the environment. There's
Do enough to avoid shellcode from the environment. There's
no need to do more.
"""
import string as s
allowed = s.ascii_letters + s.digits + "-." # hostnames & IPv4
allowed += "[]:" # IPv6
return all([c in allowed for c in hostname])
if all([c in allowed for c in hostname])
return True
if not allow_raw_ipv6_server: return False
# ipv6 is messy and complicated, can contain %zoneindex etc.
import socket
try:
# is this a valid IPv6 address?
socket.getaddrinfo(hostname,443,socket.AF_INET6)
return True
except:
return False
assert is_hostname_sane(server), `server` + " is an impossible hostname"

@ -1 +1 @@
Subproject commit d4e8a6c42a63219113099b8611197622c0d24294
Subproject commit c63d9b1b36d537338719c96a6757aed4bf1283c3

View file

@ -378,3 +378,5 @@ class session(object):
if __name__ == "__main__":
app = web.application(urls, globals())
app.run()
# vim: set tabstop=4 shiftwidth=4 expandtab