X-Git-Url: http://git.veekun.com/zzz-spline-forum.git/blobdiff_plain/5dfd3c16b080feb5e2d420b723ea646535e4092c..39c2141c656650e7624d34f8f4bf6c28dbce0981:/splinext/forum/__init__.py diff --git a/splinext/forum/__init__.py b/splinext/forum/__init__.py index 0c8edd3..974e29e 100644 --- a/splinext/forum/__init__.py +++ b/splinext/forum/__init__.py @@ -1,44 +1,22 @@ from pkg_resources import resource_filename -from pylons import c, session +from pylons import session, tmpl_context as c from spline.lib.plugin import PluginBase from spline.lib.plugin import PluginBase, PluginLink, Priority -from spline.model import meta import splinext.forum.controllers.forum -from splinext.forum import model as forum_model def add_routes_hook(map, *args, **kwargs): """Hook to inject some of our behavior into the routes configuration.""" require_POST = dict(conditions=dict(method=['POST'])) map.connect('/forums', controller='forum', action='forums') - map.connect('/forums/{forum_id}', controller='forum', action='threads') - map.connect('/forums/{forum_id}/threads/{thread_id}', controller='forum', action='posts') + map.connect(r'/forums/{forum_id:\d+}', controller='forum', action='threads') + map.connect(r'/forums/{forum_id:\d+}/threads/{thread_id:\d+}', controller='forum', action='posts') - map.connect('/forums/{forum_id}/write', controller='forum', action='write_thread') - map.connect('/forums/{forum_id}/threads/{thread_id}/write', controller='forum', action='write') - -class FrontPageNewsPost(object): - pass - -def frontpage_hook(limit): - """Hook to return recent news for the front page.""" - threads = meta.Session.query(forum_model.Thread) \ - .join(forum_model.Thread.first_post) \ - .order_by(forum_model.Post.posted_time.desc()) \ - [:limit] - - updates = [] - for thread in threads: - update = FrontPageNewsPost() - update.time = thread.first_post.posted_time - update.template = '/forum/front_page.mako' - update.post = thread.first_post - updates.append(update) - - return updates + map.connect(r'/forums/{forum_id:\d+}/write', controller='forum', action='write_thread') + map.connect(r'/forums/{forum_id:\d+}/threads/{thread_id:\d+}/write', controller='forum', action='write') class ForumPlugin(PluginBase): @@ -48,7 +26,16 @@ class ForumPlugin(PluginBase): ) def hooks(self): - return [ + hooks = [ ('routes_mapping', Priority.NORMAL, add_routes_hook), - ('frontpage_updates', Priority.NORMAL, frontpage_hook), ] + + # frontpage plugin may or may not be installed + try: + from splinext.forum.frontpage_sources import ForumSource + hooks.append( + ('frontpage_updates_forum', Priority.NORMAL, ForumSource)) + except ImportError: + pass + + return hooks