Merge branch 'master' of github.com:Kozea/radicale
This commit is contained in:
commit
52d67a906b
@ -1,3 +1,3 @@
|
|||||||
[pytest]
|
[pytest]
|
||||||
addopts = --flake8 --isort --cov radicale/ tests
|
addopts = --flake8 --isort --cov radicale/ radicale/tests
|
||||||
norecursedirs = dist .cache .git build *.egg-info .eggs venv
|
norecursedirs = dist .cache .git build *.egg-info .eggs venv
|
||||||
|
@ -35,7 +35,8 @@ import time
|
|||||||
from contextlib import contextmanager
|
from contextlib import contextmanager
|
||||||
from hashlib import md5
|
from hashlib import md5
|
||||||
from importlib import import_module
|
from importlib import import_module
|
||||||
from uuid import uuid4
|
from itertools import groupby
|
||||||
|
from random import getrandbits
|
||||||
|
|
||||||
import vobject
|
import vobject
|
||||||
|
|
||||||
@ -231,6 +232,15 @@ class BaseCollection:
|
|||||||
for href in set(hrefs):
|
for href in set(hrefs):
|
||||||
yield self.get(href)
|
yield self.get(href)
|
||||||
|
|
||||||
|
def pre_filtered_list(self, filters):
|
||||||
|
"""List collection items with optional pre filtering.
|
||||||
|
|
||||||
|
This could largely improve performance of reports depending on
|
||||||
|
the filters and this implementation.
|
||||||
|
This returns all event by default
|
||||||
|
"""
|
||||||
|
return [self.get(href) for href, _ in self.list()]
|
||||||
|
|
||||||
def has(self, href):
|
def has(self, href):
|
||||||
"""Check if an item exists by its href.
|
"""Check if an item exists by its href.
|
||||||
|
|
||||||
@ -372,25 +382,26 @@ class Collection(BaseCollection):
|
|||||||
items = []
|
items = []
|
||||||
for content in ("vevent", "vtodo", "vjournal"):
|
for content in ("vevent", "vtodo", "vjournal"):
|
||||||
items.extend(getattr(collection, "%s_list" % content, []))
|
items.extend(getattr(collection, "%s_list" % content, []))
|
||||||
processed_uids = []
|
|
||||||
for i, item in enumerate(items):
|
def get_uid(item):
|
||||||
uid = getattr(item, "uid", None)
|
return hasattr(item, 'uid') and item.uid.value
|
||||||
if uid in processed_uids:
|
|
||||||
continue
|
items_by_uid = groupby(
|
||||||
|
sorted(items, key=get_uid), get_uid)
|
||||||
|
|
||||||
|
for uid, items in items_by_uid:
|
||||||
new_collection = vobject.iCalendar()
|
new_collection = vobject.iCalendar()
|
||||||
new_collection.add(item)
|
for item in items:
|
||||||
if uid:
|
new_collection.add(item)
|
||||||
processed_uids.append(uid)
|
file_name = hex(getrandbits(32))[2:]
|
||||||
# search for items with same UID
|
self.upload(file_name, new_collection)
|
||||||
for oitem in items[i+1:]:
|
|
||||||
if getattr(oitem, "uid", None) == uid:
|
|
||||||
new_collection.add(oitem)
|
|
||||||
self.upload(uuid4().hex, new_collection)
|
|
||||||
elif tag == "VCARD":
|
elif tag == "VCARD":
|
||||||
self.set_meta("tag", "VADDRESSBOOK")
|
self.set_meta("tag", "VADDRESSBOOK")
|
||||||
if collection:
|
if collection:
|
||||||
for card in collection:
|
for card in collection:
|
||||||
self.upload(uuid4().hex, card)
|
file_name = hex(getrandbits(32))[2:]
|
||||||
|
self.upload(file_name, card)
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def list(self):
|
def list(self):
|
||||||
|
@ -837,7 +837,7 @@ def report(path, xml_request, collection):
|
|||||||
else:
|
else:
|
||||||
# Reference is a collection
|
# Reference is a collection
|
||||||
path = hreference
|
path = hreference
|
||||||
items = [collection.get(href) for href, etag in collection.list()]
|
items = collection.pre_filtered_list(filters)
|
||||||
|
|
||||||
for item in items:
|
for item in items:
|
||||||
if filters:
|
if filters:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user