Merge "Added 'NormalizingFilter' middleware."
This commit is contained in:
commit
5a053843f9
@ -119,6 +119,9 @@ paste.filter_factory = keystone.contrib.admin_crud:CrudExtension.factory
|
|||||||
[filter:ec2_extension]
|
[filter:ec2_extension]
|
||||||
paste.filter_factory = keystone.contrib.ec2:Ec2Extension.factory
|
paste.filter_factory = keystone.contrib.ec2:Ec2Extension.factory
|
||||||
|
|
||||||
|
[filter:url_normalize]
|
||||||
|
paste.filter_factory = keystone.middleware:NormalizingFilter.factory
|
||||||
|
|
||||||
[app:public_service]
|
[app:public_service]
|
||||||
paste.app_factory = keystone.service:public_app_factory
|
paste.app_factory = keystone.service:public_app_factory
|
||||||
|
|
||||||
@ -126,10 +129,10 @@ paste.app_factory = keystone.service:public_app_factory
|
|||||||
paste.app_factory = keystone.service:admin_app_factory
|
paste.app_factory = keystone.service:admin_app_factory
|
||||||
|
|
||||||
[pipeline:public_api]
|
[pipeline:public_api]
|
||||||
pipeline = token_auth admin_token_auth xml_body json_body debug ec2_extension public_service
|
pipeline = url_normalize token_auth admin_token_auth xml_body json_body debug ec2_extension public_service
|
||||||
|
|
||||||
[pipeline:admin_api]
|
[pipeline:admin_api]
|
||||||
pipeline = token_auth admin_token_auth xml_body json_body debug ec2_extension crud_extension admin_service
|
pipeline = url_normalize token_auth admin_token_auth xml_body json_body debug ec2_extension crud_extension admin_service
|
||||||
|
|
||||||
[app:public_version_service]
|
[app:public_version_service]
|
||||||
paste.app_factory = keystone.service:public_version_app_factory
|
paste.app_factory = keystone.service:public_version_app_factory
|
||||||
@ -138,10 +141,10 @@ paste.app_factory = keystone.service:public_version_app_factory
|
|||||||
paste.app_factory = keystone.service:admin_version_app_factory
|
paste.app_factory = keystone.service:admin_version_app_factory
|
||||||
|
|
||||||
[pipeline:public_version_api]
|
[pipeline:public_version_api]
|
||||||
pipeline = xml_body public_version_service
|
pipeline = url_normalize xml_body public_version_service
|
||||||
|
|
||||||
[pipeline:admin_version_api]
|
[pipeline:admin_version_api]
|
||||||
pipeline = xml_body admin_version_service
|
pipeline = url_normalize xml_body admin_version_service
|
||||||
|
|
||||||
[composite:main]
|
[composite:main]
|
||||||
use = egg:Paste#urlmap
|
use = egg:Paste#urlmap
|
||||||
|
@ -148,3 +148,17 @@ class XmlBodyMiddleware(wsgi.Middleware):
|
|||||||
except:
|
except:
|
||||||
raise exception.Error(message=response.body)
|
raise exception.Error(message=response.body)
|
||||||
return response
|
return response
|
||||||
|
|
||||||
|
|
||||||
|
class NormalizingFilter(wsgi.Middleware):
|
||||||
|
"""Middleware filter to handle URL normalization."""
|
||||||
|
|
||||||
|
def process_request(self, request):
|
||||||
|
"""Normalizes URLs."""
|
||||||
|
# Removes a trailing slash from the given path, if any.
|
||||||
|
if len(request.environ['PATH_INFO']) > 1 and \
|
||||||
|
request.environ['PATH_INFO'][-1] == '/':
|
||||||
|
request.environ['PATH_INFO'] = request.environ['PATH_INFO'][:-1]
|
||||||
|
# Rewrites path to root if no path is given.
|
||||||
|
elif not request.environ['PATH_INFO']:
|
||||||
|
request.environ['PATH_INFO'] = '/'
|
||||||
|
58
tests/test_url_middleware.py
Normal file
58
tests/test_url_middleware.py
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||||
|
|
||||||
|
# Copyright 2012 OpenStack LLC
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
import webob
|
||||||
|
|
||||||
|
from keystone import middleware
|
||||||
|
from keystone import test
|
||||||
|
|
||||||
|
import test_auth_token_middleware as test_atm
|
||||||
|
|
||||||
|
|
||||||
|
class FakeApp(object):
|
||||||
|
"""Fakes a WSGI app URL normalized."""
|
||||||
|
def __call__(self, env, start_response):
|
||||||
|
resp = webob.Response()
|
||||||
|
resp.body = 'SUCCESS'
|
||||||
|
return resp(env, start_response)
|
||||||
|
|
||||||
|
|
||||||
|
class UrlMiddlewareTest(test.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
self.middleware = middleware.NormalizingFilter(FakeApp())
|
||||||
|
self.middleware.http_client_class = test_atm.FakeHTTPConnection
|
||||||
|
self.response_status = None
|
||||||
|
self.response_headers = None
|
||||||
|
super(UrlMiddlewareTest, self).setUp()
|
||||||
|
|
||||||
|
def start_fake_response(self, status, headers):
|
||||||
|
self.response_status = int(status.split(' ', 1)[0])
|
||||||
|
self.response_headers = dict(headers)
|
||||||
|
|
||||||
|
def test_trailing_slash_normalization(self):
|
||||||
|
"""Tests /v2.0/tokens and /v2.0/tokens/ normalized URLs match."""
|
||||||
|
req1 = webob.Request.blank('/v2.0/tokens')
|
||||||
|
req2 = webob.Request.blank('/v2.0/tokens/')
|
||||||
|
_ = self.middleware(req1.environ, self.start_fake_response)
|
||||||
|
_ = self.middleware(req2.environ, self.start_fake_response)
|
||||||
|
self.assertEqual(req1.path_url, req2.path_url)
|
||||||
|
self.assertEqual(req1.path_url, 'http://localhost/v2.0/tokens')
|
||||||
|
|
||||||
|
def test_rewrite_empty_path(self):
|
||||||
|
"""Tests empty path is rewritten to root."""
|
||||||
|
req = webob.Request.blank('')
|
||||||
|
_ = self.middleware(req.environ, self.start_fake_response)
|
||||||
|
self.assertEqual(req.path_url, 'http://localhost/')
|
Loading…
Reference in New Issue
Block a user