Fixed #15707 -- Made the GIS feed compatible to the class based feeds and introduced a little helper view that works like the previous feed view in the syndication app which was removed in r15976.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@16540 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Jannis Leidel 2011-07-13 09:36:07 +00:00
parent 24f4764a48
commit 12b7c2a702
4 changed files with 36 additions and 13 deletions

View File

@ -8,13 +8,13 @@ class GeoRSSSitemap(Sitemap):
def __init__(self, feed_dict, slug_dict=None): def __init__(self, feed_dict, slug_dict=None):
""" """
This sitemap object initializes on a feed dictionary (as would be passed This sitemap object initializes on a feed dictionary (as would be passed
to `django.contrib.syndication.views.feed`) and a slug dictionary. to `django.contrib.gis.views.feed`) and a slug dictionary.
If the slug dictionary is not defined, then it's assumed the keys provide If the slug dictionary is not defined, then it's assumed the keys provide
the URL parameter to the feed. However, if you have a complex feed (e.g., the URL parameter to the feed. However, if you have a complex feed (e.g.,
you override `get_object`, then you'll need to provide a slug dictionary. you override `get_object`, then you'll need to provide a slug dictionary.
The slug dictionary should have the same keys as the feed dictionary, but The slug dictionary should have the same keys as the feed dictionary, but
each value in the slug dictionary should be a sequence of slugs that may each value in the slug dictionary should be a sequence of slugs that may
be used for valid feeds. For example, let's say we have a feed that be used for valid feeds. For example, let's say we have a feed that
returns objects for a specific ZIP code in our feed dictionary: returns objects for a specific ZIP code in our feed dictionary:
feed_dict = {'zipcode' : ZipFeed} feed_dict = {'zipcode' : ZipFeed}
@ -35,7 +35,7 @@ class GeoRSSSitemap(Sitemap):
self.locations.append('%s/%s' % (section, slug)) self.locations.append('%s/%s' % (section, slug))
else: else:
self.locations.append(section) self.locations.append(section)
def get_urls(self, page=1, site=None): def get_urls(self, page=1, site=None):
""" """
This method is overrridden so the appropriate `geo_format` attribute This method is overrridden so the appropriate `geo_format` attribute
@ -49,5 +49,5 @@ class GeoRSSSitemap(Sitemap):
return self.locations return self.locations
def location(self, obj): def location(self, obj):
return urlresolvers.reverse('django.contrib.syndication.views.feed', args=(obj,)) return urlresolvers.reverse('django.contrib.gis.views.feed', args=(obj,))

View File

@ -100,15 +100,16 @@ class GeoDjangoTestSuiteRunner(DjangoTestSuiteRunner):
# Constructing the new INSTALLED_APPS, and including applications # Constructing the new INSTALLED_APPS, and including applications
# within the GeoDjango test namespace. # within the GeoDjango test namespace.
new_installed = ['django.contrib.sites', new_installed = [
'django.contrib.sitemaps', 'django.contrib.sites',
'django.contrib.gis', 'django.contrib.sitemaps',
] 'django.contrib.gis',
]
# Calling out to `geo_apps` to get GeoDjango applications supported # Calling out to `geo_apps` to get GeoDjango applications supported
# for testing. # for testing.
new_installed.extend(geo_apps()) new_installed.extend(geo_apps())
settings.INSTALLED_APPS = new_installed settings.INSTALLED_APPS = list(self.old_installed) + new_installed
# SITE_ID needs to be set # SITE_ID needs to be set
settings.SITE_ID = 1 settings.SITE_ID = 1

View File

@ -2,7 +2,7 @@ from django.conf.urls.defaults import *
from feeds import feed_dict from feeds import feed_dict
urlpatterns = patterns('', urlpatterns = patterns('',
(r'^feeds/(?P<url>.*)/$', 'django.contrib.syndication.views.feed', {'feed_dict': feed_dict}), (r'^feeds/(?P<url>.*)/$', 'django.contrib.gis.views.feed', {'feed_dict': feed_dict}),
) )
from sitemaps import sitemaps from sitemaps import sitemaps
@ -10,5 +10,5 @@ urlpatterns += patterns('django.contrib.gis.sitemaps.views',
(r'^sitemap.xml$', 'index', {'sitemaps' : sitemaps}), (r'^sitemap.xml$', 'index', {'sitemaps' : sitemaps}),
(r'^sitemaps/(?P<section>\w+)\.xml$', 'sitemap', {'sitemaps' : sitemaps}), (r'^sitemaps/(?P<section>\w+)\.xml$', 'sitemap', {'sitemaps' : sitemaps}),
(r'^sitemaps/kml/(?P<label>\w+)/(?P<model>\w+)/(?P<field_name>\w+)\.kml$', 'kml'), (r'^sitemaps/kml/(?P<label>\w+)/(?P<model>\w+)/(?P<field_name>\w+)\.kml$', 'kml'),
(r'^sitemaps/kml/(?P<label>\w+)/(?P<model>\w+)/(?P<field_name>\w+)\.kmz$', 'kmz'), (r'^sitemaps/kml/(?P<label>\w+)/(?P<model>\w+)/(?P<field_name>\w+)\.kmz$', 'kmz'),
) )

View File

@ -0,0 +1,22 @@
from django.http import Http404
def feed(request, url, feed_dict=None):
"""Provided for backwards compatibility."""
if not feed_dict:
raise Http404("No feeds are registered.")
try:
slug, param = url.split('/', 1)
except ValueError:
slug, param = url, ''
try:
f = feed_dict[slug]
except KeyError:
raise Http404("Slug %r isn't registered." % slug)
instance = f()
instance.feed_url = getattr(f, 'feed_url', None) or request.path
instance.title_template = f.title_template or ('feeds/%s_title.html' % slug)
instance.description_template = f.description_template or ('feeds/%s_description.html' % slug)
return instance(request)