X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=mediagoblin%2Fviews.py;h=9e893d566ba3cb11121e2d426cf84616f4bc964c;hb=283043f14d8fdeb8cccad00b7d7cb7a8cc5a17bd;hp=e7d9dbdddfb1bc4cdab1782d4ae776778df04fa5;hpb=ae31c364395bba22e54c1f91f1a680260dee5aa0;p=mediagoblin.git diff --git a/mediagoblin/views.py b/mediagoblin/views.py index e7d9dbdd..9e893d56 100644 --- a/mediagoblin/views.py +++ b/mediagoblin/views.py @@ -1,5 +1,5 @@ # GNU MediaGoblin -- federated, autonomous media hosting -# Copyright (C) 2011 Free Software Foundation, Inc +# Copyright (C) 2011, 2012 MediaGoblin contributors. See AUTHORS. # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by @@ -15,17 +15,36 @@ # along with this program. If not, see . from mediagoblin import mg_globals -from mediagoblin.util import render_to_response -from mediagoblin.db.util import DESCENDING +from mediagoblin.db.models import MediaEntry +from mediagoblin.tools.pagination import Pagination +from mediagoblin.tools.pluginapi import hook_handle +from mediagoblin.tools.response import render_to_response, render_404 +from mediagoblin.decorators import uses_pagination, user_not_banned -def root_view(request): - media_entries = request.db.MediaEntry.find( - {u'state': u'processed'}).sort('created', DESCENDING) - + +@user_not_banned +@uses_pagination +def default_root_view(request, page): + cursor = request.db.query(MediaEntry).filter_by(state=u'processed').\ + order_by(MediaEntry.created.desc()) + + pagination = Pagination(page, cursor) + media_entries = pagination() return render_to_response( request, 'mediagoblin/root.html', {'media_entries': media_entries, - 'allow_registration': mg_globals.app_config["allow_registration"]}) + 'allow_registration': mg_globals.app_config["allow_registration"], + 'pagination': pagination}) + + + +def root_view(request): + """ + Proxies to the real root view that's displayed + """ + view = hook_handle("frontpage_view") or default_root_view + return view(request) + def simple_template_render(request): @@ -36,3 +55,10 @@ def simple_template_render(request): template_name = request.matchdict['template'] return render_to_response( request, template_name, {}) + +def terms_of_service(request): + if mg_globals.app_config["show_tos"] is False: + return render_404(request) + + return render_to_response(request, + 'mediagoblin/terms_of_service.html', {})