Refs #23829 -- Made ping_google command/function use https for the sitemap URL.

This commit is contained in:
Sanyam Khurana 2019-01-10 15:30:00 +05:30 committed by Tim Graham
parent 6d73278d38
commit 76d31be2d0
6 changed files with 45 additions and 14 deletions

View File

@ -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:

View File

@ -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'],
)

View File

@ -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``.

View File

@ -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

View File

@ -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)

View File

@ -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):