From 5d969ff65c4b095ba78f930afb6bc68b2f8915b6 Mon Sep 17 00:00:00 2001 From: Unrud Date: Sat, 18 Aug 2018 12:56:40 +0200 Subject: [PATCH] Include versions in item cache hash --- radicale/storage.py | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/radicale/storage.py b/radicale/storage.py index 9189030..41c9dee 100644 --- a/radicale/storage.py +++ b/radicale/storage.py @@ -40,10 +40,10 @@ from contextlib import contextmanager from hashlib import md5 from importlib import import_module from itertools import chain, groupby -from math import log from random import getrandbits from tempfile import NamedTemporaryFile, TemporaryDirectory +import pkg_resources import vobject from radicale import xmlutils @@ -90,6 +90,10 @@ elif os.name == "posix": INTERNAL_TYPES = ("multifilesystem",) +DEPS = ("radicale", "vobject", "python-dateutil",) +ITEM_CACHE_TAG = (";".join(pkg_resources.get_distribution(pkg).version + for pkg in DEPS) + ";").encode() + def load(configuration): """Load the storage manager chosen in configuration.""" @@ -331,11 +335,6 @@ def path_to_filesystem(root, *paths): return safe_path -def left_encode_int(v): - length = int(log(v, 256)) + 1 if v != 0 else 1 - return bytes((length,)) + v.to_bytes(length, 'little') - - class UnsafePathError(ValueError): def __init__(self, path): message = "Can't translate name safely to filesystem: %r" % path @@ -723,9 +722,6 @@ class BaseCollection: return True -ITEM_CACHE_VERSION = 1 - - class Collection(BaseCollection): """Collection stored in several files per calendar.""" @@ -1277,7 +1273,7 @@ class Collection(BaseCollection): def _item_cache_hash(self, raw_text): _hash = md5() - _hash.update(left_encode_int(ITEM_CACHE_VERSION)) + _hash.update(ITEM_CACHE_TAG) _hash.update(raw_text) return _hash.hexdigest()