Commit 0eeb3428 authored by Senthil Kumaran's avatar Senthil Kumaran

fix the incorrect changes made for PATH_INFO value - Issue10484

parent 25ba0efb
...@@ -85,8 +85,11 @@ class CGIHTTPRequestHandler(SimpleHTTPServer.SimpleHTTPRequestHandler): ...@@ -85,8 +85,11 @@ class CGIHTTPRequestHandler(SimpleHTTPServer.SimpleHTTPRequestHandler):
(and the next character is a '/' or the end of the string). (and the next character is a '/' or the end of the string).
""" """
splitpath = _url_collapse_path_split(self.path) splitpath = _url_collapse_path_split(self.path)
if splitpath[0] in self.cgi_directories: joined_path = '/'.join(splitpath)
self.cgi_info = splitpath dir_sep = joined_path.find('/', 1)
head, tail = joined_path[:dir_sep], joined_path[dir_sep+1:]
if head in self.cgi_directories:
self.cgi_info = head, tail
return True return True
return False return False
...@@ -323,13 +326,6 @@ def _url_collapse_path_split(path): ...@@ -323,13 +326,6 @@ def _url_collapse_path_split(path):
# Filter out blank non trailing parts before consuming the '..'. # Filter out blank non trailing parts before consuming the '..'.
path_parts = [part for part in path_parts[:-1] if part] + path_parts[-1:] path_parts = [part for part in path_parts[:-1] if part] + path_parts[-1:]
if path_parts: if path_parts:
# Special case for CGI's for PATH_INFO
if path.startswith('/cgi-bin') or path.startswith('/htbin'):
tail_part = []
while path_parts[-1] not in ('cgi-bin','htbin'):
tail_part.insert(0,path_parts.pop())
tail_part = "/".join(tail_part)
else:
tail_part = path_parts.pop() tail_part = path_parts.pop()
else: else:
tail_part = '' tail_part = ''
......
...@@ -419,6 +419,7 @@ class CGIHTTPServerTestCase(BaseTestCase): ...@@ -419,6 +419,7 @@ class CGIHTTPServerTestCase(BaseTestCase):
BaseTestCase.tearDown(self) BaseTestCase.tearDown(self)
def test_url_collapse_path_split(self): def test_url_collapse_path_split(self):
# verify tail is the last portion and head is the rest on proper urls
test_vectors = { test_vectors = {
'': ('/', ''), '': ('/', ''),
'..': IndexError, '..': IndexError,
...@@ -429,7 +430,6 @@ class CGIHTTPServerTestCase(BaseTestCase): ...@@ -429,7 +430,6 @@ class CGIHTTPServerTestCase(BaseTestCase):
'/.//': ('/', ''), '/.//': ('/', ''),
'cgi-bin/file1.py': ('/cgi-bin', 'file1.py'), 'cgi-bin/file1.py': ('/cgi-bin', 'file1.py'),
'/cgi-bin/file1.py': ('/cgi-bin', 'file1.py'), '/cgi-bin/file1.py': ('/cgi-bin', 'file1.py'),
'/cgi-bin/file1.py/PATH-INFO': ('/cgi-bin', 'file1.py/PATH-INFO'),
'a': ('/', 'a'), 'a': ('/', 'a'),
'/a': ('/', 'a'), '/a': ('/', 'a'),
'//a': ('/', 'a'), '//a': ('/', 'a'),
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment