X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/f3c4f52c83a5c5f04b6bb83783769066610e5629..14504aa581ca93dcbb32342c2b541b685f136aee:/forum/sitemap.py diff --git a/forum/sitemap.py b/forum/sitemap.py index d2d7930..43d0934 100644 --- a/forum/sitemap.py +++ b/forum/sitemap.py @@ -1,8 +1,52 @@ from django.contrib.sitemaps import Sitemap from forum.models import Question from django.conf import settings +from django.http import HttpResponse +from django.template import loader +from django.core import urlresolvers +from django.contrib.sites.models import get_current_site +from django.utils.encoding import smart_str +from django.core.paginator import EmptyPage, PageNotAnInteger -class QuestionsSitemap(Sitemap): +def index(request, sitemaps): + sites = [] + for section, site in sitemaps.items(): + if callable(site): + pages = site().paginator.num_pages + else: + pages = site.paginator.num_pages + sitemap_url = urlresolvers.reverse('forum.sitemap.sitemap', kwargs={'section': section}) + sites.append('%s%s' % (settings.APP_URL, sitemap_url)) + if pages > 1: + for page in range(2, pages+1): + sites.append('%s%s?p=%s' % (settings.APP_URL, sitemap_url, page)) + xml = loader.render_to_string('sitemap_index.xml', {'sitemaps': sites}) + return HttpResponse(xml, mimetype='application/xml') + +def sitemap(request, sitemaps, section=None): + maps, urls = [], [] + if section is not None: + if section not in sitemaps: + raise Http404("No sitemap available for section: %r" % section) + maps.append(sitemaps[section]) + else: + maps = sitemaps.values() + page = request.GET.get("p", 1) + + for site in maps: + try: + if callable(site): + urls.extend(site().get_urls(page=page)) + else: + urls.extend(site.get_urls(page=page)) + except EmptyPage: + raise Http404("Page %s empty" % page) + except PageNotAnInteger: + raise Http404("No page '%s'" % page) + xml = smart_str(loader.render_to_string('sitemap.xml', {'urlset': urls})) + return HttpResponse(xml, mimetype='application/xml') + +class OsqaSitemap(Sitemap): changefreq = 'daily' priority = 0.5 def items(self): @@ -26,7 +70,7 @@ class QuestionsSitemap(Sitemap): def get_urls(self, page=1): urls = [] for item in self.paginator.page(page).object_list: - loc = "http://%s%s" % (settings.APP_URL, self.__get('location', item)) + loc = "%s%s" % (settings.APP_URL, self.__get('location', item)) url_info = { 'location': loc, 'lastmod': self.__get('lastmod', item, None),