Refs #23829 -- Made ping_google command/function use https for the sitemap URL.
This commit is contained in:
parent
6d73278d38
commit
76d31be2d0
|
@ -15,19 +15,19 @@ class SitemapNotFound(Exception):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
def ping_google(sitemap_url=None, ping_url=PING_URL):
|
def ping_google(sitemap_url=None, ping_url=PING_URL, sitemap_uses_https=True):
|
||||||
"""
|
"""
|
||||||
Alert Google that the sitemap for the current site has been updated.
|
Alert Google that the sitemap for the current site has been updated.
|
||||||
If sitemap_url is provided, it should be an absolute path to the sitemap
|
If sitemap_url is provided, it should be an absolute path to the sitemap
|
||||||
for this site -- e.g., '/sitemap.xml'. If sitemap_url is not provided, this
|
for this site -- e.g., '/sitemap.xml'. If sitemap_url is not provided, this
|
||||||
function will attempt to deduce it by using urls.reverse().
|
function will attempt to deduce it by using urls.reverse().
|
||||||
"""
|
"""
|
||||||
sitemap_full_url = _get_sitemap_full_url(sitemap_url)
|
sitemap_full_url = _get_sitemap_full_url(sitemap_url, sitemap_uses_https)
|
||||||
params = urlencode({'sitemap': sitemap_full_url})
|
params = urlencode({'sitemap': sitemap_full_url})
|
||||||
urlopen('%s?%s' % (ping_url, params))
|
urlopen('%s?%s' % (ping_url, params))
|
||||||
|
|
||||||
|
|
||||||
def _get_sitemap_full_url(sitemap_url):
|
def _get_sitemap_full_url(sitemap_url, sitemap_uses_https=True):
|
||||||
if not django_apps.is_installed('django.contrib.sites'):
|
if not django_apps.is_installed('django.contrib.sites'):
|
||||||
raise ImproperlyConfigured("ping_google requires django.contrib.sites, which isn't installed.")
|
raise ImproperlyConfigured("ping_google requires django.contrib.sites, which isn't installed.")
|
||||||
|
|
||||||
|
@ -47,7 +47,8 @@ def _get_sitemap_full_url(sitemap_url):
|
||||||
|
|
||||||
Site = django_apps.get_model('sites.Site')
|
Site = django_apps.get_model('sites.Site')
|
||||||
current_site = Site.objects.get_current()
|
current_site = Site.objects.get_current()
|
||||||
return 'http://%s%s' % (current_site.domain, sitemap_url)
|
scheme = 'https' if sitemap_uses_https else 'http'
|
||||||
|
return '%s://%s%s' % (scheme, current_site.domain, sitemap_url)
|
||||||
|
|
||||||
|
|
||||||
class Sitemap:
|
class Sitemap:
|
||||||
|
|
|
@ -7,6 +7,10 @@ class Command(BaseCommand):
|
||||||
|
|
||||||
def add_arguments(self, parser):
|
def add_arguments(self, parser):
|
||||||
parser.add_argument('sitemap_url', nargs='?')
|
parser.add_argument('sitemap_url', nargs='?')
|
||||||
|
parser.add_argument('--sitemap-uses-http', action='store_true')
|
||||||
|
|
||||||
def handle(self, *args, **options):
|
def handle(self, *args, **options):
|
||||||
ping_google(sitemap_url=options['sitemap_url'])
|
ping_google(
|
||||||
|
sitemap_url=options['sitemap_url'],
|
||||||
|
sitemap_uses_https=not options['sitemap_uses_http'],
|
||||||
|
)
|
||||||
|
|
|
@ -481,7 +481,7 @@ You may want to "ping" Google when your sitemap changes, to let it know to
|
||||||
reindex your site. The sitemaps framework provides a function to do just
|
reindex your site. The sitemaps framework provides a function to do just
|
||||||
that: :func:`django.contrib.sitemaps.ping_google()`.
|
that: :func:`django.contrib.sitemaps.ping_google()`.
|
||||||
|
|
||||||
.. function:: ping_google(sitemap_url=None, ping_url=PING_URL)
|
.. function:: ping_google(sitemap_url=None, ping_url=PING_URL, sitemap_uses_https=True)
|
||||||
|
|
||||||
``ping_google`` takes these optional arguments:
|
``ping_google`` takes these optional arguments:
|
||||||
|
|
||||||
|
@ -493,10 +493,18 @@ that: :func:`django.contrib.sitemaps.ping_google()`.
|
||||||
* ``ping_url`` - Defaults to Google's Ping Tool:
|
* ``ping_url`` - Defaults to Google's Ping Tool:
|
||||||
https://www.google.com/webmasters/tools/ping.
|
https://www.google.com/webmasters/tools/ping.
|
||||||
|
|
||||||
|
* ``sitemap_uses_https`` - Set to ``False`` if your site uses ``http``
|
||||||
|
rather than ``https``.
|
||||||
|
|
||||||
:func:`ping_google` raises the exception
|
:func:`ping_google` raises the exception
|
||||||
``django.contrib.sitemaps.SitemapNotFound`` if it cannot determine your
|
``django.contrib.sitemaps.SitemapNotFound`` if it cannot determine your
|
||||||
sitemap URL.
|
sitemap URL.
|
||||||
|
|
||||||
|
.. versionadded:: 2.2
|
||||||
|
|
||||||
|
The ``sitemap_uses_https`` argument was added. Older versions of
|
||||||
|
Django always use ``http`` for a sitemap's URL.
|
||||||
|
|
||||||
.. admonition:: Register with Google first!
|
.. admonition:: Register with Google first!
|
||||||
|
|
||||||
The :func:`ping_google` command only works if you have registered your
|
The :func:`ping_google` command only works if you have registered your
|
||||||
|
@ -534,3 +542,9 @@ Once the sitemaps application is added to your project, you may also
|
||||||
ping Google using the ``ping_google`` management command::
|
ping Google using the ``ping_google`` management command::
|
||||||
|
|
||||||
python manage.py ping_google [/sitemap.xml]
|
python manage.py ping_google [/sitemap.xml]
|
||||||
|
|
||||||
|
.. django-admin-option:: --sitemap-uses-http
|
||||||
|
|
||||||
|
.. versionadded:: 2.2
|
||||||
|
|
||||||
|
Use this option if your sitemap uses ``http`` rather than ``https``.
|
||||||
|
|
|
@ -479,6 +479,12 @@ Miscellaneous
|
||||||
passed as a value to encode because ``None`` can't be encoded in GET and POST
|
passed as a value to encode because ``None`` can't be encoded in GET and POST
|
||||||
data. Either pass an empty string or omit the value.
|
data. Either pass an empty string or omit the value.
|
||||||
|
|
||||||
|
* The :djadmin:`ping_google` management command now defaults to ``https``
|
||||||
|
instead of ``http`` for the sitemap's URL. If your site uses http, use the
|
||||||
|
new :option:`ping_google --sitemap-uses-http` option. If you use the
|
||||||
|
:func:`~django.contrib.sitemaps.ping_google` function, set the new
|
||||||
|
``sitemap_uses_https`` argument to ``False``.
|
||||||
|
|
||||||
.. _deprecated-features-2.2:
|
.. _deprecated-features-2.2:
|
||||||
|
|
||||||
Features deprecated in 2.2
|
Features deprecated in 2.2
|
||||||
|
|
|
@ -10,8 +10,8 @@ class PingGoogleTests(SitemapTestsBase):
|
||||||
|
|
||||||
def test_default(self, ping_google_func):
|
def test_default(self, ping_google_func):
|
||||||
call_command('ping_google')
|
call_command('ping_google')
|
||||||
ping_google_func.assert_called_with(sitemap_url=None)
|
ping_google_func.assert_called_with(sitemap_url=None, sitemap_uses_https=True)
|
||||||
|
|
||||||
def test_arg(self, ping_google_func):
|
def test_args(self, ping_google_func):
|
||||||
call_command('ping_google', 'foo.xml')
|
call_command('ping_google', 'foo.xml', '--sitemap-uses-http')
|
||||||
ping_google_func.assert_called_with(sitemap_url='foo.xml')
|
ping_google_func.assert_called_with(sitemap_url='foo.xml', sitemap_uses_https=False)
|
||||||
|
|
|
@ -15,16 +15,16 @@ class PingGoogleTests(SitemapTestsBase):
|
||||||
@mock.patch('django.contrib.sitemaps.urlopen')
|
@mock.patch('django.contrib.sitemaps.urlopen')
|
||||||
def test_something(self, urlopen):
|
def test_something(self, urlopen):
|
||||||
ping_google()
|
ping_google()
|
||||||
params = urlencode({'sitemap': 'http://example.com/sitemap-without-entries/sitemap.xml'})
|
params = urlencode({'sitemap': 'https://example.com/sitemap-without-entries/sitemap.xml'})
|
||||||
full_url = 'https://www.google.com/webmasters/tools/ping?%s' % params
|
full_url = 'https://www.google.com/webmasters/tools/ping?%s' % params
|
||||||
urlopen.assert_called_with(full_url)
|
urlopen.assert_called_with(full_url)
|
||||||
|
|
||||||
def test_get_sitemap_full_url_global(self):
|
def test_get_sitemap_full_url_global(self):
|
||||||
self.assertEqual(_get_sitemap_full_url(None), 'http://example.com/sitemap-without-entries/sitemap.xml')
|
self.assertEqual(_get_sitemap_full_url(None), 'https://example.com/sitemap-without-entries/sitemap.xml')
|
||||||
|
|
||||||
@override_settings(ROOT_URLCONF='sitemaps_tests.urls.index_only')
|
@override_settings(ROOT_URLCONF='sitemaps_tests.urls.index_only')
|
||||||
def test_get_sitemap_full_url_index(self):
|
def test_get_sitemap_full_url_index(self):
|
||||||
self.assertEqual(_get_sitemap_full_url(None), 'http://example.com/simple/index.xml')
|
self.assertEqual(_get_sitemap_full_url(None), 'https://example.com/simple/index.xml')
|
||||||
|
|
||||||
@override_settings(ROOT_URLCONF='sitemaps_tests.urls.empty')
|
@override_settings(ROOT_URLCONF='sitemaps_tests.urls.empty')
|
||||||
def test_get_sitemap_full_url_not_detected(self):
|
def test_get_sitemap_full_url_not_detected(self):
|
||||||
|
@ -33,7 +33,13 @@ class PingGoogleTests(SitemapTestsBase):
|
||||||
_get_sitemap_full_url(None)
|
_get_sitemap_full_url(None)
|
||||||
|
|
||||||
def test_get_sitemap_full_url_exact_url(self):
|
def test_get_sitemap_full_url_exact_url(self):
|
||||||
self.assertEqual(_get_sitemap_full_url('/foo.xml'), 'http://example.com/foo.xml')
|
self.assertEqual(_get_sitemap_full_url('/foo.xml'), 'https://example.com/foo.xml')
|
||||||
|
|
||||||
|
def test_get_sitemap_full_url_insecure(self):
|
||||||
|
self.assertEqual(
|
||||||
|
_get_sitemap_full_url('/foo.xml', sitemap_uses_https=False),
|
||||||
|
'http://example.com/foo.xml'
|
||||||
|
)
|
||||||
|
|
||||||
@modify_settings(INSTALLED_APPS={'remove': 'django.contrib.sites'})
|
@modify_settings(INSTALLED_APPS={'remove': 'django.contrib.sites'})
|
||||||
def test_get_sitemap_full_url_no_sites(self):
|
def test_get_sitemap_full_url_no_sites(self):
|
||||||
|
|
Loading…
Reference in New Issue