X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=mediagoblin%2Fviews.py;h=9e893d566ba3cb11121e2d426cf84616f4bc964c;hb=283043f14d8fdeb8cccad00b7d7cb7a8cc5a17bd;hp=96687f9680d97a1df0df7dd01c719f466041a526;hpb=f373599bd745b7afa58013c4b6a17d1c59769cdb;p=mediagoblin.git diff --git a/mediagoblin/views.py b/mediagoblin/views.py index 96687f96..9e893d56 100644 --- a/mediagoblin/views.py +++ b/mediagoblin/views.py @@ -1,5 +1,5 @@ # GNU MediaGoblin -- federated, autonomous media hosting -# Copyright (C) 2011 MediaGoblin contributors. See AUTHORS. +# 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,18 +15,21 @@ # along with this program. If not, see . from mediagoblin import mg_globals -from mediagoblin.util import render_to_response, Pagination -from mediagoblin.db.util import DESCENDING -from mediagoblin.decorators import uses_pagination +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 + +@user_not_banned @uses_pagination -def root_view(request, page): - cursor = request.db.MediaEntry.find( - {u'state': u'processed'}).sort('created', DESCENDING) +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, @@ -34,6 +37,16 @@ def root_view(request, page): '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): """ A view for absolutely simple template rendering. @@ -42,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', {})