diff --git a/CHANGELOG.md b/CHANGELOG.md index 2292dd77..4ed800a2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,7 @@ * Improve: auth.ldap config shown on startup, terminate in case no password is supplied for bind user * Add: option [auth] uc_username for uppercase conversion (similar to existing lc_username) * Add: option [debug] storage_cache_action for conditional logging +* Fix: set PRODID on collection upload (instead of vobject is inserting default one) ## 3.3.1 diff --git a/radicale/app/put.py b/radicale/app/put.py index 6f883dca..c1f0eacd 100644 --- a/radicale/app/put.py +++ b/radicale/app/put.py @@ -2,7 +2,8 @@ # Copyright © 2008 Nicolas Kandel # Copyright © 2008 Pascal Halter # Copyright © 2008-2017 Guillaume Ayoub -# Copyright © 2017-2018 Unrud +# Copyright © 2017-2020 Unrud +# Copyright © 2020-2023 Tuna Celik # Copyright © 2024-2024 Peter Bieringer # # This library is free software: you can redistribute it and/or modify @@ -29,7 +30,8 @@ from typing import Iterator, List, Mapping, MutableMapping, Optional, Tuple import vobject import radicale.item as radicale_item -from radicale import httputils, pathutils, rights, storage, types, xmlutils +from radicale import (httputils, pathutils, rights, storage, types, utils, + xmlutils) from radicale.app.base import Access, ApplicationBase from radicale.hook import HookNotificationItem, HookNotificationItemTypes from radicale.log import logger @@ -37,6 +39,8 @@ from radicale.log import logger MIMETYPE_TAGS: Mapping[str, str] = {value: key for key, value in xmlutils.MIMETYPES.items()} +PRODID = u"-//Radicale//NONSGML Version " + utils.package_version("radicale") + "//EN" + def prepare(vobject_items: List[vobject.base.Component], path: str, content_type: str, permission: bool, parent_permission: bool, @@ -80,6 +84,7 @@ def prepare(vobject_items: List[vobject.base.Component], path: str, vobject_collection = vobject.iCalendar() for component in components: vobject_collection.add(component) + vobject_collection.add(vobject.base.ContentLine("PRODID", [], PRODID)) item = radicale_item.Item(collection_path=collection_path, vobject_item=vobject_collection) item.prepare()