diff options
author | Elrond <elrond+mediagoblin.org@samba-tng.org> | 2012-12-16 00:45:57 +0100 |
---|---|---|
committer | Elrond <elrond+mediagoblin.org@samba-tng.org> | 2012-12-23 12:26:34 +0100 |
commit | 05501c5742c85d0e2c855a02800d1f50f9df6c3d (patch) | |
tree | d30ed348bf57afb1e939899b41d30b31850b0b9d | |
parent | 7880f03e2d9074c151306cbbdd7a247a020d8b55 (diff) | |
download | mediagoblin-05501c5742c85d0e2c855a02800d1f50f9df6c3d.tar.lz mediagoblin-05501c5742c85d0e2c855a02800d1f50f9df6c3d.tar.xz mediagoblin-05501c5742c85d0e2c855a02800d1f50f9df6c3d.zip |
Rewrite routing using new MGRoute class
MGRoute subclasses Rule():
Rule doesn't have a way to tag extra data, like the
controller function, we need. So MGRoute has a new
attribute .gmg_controller, which holds this.
Rewrite everything to use this new Rule variant and drop
all the other stuff that mapped endpoints to controller
functions, mostly.
-rw-r--r-- | mediagoblin/app.py | 4 | ||||
-rw-r--r-- | mediagoblin/tools/routing.py | 27 |
2 files changed, 17 insertions, 14 deletions
diff --git a/mediagoblin/app.py b/mediagoblin/app.py index ff64f65c..936a354f 100644 --- a/mediagoblin/app.py +++ b/mediagoblin/app.py @@ -184,7 +184,7 @@ class MediaGoblinApp(object): mg_request.setup_user_in_request(request) try: - endpoint, url_values = map_adapter.match() + found_rule, url_values = map_adapter.match(return_rule=True) request.matchdict = url_values except HTTPException as exc: # Stop and render exception @@ -192,7 +192,7 @@ class MediaGoblinApp(object): request, exc, exc.get_description(environ))(environ, start_response) - controller = endpoint_to_controller(endpoint) + controller = endpoint_to_controller(found_rule) # pass the request through our meddleware classes try: diff --git a/mediagoblin/tools/routing.py b/mediagoblin/tools/routing.py index 6c5acbec..791cd1e6 100644 --- a/mediagoblin/tools/routing.py +++ b/mediagoblin/tools/routing.py @@ -24,18 +24,28 @@ _log = logging.getLogger(__name__) url_map = Map() -view_functions = {} +class MGRoute(Rule): + def __init__(self, endpoint, url, controller): + Rule.__init__(self, url, endpoint=endpoint) + self.gmg_controller = controller -def endpoint_to_controller(endpoint): - view_func = view_functions[endpoint] + def empty(self): + new_rule = Rule.empty(self) + new_rule.gmg_controller = self.gmg_controller + return new_rule + + +def endpoint_to_controller(rule): + endpoint = rule.endpoint + view_func = rule.gmg_controller _log.debug('endpoint: {0} view_func: {1}'.format(endpoint, view_func)) # import the endpoint, or if it's already a callable, call that if isinstance(view_func, basestring): view_func = import_component(view_func) - view_functions[endpoint] = view_func + rule.gmg_controller = view_func return view_func @@ -44,14 +54,7 @@ def add_route(endpoint, url, controller): """ Add a route to the url mapping """ - # XXX: We cannot use this, since running tests means that the plugin - # routes will be populated over and over over the same session. - # - # assert endpoint not in view_functions.keys(), 'Trying to overwrite a rule' - - view_functions.update({endpoint: controller}) - - url_map.add(Rule(url, endpoint=endpoint)) + url_map.add(MGRoute(endpoint, url, controller)) def mount(mountpoint, routes): |