Adds additional metadata to setup.py
[mediagoblin.git] / mediagoblin / views.py
1 # GNU MediaGoblin -- federated, autonomous media hosting
2 # Copyright (C) 2011 Free Software Foundation, Inc
3 #
4 # This program is free software: you can redistribute it and/or modify
5 # it under the terms of the GNU Affero General Public License as published by
6 # the Free Software Foundation, either version 3 of the License, or
7 # (at your option) any later version.
8 #
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU Affero General Public License for more details.
13 #
14 # You should have received a copy of the GNU Affero General Public License
15 # along with this program. If not, see <http://www.gnu.org/licenses/>.
16
17 from mediagoblin import mg_globals
18 from mediagoblin.util import render_to_response, Pagination
19 from mediagoblin.db.util import DESCENDING
20 from mediagoblin.decorators import uses_pagination
21
22 @uses_pagination
23 def root_view(request, page):
24 cursor = request.db.MediaEntry.find(
25 {u'state': u'processed'}).sort('created', DESCENDING)
26
27 pagination = Pagination(page, cursor)
28 media_entries = pagination()
29
30 return render_to_response(
31 request, 'mediagoblin/root.html',
32 {'media_entries': media_entries,
33 'allow_registration': mg_globals.app_config["allow_registration"],
34 'pagination': pagination})
35
36
37 def simple_template_render(request):
38 """
39 A view for absolutely simple template rendering.
40 Just make sure 'template' is in the matchdict!
41 """
42 template_name = request.matchdict['template']
43 return render_to_response(
44 request, template_name, {})