Improve StaticWeb 404 on web-listings/index
A common scenario is for users to make a container public via an ACL. They can then use a browser to display the objects in the container. Next, they enable StaticWeb with something such as "X-Container-Meta-Web-Index:index.html" -- but then get confused because they get 404 Not Found (when index.html does not exist). For someone who understands what they are doing, this makes sense. However, we've had several customer escalations because of this. Usually, they are just playing with our GUI and have no intention of using StaticWeb for real -- the 404 looks like something is broken; not the correct response. The solution is to provide a better error message. This message is only shown when StaticWeb is refusing to give a listing -- other 404 situations are not affected. Also, a custom 404 error page is not affected. Change-Id: I3ba8c48e0ce148d8e91a1e0dc16a0d37a692a24e
This commit is contained in:
parent
e60d541d9a
commit
2e220ca912
@ -209,7 +209,31 @@ class _StaticWebContext(WSGIContext):
|
|||||||
:param prefix: Any prefix desired for the container listing.
|
:param prefix: Any prefix desired for the container listing.
|
||||||
"""
|
"""
|
||||||
if not config_true_value(self._listings):
|
if not config_true_value(self._listings):
|
||||||
resp = HTTPNotFound()(env, self._start_response)
|
body = '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 ' \
|
||||||
|
'Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">\n' \
|
||||||
|
'<html>\n' \
|
||||||
|
'<head>\n' \
|
||||||
|
'<title>Listing of %s</title>\n' % cgi.escape(env['PATH_INFO'])
|
||||||
|
if self._listings_css:
|
||||||
|
body += ' <link rel="stylesheet" type="text/css" ' \
|
||||||
|
'href="%s" />\n' % self._build_css_path(prefix or '')
|
||||||
|
else:
|
||||||
|
body += ' <style type="text/css">\n' \
|
||||||
|
' h1 {font-size: 1em; font-weight: bold;}\n' \
|
||||||
|
' p {font-size: 2}\n' \
|
||||||
|
' </style>\n'
|
||||||
|
body += '</head>\n<body>' \
|
||||||
|
' <h1>Web Listing Disabled</h1>' \
|
||||||
|
' <p>The owner of this web site has disabled web listing.' \
|
||||||
|
' <p>If you are the owner of this web site, you can enable' \
|
||||||
|
' web listing by setting X-Container-Meta-Web-Listings.</p>'
|
||||||
|
if self._index:
|
||||||
|
body += '<h1>Index File Not Found</h1>' \
|
||||||
|
' <p>The owner of this web site has set ' \
|
||||||
|
' <b>X-Container-Meta-Web-Index: %s</b>. ' \
|
||||||
|
' However, this file is not found.</p>' % self._index
|
||||||
|
body += ' </body>\n</html>\n'
|
||||||
|
resp = HTTPNotFound(body=body)(env, self._start_response)
|
||||||
return self._error_response(resp, env, start_response)
|
return self._error_response(resp, env, start_response)
|
||||||
tmp_env = make_pre_authed_env(
|
tmp_env = make_pre_authed_env(
|
||||||
env, 'GET', '/%s/%s/%s' % (
|
env, 'GET', '/%s/%s/%s' % (
|
||||||
|
@ -58,6 +58,8 @@ meta_map = {
|
|||||||
'web-directory-type': 'text/directory'}},
|
'web-directory-type': 'text/directory'}},
|
||||||
'c12': {'meta': {'web-index': 'index.html',
|
'c12': {'meta': {'web-index': 'index.html',
|
||||||
'web-error': 'error.html'}},
|
'web-error': 'error.html'}},
|
||||||
|
'c13': {'meta': {'web-listings': 'f',
|
||||||
|
'web-listings-css': 'listing.css'}},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -604,6 +606,7 @@ class TestStaticWeb(unittest.TestCase):
|
|||||||
def test_container7listing(self):
|
def test_container7listing(self):
|
||||||
resp = Request.blank('/v1/a/c7/').get_response(self.test_staticweb)
|
resp = Request.blank('/v1/a/c7/').get_response(self.test_staticweb)
|
||||||
self.assertEquals(resp.status_int, 404)
|
self.assertEquals(resp.status_int, 404)
|
||||||
|
self.assert_('Web Listing Disabled' in resp.body)
|
||||||
|
|
||||||
def test_container8listingcss(self):
|
def test_container8listingcss(self):
|
||||||
resp = Request.blank(
|
resp = Request.blank(
|
||||||
@ -665,6 +668,7 @@ class TestStaticWeb(unittest.TestCase):
|
|||||||
resp = Request.blank('/v1/a/c11a/subdir/').get_response(
|
resp = Request.blank('/v1/a/c11a/subdir/').get_response(
|
||||||
self.test_staticweb)
|
self.test_staticweb)
|
||||||
self.assertEquals(resp.status_int, 404)
|
self.assertEquals(resp.status_int, 404)
|
||||||
|
self.assert_('Index File Not Found' in resp.body)
|
||||||
|
|
||||||
def test_container11subdirmarkeraltdirtype(self):
|
def test_container11subdirmarkeraltdirtype(self):
|
||||||
resp = Request.blank('/v1/a/c11a/subdir2/').get_response(
|
resp = Request.blank('/v1/a/c11a/subdir2/').get_response(
|
||||||
@ -682,6 +686,19 @@ class TestStaticWeb(unittest.TestCase):
|
|||||||
self.assertEquals(resp.status_int, 200)
|
self.assertEquals(resp.status_int, 200)
|
||||||
self.assert_('index file' in resp.body)
|
self.assert_('index file' in resp.body)
|
||||||
|
|
||||||
|
def test_container_404_has_css(self):
|
||||||
|
resp = Request.blank('/v1/a/c13/').get_response(
|
||||||
|
self.test_staticweb)
|
||||||
|
self.assertEquals(resp.status_int, 404)
|
||||||
|
self.assert_('listing.css' in resp.body)
|
||||||
|
|
||||||
|
def test_container_404_has_no_css(self):
|
||||||
|
resp = Request.blank('/v1/a/c7/').get_response(
|
||||||
|
self.test_staticweb)
|
||||||
|
self.assertEquals(resp.status_int, 404)
|
||||||
|
self.assert_('listing.css' not in resp.body)
|
||||||
|
self.assert_('<style' in resp.body)
|
||||||
|
|
||||||
def test_container_unicode_stdlib_json(self):
|
def test_container_unicode_stdlib_json(self):
|
||||||
with mock.patch('swift.common.middleware.staticweb.json',
|
with mock.patch('swift.common.middleware.staticweb.json',
|
||||||
new=stdlib_json):
|
new=stdlib_json):
|
||||||
|
Loading…
Reference in New Issue
Block a user