mirror of
https://github.com/django/django.git
synced 2025-01-03 06:55:47 +00:00
Fixed #31907 -- Fixed missing validate_key() calls in cache backends.
This commit is contained in:
parent
9e04b242ee
commit
b5acb9db75
1
django/core/cache/backends/locmem.py
vendored
1
django/core/cache/backends/locmem.py
vendored
@ -59,6 +59,7 @@ class LocMemCache(BaseCache):
|
||||
|
||||
def touch(self, key, timeout=DEFAULT_TIMEOUT, version=None):
|
||||
key = self.make_key(key, version=version)
|
||||
self.validate_key(key)
|
||||
with self._lock:
|
||||
if self._has_expired(key):
|
||||
return False
|
||||
|
9
django/core/cache/backends/memcached.py
vendored
9
django/core/cache/backends/memcached.py
vendored
@ -81,6 +81,7 @@ class BaseMemcachedCache(BaseCache):
|
||||
|
||||
def touch(self, key, timeout=DEFAULT_TIMEOUT, version=None):
|
||||
key = self.make_key(key, version=version)
|
||||
self.validate_key(key)
|
||||
return bool(self._cache.touch(key, self.get_backend_timeout(timeout)))
|
||||
|
||||
def delete(self, key, version=None):
|
||||
@ -145,7 +146,10 @@ class BaseMemcachedCache(BaseCache):
|
||||
return [original_keys[k] for k in failed_keys]
|
||||
|
||||
def delete_many(self, keys, version=None):
|
||||
self._cache.delete_multi(self.make_key(key, version=version) for key in keys)
|
||||
keys = [self.make_key(key, version=version) for key in keys]
|
||||
for key in keys:
|
||||
self.validate_key(key)
|
||||
self._cache.delete_multi(keys)
|
||||
|
||||
def clear(self):
|
||||
self._cache.flush_all()
|
||||
@ -173,6 +177,7 @@ class MemcachedCache(BaseMemcachedCache):
|
||||
|
||||
def get(self, key, default=None, version=None):
|
||||
key = self.make_key(key, version=version)
|
||||
self.validate_key(key)
|
||||
val = self._cache.get(key)
|
||||
# python-memcached doesn't support default values in get().
|
||||
# https://github.com/linsomniac/python-memcached/issues/159
|
||||
@ -186,6 +191,7 @@ class MemcachedCache(BaseMemcachedCache):
|
||||
# https://github.com/linsomniac/python-memcached/issues/170
|
||||
# Call _deletetouch() without the NOT_FOUND in expected results.
|
||||
key = self.make_key(key, version=version)
|
||||
self.validate_key(key)
|
||||
return bool(self._cache._deletetouch([b'DELETED'], 'delete', key))
|
||||
|
||||
|
||||
@ -201,6 +207,7 @@ class PyLibMCCache(BaseMemcachedCache):
|
||||
|
||||
def touch(self, key, timeout=DEFAULT_TIMEOUT, version=None):
|
||||
key = self.make_key(key, version=version)
|
||||
self.validate_key(key)
|
||||
if timeout == 0:
|
||||
return self._cache.delete(key)
|
||||
return self._cache.touch(key, self.get_backend_timeout(timeout))
|
||||
|
5
tests/cache/tests.py
vendored
5
tests/cache/tests.py
vendored
@ -656,6 +656,7 @@ class BaseCacheTests:
|
||||
('set', [key, 1]),
|
||||
('incr', [key]),
|
||||
('decr', [key]),
|
||||
('touch', [key]),
|
||||
('delete', [key]),
|
||||
('get_many', [[key, 'b']]),
|
||||
('set_many', [{key: 1, 'b': 2}]),
|
||||
@ -1306,11 +1307,15 @@ class BaseMemcachedTests(BaseCacheTests):
|
||||
msg = expected_warning.replace(key, cache.make_key(key))
|
||||
tests = [
|
||||
('add', [key, 1]),
|
||||
('get', [key]),
|
||||
('set', [key, 1]),
|
||||
('incr', [key]),
|
||||
('decr', [key]),
|
||||
('touch', [key]),
|
||||
('delete', [key]),
|
||||
('get_many', [[key, 'b']]),
|
||||
('set_many', [{key: 1, 'b': 2}]),
|
||||
('delete_many', [{key: 1, 'b': 2}]),
|
||||
]
|
||||
for operation, args in tests:
|
||||
with self.subTest(operation=operation):
|
||||
|
Loading…
Reference in New Issue
Block a user