]> git.openstreetmap.org Git - osqa.git/commitdiff
#OSQA-385, fixing the links of sitemaps when site is running using SCRIPT_ALIAS.
authorjordan <jordan@0cfe37f9-358a-4d5e-be75-b63607b5c754>
Tue, 4 Jan 2011 19:52:51 +0000 (19:52 +0000)
committerjordan <jordan@0cfe37f9-358a-4d5e-be75-b63607b5c754>
Tue, 4 Jan 2011 19:52:51 +0000 (19:52 +0000)
git-svn-id: http://svn.osqa.net/svnroot/osqa/trunk@668 0cfe37f9-358a-4d5e-be75-b63607b5c754

forum/sitemap.py
forum/urls.py

index b53cb160728351124d3f9e7af4425396e2b2d9ee..43d0934c49ae629038e571e6cc4360e6dc004e0e 100644 (file)
@@ -4,6 +4,9 @@ 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
 
 def index(request, sitemaps):
     sites = []
@@ -12,7 +15,7 @@ def index(request, sitemaps):
             pages = site().paginator.num_pages
         else:
             pages = site.paginator.num_pages
-        sitemap_url = urlresolvers.reverse('django.contrib.sitemaps.views.sitemap', kwargs={'section': section})
+        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):
@@ -20,6 +23,29 @@ def index(request, sitemaps):
     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
index e964bc48960b329c3ba0afd29d21c410c5036424..1771e2c8ad7de1814cef13a43974ce6d824dd662 100644 (file)
@@ -34,7 +34,7 @@ urlpatterns += patterns('',
                         url(r'^%s(.*)' % _('nimda/'), admin.site.root),
                         
                         url(r'^sitemap.xml$', 'forum.sitemap.index', {'sitemaps': sitemaps}),
-                        url(r'^sitemap-(?P<section>.+)\.xml$', 'django.contrib.sitemaps.views.sitemap', {'sitemaps': sitemaps}),
+                        url(r'^sitemap-(?P<section>.+)\.xml$', 'forum.sitemap.sitemap', {'sitemaps': sitemaps}),
 
                         (r'^favicon\.ico$', app.meta.favicon),
                         url(r'^cstyle\.css$', app.meta.custom_css, name="custom_css"),